Skip to content

Developer FAQ

brettz9 edited this page Dec 30, 2012 · 6 revisions

Frequently asked questions

## **How can I use regular XPCOM APIs?**

Firstly, I discourage this if at all possible, since one of the reasons for AsYouWish is to move toward the future-looking API of the Addons SDK, both for the hope of cross-browser support down the road (since other browsers will not agree to making calls with @mozilla.org) and given that Firefox itself is moving in this direction. That being said, the APIs may not yet be adequate for your needs, in which case, see AMO SDK Docs on XPCOM on how to gain XPCOM access. If you don't want other browsers to choke at the object destructuring involved with var {Cc, Ci} = require("chrome"); used in the example there, you can use this longer form instead: var chrome = require('chrome'), Cc = chrome.Cc, Ci = chrome.Ci;. Please also know that since my code is wrapping the APIs I have exposed to you (in order to avoid complaints from Firefox which would prevent their usage in the future if not already), you cannot use instanceof with such objects and get the expected result. (I also found one cannot use the word Components at all within SDK code, but there seems to be no problem when accessed within HTML via my add-on. (If you do need the Components object, you can do require('chrome').components.) If you come across other issues, feel free to add an explanation here, or at least report under Issues. You can see a chrome demo within AsYouWish's top-level "demos" folder.

## **I want desktop file access**

Ok, this is not a question (unless you are a linguist), but this appears to be the most common reason for people looking to use AsYouWish so far. First of all, I suggest your making sure that your needs are not already met by the emerging HTML5 standards for FileSystem access. Secondly, as with all AsYouWish needs, I suggest first looking into the Addons SDK APIs for a solution, in this case, the file module. If there is some inadequacy in the API, you may use the XPCOM APIs (see the previous question on how to do this and also to see why it is better to avoid this if possible). You can see a file demo within AsYouWish's top-level "demos" folder.

## **Can I use XUL elements within my HTML?**

AsYouWish does not enable this capability (unless you can find a way somehow via the exposed Addons SDK APIs). Mozilla has some documentation on enabling this, but I wouldn't count on relying on this for the long term given that the approach of the Addons SDK is to move away from XUL elements, even there are not currently always quick substitutes (e.g., trees). That being said, you might find this example helpful on getting remote XUL to work with HTML via iframe interaction (though see https://wiki.mozilla.org/XUL:Remote_XUL_bugs for potential issues that AsYouWish may or may not be able to overcome). Tips on migrating a XUL addon to an SDK addon may be helpful for AsYouWish code as well.

## **What kind of errors can I listen for?**

Currently, the following errors are reported (but this API is not yet frozen):

  • bad-privilege: The privilege is not even potentially supported. A second argument is populated with the specific bad privilege.
  • disallowed-privilege: The privilege is not on the user's currently enforced whitelist. A second argument is populated with the specific disallowed privilege.
  • failed-retrieval: There was an unknown failure in requiring the object. A second argument is populated with the specific failed privilege.
  • refused: The user explicitly refused permission for a privilege. A second argument is populated with the specific as yet unapproved privileges, and a third argument is populated with the currently approved privileges.
  • denied: The site has since been completely denied access. A second argument is populated with the specific bad privilege.
  • dismissed: Should occur when user clicks away or switches tabs, though due to an apparent Firefox bug, that is currently being reported be 'removed'. A second argument is populated with 'initial' or 'callback' to indicate at what phase the dismissal occurred.
  • removed: Occurs when permissions hanger is closed with 'Not now' or with 'x', but not with the explicit option 'Refuse permission' (which reports "refused"); also currently reporting dismissed, though this is apparently a Firefox bug

Currently 'shown' is only an internal event and not reported.

## **How can my "addon" website listen for an unload event to perform clean-up work**

I haven't figured out how to execute a genuine "unload" event, so currently, you have to listen for an "x-unload" event (on the window).

Clone this wiki locally