Updating extensions for Firefox 7

This article offers advice for add-on developers that want to update their extensions to work in Firefox 7. Fortunately, most of the changes are relatively minor in this release, and few add-ons should need significant changes to work in Firefox 7.

Note: For a complete list of developer-related changes in Firefox 7, see Firefox 7 for developers.

As always, you will need to recompile any binary components to make them compatible with Firefox 7.

XPCOM changes affecting compatibility

Most of the changes in this release are XPCOM interface removals, or removals of specific, obsolete APIs from interfaces.

Removed interfaces

The following interfaces are the ones that were removed that will most likely impact extension developers:

  • nsIDOM3Node
  • nsIDOM3TypeInfo
  • schemaTypeInfo
  • nsIDOMNSDocument
  • nsIDOMDocumentStyle

You can get a complete list of the removed interfaces in the Removed interfaces section of Firefox 7 for developers.

Changed methods

A few interfaces have methods that have been changed:

nsINavHistoryObserver and nsINavBookmarkObserver

These have been changed to support Firefox Sync better by adding a new GUID parameter to several of their methods. JavaScript-based code shouldn't require any changes, since this is just the addition of a new, optional, parameter. However, binary components will need to be updated to take the new parameter into account.

nsIDOMFile

A number of non-standard methods have been removed from this interface. This affects the File object's File.getDataAsUrl() and File.getAsBinary() methods. However, this functionality can now be found in the standard FileReader object.

Other changes of note

These changes won't affect compatibility (we weren't kidding when we said there weren't many changes that do in this release), but do add capabilities that are easy to take advantage of that might be of special use to you.

Unloading JavaScript code modules

The new Components.utils.unload() method lets you unload JavaScript code modules previously loaded by calling Components.utils.load(). This can be particularly handy with restartless (bootstrapped) extensions, so that you can unload an old version of a code module when a new version of your add-on is installed.

Inline preferences

You can now have preference options inline in the Add-on Manager window, which lets users configure your add-on without having to open a separate preference dialog box. There are limits to what types of configuration controls can be provided, but this is still very helpful — plus it works for restartless (bootstrapped) extensions.

See also