拡張機能 (Mozilla)
Mozillaのソフトウェアにおける拡張機能とは、Mozilla FirefoxやMozilla Thunderbirdなどで利用できるアドオンのうち、ソフトウェアに機能を追加したり、既存の機能を変更したりするものである[1]。
概要
拡張機能はMozilla Foundation製のMozilla Firefox(Firefox for Mobile含む)やMozilla Thunderbirdのほか、これらと協調して有志により開発されているSeaMonkeyなどに対して主に設定や操作の機能強化を行うものである。また同じ仕組みを利用してテーマ(スキン)も提供することができる。また、拡張機能にはセキュリティ修正パッチとして作成されるものや英語版しか出ていないソフトウェアに対する日本語化パックとして配布されるものもある。
歴史
2015年以前のFirefoxでは、「寛容なアドオンモデル」が採用されていた。これは、XULやXPCOMといった技術によってFirefoxの内部にアクセスし、ユーザーインターフェイスを大きく変えてしまうような大きな柔軟性をもたらすものだった。しかしそれは、Firefoxの内部構造に依存しすぎており、Firefoxのバージョンアップによって使用できなくなったり、クラッシュやパフォーマンスの低下を起こす可能性があった。さらに、Firefoxのマルチプロセス化(e10s)のような新技術の導入を阻害することも問題となっていた[2]。
そこでMozillaは、2015年8月21日にFirefoxのアドオンをWebExtensionsに置き換えていく方針を明らかにした。WebExtensionsはBlinkのアドオンと互換性が高く、Blinkのものを簡単に移植できる[2]。この移行には否定的な声も少なくなかったが[3]、Mozillaは2017年11月14日リリースの「Firefox Quantum(Firefox 57)」ですべてのレガシーアドオンを廃止した[4]。延長サポート版であるFirefox ESRはヴァージョン52まで対応するが、2018年6月まででサポート終了となりESR 59以降はレガシーアドオンが廃止となる[5]。なお、Firefoxから派生したWaterfoxとPale Moonは、レガシーアドオンのサポートを続けている[6][7]。
一方、Thunderbirdでは2018年3月リリースのThunderbird 59でもレガシーアドオンのサポートが継続される。ただし、コアエンジンの更新によって使用できなくなるものもありうる[8]。
技術
2015年にMozillaがアドオンをWebExtensionsに移行させることを発表する前には[2]、XUL/XPCOMオーバーレイ、ブートストラップ型拡張機能、Add-on SDKを利用した開発方法が存在した。しかし、WebExtensionsが採用されるようになってからは、それらの技術は廃止されることになった。WebExtensionsはクロスブラウザで動作可能なアドオンを開発するための技術で、Google ChromeやOperaのextension APIと互換性があり、わずかな変更でFirefoxで動作させることができる。WebExtensionsはJavaScript、HTML、CSSに専用のJavaScript APIを加えることで作られる[9]。
インストールと管理
拡張機能を利用するにはユーザーが各自Mozilla Add-onsのような任意のサイトから配布されている拡張機能をダウンロードし、インストールすることが必要となる。インストールにはXPInstallモジュールを用いることでユーザーはインストールを許可するだけで自動的にインストールが完了するようになっている。
拡張機能はアドオンマネージャを用いて管理する。拡張機能にアップデートの提供元が記述されているとき、自動的にアップデートが無いかをチェックする。特にブラウザのバージョンアップをしたときは互換性チェックを再度行い、不合格である拡張機能は無効化される。アドオンマネージャから直接 Mozilla Add-ons に登録された拡張機能を検索し、インストールすることもできるようになっている。
拡張機能のインストールにはその拡張機能がインストールしたいブラウザに対応していることが条件であり、標準ではインストール直前にブラウザのバージョンチェックが行われる。ブラウザとの互換性チェックはその拡張機能で設定されたバージョンの範囲にインストールするブラウザのバージョンが含まれているかどうかで調べるため、公式には対応が謳われていない拡張機能でもその情報さえ弄れば動作してしまう場合もある。Firefox 5以降で採用されたラピッドリリースへの対応のため、Firefox 10以降相当のブラウザではアドオンの最高対応バージョンがFirefox 4以降であればそのブラウザに対応しているものとみなしてインストールされるようになった[10]。
拡張機能が登場した背景
Firefoxの登場以前に開発されていたMozilla Suiteではソフトウエア本体に様々な機能追加を行ったため、開発が進むに従いソフトウェアの肥大化やバグの増加をもたらした。次世代ブラウザであるFirefoxやThunderbirdではこのような事態を避けるため、高い拡張性を残しながらもソフトウェアのサイズを小さいものにとどめる方法として、機能追加は拡張機能で行うよう方針が改められた。
プラグインとの違い
拡張機能はブラウザそのものの機能を拡張するのに対し、プラグインはFlashのようなグラフィックフォーマットへの対応を強化するもので、ブラウザそのものの機能には影響を与えない。
窓の杜「プラグイン」問題
事の発端は2005年2月17日に掲載された窓の杜の『「Firefox」プラグイン特集[11]』という記事である。編集部が“拡張機能”という言葉が一般に認識されにくい、IEなど他製品で言う“プラグイン”と同じものであるとして意識して欲しいなどの理由から、記事の中で“プラグイン”という表記を取った。(しかしIEの機能拡張プログラムは「アドオン」と呼ばれており、窓の杜もそれを肯定しているため既に主張が破綻しているとの指摘がある[12])。
しかしこの表記がユーザーの混乱を招くとして懸念され、Bugzilla-jpにはバグとして登録される[13]まで問題が発展した。
このことについて国内の拡張機能開発者Piroらは以下のような点が問題だと述べている。
- ユーザーが拡張機能を「プラグイン」として認識してしまうと検索などで拡張機能を探し出すことが困難となる。
- 用語の浸透度が逆転すると本来の「プラグイン」の情報が「プラグインとして認識された拡張機能」の情報に埋もれてしまい、本来の「プラグイン」を検索したいユーザーや開発者を翻弄させる。
この問題は1年近く議論されていたが、窓の杜2006年3月23日の記事[14]で編集部は「今後“プラグイン”と“拡張機能”を区別して表記する」と書いたため問題は終結した。
その後MozillaはFirefox 2.0のリリース以降ソフトウェアの画面や公式ページで拡張機能やテーマをまとめて「アドオン」としており、拡張機能は「アドオン」とも呼ばれるようになっている。
主な拡張機能の種類
- 機能を追加し、向上させるもの
- Mozilla Suiteの機能と同等の働きをするもの - ChatZilla、Eメール、ニュースリーダーなど。
- ブラウジング性能の向上 - Tab Mix Plusなど。
- ブックマークなどのデータの同期 - 標準機能であるFirefox Syncに近い。
- 検索プラグイン - Mozillaでは検索ツールなどと呼ぶ
- ツールバー - 検索プラグインとは異なる。
- など
- 開発・デバッグツール
- DOM Inspector - ウェブページや
- Firebug
- ウェブページの見た目を変更するもの
- など
- 全く無意味であるもの(ジョークソフト)
- 中止ボタンがしいたけに見えて困る
- など。
他のブラウザにおける類似の機能
Google Chrome、Operaのextension APIは、WebExtensionsと互換性がある。また、WebExtensionsはMicrosoft Edgeでも動作する[9]。
脚注
- ^ “アドオンで Firefox を活用する”. 2014年3月5日閲覧。
- ^ a b c 樽井秀人 (2015年8月24日). “Mozilla、「Firefox」のアドオンを「Google Chrome」互換の“WebExtensions”へ”. 窓の杜. 2017年10月2日閲覧。
- ^ 中井浩晶 (2015年9月1日). “動揺が広がるFirefox拡張機能の改革”. 窓の杜. 2017年10月2日閲覧。
- ^ 樽井秀人 (2017年2月17日). “「Firefox」の“WebExtensions”への移行ロードマップが公開 ~レガシーアドオンは廃止”. 窓の杜. 2017年10月2日閲覧。
- ^ 樽井秀人 (2017年10月4日). “「Firefox ESR」のレガシーアドオン対応は2018年6月まで ~「ESR 59」では利用不能”. 窓の杜. 2017年10月6日閲覧。
- ^ 樽井秀人 (2017年10月5日). “レガシーアドオン対応を継続するFirefox派生ブラウザー「Waterfox」の今後が明らかに”. 窓の杜. 2017年10月5日閲覧。
- ^ 樽井秀人 (2017年11月9日). “「Pale Moon」v27.6.0が公開、さまざまな改善を加えたメジャー更新”. 窓の杜. 2017年11月9日閲覧。
- ^ 樽井秀人 (2017年11月29日). “「Firefox Quantum」で打ち切られたレガシーアドオン対応、「Thunderbird」ではどうなる?”. 窓の杜. 2017年11月29日閲覧。
- ^ a b “WebExtensions とは何か?”. Mozilla Developer Network (2016年12月14日). 2017年10月2日閲覧。
- ^ “Firefox 11 のアドオン互換性に関わる修正のまとめ”. 2013年7月12日閲覧。
- ^ http://www.forest.impress.co.jp/article/2005/02/17/firefoxplugins.html
- ^ http://www.d-toybox.com/studio/weblog/show.php?mode=single&id=2006031300
- ^ http://bugzilla.mozilla.gr.jp/show_bug.cgi?id=5052
- ^ http://www.forest.impress.co.jp/article/2006/03/23/ffplugins15_5.html
関連項目
- Greasemonkey - 機能を向上させるためのスクリプトの実行環境を追加する。