Install.rdf: Difference between revisions

From MozillaZine Knowledge Base
Jump to navigationJump to search
(→‎Creating install.rdf using tools: added TM's new Extension Wizard)
(redirect to devmo)
Line 1: Line 1:
{{extdev}}
See the [http://developer.mozilla.org/en/docs/install.rdf Mozilla Developer Center] for info on install.rdf.
: ''Most of information here applies to install.rdf used in themes too. See [[#install.rdf for themes|below]] for detailed information.''


Firefox 0.9, Thunderbird 0.7, Nvu 0.? and all subsequent versions of these products use the Extension Manager (''"the EM"'') for managing extensions and themes. In order to have your extension supported by it you have to package your extensions as described in "[http://www.mozilla.org/projects/firefox/extensions/packaging/extensions.html Packaging Firefox/Thunderbird Extensions]" document at mozilla.org (see also documentation at [http://developer.mozilla.org/en/docs/Install_Manifests Devmo]). This includes providing a valid '''install.rdf''' file.
[[Category:Redirects]]
 
== Creating install.rdf using tools ==
You can use any of these tools:
* [http://ted.mielczarek.org/code/mozilla/extensiondev/ Extension developer's extension] has Extension Builder functionality.
* Ted Mielczarek's [http://ted.mielczarek.org/code/mozilla/ffinstall/ webapp for install.rdf creation].
* Ted Mielczarek's [http://ted.mielczarek.org/code/mozilla/extensionwiz/ Extension Wizard] for Firefox/Thunderbird version 1.5 and above ([http://forums.mozillazine.org/viewtopic.php?t=381720 disscussion thread at MZ forums]).
* [http://www.extensionsmirror.nl/index.php?showtopic=1379 xpiZilla] - Windows-only install.rdf and XPI generator by Will Ryan ([http://forums.mozillazine.org/viewtopic.php?t=96578 disscussion thread at MZ forums]).
* [http://physnet.uni-oldenburg.de/~schlenk/tcl/firefox/extensionmaker.kit Extensionmaker] - A Tcl Starkit for windows, that generates an install.rdf. You need a tclkit runtime for Windows to start it (see [http://www.equi4.com/tclkit.html]). It's currently beta.
 
== Template ==
If you choose to manually create an "install.rdf" file, you can use the template below as a guide.
 
<pre>
<?xml version="1.0"?>
<RDF xmlns="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
    xmlns:em="http://www.mozilla.org/2004/em-rdf#">
 
<Description about="urn:mozilla:install-manifest">
<em:id>{XXXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX}</em:id>
<em:name>Sample Extension</em:name>
<em:version>1.0</em:version>
<em:description>A sample extension with advanced features</em:description>
<em:creator>Your Name Here</em:creator>
<!-- optional items -->
<em:contributor>A person who helped you</em:contributor>
<em:contributor>Another one</em:contributor>
<em:homepageURL>http://sampleextension.mozdev.org/</em:homepageURL>
<em:optionsURL>chrome://sampleext/content/settings.xul</em:optionsURL>
<em:aboutURL>chrome://sampleext/content/about.xul</em:aboutURL>
<em:iconURL>chrome://sampleext/skin/mainicon.png</em:iconURL>
<em:updateURL>http://sampleextension.mozdev.org/update.rdf</em:updateURL>
<em:type>2</em:type> <!-- type=extension -->
 
                <!-- Firefox -->
<em:targetApplication>
<Description>
<em:id>{ec8030f7-c20a-464f-9b0e-13a3a9e97384}</em:id>
<em:minVersion>0.9</em:minVersion>
<em:maxVersion>1.0</em:maxVersion>
</Description>
</em:targetApplication>
 
                <!-- This is not needed for Firefox 1.1 and later. Only include this
                    if you want to make your extension compatible with older versions -->
<em:file>
<Description about="urn:mozilla:extension:file:sampleext.jar">
<em:package>content/</em:package>
<!-- optional items -->
<em:skin>skin/classic/</em:skin>
<em:locale>locale/en-US/</em:locale>
<em:locale>locale/ru-RU/</em:locale>
</Description>
</em:file>
</Description>
 
</RDF>
</pre>
 
== Target applications' GUIDs ==
{|
|-
| Firefox
| <tt>{ec8030f7-c20a-464f-9b0e-13a3a9e97384}</tt>
|-
| Thunderbird
| <tt>{3550f703-e582-4d05-9a08-453d09bdfdc6}</tt>
|-
| Nvu
| <tt>{136c295a-4a5a-41cf-bf24-5cee526720d5}</tt>
|-
| Mozilla Suite
| <tt>{86c18b42-e466-45a9-ae7a-9b95ba6f5640}</tt>
|-
| SeaMonkey
| <tt>{92650c4d-4b8e-4d2a-b7eb-24ecf4f6b63a}</tt>
|-
| Sunbird
| <tt>{718e30fb-e89b-41dd-9da7-e25a45638b28}</tt>
|-
| Netscape Browser
| <tt>{3db10fab-e461-4c80-8b97-957ad5f8ea47}</tt>
|-
| Flock Browser
| <tt>{a463f10c-3994-11da-9945-000d60ca027b}</tt>
|}
 
 
=== Notes ===
* '''Mozilla Suite''' ignores ''install.rdf'', but you ought to include corresponding <tt>targetApplication</tt> item in ''install.rdf'' if you support the Suite and are going to submit your extension to [http://update.mozilla.org/ update.mozilla.org], see [http://forums.mozillazine.org/viewtopic.php?t=99246 this thread]. '''You still must include an [[install.js]] file if you support Mozilla Suite.'''
* '''"[http://wiki.mozilla.org/SeaMonkey:Home_Page SeaMonkey]"''' is now the name of the community project, that continues working on the Mozilla Suite codebase, after Mozilla Foundation has [http://www.mozilla.org/seamonkey-transition.html announced] it will not actively develop the Mozilla Suite any further. At the moment it doesn't read install.rdf, just as the Mozilla Suite, but it's planned to implement this in future.
* The <tt>em:type</tt> arc was introduced in '''Toolkit 1.1a''' applications. It's used to specify the type of an item. Use the value of 2 for extensions, 4 for themes.
 
== Items' IDs ==
Each extension must have an unique ID (the value of em:id arc).
 
Initially, it was recommended to use GUIDs for extensions IDs. To generate a GUID, you can use [http://www.microsoft.com/downloads/details.aspx?FamilyId=94551F58-484F-4A8C-BB39-ADB270833AFC&displaylang=en MS guidgen] (a GUID generator for Windows NT-based systems), uuidgen (for *nix, also comes with MSVS), a web-based generator such as [http://kruithof.xs4all.nl/uuid/uuidgen this] and [http://www.hoskinson.net/webservices/guidgeneratorclient.aspx this], or open your [[IRC]] client, go to ''irc://irc.mozilla.org/botbot'' and say 'botbot uuid'.
 
Extension Manager in Toolkit 1.5-based applications '''will not install''' extensions using arbitrary strings as their IDs. Only GUIDs and IDs of ''extension@domain'' form are now accepted. For example, the DOM Inspector has ''inspector@mozilla.org'' ID.
 
== Versioning ==
See [http://developer.mozilla.org/en/docs/Toolkit_version_format Toolkit version format] document for details about version's format used.
 
== install.rdf for themes ==
'''TBD.''' See [http://developer.mozilla.org/en/docs/Theme_Packaging#install.rdf]. The main difference is the additional "em:internalName" arc in theme's manifest.
 
[[Category:Development]]

Revision as of 22:34, 30 August 2006

See the Mozilla Developer Center for info on install.rdf.