InfoQ

News

Buzzwordでのスペルチェッカー実装に注目

作者 Jon Rose, 翻訳者 編集部 投稿日 2007年12月12日 午前12時32分

コミュニティ
Java,
Architecture
トピック
リッチクライアント/デスクトップ,
RIA,
Web 2.0
タグ
Apollo,
Flex,
Adobe,
Adobe Integrated Runtime,
Flash
9月に行われたBuzzwordのリリース(source)においてAdobe Flex Frameworkを使用して構築されたオンラインのワードプロセッサにスペルチェックサポートが追加された。今週BuzzwordチームのDavid Coletta氏が、彼のブログにおいてその実装におけるこの部分の詳細をブログ"Buzzword Spell Checking Internals"(source)にて綴っている。

Buzzwordの中核スペルチェックエンジンはGrant Skinner's Spelling Plus Library(SPL)(source)である。SPLは100%Flash・Flex用のプログラミング言語であるActionScript 3で書かれた商用ライセンスされた製品である。

Coletta氏は彼のブログ上で9月のリリースにおいてこれを議論している(source)
私達はGrant Skinnerの素晴らしいSpellin Plus Library(SPL)を、ディクショナリールックアップとサジェスチョンを提供するため私達のエディターに追加しました。SPLは全体的にActionScript 3で実装されていてとても小さく速く、そしてアプリケーションが起動している間にバックグラウンドでディクショナリーをダウンロードし、解凍する機能を提供するのです。だからユーザはディクショナリーがダウンロードされている間待つ必要がないのです。スペルチェックを簡単にFlexとFlashコンポー ネントに含ませるのが可能なSPLのハイレベルなインターフェースに加え、ワードルックアップとサジェスチョンを行う低レベルのAPIがあります。(現在私達が使用している)スペルチェックソリューションを全体的にクライアント側で持っているのはとても良いことなので、将来的には未接続の使用をサポートする時も同様に動作するようになるでしょう。
今週のColettaの掲載(source)において、彼はFlashランタイムのシングルスレッド性質における挑戦に関して論じている。
Buzzwordはユーザインターフェースを反応良く保つために、それぞれのキーストロークで動作を最小限に抑える必要がありますが、FlashはActionScriptが 実行できるスレッドをたった一つしか提供しないので、バックグラウンドスレッドを使用するという贅沢はできないのです(タイマーとframeEnterイベントを使用してバックグラウンドプロセスを行う方法はたくさんありますが、それらのイベントハンドラの競争とメインスレッドを自ら注意深く管理しないといけま せん。)。Buzzwordにおいて、私達は全てのスペルチェックを同期的に行います。私達は、ドキュメントの汚い区分のリストを保ち、ユーザがアイドリン グ中にタイマーイベント上の汚いリストに取り掛かりながらそれをバックグラウンドで行うことを考えたのですが、そうするとデザインの複雑性と不確定性が非常 に上がってしまうのでそれを全てフォアグラウンドで行い、どうになるか様子を見ることにしたのです。そしてそれが適切なアプローチであることが判明したのです。
シングルスレッド環境でスペルチェックを実装するという挑戦と共に、Coletta氏はパフォーマンスにおける挑戦に関しても論じている。
Buzzwordが出来る限り早く起動するために私達がしている事の一つは、バックグラウンドでメインのスペルチェックをロードして解凍することです(実はバックグラウンドロードと解凍はSPL内にて起こるので、その製品のユーザは誰でもその恩恵を受けることになるのです。)。しかしながらバックグラウンドでディクショナリーをロードするには弱点もあります。それはディクショナリーのロードとドキュメントのエディット間で競合状態を生むのです。ディクショナリーがスペルチェック用に完全に有効になる前にドキュメント上で5、10秒程の作業をするのは、Agileのユーザにとっては難しいことではありません。ユーザを5秒、もしくは10秒も待たせるのはよくありません。通常私達はドキュメントが開いたときにフラッグされている言葉だけを再チェックするのですが、この特別なケースにおいては、ユーザがしばらくの間"あなたがタイプしている間の"チェックなしに編集することが可能なので、私達はそのディクショナリーがロードし次第すぐにドキュメント全体をリスキャンする必要があるのです。
Buzzwordの協力的な性質を支持する一方、スペルチェッカー機能を付加するという挑戦に関して論じているDavid Coletta氏のブログ(source)の続きを読んでみて欲しい。より従来的なサーバサイドのフレームワークと比較した時、BuzzwordのようなRIAアプリケー ションを構築することに関して明らかに新たな考え方があることが分かる。Flexアプリケーションにおいて、新たな挑戦はFlash Runtime用のクライアントサイドのプログラミングのニュアンスを伴ってプラットフォームの力に付随してくる新たな使用ケースに関連していることが多いのである。

原文はこちらです:http://www.infoq.com/news/2007/12/buzzword-spell-checker
ブックマーク
digg+,
reddit+,
del.icio.us+,
dzone+,
Hatena

No comments

返信

特集コンテンツ一覧

トップスポーツチームの監督に教わる秘訣

この論文では、氏が発見した原則を要約し、その原則をいかにしてソフトウェア開発に応用するかを説明します。

事例研究:Dutch Railwaysのプロジェクトにおける分散拠点でのスクラム・プロジェクト

この記事では、私達がどのようにして大規模(240人月、10万行強)でインドとオランダの開発者も参加したスクラム・プロジェクトを成功させたのかを示しています。

Agile2008チーム参加レポート - 帰国そして変化

Agileカンファレンスに「参加者としてだけでなく、発表者として参加しよう」を掲げたチームgoyattomは、サブミッションを提出し、7つのセッションが日本から選択されました。参加者はカンファレンスで各々の発表や、各セッションへの参加、諸外国のエンジニアとの出会い、ステージ上で DearXPを熱演などの様々な思い出を抱えて、無事日本に戻ってきました。

SilverlightとJavaのインターオペラビリティ

マイクロソフトのRobert Bellが、SilverlightとJavaを使用したインターオペラビリティのシナリオを紹介し、サンプルコードを例にとってアーキテクチャの手引きを提供します。

Agile2008 チーム参加レポート - カンファレンス参加編

Agileカンファレンスに「参加者としてだけでなく、発表者として参加しよう」を掲げたチームgoyattomは、サブミッションを提出し、7つのセッションが日本から選択されました。サブミッションが選択された人、そうでない人も含めて、個々の目的意識の確認、膨大なプログラムから聞きたいセッションの選択、旅行の準備、プレゼンテーションの準備の期間を終えて、無事当日を迎えました。

Agile2008 チーム参加レポート - 動機/準備編

筆者はアジャイルソフトウェア開発についての年に一度の国際会議であるAgile2008に初めて参加してきました。今年の日本からの参加者の数は14名にも及び、発表者は5名、受け持ったセッションは8つに及び、例年にない活躍を見せました。なぜ今年のAgile2008では、これほど多くの日本人が参加し発表に至ったのか? そのレポートをお届けします。

Javaトラブルシューティングメルマガ総集編 2008/08~09

エスエムジーでは、Java全般を対象にしたトラブルシューティングサービス「JaTS」を提供しています。この記事では、前回に引き続き、JaTSにて蓄積したトラブル事例とその解決ノウハウの一部をお送りしている「Javaトラブルシューティングメールマガジン」(JTSMM)の総集編として、過去2ヶ月のトラブル事例と追加情報をダイジェストとして提供いたします。

モデル駆動アプローチがうまく機能しない(しなくなる)8 つの理由

この記事では、モデル駆動アプローチがうまく機能しない、または機能しなくなることによって期待した結果が実現できなくなる 8 つの理由について書きたいと思います。