blob: a644ae451a928b643ce95d41f45dbf22ef7f848a (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
|
---
title: Updating extensions for Firefox 3.1
slug: Updating_extensions_for_Firefox_3.1
---
<p>{{ fx_minversion_header(3.1) }}</p>
<p>この記事は、自分の拡張機能を Firefox 3.1 で正しく動作するよう更新しようとしている拡張機能開発者のために役立つ情報を提供します。</p>
<h2 id="更新の基本">更新の基本</h2>
<p>この節では、Firefox の新しいバージョンに向けて拡張機能を更新する際に必ず行わなければならないことの基本を説明します。</p>
<h3 id="拡張機能のテスト">拡張機能のテスト</h3>
<p>まずはじめに、拡張機能の <code>install.rdf</code> ファイルを編集して、(Firefox 3.1 beta 2 でテストを行っている場合は) <code>maxVersion</code> を 3.1b2 に更新し、それに合わせて <code>version</code> を上げましょう。</p>
<p>Firefox のプロファイルを新規作成し、テストが常用のプロファイルに影響しないようにします。 Firefox が含まれるディレクトリに移動して、以下のコマンドを実行します。</p>
<pre>firefox -createProfile testBeta2
</pre>
<p>Mac では、Firefox のアプリケーションバンドル内へはるばる移動する必要があります。</p>
<pre>cd /Applications/Firefox.app/Contents/MacOS/
firefox -createProfile testBeta2
</pre>
<p>コマンドライン上で以下のコマンドを実行し、新規プロファイルで Firefox を起動します。</p>
<pre>firefox -P testBeta2
</pre>
<p>自分の拡張機能を徹底的にテストします。 JavaScript のあらゆる警告や例外を通知するために、以下の設定項目を true に設定しておくことをお勧めします。</p>
<ul> <li><code>javascript.options.strict</code></li> <li><code>javascript.options.showInConsole</code></li>
</ul>
<h3 id="拡張機能の更新">拡張機能の更新</h3>
<p>テスト中に何か問題を発見した場合は、コードを更新して問題を修正しましょう。 この記事には、若干の更新作業が必要な箇所についての役立つ情報が載っています。</p>
<p>テストが完了したら、今度は常用のプロファイルを使って、再度その拡張機能を使ってみます。 この作業は、保存されている既存のデータとの互換性を確認するのに役立ちます。</p>
<h3 id="addons.mozilla.org_に登録されている拡張機能の更新">addons.mozilla.org に登録されている拡張機能の更新</h3>
<p>ついに、更新した拡張機能を公開するときが来ました。 もし自分の拡張機能に一切コードの変更が必要ない場合は、AMO のダッシュボードにログインして、互換性のあるバージョンを更新するだけで済みます。 何らかの変更を加えた場合は、新しいバージョンを AMO にアップロードする必要があります。</p>
<p>詳しくは <a class="internal" href="/ja/Submitting_an_add-on_to_AMO" title="ja/Submitting an add-on to AMO">AMO へのアドオンの登録</a> を参照してください。</p>
<h2 id="Places_データベースへのアクセス">Places データベースへのアクセス</h2>
<p>Firefox 3.1 以前は、<a class="internal" href="/ja/Storage" title="ja/Storage">Storage API</a> を使って Places データベースへ直接アクセスする場合、以下のように少々工夫が必要でした。</p>
<pre class="brush: js">var places = Components.classes["@mozilla.org/file/directory_service;1"].
getService(Components.interfaces.nsIProperties).
get("ProfD", Components.interfaces.nsIFile);
places.append("places.sqlite");
var db = Components.classes["@mozilla.org/storage/service;1"].
getService(Components.interfaces.mozIStorageService).openDatabase(places);
</pre>
<p>これは <code>places.sqlite</code> データベースファイルへのパスを自力で作成し、Storage アクセスのためのファイルを開くものでした。</p>
<p>Firefox 3.1 には、Places データベースへアクセスするための便利な方法を提供する、専用のサービスが追加されており、上記の方法は Firefox 3.1 以降では機能しません。</p>
<pre class="brush: js">var db = Components.classes["@mozilla.org/browser/nav-history-service;1"].
getService(Components.interfaces.nsPIPlacesDatabase).DBConnection;
</pre>
<h2 id="テキストボックスの検索">テキストボックスの検索</h2>
<p><a class="internal" href="/ja/XUL/textbox" title="ja/XUL/Textbox"><code>textbox</code></a> の種類のひとつ、<code>timed</code> は廃止予定となりました。代わりに <code>search</code> を使ってください。</p>
<p>Firefox 3 では、以下のようなコードが使われていたはずです。</p>
<pre><textbox type="timed" timeout="1000" oncommand="alert(this.value);"/>
</pre>
<p>Firefox 3.1 では、これを以下のように書き換える必要があります。</p>
<pre><textbox type="search" timeout="1000" oncommand="alert(this.value);"/>
</pre>
<h2 id="JSON">JSON</h2>
<p>JSON.jsm JavaScript モジュールは Firefox 3.1 では削除され、ネイティブの JSON オブジェクトサポートに置き換えられました。 詳しくは、<a class="internal" href="/ja/Using_JSON_in_Firefox" title="/ja/Using JSON in Firefox">Firefox で JSON を使用する</a> をご覧ください。JSON のより一般的な概要と、各種バージョンの Firefox で JSON を使う方法については、<a class="internal" href="/ja/JSON" title="ja/JSON">JSON</a> のページからリンクされている記事を参照してください。</p>
<p>Firefox 3 と Firefox 3.1 の両方について互換性を確保するには、以下のように記述します。</p>
<pre class="brush: js">if (typeof(JSON) == "undefined") {
Components.utils.import("resource://gre/modules/JSON.jsm");
JSON.parse = JSON.fromString;
JSON.stringify = JSON.toString;
}
</pre>
<p>JSON がネイティブサポートされていない場合は JSON.jsm JavaScript モジュールをインポートして、そのモジュールによって提供されているメソッドをネイティブ JSON で使われているものにマッピングします。これによって、同じ呼び出しが可能になります。</p>
<p>また、{{ interface("nsIJSON") }} インタフェースを直接利用することでも、この問題を回避できます。</p>
<h2 id="クローム登録に関する変更">クローム登録に関する変更</h2>
<p>Firefox 3.1 では、リモートのクロームを利用可能にするセキュリティホールが修正されています。 これは、<code>chrome.manifest</code> ファイルに Web サイトを参照するリソースが含まれているすべてのアドオンに影響します。</p>
<p>この問題は {{ Bug(466582) }} で詳しく説明されています。{{ interface("nsIProtocolHandler") }} インタフェースに追加された新しいフラグ <code>URI_IS_LOCAL_RESOURCE</code> によって、そのプロトコルがクロームとして登録しても安全であることを示すことができます。 独自のプロトコルハンドラを作成し、それを <code>chrome.manifest</code> 内で登録しようとするアドオンは、正しく動作するようにこのフラグを追加する必要があります。</p>
<h2 id="カスタマイズ可能なツールバー">カスタマイズ可能なツールバー</h2>
<p>Firefox 3.1 では、カスタマイズ可能なツールバーの挙動が次のように変更されました。<xul:toolbar/> バインディングは、関連付けられた <xul:toolbarpalette/> からツールバー削除、もしくはツールバーへ追加するようになりました。これまでは、項目を複製してツールバーへコピーしていました。 つまり、パレットには、ツールバー上に存在しないアイテムしか含めることができません。これまでの挙動では、ツールバー上に表示されているかどうかに関わらず、カスタマイズ可能なすべての要素が含まれていました。 これは、<xul:toolbarpalette/> からカスタマイズ可能なすべてのツールバー項目を取得できることに依存した処理を行っていたり、ツールバーのカスタマイズ中に動的にパレットへ項目を挿入し、それらを利用可能にしようとしているアドオンで問題となる可能性があります。 詳しくは、{{ Bug(407725) }} と {{ Bug(467045) }} をご覧ください。</p>
<h2 id="興味深い新機能">興味深い新機能</h2>
<h3 id="すべてのタブのイベントを監視する">すべてのタブのイベントを監視する</h3>
<p>Firefox 3.1 では、すべてのタブを監視するプログレスリスナーを追加、削除できるようになりました。 詳しくは、<a class="internal" href="/ja/Listening_to_events_on_all_tabs" title="ja/Listening to events on all tabs">すべてのタブのイベントを監視する</a> をご覧ください。</p>
<h2 id="テーマ開発者の方へ">テーマ開発者の方へ</h2>
<ul> <li><a class="internal" href="/ja/Theme_changes_in_Firefox_3.1" title="ja/Theme changes in Firefox 3.1">Firefox 3.1 でのテーマ関連の変更</a> を確認してください。</li> <li>Mozillazine フォーラムの <a class="topictitle external" href="http://forums.mozillazine.org/viewtopic.php?f=18&t=665138" title="http://forums.mozillazine.org/viewtopic.php?f=18&t=665138">Theme changes for FF3.1</a> を参照して、3.0 から 3.1 の間に行われた、テーマ開発者に影響するすべての変更の概要、一覧を確認してください。 このスレッドでは、CSS の新機能 (nth-child、-moz-box-shadow など)、既存の UI 部品への変更、UI 全体の改善、Firefox 3.1 の新機能 (audio/video のサポート、プライベートブラウジング、セッション復元機能の拡張、ボックス・ウィンドウ・テキストシャドウ) が議論されています。</li>
</ul>
|