Search completed in 2.74 seconds.
  
   
    Using XPInstall to Install Plugins - Archive of obsolete content
    
         parts of this page show the use of the 
xpinstall api.
...
xpinstall is a javascript-based installer technology that works across all the platforms that mozilla and netscape browsers based on mozilla (such as netscape 7) are deployed.
...exe) installer, 
xpinstall can wrap this native installer and run it so that the user never has to leave the browsing environment and click on the exe to run it.
...And 61 more matches
   
 
   
    Learn XPI Installer Scripting by Example - Archive of obsolete content
    
        parts of this page show the use of the 
xpinstall api.
... this article uses the installer script from browser.
xpi install package as the basis for discussing 
xpi installations in general.
... this installer script is relatively short, but it exercises most of the important features of the 
xpinstall api, and it can easily be used as a template for other more general software installations.
...And 23 more matches
   
 
   
    Signing an XPI - Archive of obsolete content
    
it was developed from the linux article so you want to sign your 
xpi package?
...certificate common name: 
xpi test organization: tjworld organization unit: software state or province: nottingham country (must be exactly 2 characters): gb username: tj email address: certificates@lan.tjworld.net generated public/private key pair certificate request generated certificate has been signed certificate "mytestcert" added to database exported certificate to x509.raw and x509.cacert.
...   x509.cacert will be used to sign your 
xpi package.
...And 15 more matches
   
 
   
    XPIDL
    
        xpidl is an interface description language used to specify xpcom interface classes.
...
xpidl is expected to converge towards webidl in the future.
...   note: starting in gecko 9.0, the older 
xpidl utility, which was previously used to generate c++ header files, typelib information, and so forth has been replaced with py
xpidl in the gecko sdk.
...And 15 more matches
   
 
   
    Creating XPI Installer Modules - Archive of obsolete content
    
this new packaging scheme is called 
xpi (pronounced "zippy"), and interacts with 
xpinstall.
... a 
xpi file typically contains the resources to be installed (in this case the barley.jar we want to have installed in the mozilla/bin/chrome/ directory) and an install script that guides the installation process.
...the 
xpi packaging scheme a complete description of the new packaging scheme is beyond the scope of this article.
...And 12 more matches
   
 
   
    Places Expiration
    
        e
xpiration is handled in toolkit/components/places/nsplacese
xpiration.js.
...  algorithm  e
xpiration is based on hardware specs, specifically on memory size and available disk space.
... this means on mobile and old systems e
xpiration will be more aggressive than on high-end hardware, to try keep the database size at a reasonable (and performant) value.
...And 10 more matches
   
 
   
    XPIDL Syntax
    
        status of this document this is a partial reverse-engineering of the libidl source code's parser, limited mostly to the subset of functionality that is supported by the mozilla 
xpidl binary.
... purpose of this document this document is not an introduction to 
xpidl or idl in general.
...  it is more focused on 
xpidl syntax and grammar.
...And 9 more matches
   
 
   
    XPI
    
        cross-platform installer module (
xpi) is a zip file used to install packages, utilizing the 
xpinstall technology.
... 
xpi modules (so called "bundles") are employed to install a wide variety of software, including plugins, extensions, themes, and thunderbird dictionaries.
...  an 
xpi contains installation instructions (install.js or install.rdf) as well as the actual software to install, which is often itself packaged as a jar file.
...And 6 more matches
   
 
   
    pyxpidl
    
        the py
xpidl tool suite has been built to replace the older 
xpidl tool which, in the past, was used to turn 
xpidl files into c++ headers and xpcom typelibs (xpt files).
... py
xpidl has been in use for a while, but replaced 
xpidl in the gecko sdk starting in gecko 9.0.
...  using py
xpidl  py
xpidl is in the sdk in the sdkdir/sdk/bin/ directory.
...And 5 more matches
   
 
   
    XPInstall - Archive of obsolete content
    
        parts of this page show the use of the 
xpinstall api.
...<?xml version="1.0" encoding="utf-8"?>  <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">     <!-- properties -->   </description> </rdf>   cross-platform install (
xpinstall) is a technology used by mozilla application suite, mozilla firefox, mozilla thunderbird and other xul-based applications for installing extensions.
... an 
xpi (pronounced "zippy" and derived from 
xpinstall) installer module is a zip file that contains an install script or manifest (entitled install.js or install.rdf) at the root of the file.
...And 4 more matches
   
 
   
    xpidl
    
        xpidl is a tool for generating xpcom interface information, based on 
xpidl interface description files.
... it generates:    c++ header files (.h), with a commented template for full c++ implementation of the interface  xpconnect typelib files (.xpt), with runtime type information to dynamically call xpcom objects through xpconnect    note: starting in gecko 9.0, 
xpidl has been replaced with py
xpidl in the gecko sdk.
... py
xpidl has been used for some time now, but now this older tool has been fully retired.
...And 4 more matches
   
 
   
    BasicCardResponse.expiryMonth - Web APIs
    
    the e
xpirymonth property of the basiccardresponse dictionary contains the e
xpiry month of the card used to make the payment.
...  syntax  "e
xpirymonth" : "number"  value  a domstring representing the card e
xpiry month as a two-digit number in the range 01 to 12.
...dick straw",   "cardsecuritycode" : "999",   "e
xpirymonth" : "07",   "e
xpiryyear" : "2021",   "billingaddress" : {     "country" : "gb",     // etc.
...And 2 more matches
   
 
   
    BasicCardResponse.expiryYear - Web APIs
    
    the e
xpiryyear property of the basiccardresponse dictionary contains the e
xpiry year of the card used to make the payment.
...  syntax  "e
xpiryyear" : "number"  value  a domstring representing the card e
xpiry year as a four-digit number in the range 0000 to 9999.
...dick straw",   "cardsecuritycode" : "999",   "e
xpirymonth" : "07",   "e
xpiryyear" : "2021",   "billingaddress" : {     "country" : "gb",     // etc.
...And 2 more matches
   
 
   
    RTCIceCandidatePairStats.consentExpiredTimestamp - Web APIs
    
 the rtcicecandidatepairstats property consente
xpiredtimestamp indicates the time at which the most recent stun binding response e
xpired.
... this indicates when the current stun bindings — the mapping of the ip address and port configurations for both peers on the webrtc connection — are due to e
xpire.
... if this time has arrived or passed, the bindings have e
xpired.
...And 2 more matches
   
 
   
    Expires - HTTP
    
 the e
xpires header contains the date/time after which the response is considered stale.
...  invalid dates, like the value 0, represent a date in the past and mean that the resource is already e
xpired.
...  if there is a cache-control header with the max-age or s-maxage directive in the response, the e
xpires header is ignored.
...And 2 more matches
   
 
   
  
   
    JS_SetRegExpInput
    
  syntax  bool js_setrege
xpinput(jscontext *cx, js::handleobject obj, js::handlestring input,                   bool multiline);            name    type    description          cx    jscontext *         the context.
...       description  js_setrege
xpinput sets the pending input string of the built-in regexp object to the specified input string.
... on successful, js_setrege
xpinput returns true, otherwise returns false.
...  see also    mxr id search for js_setrege
xpinput  js_newregexpobject  js_newucregexpobject  jsreg_multiline  js_clearregexpstatics  regexp                    ...
   
 
   
    nsXPIDLCString
    
         class declaration  nst
xpidlstring extends nststring such that:  (1) mdata can be null (2) objects of this type can be automatically cast to |const chart*| (3) getter_copies method is supported to adopt data allocated with ns_alloc, such as "out string" parameters in 
xpidl.
...  names: ns
xpidlstring for wide characters ns
xpidlcstring for narrow characters method overview     constructors     operator const char*     operator[]     operator=     get     find     rfind     rfindchar     findcharinset     rfindcharinset     compare     equalsignorecase     tofloat     tointeger     mid     left     right     setcharat     stripchars     stripwhitespace     replacechar     replacesubstring     trim     compresswhitespace     assignwithconversion     appendwithconversion     appendint     appendfloat     beginreading     endreading     beginwriting     endwriting     data     length     isempty     isvoid     isterminated     charat     first     last     countchar     findchar     equals     equalsascii     equalsliteral(const char     equalsliteral(char     lowercasee...
... methods   constructors   void ns
xpidlcstring() - source    void ns
xpidlcstring(const ns
xpidlcstring&) - source   parameters  ns
xpidlcstring& str      operator const char*   char* operator const char*() const - source      operator[]   char operator[](print32) const - source   parameters  print32 i    char operator[](pruint32) const - source   parameters  pruint32 i      operator=   ns
xpidlcstring& operator=(const ns
xpidlcstring&) -...
... source   parameters  ns
xpidlcstring& str    nscstring& operator=(const nscstring&) - source   parameters  nscstring& str    nsacstring_internal& operator=(char) - source   parameters  char c    nsacstring_internal& operator=(const char*) - source   parameters  char* data    nsacstring_internal& operator=(const nsacstring_internal&) - source   parameters  nsacstring_internal& str    nsacstring_internal& operator=(const nscsubstringtuple&) - source   parameters  nscsubstringtuple& tuple      get   char* get() const - source   returns the null-terminated string     find   print32 find(const nscstring&, prbool, print32, print32) const - source   search for the given substring within this string.
   
 
   
    nsXPIDLString
    
         class declaration  nst
xpidlstring extends nststring such that:  (1) mdata can be null (2) objects of this type can be automatically cast to |const chart*| (3) getter_copies method is supported to adopt data allocated with ns_alloc, such as "out string" parameters in 
xpidl.
...  names: ns
xpidlstring for wide characters ns
xpidlcstring for narrow characters method overview     constructors     operator const prunichar*     operator[]     operator=     get     find     rfind     rfindchar     findcharinset     rfindcharinset     equalsignorecase     tofloat     tointeger     mid     left     right     setcharat     stripchars     stripwhitespace     replacechar     replacesubstring     trim     compresswhitespace     assignwithconversion     appendwithconversion     appendint     appendfloat     beginreading     endreading     beginwriting     endwriting     data     length     isempty     isvoid     isterminated     charat     first     last     countchar     findchar     equals     equalsascii     equalsliteral(const char     equalsliteral(char     lowercaseequalsas...
... methods   constructors   void ns
xpidlstring() - source    void ns
xpidlstring(const ns
xpidlstring&) - source   parameters  ns
xpidlstring& str      operator const prunichar*   prunichar* operator const prunichar*() const - source      operator[]   prunichar operator[](print32) const - source   parameters  print32 i    prunichar operator[](pruint32) const - source   parameters  pruint32 i      operator=   ns
xpidlstring& operator=(cons...
...t ns
xpidlstring&) - source   parameters  ns
xpidlstring& str    nsstring& operator=(const nsstring&) - source   parameters  nsstring& str    nsastring_internal& operator=(prunichar) - source   parameters  prunichar c    nsastring_internal& operator=(const prunichar*) - source   parameters  prunichar* data    nsastring_internal& operator=(const nsastring_internal&) - source   parameters  nsastring_internal& str    nsastring_internal& operator=(const nssubstringtuple&) - source   parameters  nssubstringtuple& tuple      get   prunichar* get() const - source   returns the null-terminated string     find   print32 find(const nscstring&, prbool, print32, print32) const - source   search for the given substring within this string.
   
 
   
    PushSubscription.expirationTime - Web APIs
    
   the e
xpirationtime read-only property of the pushsubscription interface returns a domhighrestimestamp of the subscription e
xpiration time associated with the push subscription, if there is one, or null otherwise.
...  syntax  var e
xpirationtime = pushsubscription.e
xpirationtime  value  a domhighrestimestamp.
...  specifications           specification    status    comment          push apithe definition of 'e
xpirationtime' in that specification.
... desktopmobilechromeedgefirefoxinternet exploreroperasafariandroid webviewchrome for androidfirefox for androidopera for androidsafari on iossamsung internete
xpirationtimechrome                 full support                              60edge                 full support                              16firefox                 no support                              noie                 no support                              noopera                 full support                              47safari                 no support                              no...
   
 
   
    expiration - Web APIs
    
           the mediakeysession.e
xpiration read-only property returns the time after which the keys in the current session can no longer be used to decrypt media data, or nan if no such time exists.
... syntax  var e
xpirationtime = mediakeysessionobj.e
xpiration;  specifications           specification    status    comment          encrypted media extensionsthe definition of 'e
xpiration' in that specification.
   
 
   
   
    RegExpInstance.lastIndex - JavaScript
    
                  property attributes of rege
xpinstance.lastindex                       writable       yes                 enumerable       no                 configurable       no           description  this property is set only if the regular expression instance used the g flag to indicate a global search, or the y flag to indicate a sticky search.
   
 
   
    nsIAnnotationService
    
  method overview           void setpageannotation(in nsiuri auri, in autf8string aname, in nsivariant avalue, in long aflags, in unsigned short ae
xpiration);          void setitemannotation(in long long aitemid, in autf8string aname, in nsivariant avalue, in long aflags, in unsigned short ae
xpiration);          void setpageannotationstring(in nsiuri auri, in autf8string aname, in astring avalue, in long aflags, in unsigned short ae
xpiration);          boolean setitemannotationstring(in long long aitemid, in autf8string aname, in astring avalue...
..., in long aflags, in unsigned short ae
xpiration);          void setpageannotationint32(in nsiuri auri, in autf8string aname, in long avalue, in long aflags, in unsigned short ae
xpiration);          void setitemannotationint32(in long long aitemid, in autf8string aname, in long avalue, in long aflags, in unsigned short ae
xpiration);          void setpageannotationint64(in nsiuri auri, in autf8string aname, in long long avalue, in long aflags, in unsigned short ae
xpiration);          void setitemannotationint64(in long long aitemid, in autf8string aname, in long long avalue, in long aflags, in unsigned short ae
xpiration);          void setpageannotationdouble(in nsiuri auri, in autf8string aname, in double avalue, in long aflags, in unsigned short ae
xpiration);          void setitemannotationdo...
...uble(in long long aitemid, in autf8string aname, in double avalue, in long aflags, in unsigned short ae
xpiration);          void setpageannotationbinary(in nsiuri auri, in autf8string aname,[const, array, size_is(adatalen)] in octet adata, in unsigned long adatalen, in autf8string amimetype, in long aflags, in unsigned short ae
xpiration);          void setitemannotationbinary(in long long aitemid, in autf8string aname,[const, array, size_is(adatalen)] in octet adata, in unsigned long adatalen, in autf8string amimetype, in long aflags, in unsigned short ae
xpiration);          nsivariant getpageannotation(in nsiuri auri, in autf8string aname);          nsivariant getitemannotation(in long long aitemid, in autf8string aname);          astring getpageannotationstring(in nsiuri auri, in autf8strin...
...And 38 more matches
   
 
   
    jpm - Archive of obsolete content
    
         jpm 
xpi    package your add-on as an 
xpi file, which is the install file format for firefox add-ons.
...          jpm post    package your add-on as an 
xpi file, and then post it to some url.
...          jpm watchpost    package your add-on as an 
xpi file whenever there is a file change and post that to some url.
...And 31 more matches
   
 
   
    Index - Archive of obsolete content
    
these type of extensions have many advantages for both users and developers compared to the old 
xpinstall/-style extensions.
...       247     installing extensions and themes from web pages     add-ons, extensions, obsolete, themes       there are a variety of ways you can install extensions and themes from web pages, including direct linking to the 
xpi files and using the installtrigger object.
...       299     signing an 
xpi     add-ons, code snippets, extensions, guide, needshelp, 
xpinstall       this article describes how to sign your own firefox extensions with a code-signing certificate on a windows platform.
...And 29 more matches
   
 
   
    cfx - Archive of obsolete content
    
         cfx 
xpi    package your add-on as an 
xpi file, which is the install file format for firefox add-ons.
...       cfx 
xpi  this tool is used to package your add-on as an 
xpi file, which is the install file format for mozilla add-ons.
...  called with no options, this command looks for a file called package.json in the current directory and creates the corresponding 
xpi file.
...And 16 more matches
   
 
   
    Packaging WebLock
    
for more detailed information on packaging and installation of components into gecko-based applications, see http://www.mozilla.org/projects/
xpinstall.
...   component installation overview  
xpinstall is a set of javascript apis for creating installation scripts.
... using 
xpinstall, you can create web-based installations for gecko-based applications, mozilla extensions, or individual components.
...And 15 more matches
   
 
   
    Starting WebLock
    
 instead of starting with the implementation, developers use 
xpidl (see 
xpidl and type libraries for more information about 
xpidl) to define the interface to the component: how the functionality should be organized, expressed, and exposed to its clients.
... as a strongly typed and implementation-agnostic language, 
xpidl requires that you be quite specific about the apis, the list of parameters, their order, and their types.
... 
xpidl requires that you spell it all out, in other words.
...And 15 more matches
   
 
   
    Setting Up a Development Environment - Archive of obsolete content
    
 to package 
xpi files, we use make.
... we recommend you set up make in your system, since our examples come with all the necessary files to build and install the resulting 
xpi using this tool.
...this is where all the resulting build files will be created, and where you'll find the extension 
xpi file once you get it to build.
...And 14 more matches
   
 
   
    Index - Web APIs
    
       256     basiccardresponse     api, basic card payment, basiccardresponse, experimental, interface, payment request, payment request api, reference       the basiccardresponse dictionary (related to the payment request api, although defined in the basic card payment spec) defines an object structure for payment response details such as the number/e
xpiry date of the card used to make the payment, and the billing address.
...       261     basiccardresponse.e
xpirymonth     api, basic card payment, basiccardresponse, experimental, payment request, payment request api, property, reference, e
xpirymonth       the e
xpirymonth property of the basiccardresponse dictionary contains the e
xpiry month of the card used to make the payment.
...        262     basiccardresponse.e
xpiryyear     api, basic card payment, basiccardresponse, experimental, payment request, payment request api, property, reference, e
xpiryyear       the e
xpiryyear property of the basiccardresponse dictionary contains the e
xpiry year of the card used to make the payment.
...And 14 more matches
   
 
   
  
   
    Creating custom Firefox extensions with the Mozilla build system - Archive of obsolete content
    
topsrcdir = @top_srcdir@ srcdir    = @srcdir@ vpath     = @srcdir@  include $(depth)/config/autoconf.mk  module = myextension  dirs = public src  
xpi_name             = myextension install_extension_id = myextension@mycompany.com 
xpi_pkgname          = myextension  dist_files = install.rdf  include $(topsrcdir)/config/rules.mk        a detailed description of the make process, describing the key features of this makefile, can be found here.
... module and 
xpi_name are both set to the name of your extension; they should be repeated in all project makefiles so that all of the files land in the same place in the 
xpi staging area (see below).
...you don't have to provide an 
xpi_pkgname, but if you do an 
xpi file, suitable for distribution, is automatically created in the root of the 
xpi staging area (/mozilla/$(moz_objdir)/dist/
xpi-stage/).
...And 13 more matches
   
 
   
    Chapter 5: Let's build a Firefox extension - Archive of obsolete content
    
using the normal 
xpi-style installer would just be added trouble in this case, so we won’t use it.
...           phase 5: 
xpi packaging  we actually completed our hello world extension in phase 4, but you can’t distribute the source files in this state to other users.
... so we need to create an 
xpi-formatted installer.
...And 12 more matches
   
 
   
    Introduction to XPCOM for the DOM
    
an interface can also be defined using 
xpidl.
...first we will take a look at 
xpidl and how it can help you define interfaces.
... 
xpidl  
xpidl stands for cross-platform interface definition language.
...And 12 more matches
   
 
   
    nsIFaviconService
    
to use this service, use: var faviconservice = components.classes["@mozilla.org/browser/favicon-service;1"]                      .getservice(components.interfaces.nsifaviconservice);  method overview          void addfailedfavicon(in nsiuri afaviconuri);          void e
xpireallfavicons();           void getfavicondata(in nsiuri afaviconuri, out autf8string amimetype, [optional] out unsigned long adatalen, [array,retval,size_is(adatalen)] out octet adata); obsolete since gecko 22.0          astring getfavicondataasdataurl(in nsiuri afaviconuri);  obsolete since gecko 22.0          nsiuri getfaviconforpage(in nsiuri apageuri); obsolete since gecko 22.0          nsiur...
...uri afaviconuri);          void setandloadfaviconforpage(in nsiuri apageuri, in nsiuri afaviconuri, in boolean aforcereload, in unsigned long afaviconloadtype, [optional] in nsifavicondatacallback acallback); obsolete since gecko 22.0          void setfavicondata(in nsiuri afaviconuri, [const,array,size_is(adatalen)] in octet adata, in unsigned long adatalen, in autf8string amimetype, in prtime ae
xpiration); obsolete since gecko 22.0          void setfavicondatafromdataurl(in nsiuri afaviconuri, in astring adataurl, in prtime ae
xpiration);  obsolete since gecko 22.0          void setfaviconurlforpage(in nsiuri apageuri, in nsiuri afaviconuri); obsolete since gecko 22.0       attributes          attribute    type    description          defaultfavicon    nsiuri    the default favicon uri.
... e
xpireallfavicons() e
xpires all known favicons, removing them from the database.
...And 12 more matches
   
 
   
    Enhanced Extension Installation - Archive of obsolete content
    
first it must locate the firefox executable, then run it with the -install-global-extension command line flag, which installs from a 
xpi into the firefox application directory.
... aside from the work of locating the firefox executable in the first place (which varies from platform to platform), this is very limiting because:       it forces the third party application to package its firefox integration hooks as a 
xpi.
... extension installation and registration is also prohibitively difficult/annoying for developers, who are forced to either dangerously hand-edit all the appropriate manifest files, or package their code as a 
xpi and install it that way every time they make a change.
...And 11 more matches
   
 
   
    Installing Extensions and Themes From Web Pages - Archive of obsolete content
    
        there are a variety of ways you can install extensions and themes from web pages, including direct linking to the 
xpi files and using the installtrigger object.
...  extension and web authors are encouraged to use the method described below to install 
xpis, as it provides the best experience to users.
...aevent.target; a.href === undefined;) a = a.parentnode;   var params = {     "foo": { url: aevent.target.href,              iconurl: aevent.target.getattribute("iconurl"),              hash: aevent.target.getattribute("hash"),              tostring: function () { return this.url; }     }   };   installtrigger.install(params);    return false; } //--> </script>  <a href="http://www.example.com/foo.
xpi"   iconurl="http://www.example.com/foo.png"   hash="sha1:28857e60d043447c5f4550853f2d40770b326a13"   onclick="return install(event);">install extension!</a>   let's go through this piece by piece.
...And 11 more matches
   
 
   
    Extension Packaging - Archive of obsolete content
    
 after the extension files and install.rdf have been prepared, there are several ways to prepare an extension for installation: zip the extension directory into a user-installable 
xpi (
xpinstall) file, unpack the extension directly into the user's application or profile directory, or register the extension in the windows registry.
...   note: starting in gecko 2.0, 
xpi files are no longer unpacked when extensions are installed.
... instead, the 
xpi itself is placed in the extensions directory, and files are loaded directly out of the package.
...And 10 more matches
   
 
   
    Creating an Installer - Archive of obsolete content
    
        parts of this page show the use of the 
xpinstall api.
... 
xpinstall packages  mozilla provides a mechanism which can be used to package xul windows, scripts, skins and other files into single file installers.
...this mechanism is called 
xpinstall (cross platform install).
...And 10 more matches
   
 
   
    Using the Places annotation service
    
from c++ you must use the setter for the explicit data type being saved:    setpageannotationstring(auri, aname, avalue, aflags, ae
xpiration);  setpageannotationint32(auri, aname, avalue, aflags, ae
xpiration);  setpageannotationint64(auri, aname, avalue, aflags, ae
xpiration);  setpageannotationdouble(auri, aname, avalue, aflags, ae
xpiration);  setpageannotationbinary(auri, aname, adata, adatalen, aflags, ae
xpiration);   and likewise for items in the places database:    setitemannotationstring(aitemid, aname, avalue, aflags, aexp...
...iration);  setitemannotationint32(aitemid, aname, avalue, aflags, ae
xpiration);  setitemannotationint64(aitemid, aname, avalue, aflags, ae
xpiration);  setitemannotationdouble(aitemid, aname, avalue, aflags, ae
xpiration);  setitemannotationbinary(aitemid, aname, avalue, adatalen, aflags, ae
xpiration);   from javascript there are two simple function to perform all of these operations:    setpageannotation(auri, aname, avalue, aflags, ae
xpiration);  setitemannotation(aitemid, aname, avalue, aflags, ae
xpiration);   these annotations all take similar parameters:    uri or itemid: this is the nsiuri of the page to annotate, or for items in the places database, the id of the item.
... e
xpiration: the e
xpiration time for the annotation (see "lifetime of annotations" below).
...And 10 more matches
   
 
   
    Getting started (cfx) - Archive of obsolete content
    
 packaging the add-on  when you've finished the add-on and are ready to distribute it, you'll need to package it as an 
xpi file.
...you can distribute 
xpi files yourself or publish them to https://addons.mozilla.org so other users can download and install them.
...  to build an 
xpi, just execute the command cfx 
xpi from the add-on's directory:  cfx 
xpi   you should see a message like:  exporting extension to my-addon.
xpi.
...And 9 more matches
   
 
   
    nsINavHistoryObserver
    
ing aguid);  obsolete since gecko 21.0          void onbeginupdatebatch();          void onclearhistory();          void ondeleteuri(in nsiuri auri, in acstring aguid);          void ondeletevisits(in nsiuri auri, in prtime avisittime, in acstring aguid);           void onendupdatebatch();          void onpagechanged(in nsiuri auri, in unsigned long awhat, in astring avalue);          void onpagee
xpired(in nsiuri auri, in prtime avisittime, in boolean awholeentry); obsolete since gecko 2.0          void ontitlechanged(in nsiuri auri, in astring apagetitle);          void onvisit(in nsiuri auri, in long long avisitid, in prtime atime, in long long asessionid, in long long areferringid, in unsigned long atransitiontype, in acstring aguid, out unsigned long aadded);        constants          con...
... ondeletevisits() called when some visits of an history entry are e
xpired.
...   note: when all visits for a page are e
xpired and also the full page entry is e
xpired, you will only get an ondeleteuri notification.
...And 9 more matches
   
 
   
    nsIPermissionManager
    
     last changed in gecko 16 (firefox 16 / thunderbird 16 / seamonkey 2.13)   inherits from: nsisupports  method overview           void add(in nsiuri uri, in string type, in pruint32 permission, [optional] in pruint32 e
xpiretype, [optional] in print64 e
xpiretime);          void addfromprincipal(in nsiprincipal principal, in string type, in pruint32 permission, [optional] in pruint32 e
xpiretype, [optional] in print64 e
xpiretime);           void remove(in autf8string host, in string type);               void removefromprincipal(in nsiprincipal principal, in string type);                    void removepermission(in ns...
...       permission e
xpiration constants             constant    value    description          e
xpire_never    0    permission never e
xpires.
...          e
xpire_session    1    permission e
xpires at end of session.
...And 9 more matches
   
 
   
    HTTP caching - HTTP
    
 cache-control: private cache-control: public   e
xpiration  the most important directive here is "max-age=<seconds>" which is the maximum amount of time a resource will be considered fresh.
... contrary to e
xpires, this directive is relative to the time of the request.
... cache-control: max-age=31536000  validation  when using the "must-revalidate" directive, the cache must verify the status of the stale resources before using it and e
xpired ones should not be used.
...And 9 more matches
   
 
   
    Install Wizards (aka: Stub Installers) - Archive of obsolete content
    
 an installer package is an archive file (called 
xpi--pronounced "zippies"--because of its .
xpi extensions) in phil katz zip format.
...to learn more about the 
xpinstall and installer packages please refer to  the annotated browser 
xpi installer and the 
xpinstall api reference.
... the 
xpinstall engine processes installer packages by reading instructions from their install scripts to extract files and take other install actions.
...And 8 more matches
   
 
   
    How to convert an overlay extension to restartless - Archive of obsolete content
    
 a file:// uri to the install location, or .
xpi file, is available in installpath property of the bootstrap data structure passed to the startup(), shutdown(), install(), and uninstall() functions in what will be your bootstrap.js file (see below).
...an old-style add-on installer is packaged something like this:  myaddon.
xpi file (glorified zip) └─ chrome.manifest └─ install.rdf └─ chrome folder   └─ myaddon folder     └─ content.jar file       └─ content folder (most files go here)       └─ locale folder (your locale files go here)  in versions of firefox prior to 4.0 (gecko 2.0), the 
xpi would be extracted into a folder in your profile's extensions folder.
... in current versions it stays unextracted as an 
xpi.
...And 7 more matches
   
 
   
  
   
    Redis Tips
    
n in the last hour, you could do:  > var an_hour_ago = now() - (60 * 60); > r.zrevrangebyscore('last-login', an_hour_ago, infinity, print);   here are two ways to get the last person who logged in:  > r.zrevrange('last-login', 0, 0, print); ["lloyd"]   > r.zrevrangebyscore('last-login', infinity, 0, 'withscores', 'limit', 0, 1, print); ["lloyd", "1339627441.115"]     timeout keys  you can set an e
xpiration date on keys in redis.
...   e
xpire  e
xpireat  ttl  persist  setex   example:  redis> set foo 42 ok redis> ttl foo (integer) -1 redis> e
xpire foo 5 (integer) 1   three seconds later ...
... redis> get foo (nil) redis> ttl foo (integer) -1   using e
xpire you set an e
xpiration in seconds from the present.
...And 7 more matches
   
 
   
    nsIZipReader
    
  example demonstrating this function: list contents of 
xpi and read file contents   extract()  extracts a zip entry into a local file specified by outfile.
...  example demonstrating this function: list contents of 
xpi and read file contents   getentry()  returns a nsizipentry describing a specified zip entry.
...  example demonstrating this function: list contents of 
xpi and read file contents   getinputstream()  returns an input stream containing the contents of the specified zip entry.
...And 7 more matches
   
 
   
    An Overview of XPCOM
    
 xpidl and type libraries  an easy and powerful way to define an interface - indeed, a requirement for defining interfaces in a cross-platform, language neutral development environment - is to use an interface definition language (idl).
... xpcom uses its own variant of the corba omg interface definition language (idl) called 
xpidl, which allows you to specify methods, attributes and constants of a given interface, and also to define interface inheritance.
...  there are some drawbacks to defining your interface using 
xpidl.
...And 6 more matches
   
 
   
    Set-Cookie - HTTP
    
          header type    response header          forbidden header name    no          forbidden response-header name    yes        syntax  set-cookie: <cookie-name>=<cookie-value> set-cookie: <cookie-name>=<cookie-value>; e
xpires=<date> set-cookie: <cookie-name>=<cookie-value>; max-age=<non-zero-digit> set-cookie: <cookie-name>=<cookie-value>; domain=<domain-value> set-cookie: <cookie-name>=<cookie-value>; path=<path-value> set-cookie: <cookie-name>=<cookie-value>; secure set-cookie: <cookie-name>=<cookie-value>; httponly  set-cookie: <cookie-name>=<cookie-value>; samesite=strict set-cookie: <cookie-name>=<cookie-value...
...     e
xpires=<date> optional    the maximum lifetime of the cookie as an http-date timestamp.
...    when an e
xpires date is set, the deadline is relative to the client the cookie is being set on, not the server.
...And 6 more matches
   
 
   
    Unix stub installer - Archive of obsolete content
    
copy the 
xpi directory into the src2 directory you are debugging from.
...  how we get setup to debug the 
xpinstall engine from the unix stub installer?
... go to mozilla/
xpinstall/packager/unix.
...And 5 more matches
   
 
   
    Complete - Archive of obsolete content
    
if you want to see these techniques in action, then you can download and install the complete allcustom extension:  allcustom.
xpi (the link is external only because this wiki does not support 
xpi files.) the extension does not contain any useful functions.
...to see the code, use a jar tool or zip tool to unpack the 
xpi file that you downloaded.
...the extension is supplied as a 
xpi, which is compressed to reduce download times.
...And 5 more matches
   
 
   
    Building a Theme - Archive of obsolete content
    
   setting up the development environment  themes and extensions are packaged and distributed in zip files or bundles, with the 
xpi (pronounced “zippy”) file extension.
...  an example of the content within a typical 
xpi file for a theme:  example.
xpi:               /install.rdf               /chrome.manifest               /preview.png               /icon.png               /chrome/                      browser/                      communicator/                      global/                      mozapps/    we'll want to create a file structure similar to the one above for our tutorial, so let's begin by creating a folder for your theme somewhere on your hard disk (e.g.
... zip up the contents of your theme's folder (not the theme folder itself), and rename the zip file to have a .
xpi extension.
...And 5 more matches
   
 
   
    Index
    
    the key and certificate management process generally begins with creating    keys in the key database, then generating and managing certificates in the    certificate database(see certutil tool) and continues with certificates    e
xpiration or revocation.
...if any of your            certificates are e
xpired or invalid, the list will so specify.
...this includes checking that the            certificate for the issuer of the object-signing certificate is            listed in the certificate database, that the ca's digital            signature on the object-signing certificate is valid, that the            relevant certificates have not e
xpired, and so on.
...And 5 more matches
   
 
   
    Index
    
this is not called when annotations are e
xpired (normally happens when the application exits).
...       411     nsicomponentmanager     component manager, components, interfaces, interfaces:scriptable, xpcom, xpcom api reference, xpcom interface reference       loads a "bootstrapped" chrome.manifest file from the specified directory or 
xpi file.
...a good example of this is the old install.js scripts that were used in 
xpinstall in older mozilla versions.
...And 5 more matches
   
 
   
    mozIAsyncFavicons
    
 acallback);                  void setandfetchfaviconforpage(in nsiuri apageuri, in nsiuri afaviconuri, in boolean aforcereload, in unsigned long afaviconloadtype, [optional] in nsifavicondatacallback acallback);                 void replacefavicondata(in nsiuri afaviconuri, [const,array,size_is(adatalen)] in octet adata, in unsigned long adatalen, in autf8string amimetype, [optional] in prtime ae
xpiration);                  void replacefavicondatafromdataurl(in nsiuri afaviconuri, in astring adataurl, [optional] in prtime ae
xpiration);           methods getfaviconurlforpage() retrieve the url of the favicon for the given page.
...       aforcereload        if false, we try to reload the favicon only if we do not have it or it has e
xpired from the cache.
...favicon data for favicon uris that are not associated with a page uri via setandfetchfaviconforpage will be stored in memory, but may be e
xpired at any time, so you should make an effort to associate favicon uris with page uris as soon as possible.
...And 5 more matches
   
 
   
    Getting Started (jpm) - Archive of obsolete content
    
 packaging the add-on  when you've finished the add-on and are ready to distribute it, you'll need to package it as an 
xpi file.
...you can distribute 
xpi files yourself or publish them to https://addons.mozilla.org so other users can download and install them.
...  to build an 
xpi, just execute the command jpm 
xpi from the add-on's directory:  jpm 
xpi   you should see a message like:  jpm info successfully created 
xpi at /path/to/my-addon/@my-addon-0.0.1.
xpi   to test that this worked, try installing the 
xpi file in your own firefox installation.
...And 4 more matches
   
 
   
    Getting Started with Firefox Extensions - Archive of obsolete content
    
unsigned add-ons can still be installed in developer edition, nightly, and esr versions of firefox, after toggling the 
xpinstall.signatures.required preference in about:config.
... extension contents  you may have noticed that the extension file you installed is named xulschoolhello1.
xpi.
... 
xpi (pronounced "zippy") stands for cross-platform installer, because the same installer file can work on all platforms firefox supports.
...And 4 more matches
   
 
   
    Install.js - Archive of obsolete content
    
        parts of this page show the use of the 
xpinstall api.
...to make your extension install in mozilla suite, seamonkey, mozilla firefox pre-0.9 and mozilla thunderbird pre-0.7, you need to have an install.js file in the root of your 
xpi file.
...cons: code is bloated since it has to cater for several different ways an extension author can package the .jar file contained in the .
xpi file.
...And 4 more matches
   
 
   
    Properties - Archive of obsolete content
    
        parts of this page show the use of the 
xpinstall api.
...c:\temp\argstest.
xpi)        arguments        args can be passed in through the triggering apis by attaching a ?
... and then the rg string to the 
xpi url: (e.g.
...And 4 more matches
   
 
   
    History Service Design
    
      relevance calculation: maintain and e
xpire frecency values for pages.
...       history e
xpiration: e
xpire old visits and invalid informations from the database.
... e
xpiration  e
xpiration is an important part of data management for two reasons:    privacy: e
xpiring data based on user interaction is important, nothing must be left behind on a page removal  database maintenance: having cleaner and smaller tables helps queries performances   e
xpiration is done at certain moments, but in future will most likely be moved to async queries, to be executed on a separate ...
...And 4 more matches
   
 
   
  
   
    Using the Places favicon service
    
  creating the favicon service  the favicon service's contract id is @mozilla.org/browser/favicon-service;1, so to gain access to the favicon service, you should do something like this:  var faviconservice = components.classes["@mozilla.org/browser/favicon-service;1"]                                .getservice(components.interfaces.nsifaviconservice);   caching  the favicon service stores an e
xpiration time for each favicon.
...if you are manually loading favicon data, you can specify the e
xpiration time yourself.
... otherwise, nsifaviconservice.setandloadfaviconforpage() will use the default e
xpiration time.
...And 4 more matches
   
 
   
    nsIUpdateItem
    
 method overview           void init(in astring id, in astring version, in astring installlocationkey, in astring minappversion, in astring maxappversion, in astring name, in astring downloadurl, in astring 
xpihash, in astring iconurl, in astring updateurl, in astring updatekey, in long type, in astring targetappid);        attributes           attribute    type    description          iconurl    astring    the url of the icon that can be shown for this item.
...         
xpihash    astring    the string hash for the 
xpi file.
... can be null and if supplied must be in the format of "type:hash" (see the types in nsicryptohash and nsi
xpinstallmanager.initmanagerwithhashes().
...And 4 more matches
   
 
   
    Cache-Control - HTTP
    
-control: stale-if-error=<seconds>   directives  cacheability  a response is normally cached by the browser if:    it has a status code of 301, 302, 307, 308, or 410 and  cache-control does not have no-store, or if proxy, does not have private and  authorization is unset  either       has a status code of 301, 302, 307, 308, or 410 or    has public, max-age or s-maxage in cache-control or    has e
xpires set          public  the response may be stored by any cache, even if the response is normally non-cacheable.
...  e
xpiration    max-age=<seconds>  the maximum amount of time a resource is considered fresh.
... unlike e
xpires, this directive is relative to the time of the request.
...And 4 more matches
   
 
   
    jpmignore - Archive of obsolete content
    
 use .jpmignore to ignore files from your 
xpi builds created via jpm.
...by using this file you can let jpm know which files and directories you would like it to ignore when building a .
xpi file with jpm 
xpi.
...  here is an example:  # ignore .ds_store files created by mac .ds_store  # ignore any zip or 
xpi files *.zip *.
xpi  # ignore specific directory # you can start patterns with a forward slash (/) to avoid recursivity.
...And 3 more matches
   
 
   
    Extension Versioning, Update and Compatibility - Archive of obsolete content
    
>             <em:targetapplication>               <rdf:description>                 <em:id>{ec8030f7-c20a-464f-9b0e-13a3a9e97384}</em:id>                 <em:minversion>1.5</em:minversion>                 <em:maxversion>2.0.0.*</em:maxversion>                  <!-- this is where this version of the add-on will be downloaded from -->                 <em:updatelink>https://www.mysite.com/foobar2.2.
xpi</em:updatelink>                  <!-- a page describing what is new in this updated version -->                 <em:updateinfourl>http://www.mysite.com/updateinfo2.2.xhtml</em:updateinfourl>               </rdf:description>             </em:targetapplication>           </rdf:description>         </rdf:li>          <rdf:li>           <rdf:description>             <em:version>2.5</em:version>      ...
...       <em:targetapplication>               <rdf:description>                 <em:id>{ec8030f7-c20a-464f-9b0e-13a3a9e97384}</em:id>                 <em:minversion>1.5</em:minversion>                 <em:maxversion>2.0.0.*</em:maxversion>                 <em:updatelink>http://www.mysite.com/foobar2.5.
xpi</em:updatelink>                 <em:updatehash>sha256:78fc1d2887eda35b4ad2e3a0b60120ca271ce6e64ad2e3a0b60120ca271ce6e6</em:updatehash>               </rdf:description>             </em:targetapplication>           </rdf:description>         </rdf:li>        </rdf:seq>     </em:updates>      <!-- a signature is only necessary if your add-on includes an updatekey          in its install.rdf.
...to do this, just provide new em:id in install.rdf within new 
xpi file, and put its url in em:updatelink in update.rdf.
...And 3 more matches
   
 
   
    The Essentials of an Extension - Archive of obsolete content
    
  repackage the 
xpi.
... issue the following command from within the extension root directory on linux or mac os x:  zip -r ../xulschoolhello2.
xpi *   on windows, use a zip tool to compress all files and subdirectories within the extension root directory.
... name the file with extension .
xpi  re-install the 
xpi.
...And 3 more matches
   
 
   
    Creating a Firefox sidebar extension - Archive of obsolete content
    
then the registration files are made and finally the sidebar is packed into an installable 
xpi file.
...  pre-requisites  this article is a quick start, it won't explain all elements of xul, packaging and 
xpi's.
...installation requires the creation of an 
xpi file which is identified as extension in firefox.
...And 3 more matches
   
 
   
   
    Mozilla Application Framework in Detail - Archive of obsolete content
    
other features of xpcom:   
xpidl, a language for defining interfaces in a language-neutral way and the 
xpidl compiler can create header files, binary type libraries, documentation, and even generate stub c++ code for your component implementations.
... more information  using the mozilla soap api (an article written for the apple developer connection)  xml extras (the home page for the xml extras code module, which contains mozilla's web services support)  soap scripts in mozilla (documentation on soap in mozilla from the engineer who implemented it)  
xpinstall, mozilla's cross platform installation technology one of the many things that makes the mozilla platform easy for both users and developers is that applications can be installed, extended, or upgraded with simple web page links.
... the technology that makes this possible, 
xpinstall, allows application developers to write javascript installations that manage special cross-platform installation archives (called 
xpis, or "zippies"), in which packages such as new skins for the browser, patches, browser extensions, new gecko-based applications, and third party standalone applications are stored.
...And 3 more matches
   
 
   
    addFile - Archive of obsolete content
    
method of install object syntax public int addfile (    string registryname,    installversion version,    string 
xpisourcepath,    object localdirspec,    string relativelocalpath,    boolean forceupdate);  public int addfile (    string registryname,    string version,    string 
xpisourcepath,    object localdirspec,    string relativelocalpath,    boolean forceupdate);  public int addfile (    string 
xpisourcepath);  public int addfile (    string registryname,    string 
xpisourcepath,    object localdirspec,    string relativelocalpath);  public int addfile (    string registryname,    string version,    str...
...ing 
xpisourcepath,    object localdirspec,    string relativelocalpath);  parameters the addfile method has the following parameters:         registryname        the pathname in the client version registry about the file.
...this parameter can also be null, in which case the 
xpisourcepath parameter is used as a relative pathname.note that the registry pathname is not the location of the software on the machine; it is the location of information about the software inside the client version registry.
...And 3 more matches
   
 
   
    registerChrome - Archive of obsolete content
    
method of install object syntax int registerchrome(   switch,   srcdir,   
xpipath);  parameters the registerchrome method has the following parameters:         switch        switch is the chrome switch indicating what type of file is being registered.
...package, a third possibility is the equivalent of skin and/or locale, and ensures that everything in the 
xpi is registered.
...       
xpipath        
xpipath is the path within the 
xpi in where the contents.rdf file defining the chrome is located.
...And 3 more matches
   
 
   
    Building accessible custom components in XUL - Archive of obsolete content
    
a super-simple spreadsheet  download stage-1.zip install stage-1.
xpi  to build our xul spreadsheet, we'll use three built-in xul controls:  a single grid element to contain the other elements and position them in rows and columns.
...order-bottom: 1px solid black;   border-left: 1px solid black;   margin: 0;   padding: 3px; }  grid.spreadsheet description {   color: black;   background-color: white;   margin: 0px;   padding: 2px;   border-left: thin solid;   border-bottom: thin solid;   font-family: monospace;   font-size: 12pt;   text-align: center;   font-weight: bold; } </code> you can see the results by installing stage-1.
xpi, restarting firefox, and selecting accjax from the tools menu.
...further reading  grid element reference description element reference label element reference grid tutorial label tutorial  adding roles with dhtml accessibility  download stage-2.zip install stage-2.
xpi  using the new dhtml accessibility techniques in firefox 1.5, we can declare the role of each element in our spreadsheet.
...And 3 more matches
   
 
   
    nss tech note8
    
as originally designed, before calling the cache function, the caller was responsible to fill in the session creation time (which might not be the same as the time of insertion into the cache) and the session e
xpiration time, among other things.
... so, ssl protocol code that wanted to cache a sid would do these steps, whether for client or for server:  for ssl2:     sid->lastaccesstime = sid->creationtime = ssl_time();     sid->e
xpirationtime = sid->creationtime + ssl_sid_timeout;     (*ss->sec.cache)(sid); for ssl3:     sid->lastaccesstime = sid->creationtime = ssl_time();     sid->e
xpirationtime = sid->creationtime + ssl3_sid_timeout;     (*ss->sec.cache)(sid);  the cache api was defined such that the caller must set creationtime properly, and may set e
xpirationtime to the desired value or to zero.
... if zero, then the called cache function would compute the correct e
xpiration time by adding the chosen timeout (from one of those two global variables) to the sid's creationtime, giving the e
xpirationtime.
...And 3 more matches
   
 
   
    The Places database
    
       e
xpiration  e
xpiration is handled in toolkit/components/places/nsplacese
xpiration.js.
... periodically at runtime, the following happens to e
xpire pages:    e
xpire visits that are older than the history e
xpiration threshold.
...  delete the history entries that were referenced by the e
xpired visits and not referenced by any non-e
xpired visit or bookmark.
...And 3 more matches
   
 
   
    BasicCardResponse - Web APIs
    
    the basiccardresponse dictionary (related to the payment request api, although defined in the basic card payment spec) defines an object structure for payment response details such as the number/e
xpiry date of the card used to make the payment, and the billing address.
...	basiccardresponse.e
xpirymonth read only  secure context optional 	contains the e
xpiry month of the card used to make the payment.
... 	basiccardresponse.e
xpiryyear read only  secure context optional 	contains the e
xpiry year of the card used to make the payment.
...And 3 more matches
   
 
   
  
   
    InstallTrigger - Web APIs
    
                        the installtrigger interface is an interesting outlier in the apps api; it's included in this api but are inherited from the old mozilla 
xpinstall technology for installing add-ons.
... it is used for triggering the download and installation of an add-on (or anything packaged in an .
xpi file) from a web page, using javascript code to kick off the install process.
...in either case, you must trigger the installation process by creating a web page script in which installtrigger methods download the specified 
xpi file and "trigger" the execution of the install.js script at the top level of that 
xpi.
...And 3 more matches
   
 
   
    cfx to jpm - Archive of obsolete content
    
in a built 
xpi, it's the id field in the add-on's install manifest (install.rdf) file.
...the sdk expects the latter format, and if the id in package.json doesn't contain "@", then cfx 
xpi will append "@jetpack" to the package.json field, and make that the add-on id.
... id handling with jpm  when you create an 
xpi with jpm 
xpi:    if the package.json does not include an id field, then the id written into the install.rdf is the value of the name field prepended with "@".
...And 2 more matches
   
 
   
    Deploying a Plugin as an Extension - Archive of obsolete content
    
first, let's take a look at the structure of the 
xpi file used for a browser plugin.
... rhapsodyplayerengine_inst_win.
xpi   install.rdf   plugins/     license.rtf     nprhapengine.dll  the important file here is the install.rdf file.
...now that we have an install.rdf file, we can actually package the 
xpi.
...And 2 more matches
   
 
   
    Multiple item extension packaging - Archive of obsolete content
    
 multiple item package file layout  the multiple item package file layout is a simplified form of an installable bundle and requires a file extension of 
xpi.
...
xpi file extension) and themes (e.g.
...the basic structure is shown below:  /install.rdf                        install manifest /extension1.
xpi                     extension /extension2.
xpi                     extension /theme1.jar                         theme /theme2.jar                         theme ...
...And 2 more matches
   
 
   
    Signing an extension - Archive of obsolete content
    
the following instructions also apply to a theme and other 
xpi files.
...id" \  -p $mypassword \  -x -z ~/desktop/myextension/dest/myextension-1.0.
xpi \  ~/desktop/myextension/source unset mypassword  then a signed 
xpi file will be generated.
...  verify  drag and drop the 
xpi file into the content area of firefox.
...And 2 more matches
   
 
   
    Source code directories overview - Archive of obsolete content
    
 idl contains the 
xpidl (cross platform interface definition language) interface files.
...
xpidl files have their own mini-language and processing tools.
...as more code is written with or converted to 
xpidl interfaces, the value of the public directory diminishes.
...And 2 more matches
   
 
   
    Repackaging Firefox - Archive of obsolete content
    
 xpi files are specially crafted zip files in disguise.
...this 
xpi has the following contents  chrome.manifest components/partnerbookmarks.js defaults/preferences/partner.js install.rdf locale/ar/partner.properties locale/cs/partner.properties locale/da/partner.properties locale/de/partner.properties locale/el/partner.properties locale/en-gb/partner.properties locale/partner.properties locale/es-ar/partner.properties locale/es-es/partner.properties locale/fi/partner.properties locale/fr/partner.properties locale/he/partner.properties locale/hu/partner.properties locale/it/partner.properties locale/ja/partner.properties locale/ja-jp-mac/partner.properties locale/ko/partner.properties locale/nb-no/partner.properties locale/nl/partner.properties locale/pl/partner.
...properties locale/pt-br/partner.properties locale/pt-pt/partner.properties locale/ru/partner.properties locale/sk/partner.properties locale/sv-se/partner.properties locale/tr/partner.properties locale/zh-cn/partner.properties locale/zh-tw/partner.properties partner-bookmarks.xml   one by one, the files listed above are:  chrome.manifest  contains a specialized listing of the contents of the 
xpi.
...And 2 more matches
   
 
   
    Mac stub installer - Archive of obsolete content
    
  how we get setup to debug the 
xpinstall engine from the mac installer?
...  once you have the mac installer built and ready to debug you may want to debug the 
xpinstall engine in the context of the installer rather than in the context of the browser.
... to do this, in addition to the above steps to set up the mac installer to debug you will need to do the following:   create a file named xpcom.
xpi with the shared libraries in the structure described under the [xpcom] section in: <http://lxr.mozilla.org/seamonkey/sou...ackages-mac#33>  note that if you are using the debug target of the installer binary all shared libraries are expected to have the name format <libname>debug.shlb  now set a break point at 
xpi_init() in the mac installer code and step into 
xpistub and eventually the 
xpinstall engine will load including symbols so you can set a break point in the 
xpinstall engine itself.
...And 2 more matches
   
 
   
    Windows stub installer - Archive of obsolete content
    
(if you need to rebuild stub installer, got to /mozilla/
xpinstall/wizard/windows/setup and type "nmake /f makefile.win")  go to mozilla/
xpinstall/wizard/windows/builder  on the shell prompt type "perl build.pl".
...  now you will find an installer *and* the xpcom.
xpi and other debug 
xpis delivered to mozilla/dist/win32_d.obj/install.
... if you need to use vc++ to debug the installer:  under project | settings | debug  set "executable for debug session" to be the path to mozilla/dist/win32_d.obj/install/setup.exe  set "working directory" to be the path to mozilla/dist/wind32_d.obj/install   press f10 to step into the code    how we get setup to debug the 
xpinstall engine from the windows stub installer?
...And 2 more matches
   
 
   
    patch - Archive of obsolete content
    
 method of install object  syntax int patch (    string registryname,    string 
xpisourcepath,    object localdirspec,    string relativelocalpath);  int patch (    string registryname,    installversion version,    string 
xpisourcepath,    object localdirspec,    string relativelocalpath);  int patch (    string registryname,    string version,    string 
xpisourcepath,    object localdirspec,    string relativelocalpath);   parameters  the patch method has the following parameters:          registryname        the pathname in the client version registry for the component that is to be patched.this parameter can be an absolute pathname, such as /royalairways/royalsw/executable or a relative pathname, such as executable.
...this parameter can also be null, in which case the 
xpisourcepath parameter is used as a relative pathname.
...       
xpisourcepath        a string specifying the location of the differences file within the 
xpi file.
...And 2 more matches
   
 
   
    Return Codes - Archive of obsolete content
    
in mozilla/seamonkey, these constants are defined as part of the 
xpinstall object (formerly the softwareupdate object in netscape communicator 4.5).
...                no_matching_certificate       -206       extracted file was not signed by the certificate used to sign the installation script                 cant_read_archive       -207       
xpi package cannot be read                 invalid_arguments       -208       bad parameters to a function                 illegal_relative_path       -209       illegal relative path                 user_cancelled       -210       user clicked cancel on install dialog                 install_not_started       -211       a problem occurred with the parameters to initinstall, or initinstall was not ca...
...                patch_bad_checksum_target       -221       the checksum generated for the source file does not match the checksum in the 
xpi file.
...And 2 more matches
   
 
   
    Introduction to Public-Key Cryptography - Archive of obsolete content
    
 in addition to a public key, a certificate always includes the name of the entity it identifies, an e
xpiration date, the name of the ca that issued the certificate, a serial number, and other information.
...   e
xpired validity dates, an invalid signature, or the absence of a certificate for the issuing ca at any point in the certificate chain causes authentication to fail.
...for example, an administrator may wish to be notified automatically when a certificate is about to e
xpire, so that an appropriate renewal process can be completed in plenty of time without causing the certificate's subject any inconvenience.
...And 2 more matches
   
 
   
    Makefile - variables
    
                xpidl_module       module name to use when generating .xpt files, default to module.
...                 
xpidlsrcs       internal: a list of .idl files to generate exported headers from.
...                 
xpidl_name       name of extension to build see also                         configure.sh variables       description                       build_project_arg       command line/environment override                 configure_env_args       command line/environment override                         directory variable                               dirs       a list of subdirectories to build recursively.
...And 2 more matches
   
 
   
    Installing headers using EXPORTS
    
this is accomplished by setting make variables telling the build system which     module  the headers are for (since headers are organized by module under <tt>dist/include</tt>), and which headers need to be created from idl files by 
xpidl.
...for 
xpidl-generated headers, you should set 
xpidlsrcs to the list of idl files to export.
...for 
xpidl-generated headers, you may also set 
xpidl_module to determine which     typelib  file is produced from the idl files.
...And 2 more matches
   
 
   
    L10n Checks
    
if you want to test the localization for de, run: check-l10n-completeness browser/locales/l10n.ini ../l10n/ de  add-ons (
xpi) mode l10n checks gathers the locales to compare from the chrome.manifest file inside the 
xpi file.
... you pass the path to the 
xpi file (optionally) followed by the locale codes of the locales you want to compare.
... if you want to test the localization for de, run: check-l10n-completeness -i 
xpi my-extension.
xpi de  to check all locales in an extension: check-l10n-completeness -i 
xpi my-extension.
xpi  language packs (
xpis) mode l10n checks can compare two locales found in different 
xpi files.
...And 2 more matches
   
 
   
  
   
    sslerr.html
    
             ssl_error_e
xpired_cert_alert    -12269    "ssl peer rejected your certificate as e
xpired."            the remote system has received a certificate from the local system, and has determined that the certificate has e
xpired.
...         sec_error_e
xpired_certificate    -8181    peer's certificate has e
xpired.
...         sec_error_e
xpired_issuer_certificate    -8162    the certificate issuer's certificate has e
xpired.
...And 2 more matches
   
 
   
    Places utilities for JavaScript
    
the annotation objects returned or send from/to all these functions all are arrays of objects which have the properties:    name  the annotation name  flags  annotation flags  e
xpires  annotation e
xpiration  mimetype  mimetype of the annotation, usually only used for binary annotations  type  the type used for non-binary annotations  value  the value of the annotation   getannotationsforuri()  fetch all annotations for a uri, including all properties of each annotation which would be required to recreate it.
...  return array of objects, each containing the following properties: name, flags, e
xpires, mimetype, type, value  getannotationsforitem()  fetch all annotations for an item, including all properties of each annotation which would be required to recreate it.
...  return type  return array of objects, each containing the following properties: name, flags, e
xpires, mimetype, type, value  setannotationsforuri()  annotate a uri with a batch of annotations.
...And 2 more matches
   
 
   
    How to build an XPCOM component in JavaScript
    
xpcom uses a dialect of idl to define interfaces, called 
xpidl.
... here's the 
xpidl definition for our helloworld component:  helloworld.idl  #include "nsisupports.idl"  [scriptable, uuid(xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx)] interface nsihelloworld : nsisupports {   string hello(); };   note that you must generate a new uuid for each xpcom component that you create.
... for code outside the tree  note: on windows if you download the gecko sdk without the whole build tree, you will be missing some required dlls for 
xpidl.exe and it will run with no errors but not do anything.
...And 2 more matches
   
 
   
    Setting up the Gecko SDK
    
          application name    description of functionality          regxpcom.exe    registers or unregisters components with xpcom          
xpidl.exe    generates typelib and c++ headers from 
xpidl          xpt_dump.exe    prints out information about a given typelib          xpt_link.exe    combines multiple typelibs into a single typelib                 library name    description of functionality          xpcomglue.lib    xpcom glue library to be used by xpcom components.
... this allows you to created the component without sending any extra dlls  set path=%path%;d:\projects\xulrunner-sdk\sdk\bin;d:\projects\xulrunner-sdk\bin   this tells the command prompt where to find the gecko tools, importantly (
xpidl, regxpcom, and gmake).
... 
xpidl -m header ispecialthing.idl 
xpidl -m typelib ispecialthing.idl   the code  add the main code, the real work horse.
...And 2 more matches
   
 
   
    nsIPushSubscription
    
 method overview           void getkey(in domstring name, [optional] out uint32_t keylen, [array, size_is(keylen), retval] out uint8_t key);          bool quotaapplies();          bool ise
xpired();        attributes           attribute    type    description          endpoint    domstring    the subscription url.
...please see method parameters in 
xpidl for more details on using out parameters in javascript.
... ise
xpired()  indicates whether this subscription has e
xpired and must be renewed.
...And 2 more matches
   
 
   
    nsISupports proxies
    
a good example of this is the old install.js scripts that were used in 
xpinstall in older mozilla versions.
...
xpinstall installation scripts are sometimes very complex and can require long execution time due to unzipping or native file system actions.
... if 
xpinstall ran on the ui thread, the product would appear frozen until the script was complete.
...And 2 more matches
   
 
   
    Document.cookie - Web APIs
    
       ;max-age=max-age-in-seconds (e.g., 60*60*24*365 or 31536000 for a year)    ;e
xpires=date-in-gmtstring-format if neither e
xpires nor max-age specified it will e
xpire at the end of session.
...many browsers let users specify that cookies should never e
xpire, which is not necessarily safe.
... function doonce() {   if (!document.cookie.split('; ').find(row => row.startswith('dosomethingonlyonce'))) {     alert("do something here!");     document.cookie = "dosomethingonlyonce=true; e
xpires=fri, 31 dec 9999 23:59:59 gmt";   } }  <button onclick="doonce()">only do something once</button>    example #4: reset the previous cookie  function resetonce() {   document.cookie = "dosomethingonlyonce=; e
xpires=thu, 01 jan 1970 00:00:00 gmt"; }  <button onclick="resetonce()">reset only once cookie</button>    example #5: check a cookie existence  //es5  if (document.cookie.split(';').some(f...
...And 2 more matches
   
 
   
    install - Web APIs
    
        summary installs one or more 
xpi files on the local machine.
...   method of installtrigger object   syntax int install(array 
xpilist [, function callbackfunc ] )    parameters the install method has the following parameters:         
xpilist        an array of files to be installed (see example below).
...for installations, these pairs are the 
xpinstall confirm dialog display name and the path of the 
xpi, respectively.
...And 2 more matches
   
 
   
    Install Manifests - Archive of obsolete content
    
 the file must be called install.rdf and live at the top level of an add-on's 
xpi file.
... examples  <em:translator>janez novak</em:translator> <em:translator>kari nordmann</em:translator>  unpack  a true or false value that tells the application whether the extension requires its files be unpacked into a directory in order to work or whether the extension can be loaded direct from the 
xpi.
...in either case, the referenced chrome package file(s) must be placed in the chrome subdirectory of the 
xpi's top level.
... in extensions for firefox 1.5, this property is no longer necessary: the chrome.manifest at the top level of the 
xpi is used to locate chrome to register.
   
 
   
    XPCOM Objects - Archive of obsolete content
    
this section is a quick guide on how to read xpcom documentation, which basically amounts to understanding the syntax of 
xpidl, the language used to specify xpcom interfaces.
...       there are more details about 
xpidl in the xpdil syntax definition.
...in your final extension 
xpi you'll need to include the js implementation file, and the xpt file, which is a compiled version of your idl file.
...this is a known limitation of 
xpidl, and a simple workaround is to define a readonly attribute instead.
   
 
   
    addDirectory - Archive of obsolete content
    
method of install object syntax public int adddirectory (    string 
xpisourcepath);  public int adddirectory (    string registryname,    string 
xpisourcepath,    object localdirspec,    string relativelocalpath);  public int adddirectory (    string registryname,    string version,    string 
xpisourcepath,    object localdirspec,    string relativelocalpath);  public int adddirectory (    string registryname,    string version,    string 
xpisourcepath,    object localdirspec,    string relativelocalpath,    boolean forceupdate);  public int adddirectory (    string registryname,    installversion version,    string 
xpisourcepath,    object localdirspec,    string relativelocalpath,    boolean forceupdate);  parameter...
...a relative pathname is appended to the registry name of the package as specified by the package parameter to the  initinstall method.this parameter can also be null, in which case the 
xpisourcepath parameter is used as a relative pathname.note that the registry pathname is not the location of the software on the computer; it is the location of information about the software inside the client version registry.
...       
xpisourcepath        a string specifying the location of the directory within the 
xpi file.an empty string ("") causes the creation of a subdirectory node in the registry without actually unpacking any files, which may be useful when you are updating a package that contains subcomponents that could also be updated separately.
... when 
xpisourcepath is an empty string, registryname cannot be null.
   
 
   
    execute - Archive of obsolete content
    
 method of install object  syntax  int execute (    string 
xpisourcepath [, boolean blocking]);  int execute (    string 
xpisourcepath,    string args [, boolean blocking]);  parameters the execute method has the following parameters:     
xpisourcepath   the pathname of the file to extract and execute.
... (note that this path points into the 
xpi itself.)   args   a parameter string that is passed to the executable.
... description  the execute method extracts the named file from the 
xpi file to a temporary file name.
...you can use this method to launch an installshield installer or any install executable file stored in a 
xpi file.
   
 
   
    Installer Script - Archive of obsolete content
    
    registerchrome(content | delayed_chrome, getfolder(cf,"toolkit.
xpi"),"content/global/"); 44.
...     registerchrome(content | delayed_chrome, getfolder(cf,"browser.
xpi"),"content/communicator/"); 45.
...     registerchrome(content | delayed_chrome, getfolder(cf,"browser.
xpi"),"content/editor/"); 46.
...     registerchrome(content | delayed_chrome, getfolder(cf,"browser.
xpi"),"content/navigator/"); 47.
   
 
   
    A XUL Bestiary - Archive of obsolete content
    
the mozilla xparchitecture section below describes xpcom, 
xpidl, and xpconnect, three somewhat related technologies for getting access to application code from the interface.
...
xpidl, the cross-platform interface definition language, is a language in which these interfaces insisted upon by xpcom can be described.
... when 
xpidl is used to describe the xpcom interfaces, it makes those interfaces available in special header files.
... finally, xpconnect is the technology that connects these xpcom/
xpidl interfaces to javascript, the scripting language xul uses.
   
 
   
    The Joy of XUL - Archive of obsolete content
    
             xpinstall    
xpinstall, mozilla's cross platform install facility, provides a standard way of packaging xul application components with an install script that mozilla can download and execute.
...     
xpinstall enables users to effortlessly install new xul applications over the internet or from corporate intranet servers.
... 
xpinstall is easy for developers and for users.the calendar is not a planned deliverable for the mozilla 1.0 release, and therefore is not included as a standard component in regular nightly and milestone release builds.
...using 
xpinstall it was easy for the developers to package a version of calendar that could be installed directly over the internet by clicking a link.
   
 
   
  
   
    SeaMonkey - making custom toolbar (SM ver. 1.x) - Archive of obsolete content
    
you can optionally use a jar tool or zip tool to package your button as a cross-platform installable (
xpi) for other people to install and use.
...  name the package file with the .
xpi extension.
... to install the packaged extension, open the 
xpi file in seamonkey.
...from the menu bar.) distribute the 
xpi file to other users.
   
 
   
    Manifest Files - Archive of obsolete content
    
an extension is packaged up into an 
xpi file.
... 
xpi is short for 
xpinstall and is used by mozilla to install components.
... like a jar file, an 
xpi file is just a zip file with a different extension, so you can create and view 
xpi files with a zip utility.
... firefox's extension manager handles installing extensions packaged into 
xpi files automatically.
   
 
   
    XULRunner tips - Archive of obsolete content
    
the following prefs must also be set to make the 
xpinstall dialog, extension manager, and theme manager work:  pref("
xpinstall.dialog.confirm", "chrome://mozapps/content/
xpinstall/
xpinstallconfirm.xul"); pref("
xpinstall.dialog.progress.skin", "chrome://mozapps/content/extensions/extensions.xul?type=themes"); pref("
xpinstall.dialog.progress.chrome", "chrome://mozapps/content/extensions/extensions.xul?type=extensions"); pref("
xpinstall.dialog.progres...
...s.type.skin", "extension:manager-themes"); pref("
xpinstall.dialog.progress.type.chrome", "extension:manager-extensions"); pref("extensions.update.enabled", true); pref("extensions.update.interval", 86400); pref("extensions.dss.enabled", false); pref("extensions.dss.switchpending", false); pref("extensions.ignoremtimechanges", false); pref("extensions.logging.enabled", false); pref("general.skins.selectedskin", "classic/1.0"); // nb these point at amo pref("extensions.update.url", "chrome://mozapps/locale/extensions/extensions.properties"); pref("extensions.getmoreextensionsurl", "chrome://mozapps/locale/extensions/extensions.properties"); pref("extensions.getmorethemesurl", "chrome://mozapps/locale/extensions/extensions.properties");   if your application is based on gecko 2.0, you need to re...
... save the dom_inspector-*.
xpi package to a temporary directory  unzip the package  copy the following files:   chrome/inspector.jar to the chrome directory of your xulrunner application   components/inspector-cmdline.js to your components directory   defaults/preferences/inspector.js to your preferences directory  open your chrome.manifest file and add these lines:   content  inspector                       jar:inspector.jar!
... pref("signon.remembersignons", true); pref("signon.e
xpiremasterpassword", false); pref("signon.signonfilename", "signons.txt");   you also need to get an instance of the login manager service, which internally initializes the system:  components.classes["@mozilla.org/login-manager;1"].getservice(components.interfaces.nsiloginmanager);   using firefox to run xulrunner applications  firefox 3 and up contain the xulrunner runtime.
   
 
   
    Shipping a plugin as a Toolkit bundle - Archive of obsolete content
    
plugin packages should only need to package a small set of files in the following structure in the 
xpi file: install.rdf plugins/     pluginlib.dll     plugintypes.xpt  the install.rdf file contains an install manifest that describes the plugin to the user.
...platform-specific files gecko 1.9.2 (firefox 3.6) and earlier prior to gecko 2.0 (firefox 4 / thunderbird 3.3 / seamonkey 2.1), it was possible to package multiple plugin libraries for different operating systems into a single 
xpi bundle.
... in the 
xpi you can use the following structure: platform/     linux_x86-gcc3/         plugins/             libplugin.so     darwin_ppc-gcc3/         plugins/             libplugin.dylib  more specific information can be found in the platform-specific subdirectories documentation.
... the unpack property is necessary to tell applications using newer versions of gecko to unpack the plugin because dlls can't be loaded from 
xpi files.
   
 
   
    Storage access policy: Block cookies from trackers
    
the tracking origin must have received user interaction as a first party within the past 30 days, and the storage access permission e
xpires after 15 minutes.
...   http: yes     js: no        storage access e
xpiration  the storage access grant e
xpires after 30 days.
... domains classified as tracking resources may be granted third-party storage access on multiple first parties, and the storage permission for each party e
xpires independently.
... each time the heuristic is activated, or a success call to the storage access api is made, the pre-existing storage access e
xpiration will be extended by 30 days, counting from the time the previous access was granted.
   
 
   
    Gecko SDK
    
        the gecko sdk, also known as the xulrunner sdk, is a set of 
xpidl files, headers and tools to develop xpcom components which can then in turn e.g.
... the gecko sdk contains all of the necessary tools and headers for making scriptable npapi plugins including the 
xpidl compiler/linker and the latest npapi.h.
... issues with the os x sdk  if you need to use the 
xpidl utility to compile idl files on os x, it's likely that you will receive a strange error when running the tool that looks something along the lines of this:  dyld: library not loaded: /opt/local/lib/libintl.3.dylib   referenced from: /users/varmaa/xulrunner-sdk/bin/./
xpidl   reason: image not found trace/bpt trap   unfortunately, this is caused by a problem with the sdk build process which canno...
... resources    static 
xpidl.exe (non-official) if you are looking for a static linked 
xpidl.exe, you can download here.
   
 
   
    HTTP Cache
    
the only way to remove cacheentry objects from memory is by exhausting a memory limit for intermediate memory caching, what triggers a background process of purging e
xpired and then least used entries from memory.
...handle given to the current writer, then exit  state == writing: the writer failed to call metadataready on the entry - state = empty  state == revalidating: the writer failed the re-validation process and failed to call setvalid on the entry - state = ready  call to cacheentry::invokecallbacks   all consumers release the reference:    the entry may now be purged (removed) from memory when found e
xpired or least used on overrun of the memory pool limit  when this is a disk cache entry, its cached data chunks are released from memory and only meta data is kept   intermediate memory caching of frequently used metadata (a.k.a.
...when the limit is exceeded, we purge (throw away) first e
xpired and then least used entries to free up memory again.
... the memory pool is represented by two lists (strong refering ordered arrays) of cacheentry objects:    sorted by e
xpiration time (that default to 0xffffffff)  sorted by frecency (defaults to 0)   we have two such pools, one for memory-only entries actually representing the memory-only cache and one for disk cache entries for which we only keep the meta data.
   
 
   
    PR_WaitCondVar
    
after a call to pr_waitcondvar, the lock is released and the thread is blocked in a "waiting on condition" state until another thread notifies the condition or a caller-specified amount of time e
xpires.
... any value other than pr_interval_no_timeout or pr_interval_no_wait for the timeout parameter will cause the thread to be rescheduled due to either explicit notification or the e
xpiration of the specified interval.
... the latter must be determined by treating time as one part of the monitored data being protected by the lock and tested explicitly for an e
xpired interval.
... to detect the e
xpiration of the specified interval, call pr_intervalnow before and after the call to pr_waitcondvar and compare the elapsed time with the specified interval.
   
 
   
    NSS tools : signtool
    
if any of your            certificates are e
xpired or invalid, the list will so specify.
...this includes checking that the            certificate for the issuer of the object-signing certificate is            listed in the certificate database, that the ca's digital            signature on the object-signing certificate is valid, that the            relevant certificates have not e
xpired, and so on.
...this option is useful if you want the e
xpiration date            of the signature checked against the current date and time rather            than the time the files were signed.
...     e
xpires: tue may 19, 1998  test object signing cert      issued by: test object signing cert (signtool 1.0 testing  certificate (960187691))      e
xpires: sun may 17, 1998  ---------------------------------------     for a list including cas, use the -l option.
   
 
   
    Places Developer Guide
    
resultcontainernode.containeropen = true; for (var i=0; i < resultcontainernode.childcount; ++i) {   var childnode = resultcontainernode.getchild(i);    // accessing properties of matching bookmarks   var title = childnode.title;   var uri = childnode.uri; }  observing history the nsinavhistoryobserver interface allows observation of history events such as new visits, page title changes, page e
xpiration and when all history is cleared.
....nsinavhistoryservice); let observer = {   onbeginupdatebatch: function() {   },   onendupdatebatch: function() {   },   onvisit: function(auri, avisitid, atime, asessionid, areferringid, atransitiontype) {   },   ontitlechanged: function(auri, apagetitle) {   },   ondeleteuri: function(auri) {   },   onclearhistory: function() {   },   onpagechanged: function(auri, awhat, avalue) {   },   onpagee
xpired: function(auri, avisittime, awholeentry) {   },   queryinterface: function(iid) {     if (iid.equals(components.interfaces.nsinavhistoryobserver) ||         iid.equals(components.interfaces.nsisupports)) {       return this;     }     throw cr.ns_error_no_interface;   } };  history.addobserver(observer, false);  new tagging service the tagging of uris is provided by nsitaggingservice.
...ookmark: // get the annotation service var annotations = cc["@mozilla.org/browser/annotation-service;1"]                   .getservice(ci.nsiannotationservice);  // create a uri to annotate var ioservice = cc["@mozilla.org/network/io-service;1"]                 .getservice(ci.nsiioservice); var myuri = ioservice.newuri("http://www.mozilla.com", null, null);  // add an annotation to the uri, that e
xpires when the uri is deleted // or e
xpires from the browser history annotations.setpageannotation(myuri, "myannotation", "notes for this uri...",                               0, annotations.e
xpire_with_history);  // create a bookmark to annotate var bookmarks = cc["@mozilla.org/browser/nav-bookmarks-service;1"]                 .getservice(ci.nsinavbookmarksservice); var mybookmark = bookmarks.inse...
...rtbookmark(bookmarks.toolbarfolder, myuri,                                           bookmarks.default_index, "my bookmark");  // add an annotation to the bookmark, that e
xpires only when // the bookmark is deleted annotations.setitemannotation(mybookmark, "myannotation", "notes for this bookmark...",                               0, annotations.e
xpire_with_history);  note the syntactic difference between the uri and bookmark annotation apis: uri annotation apis use "page" in method names whereas bookmark annotation apis use "item" in method names.
   
 
   
    Using the Places livemark service
    
when the update timer fires, it iterates over the list of livemarks, and will refresh a livemark *only* if it's e
xpired.
... the e
xpiration time for a livemark is determined by using information provided by the server when the feed was requested, specifically nsicacheentryinfo.e
xpirationtime.
... if no information was provided by the server, the default e
xpiration time is 1 hour.
... users can modify the default e
xpiration time via the <tt>browser.bookmarks.livemark_refresh_seconds</tt> preference, which indicates the e
xpiration time in seconds.
   
 
   
    Component Internals
    
as this section and the next describe, you can register your component explicitly during installation, or with the regxpcom program, or you can use the autoregistration methods in the service manager to find and register components in a specified components directory:    
xpinstall apis  regxpcom command-line tool  nsicomponentregistrar apis from service manager   the registration process is fairly involved.
...the first is to use 
xpinstall, which is an installation technology that may or may not come with a gecko application and provides interfaces for registering your component during installation.
... a gecko embedding application may also provide its own way of registering xpcom components using the interface that is in fact used by both 
xpinstall and regxpcom, nsicomponentregistrar.
...at last count there were over 1300 interfaces defined in 
xpidl.
   
 
   
    Using XPCOM Utilities to Make Things Easier
    
when an interface is written in 
xpidl, the headers include static declarations of their iids.
... on any interface that is generated by 
xpidl, you can call ns_get_iid() to obtain the iid which is associated with that interface.
...for example, ns_decl_nsifoo will declare all of the methods of nsifoo provided that it exists and that nsifoo.h was generated by the 
xpidl compiler.
...interface must be generated by 
xpidl        using the macros described here, the code for the weblock component has gone from around 340 lines of code to just under 40.
   
 
   
    nsICookiePermission
    
     last changed in gecko 1.9 (firefox 3)  inherits from: nsisupports method overview    nscookieaccess canaccess(in nsiuri auri, in nsichannel achannel);   boolean cansetcookie(in nsiuri auri, in nsichannel achannel, in nsicookie2 acookie, inout boolean aissession, inout print64 ae
xpiry);   nsiuri getoriginatinguri(in nsichannel achannel);    void setaccess(in nsiuri auri, in nscookieaccess aaccess);    constants    constant value description   access_default 0 nscookieaccess's access default value   access_allow 1 nscookieaccess's access allow value   access_deny 2 nscookieaccess's access deny value   access_session 8 additional values for nscookieaccess, which are not direct...
...it may modify the issession and e
xpiry attributes of the cookie via the aissession and ae
xpiry parameters, in order to limit or extend the lifetime of the cookie.
...boolean cansetcookie(   in nsiuri auri,   in nsichannel achannel,   in nsicookie2 acookie,   inout boolean aissession,   inout print64 ae
xpiry );  parameters  auri the uri trying to set the cookie.
...ae
xpiry when cansetcookie is invoked, this is the current e
xpiry time of the cookie.
   
 
   
    nsIZipWriter
    
')    detail: this azipentry is very important, this example demonstrates its usage:   var zw = cc['@mozilla.org/zipwriter;1'].createinstance(ci.nsizipwriter); var myzipfile = fu.file('c:\\myzipfile.zip'); //this file will be creatd in c drive var pr = {pr_rdonly: 0x01, pr_wronly: 0x02, pr_rdwr: 0x04, pr_create_file: 0x08, pr_append: 0x10, pr_truncate: 0x20, pr_sync: 0x40, pr_excl: 0x80}; zw.open(
xpi, pr.pr_wronly | pr.pr_create_file | pr.pr_truncate); //
xpi file is created if not there, if it is there it is truncated/deleted  var filetoaddtozip = fileutils.file('c:\\add this file.txt'); var saveinzipas = 'blah.txt'; zw.addentryfile(saveinzipas, ci.nsizipwriter.compression_none, filetoaddtozip, false);   in the above example, the file ("add this file.txt") located at "c:\add this file.txt" wi...
...using backward slash will not throw any errors but if this was an 
xpi file, firefox would not be able to read it properly.
...but note that if dir doesnt exist zw.open throws problems     //var path = fp.file.path; //returns c:\users\3k2kyc1\documents\prefs\prefs      var 
xpi = fu.file(dir.path + '\\' + dir.leafname + '.zip');      zw.open(
xpi, pr.pr_rdwr | pr.pr_create_file | pr.pr_truncate); //pr_truncate overwrites if file exists //pr_create_file creates file if it dne //pr_rdwr opens for reading and writing      //recursviely add all     var dirarr = [dir]; //adds dirs to this as it finds it     for (var i=0; i<dirarr.length; i++) {         cu.reporterror('adding ...
...contents of dir['+i+']: ' + dirarr[i].leafname + ' path: ' + dirarr[i].path);         var direntries = dirarr[i].directoryentries;         while (direntries.hasmoreelements()) {         	var entry = direntries.getnext().queryinterface(ci.nsifile); //entry is instance of nsifile so here https://developer.mozilla.org/docs/xpcom_interface_reference/nsifile         	if (entry.path == 
xpi.path) {         		cu.reporterror('skipping entry - will not add this entry to the zip file - as this is the zip itself: "' + 
xpi.path + '" leafname:"' + 
xpi.leafname + '"');         		continue;         	}         	if (entry.isdirectory()) {         	   dirarr.push(entry);         	}             var relpath = entry.path.replace(dirarr[0].path, ''); //need relative because we need to use this for telling addentryfi...
   
 
   
  
   
    word-break - CSS: Cascading Style Sheets
    
<code>word-break: normal</code></p> <p class="normal narrow">this is a long and  honorificabilitudinitatibus califragilistice
xpialidocious taumatawhakatangihangakoauauotamateaturipukakapikimaungahoronukupokaiwhenuakitanatahu  グレートブリテンおよび北アイルランド連合王国という言葉は本当に長い言葉</p>  <p>2.
... <code>word-break: break-all</code></p> <p class="breakall narrow">this is a long and  honorificabilitudinitatibus califragilistice
xpialidocious taumatawhakatangihangakoauauotamateaturipukakapikimaungahoronukupokaiwhenuakitanatahu  グレートブリテンおよび北アイルランド連合王国という言葉は本当に長い言葉</p>  <p>3.
... <code>word-break: keep-all</code></p> <p class="keepall narrow">this is a long and  honorificabilitudinitatibus califragilistice
xpialidocious taumatawhakatangihangakoauauotamateaturipukakapikimaungahoronukupokaiwhenuakitanatahu  グレートブリテンおよび北アイルランド連合王国という言葉は本当に長い言葉</p>  <p>4.
... <code>word-break: break-word</code></p> <p class="breakword narrow">this is a long and   honorificabilitudinitatibus califragilistice
xpialidocious taumatawhakatangihangakoauauotamateaturipukakapikimaungahoronukupokaiwhenuakitanatahu  グレートブリテンおよび北アイルランド連合王国という言葉は本当に長い言葉</p>  css  .narrow {   padding: 10px;   border: 1px solid;   width: 500px;   margin: 0 auto;   font-size: 20px;   line-height: 1.5;   letter-spacing: 1px; }  .normal {   word-break: normal; }  .breakall {   word-break: break-all; }  .keepall {   word-break: keep-all; }  .breakword {   word-break: break-word; }     specifications           specification    status    comment              css text module level 3the definition of 'word-break' in that specificatio...
   
 
   
    Using HTTP cookies - HTTP
    
an e
xpiration date or duration can be specified, after which the cookie is no longer sent.
... permanent cookies are deleted at a date specified by the e
xpires attribute, or after a period of time specified by the max-age attribute.
...   for example:  set-cookie: id=a3fwa; e
xpires=wed, 31 oct 2021 07:28:00 gmt;   note: when an e
xpires date is set, the time and date set is relative to the client the cookie is being set on, not the server.
... here is an example:  set-cookie: id=a3fwa; e
xpires=wed, 21 oct 2021 07:28:00 gmt; secure; httponly  define where cookies are sent  the domain and path attributes define the scope of the cookie: what urls the cookies should be sent to.
   
 
   
    Strict-Transport-Security - HTTP
    
          header type    response header          forbidden header name    no        syntax  strict-transport-security: max-age=<e
xpire-time> strict-transport-security: max-age=<e
xpire-time>; includesubdomains strict-transport-security: max-age=<e
xpire-time>; preload   directives    max-age=<e
xpire-time>  the time, in seconds, that the browser should remember that a site is only to be accessed using https.
... when the e
xpiration time specified by the strict-transport-security header elapses, the next attempt to load the site via http will proceed as normal instead of automatically using https.
...  whenever the strict-transport-security header is delivered to the browser, it will update the e
xpiration time for that site, so sites can refresh this information and prevent the timeout from e
xpiring.
... should it be necessary to disable strict transport security, setting the max-age to 0 (over a https connection) will immediately e
xpire the strict-transport-security header, allowing access via http.
   
 
   
    Program ID - Archive of obsolete content
    
when you package your add-on for distribution using jpm 
xpi, it will become the id field in the add-on's install manifest.
... when you create an 
xpi with jpm 
xpi:    if the package.json does not include an id field, then the id written into the install.rdf is the value of the name field prepended with "@".
... if the package.json does include an id field, and it does not contain "@", then jpm 
xpi raises an error and the 
xpi will not be built.
   
 
   
    Developing for Firefox Mobile - Archive of obsolete content
    
 running jpm-mobile test is identical:  jpm-mobile test --adb /path/to/adb   packaging mobile add-ons  to package a mobile add-on as an 
xpi, use the command:  jpm 
xpi   actually installing the 
xpi on the device is a little tricky.
... the easiest way is probably to copy the signed 
xpi somewhere on the device:  adb push my-addon.
xpi /mnt/sdcard/   then open firefox mobile and type this into the address bar:  file:///mnt/sdcard/my-addon.
xpi   the browser should open the 
xpi and ask if you want to install it.
...  afterwards you can delete it using adb as follows:  adb shell cd /mnt/sdcard rm my-addon.
xpi     module compatibility  modules not supported in firefox mobile are marked in the tables below.
   
 
   
    Bootstrapped extensions - Archive of obsolete content
    
 in firefox 10 and later the chrome.manifest file located in the root of the add-on's 
xpi (i.e.
... backward compatibility  because older versions of firefox don't know about the bootstrap property or bootstrap.js file, it's not overly difficult to create an 
xpi that will work on both as a bootstrappable extension and as a traditional extension.
...this may be a directory or an 
xpi file depending on whether the add-on is installed unpacked or not.
   
 
   
    Index of archived content - Archive of obsolete content
    
ful mozilla community sites               user notifications and alerts               xpcom objects                                                             performance best practices in extensions           search extension tutorial (draft)           security best practices in extensions           session store api           setting up an extension development environment           signing an 
xpi           signing an extension           supporting search suggestions in search plugins           tabbed browser                       techniques                         promises                                  updating addons broken by private browsing changes           using dependent libraries in extension components           using the stylesheet service           bookmarks.export()        ...
...ith nspr threads on win16           using cross commit           using gdb on wimpy computers                       venkman                         using breakpoints in venkman             venkman internals             venkman introduction                                  video presentations           when to use ifdefs           writing textual data           xml in mozilla                       
xpinstall                         creating 
xpi installer modules                           install wizards (aka: stub installers)                             mac stub installer               unix stub installer               windows stub installer                                                      learn 
xpi installer scripting by example                             installer script                 ...
...                                     using 
xpinstall to install plugins                             install script template                                                      
xpinstall api reference                                             examples                                 file.macalias                 file.windowsshortcut                 install.adddirectory                 install.addfile                 installtrigger.installchrome                 installtrigger.startsoftwareupdate                 trigger scripts and install scripts                 windows install                                                              file object                                 methods                                                              install object                             ...
   
 
   
    Modularization techniques - Archive of obsolete content
    
 a simple example   it is recommended that you use 
xpidl to define your interfaces.
... instead of microsoft's midl compiler, we are using a corba-compliant idl compiler, 
xpidl.
... links    the component object model specification   revision history    feb 25, 1998, created  oct 19, 1998, dusted off momentarily  oct 10, 1999, added comments about 
xpidl, language-independentness    original document information    author(s): will scullin  last updated date: september 13, 2004  copyright information: portions of this content are © 1998–2007 by individual mozilla.org contributors; content available under a creative commons license | details                                  ...
   
 
   
    loadResources - Archive of obsolete content
    
method of install object syntax object loadresources( string 
xpipath );  parameters the sole input parameter for loadresources is a string representing the path to the properties file in the 
xpi in which the key/value pairs are defined.
...be aware that the parameter specifies the file within the 
xpi and not on the file system, as the following example demonstrates.
... example given a 
xpi with this internal structure: install.js bin/res_eg_2.properties bin/somefile.exe bin/...
   
 
   
    Custom toolbar button - Archive of obsolete content
    
 you can optionally use a jar tool or zip tool to package your button as a cross-platform installable (
xpi) for other people to install and use.
...name the packed file with the extension .
xpi and make it available to other users.
...  users can install the 
xpi file in an application's extensions window in the normal way.
   
 
   
    XULRunner 1.8.0.1 Release Notes - Archive of obsolete content
    
 installing xul applications xul applications can be obtained from various sources, and are typically packaged as a zip archive with the extension .xulapp or .
xpi.
... windows run the following command from the start menu -> run or from a command prompt: "c:\program files\mozilla xulrunner\1.8.0.1\xulrunner\xulrunner.exe" --install-app "c:\documents and settings\user\desktop\myapplication.
xpi"  the application will be installed to c:\program files\vendorname\applicationname mac os x run the following command in a command prompt: /library/frameworks/xul.framework/xulrunner-bin --install-app ~/desktop/myapplication.
xpi  the application will be installed to /applications/vendor/appicationname linux run the following command in a command prompt: /opt/xulrunner/1.8.0.1/xulrunner/xulrunner --install-app ~/desktop/myap...
...plication.
xpi  the application will be installed to /usr/lib/vendor/applicationname known issues    firewall software may identify all xul applications as the same application.
   
 
   
    XULRunner 1.8.0.4 Release Notes - Archive of obsolete content
    
  installing xul applications  xul applications can be obtained from various sources, and are typically packaged as a zip archive with the extension .xulapp or .
xpi.
...  windows  run the following command from the start menu -> run or from a command prompt:  "c:\program files\mozilla xulrunner\1.8.0.4\xulrunner\xulrunner.exe" --install-app "c:\documents and settings\user\desktop\myapplication.
xpi"   the application will be installed to c:\program files\vendorname\applicationname  mac os x  run the following command in a command prompt:  /library/frameworks/xul.framework/xulrunner-bin --install-app ~/desktop/myapplication.
xpi   the application will be installed to /applications/vendor/applicationname  linux  run the following command in a command prompt:  /opt/xulrunner/1.8.0.4/xulrunner/xulrunner --install-app ~/...
...desktop/myapplication.
xpi   the application will be installed to /usr/lib/vendor/applicationname  known issues    firewall software may identify all xul applications as the same application.
   
 
   
    XULRunner 1.9.1 Release Notes - Archive of obsolete content
    
 installing xul applications xul applications can be obtained from various sources, and are typically packaged as a zip archive with the extension .xulapp or .
xpi.
... windows run the following command from the start menu -> run or from a command prompt: "c:\program files\mozilla xulrunner\1.9.1\xulrunner\xulrunner.exe" --install-app "c:\documents and settings\user\desktop\myapplication.
xpi"  the application will be installed to c:\program files\vendorname\applicationname mac os x run the following command in a command prompt: /library/frameworks/xul.framework/xulrunner-bin --install-app ~/desktop/myapplication.
xpi  the application will be installed to /applications/vendor/applicationname linux run the following command in a command prompt: /opt/xulrunner/1.9.1/xulrunner/xulrunner --install-app ~/desktop/myappli...
...cation.
xpi  the application will be installed to /usr/lib/vendor/applicationname known issues    firewall software may identify all xul applications as the same application.
   
 
   
    XULRunner 1.9.2 Release Notes - Archive of obsolete content
    
type sudo rm /var/db/receipts/org.mozilla.xulrunner.*  installing xul applications xul applications can be obtained from various sources, and are typically packaged as a zip archive with the extension .xulapp or .
xpi.
... windows run the following command from the start menu -> run or from a command prompt: "c:\program files\mozilla xulrunner\1.9.2\xulrunner\xulrunner.exe" --install-app "c:\documents and settings\user\desktop\myapplication.
xpi"  the application will be installed to c:\program files\vendorname\applicationname mac os x run the following command in a command prompt: /library/frameworks/xul.framework/xulrunner-bin --install-app ~/desktop/myapplication.
xpi  the application will be installed to /applications/vendor/applicationname linux run the following command in a command prompt: /opt/xulrunner/1.9.2/xulrunner/xulrunner --install-app ~/desktop/myapplica...
...tion.
xpi  the application will be installed to /usr/lib/vendor/applicationname known issues  firewall software may identify all xul applications as the same application.
   
 
   
    XULRunner 1.9 Release Notes - Archive of obsolete content
    
  installing xul applications  xul applications can be obtained from various sources, and are typically packaged as a zip archive with the extension .xulapp or .
xpi.
...  windows  run the following command from the start menu -> run or from a command prompt:  "c:\program files\mozilla xulrunner\1.9\xulrunner\xulrunner.exe" --install-app "c:\documents and settings\user\desktop\myapplication.
xpi"   the application will be installed to c:\program files\vendorname\applicationname  mac os x  run the following command in a command prompt:  /library/frameworks/xul.framework/xulrunner-bin --install-app ~/desktop/myapplication.
xpi   the application will be installed to /applications/vendor/applicationname  linux  run the following command in a command prompt:  /opt/xulrunner/1.9/xulrunner/xulrunner --install-app ~/desktop/...
...myapplication.
xpi   the application will be installed to /usr/lib/vendor/applicationname  known issues    firewall software may identify all xul applications as the same application.
   
 
   
  
   
    XULRunner 2.0 Release Notes - Archive of obsolete content
    
 installing xul applications xul applications can be obtained from various sources, and are typically packaged as a zip archive with the extension .xulapp or .
xpi.
... windows run the following command from the start menu -> run or from a command prompt: "c:\program files\mozilla xulrunner\2.0\xulrunner\xulrunner.exe" --install-app "c:\documents and settings\user\desktop\myapplication.
xpi"  the application will be installed to c:\program files\vendorname\applicationname mac os x run the following command in a command prompt: /library/frameworks/xul.framework/xulrunner-bin --install-app ~/desktop/myapplication.
xpi  the application will be installed to /applications/vendor/applicationname linux run the following command in a command prompt: /opt/xulrunner/2.0/xulrunner/xulrunner --install-app ~/desktop/myapplication...
....
xpi  the application will be installed to /usr/lib/vendor/applicationname known issues  firewall software may identify all xul applications as the same application.
   
 
   
    2006-10-06 - Archive of obsolete content
    
     ../../dist/host/bin/host_
xpidl -m header -w -i~mozilla/xpcom/base  -i../../dist/idl -o _
xpidlgen/nsiconsolelistener  ~/mozilla/xpcom/base/nsiconsolelistener.idl  gmake[2]: *** [_
xpidlgen/nsiconsolelistener.h] bus error  gmake[2]: *** deleting file `_
xpidlgen/nsiconsolelistener.h'  gmake[1]: *** [export] error 2  make: *** [all] error 2::     on octorber 4th ludwig hügelschäfer responded to his original post with the solution to his own problem.
...   he found out that a broken host_
xpidl was the source of the problem.
... in order to fix this he deleted the tree part where host_
xpidl was located.
   
 
   
    Building Mozilla XForms - Archive of obsolete content
    
switch to the root of your source directory and start the build with make -f client.mk build  after the build finishes, you'll have a xforms.
xpi in obj-*/dist/
xpi-stage/xforms.
xpi.
...the built 
xpi file will only install on a nightly snapshot from the same day or your self-built firefox version.
... if you are sure that older or newer firefox versions are compatible with your extension, you can unzip the 
xpi file (it's a regular zip file), edit the install.rdf and change the minversion and maxversion entries.
   
 
   
    A bird's-eye view of the Mozilla framework
    
the client simply queries the provider for a particular service, and if available, accesses that service through an interface defined in 
xpidl (cross-platform idl), derived from the corba idl.
... the 
xpidl interface description is independent of the programming language used to implement the object itself.
... for example, a javascript object or c++ class could both implement the same 
xpidl interface.
   
 
   
    Chrome registration
    
this is accomplished through 
xpinstall and the extension manager.
... interfaces    interfaces component/mycomponent.xpt [flags]   instructs mozilla to load interface information from a typelib file produced by 
xpidl.
...  structure of an installable bundle: describes the common structure of installable bundles, including extensions, themes, and xulrunner applications  extension packaging: specific information about how to package extensions  theme packaging: specific information about how to package themes  multiple-item extension packaging: specific information about multiple-item extension 
xpis  xul application packaging: specific information about how to package xulrunner applications  chrome registration                                 ...
   
 
   
    Creating a Language Pack
    
 $ cd ../../dist  the 
xpi file can be found in the directory win32/
xpi on windows, linux-i686/
xpi or linux-x86_64 on linux or mac/
xpi on mac.
...  open the 
xpi file contained in this directory with firefox to see your work.
...70 27 lis 13:33 branding -rw-r--r--@ 1 your_id  your_status  25248119 26 lis 14:34 firefox-3.6b5pre.en-us.mac.dmg -rw-r--r--@ 1 your_id  your_status  26056973 27 lis 13:40 firefox-3.6b5pre.x-testing.mac.dmg drwxr-xr-x  3 your_id  your_status       102 27 lis 13:38 install drwxr-xr-x  3 your_id  your_status       102 27 lis 13:40 l10n-stage drwxr-xr-x  3 your_id  your_status       102 27 lis 13:37 
xpi-stage   you can install your locale's binary just as you would an official one.
   
 
   
    Creating a spell check dictionary add-on
    
 packaging  a firefox add-on is a zip file renamed to use an .
xpi file extension instead of the normal .zip file extension.
... to create a dictionary add-on, simply create a zip file which contains the following files and folders:  my-dictionary.
xpi    install.rdf  dictionaries/       locale-code.dic    locale-code.aff        the .dic and .aff files must be placed in a subfolder named dictionaries within the zip file.
...  once you have added these files to your zip file and renamed the file to have the .
xpi extension, you can install your add-on in firefox and test it.
   
 
   
    NSS tools : certutil
    
 $ certutil -l -d sql:/home/my/sharednssdb    certificate nickname                                         trust attri  butes                                                               ssl,s/mime,  jar/
xpi    ca administrator of instance pki-ca1's example domain id     u,u,u  tps administrator's example domain id                        u,u,u  google internet authority                                    ,,  certificate authority - example domain                       ct,c,c       using additional arguments with -l can return and print the     information for a single, specific certificate.
... certutil -d -d [sql:]directory -n "nickname"       for example:  $ certutil -d -d sql:/home/my/sharednssdb -n "my-ssl-cert"       validating certificates       a certificate contains an e
xpiration date in itself, and     e
xpired certificates are easily rejected.
... however, certificates     can also be revoked before they hit their e
xpiration date.
   
 
   
    certutil
    
  $ certutil -l -d sql:/home/my/sharednssdb   certificate nickname                                         trust attributes                                                               ssl,s/mime,jar/
xpi   ca administrator of instance pki-ca1's example domain id     u,u,u  tps administrator's example domain id                        u,u,u  google internet authority                                    ,,  certificate authority - example domain                       ct,c,c     using additional arguments with -l can return and print the information    for a single, specific certificate.
...  certutil -d -d [sql:]directory -n "nickname"     for example:   $ certutil -d -d sql:/home/my/sharednssdb -n "my-ssl-cert"     validating certificates     a certificate contains an e
xpiration date in itself, and e
xpired    certificates are easily rejected.
... however, certificates can also be    revoked before they hit their e
xpiration date.
   
 
   
    Creating a Python XPCOM component
    
   tip: you can achieve a copy of binary of pyxpcom from pythonext; simply unpack 
xpi and take everything you need.
...registering the interface in the "components" directory, execute : ../
xpidl -m typelib -w -v -i /usr/share/idl/mozilla/ nsipysimple.idl  on windows you must point to the idl directory as part of your mozilla build.
... for example: 
xpidl.exe -m typelib -w -v -i c:\source\mozilla\obj-i686-pc-mingw32\dist\idl foo.idl  
xpidl will then create nsipysimple.xpt, which should be placed correctly (e.g., in the 'components' directory).
   
 
   
    Creating XPCOM components
    
   note:this article describes a method that uses 
xpidl but you should use webidl instead.
...   preface    who should read this book  organization of the tutorial  following along with the examples  conventions  acknowledgements   an overview of xpcom    the xpcom solution  gecko  components  interfaces     interfaces and encapsulation   the nsisupports base interface      xpcom identifiers     cid   contract id      factories     
xpidl and type libraries      xpcom services  xpcom types     method types   reference counting   status codes   variable mappings   common xpcom error codes       using xpcom components    component examples      cookie manager   the webbrowserfind component   the weblock component      component use in mozilla     finding mozilla components   using xpcom components in your cpp   xpconnect: using xpcom components from script       component internals    cr...
...mmon implementation macros   declaration macros      weblock2.cpp  string classes in xpcom     using strings   nsembedstring and nsembedcstring      smart pointers   starting weblock    getting called at startup      registering for notifications   getting access to the category manager      providing access to weblock  creating the weblock programming interface  defining the weblock interface in 
xpidl     the 
xpidl syntax   scriptable interfaces   subclassing nsisupports   the web locking interface      implementing weblock     declaration macros   representing return values in xpcom   
xpidl code generation   getting the weblock service from a client   implementing the iweblock interface   the directory service   modifying paths with nsifile   manipulating files with nsifile   using nsilocal...
   
 
   
    How to build a binary XPCOM component using Visual Studio
    
 note: wintools.zip seems old and lots of newer mdc documentation refers to moztools.zip archive, but the version of 
xpidl.exe that comes with the gecko-sdk crashes with the dll’s from moztools.
...then make the following tweaks:   add "..\gecko-sdk\include" to additional include directories  add "..\gecko-sdk\lib" to additional library directories  add "nspr4.lib xpcom.lib xpcomglue_s.lib" to additional dependencies  add "xp_win;xp_win32″ to preprocessor definitions  turn off precompiled headers (just to keep it simple)  use a custom build step for the xpcom idl file (spawns 
xpidl-build.bat to process the idl with mozilla toolset, not midl)  vc++ express project: xpcom-test.zip  note: the project uses xpcom_glue.
...the command executes 
xpidl.exe twice, like this:  {path_to_geckosdk}\bin\
xpidl.exe -m header -i..\gecko-sdk\idl {your_idl_file} {path_to_geckosdk}\bin\
xpidl.exe -m typelib -i..\gecko-sdk\idl {your_idl_file}  the generated h file actually has a skeleton implementation (commented out).
   
 
   
    nsAdoptingCString
    
         class declaration  nstadoptingstring extends nst
xpidlstring such that:  (1) adopt given string on construction or assignment, i.e.
...al(const char     lowercaseequalsliteral(char     assign     assignascii     assignliteral(const char     assignliteral(char     adopt     replace     replaceascii     append     appendascii     appendliteral(const char     appendliteral(char     operator+=     insert     cut     setcapacity     setlength     truncate     getdata     getmutabledata     setisvoid     stripchar     base classes   ns
xpidlcstring   data members  no public members.
...  methods   constructors   void nsadoptingcstring() - source    void nsadoptingcstring(char*, pruint32) - source   parameters  char* str pruint32 length    void nsadoptingcstring(const nsadoptingcstring&) - source   parameters  nsadoptingcstring& str      operator=   nsadoptingcstring& operator=(const nsadoptingcstring&) - source   parameters  nsadoptingcstring& str    ns
xpidlcstring& operator=(const ns
xpidlcstring&) - source   parameters  ns
xpidlcstring& str    nscstring& operator=(const nscstring&) - source   parameters  nscstring& str    nsacstring_internal& operator=(char) - source   parameters  char c    nsacstring_internal& operator=(const char*) - source   parameters  char* data    nsacstring_internal& operator=(const nsacstring_internal&) - source   parameters  nsacstring_internal& st...
   
 
   
    nsAdoptingString
    
         class declaration  nstadoptingstring extends nst
xpidlstring such that:  (1) adopt given string on construction or assignment, i.e.
...al(const char     lowercaseequalsliteral(char     assign     assignascii     assignliteral(const char     assignliteral(char     adopt     replace     replaceascii     append     appendascii     appendliteral(const char     appendliteral(char     operator+=     insert     cut     setcapacity     setlength     truncate     getdata     getmutabledata     setisvoid     stripchar     base classes   ns
xpidlstring   data members  no public members.
...  methods   constructors   void nsadoptingstring() - source    void nsadoptingstring(prunichar*, pruint32) - source   parameters  prunichar* str pruint32 length    void nsadoptingstring(const nsadoptingstring&) - source   parameters  nsadoptingstring& str      operator=   nsadoptingstring& operator=(const nsadoptingstring&) - source   parameters  nsadoptingstring& str    ns
xpidlstring& operator=(const ns
xpidlstring&) - source   parameters  ns
xpidlstring& str    nsstring& operator=(const nsstring&) - source   parameters  nsstring& str    nsastring_internal& operator=(prunichar) - source   parameters  prunichar c    nsastring_internal& operator=(const prunichar*) - source   parameters  prunichar* data    nsastring_internal& operator=(const nsastring_internal&) - source   parameters  nsastring_i...
   
 
   
    nsICacheEntryDescriptor
    
n gecko 2.0 (firefox 4 / thunderbird 3.3 / seamonkey 2.1)  method overview    void close();   void doom();   void doomandfailpendingrequests(in nsresult status);   string getmetadataelement(in string key);   void markvalid();   nsiinputstream openinputstream(in unsigned long offset);   nsioutputstream openoutputstream(in unsigned long offset);   void setdatasize(in unsigned long size);   void sete
xpirationtime(in pruint32 e
xpirationtime);   void setmetadataelement(in string key, in string value);   void visitmetadata(in nsicachemetadatavisitor visitor);    attributes    attribute type description   accessgranted nscacheaccessmode get the access granted to this descriptor.
... sete
xpirationtime() this method sets the time at which the cache entry should be considered invalid (in seconds since the epoch).
... void sete
xpirationtime(   in pruint32 e
xpirationtime );  parameters  e
xpirationtime the time for cache entry e
xpiration (in seconds).
   
 
   
  
   
    nsIComponentManager
    
s, in nsiidref aiid, [iid_is(aiid),retval] out nsqiresult result);          void getclassobjectbycontractid(in string acontractid, in nsiidref aiid, [iid_is(aiid),retval] out nsqiresult result);          void removebootstrappedmanifestlocation(in nsilocalfile alocation);         methods  addbootstrappedmanifestlocation()  loads a "bootstrapped" chrome.manifest file from the specified directory or 
xpi file.
... void addbootstrappedmanifestlocation(   in interface nsilocalfile alocation );   parameters    alocation  the directory or 
xpi from which to load the chrome.manifest.
... void removebootstrappedmanifestlocation(   in interface nsilocalfile alocation );   parameters  examples  using addbootstrappedmanifestlocation in a bootstrapped extension for firefox 8 and 9:    alocation  the directory or 
xpi to stop reading the chrome.manifest from.
   
 
   
    nsICookie
    
     last changed in gecko 1.7   inherits from: nsisupports attributes    attribute type description   e
xpires pruint64 e
xpiration time in seconds since midnight (00:00:00), january 1, 1970 utc.
... e
xpires = 0 represents a session cookie.
... e
xpires = 1 represents an e
xpiration time earlier than jan 1, 1970.
   
 
   
    nsICookieManager2
    
to create an object implementing this interface:  components.utils.import("resource://gre/modules/services.jsm"); var cookieservice = services.cookies;     method overview           void add(in autf8string ahost, in autf8string apath, in acstring aname, in acstring avalue, in boolean aissecure, in boolean aishttponly, in boolean aissession, in print64 ae
xpiry);          boolean cookieexists(in nsicookie2 acookie);           unsigned long countcookiesfromhost(in autf8string ahost);           boolean findmatchingcookie(in nsicookie2 acookie, out unsigned long acountfromhost); obsolete since gecko 1.9          nsisimpleenumerator getcookiesfromhost(in autf8string ahost);           void importcookies(in nsifile acookiefile);         methods  add()  adds...
... void add(   in autf8string ahost,   in autf8string apath,   in acstring aname,   in acstring avalue,   in boolean aissecure,   in boolean aishttponly,   in boolean aissession,   in print64 ae
xpiry );   parameters    ahost  the host or domain for which the cookie is set.
... ae
xpiry  holds the e
xpiration date, in seconds since the epoch.
   
 
   
    nsICookieService
    
this typically happens because they have either e
xpired or because the cookie list has grown too large.
...  setcookiestringfromhttp()  set the cookie string and e
xpires associated with the uri.
... aservertime  the e
xpiry information of the cookie (the date header from the http response).
   
 
   
    nsIInstallLocation
    
        1.0    66        introduced gecko 1.8          obsolete    gecko 2.0           inherits from: nsisupports last changed in gecko 2.0 (firefox 4 / thunderbird 3.3 / seamonkey 2.1)  note: while this api still works, firefox 4 no longer extracts 
xpis by default, so this will now point to the 
xpi file instead of to the directory.
...  itemlocations nsidirectoryenumerator  an enumeration of nsifiles for:  locations that contain items potential dropped-in 
xpis  note: this enumeration resolves text links to the directories they refer to.
...getstagefile() returns the most recently staged package (for example the last 
xpi or jar in a directory) for an item and removes items that do not qualify.
   
 
   
    nsIPermission
    
                e
xpiretime       print64       the e
xpiration time of the permission measured in milliseconds since 1970 jan 1 0:00:00.
...                 e
xpiretype       pruint32       the e
xpiration type of the permission: on session termination, on a specified time, or never.
... constants are defined in nsipermissionmanager.permission_e
xpiration_constants.
   
 
   
    nsIRequest
    
          constant    value    description          validate_always    1 << 11    forces validation of any cached content independent of its e
xpiration time.
...          validate_never    1 << 12    disables validation of e
xpired content.
...          validate_once_per_session    1 << 13    disables validation of e
xpired content, provided it has already been validated (at least once) since the start of this session.
   
 
   
    Building a Thunderbird extension 2: extension file layout
    
  extensions are packaged and distributed in archive files (also known as bundles), with the 
xpi (pronounced “zippy”) file extension.
...when this tutorial is finished, our extension will look like this:  myfirstext.
xpi:                                //created in step 8               /install.rdf                     //created in step 3               /chrome.manifest                 //created in step 4               /chrome/               /content/               /content/myhelloworld.xul        //created in step 5               /content/overlay.js              //created in step 6               /chrome/locale/*                 //building an extension# localization               /chrome/skin/              ...
... /defaults/preferences/           //building an extension# defaults files   the following tutorial pages will explain how to write each of these files (except locale/ and defaults/) and package them into an 
xpi (zippy) file.
   
 
   
    startSoftwareUpdate - Web APIs
    
  method of installtrigger object   syntax boolean startsoftwareupdate ( string url);    parameters the startsoftwareupdate method has the following parameter:    url   a uniform resource locator specifying the location of the 
xpi file containing the software.
...this method has been largely superseded by newer  install method, which is more flexible and allows you to install more than one 
xpi.
... note also that 
xpis installed with this method must have their own install.js files in which the full installation is defined.
   
 
   
    WindowOrWorkerGlobalScope.setTimeout() - Web APIs
    
 the settimeout() method of the windoworworkerglobalscope mixin (and successor to window.settimeout()) sets a timer which executes a function or specified piece of code once the timer e
xpires.
...  syntax  var timeoutid = scope.settimeout(function[, delay, arg1, arg2, ...]); var timeoutid = scope.settimeout(function[, delay]); var timeoutid = scope.settimeout(code[, delay]);   parameters    function  a function to be executed after the timer e
xpires.
...  code  an alternative syntax that allows you to include a string instead of a function, which is compiled and executed when the timer e
xpires.
   
 
   
    How to check the security state of an XMLHTTPRequest over SSL - Web APIs
    
 was the used ssl certificate valid and what are its details (owner, e
xpiration, certificate authority, etc.)?
...      let nsserr = math.abs(nsinsserrorsservice.nss_sec_error_base) - (status & 0xffff);        switch (nsserr) {         case 11: // sec_error_e
xpired_certificate, sec(11)           errname = 'securitye
xpiredcertificateerror';           break;         case 12: // sec_error_revoked_certificate, sec(12)           errname = 'securityrevokedcertificateerror';           break;                    // per bsmith, we will be unable to tell these errors apart very soon,         // so it makes sense to just folder them all together already.
...        sha1 fingerprint = f4:99:64:18:6b:7d:c8:fa:c0:0c:2e:a9:61:77:28:67:13:c4:97:7b         valid from 7/14/2011 0:00:00 am         valid until 8/20/2013 23:59:59 pm  and here is the output of making an https request to a server that uses an e
xpired certificate: test("https://www.appliancetherapy.com/");  note that the security state has become "insecure" now and there is an error name reported: connection status:         failed: securitye
xpiredcertificateerror security info:         security state: insecure         common name (cn) = www.appliancetherapy.com         organisation = appliance therapy group (selane products, inc)         is...
   
 
   
   
    Web audio codec guide - Web media technologies
    
ompatibility                              feature        chrome        edge        firefox        internet explorer        opera        safari                      g.711 support        23[1]        15[1]        22[1]        no        43[1]        11[1]                                container support    3gp          rtp / webrtc compatible    yes          licensing    all applicable patents have e
xpired, so g.711 is free to use without restriction        [1] g.711 is supported only for webrtc connections.
...                             feature        chrome        edge        firefox        internet explorer        opera        safari                      g.722 support        yes[1]        yes[1]        yes[1]        no        yes[1]        yes[1]                                container support    3gp, amr-wb          rtp / webrtc compatible    yes          licensing    all applicable patents have e
xpired; g.722 is free to use without restriction        [1] webrtc only.
... the patents behind mp3 have e
xpired, removing many or most licensing concerns around using mp3 files in your projects.
   
 
   
    Image file type and format guide - Web media technologies
    
as of july 7, 2004, all relevant patents have e
xpired and the gif format may be used freely        ico (microsoft windows icon)  the ico (microsoft windows icon) file format was designed by microsoft for desktop icons of windows systems.
...                               compression    lossy; based on the discrete cosine transform          licensing    as of october 27, 2006, all united states patents have e
xpired.
...         licensing    no license required (aside from any associated with libraries you might use); all known patents have e
xpired.
   
 
   
    Module structure of the SDK - Archive of obsolete content
    
 although the sdk repository in github includes copies of these modules, they are built into firefox and by default, when you run or build an add-on using jpm run or jpm 
xpi, it is the versions of the modules in firefox that are used.
... if you need to use a different version of the modules, you can do this by checking out the version of the sdk that you need and passing the -o or --overload option to jpm run or jpm 
xpi.
   
 
   
  
   
    Testing the Add-on SDK - Archive of obsolete content
    
 this suite basically tests cfx 
xpi's ability to produce the 
xpi files that we expect it to.
... this suite builds the entire addon-sdk repo as an add-on, like cfx 
xpi would, then runs the add-on like cfx test would.
   
 
   
    self - Archive of obsolete content
    
the package in which you run jpm 
xpi).
...all files in this directory will be copied into the 
xpi and made available through the data object.
   
 
   
    package.json - Archive of obsolete content
    
 some of its entries, such as icon, name, and description, have direct analogues in the install manifest format, and entries from package.json are written into the install manifest when the add-on is built using jpm 
xpi.
...     when the add-on is built as an 
xpi, if the fullname and title keys are not present, name is used as the add-on's em:name element in its install.rdf.
   
 
   
    Storing annotations - Archive of obsolete content
    
            data.url('widget/pencil-on.png') :             data.url('widget/pencil-off.png'); });  widget.port.on('right-click', function() {     console.log('show annotation list');     annotationlist.show(); });  this time execute cfx 
xpi to build the 
xpi for the add-on, and install it in firefox.
... until now we've always run cfx run rather than building an 
xpi and installing the add-on in firefox.
   
 
   
    Chrome Authority - Archive of obsolete content
    
 manifest generation  the manifest is a list, included in the generated 
xpi, which specifies which modules have requested require() access to which other modules.
... commands that build a manifest, like "jpm 
xpi" or "jpm run", will scan all included modules for use of cc/ci aliases (or the expanded components.classes forms).
   
 
   
    Localization - Archive of obsolete content
    
      the sdk tools compile the locale files into a json format when producing an 
xpi.
... this means that translators can't localize an add-on given the 
xpi alone, but must be given access to the add-on source.
   
 
   
   
    Makefile.mozextension.2 - Archive of obsolete content
    
xxx-xxxx-xxxx-xxxxxxxxxxxx} project_id=test@testworld.ext project_version=1.0 project_desc="a $(project_name) project with advanced features" project_author=author name   # mkdir=$(shell which mkdir) mkdir=/bin/mkdir zipprog=/usr/bin/zip shell = /bin/sh noop = $(shell) -c true noecho = @ rm_rf=rm -f cp=/bin/cp -i   .phony: all   all ::  make_structure make_files 	$(noecho) $(noop)  package:: make_
xpi 	$(noecho) $(noop)  #install :: make_
xpi make_install #	$(noecho) $(noop)  clean :: make_clean 	$(noecho) $(noop)  make_structure: 	@$(mkdir) $(project) || { echo "creating directory failed; it probably exists.
... either remove (clean it), or choose individual targets to build."; exit 1; } 	@echo $(mkdir) $(project) 	$(mkdir) $(project)/content $(project)/locale $(project)/locale/en-us $(project)/components/ $(project)/defaults/ $(project)/defaults/preferences/ $(project)/locale/de-de $(project)/skin  make_
xpi: 	$(mkdir) $(project)/chrome && \ 	cd $(project) && \ 	$(zipprog)  -r  chrome/$(project).jar content locale skin && \ 	$(zipprog)  -r  $(project).
xpi chrome.manifest install.rdf components defaults chrome && cd ..
   
 
   
    InstallTrigger.installChrome - Archive of obsolete content
    
when a user clicks the link "install the new blue theme" in the example below, 
xpinstall downloads, registers, and installs the theme contained in newblue.
xpi to the user's profile directory.
... <a href="#"   onclick="installtrigger.installchrome(      installtrigger.skin,      'http://wildskins/newblue.
xpi',      'newblue/1.0');"> install the new blue theme</a>                                 ...
   
 
   
    InstallTrigger.startSoftwareUpdate - Archive of obsolete content
    
        installtrigger.startsoftwareupdate this is a very simple example of the installtrigger object's principal method,  startsoftwareupdate, which takes a string representing the path to the 
xpi and installs that 
xpi on the local machine.
... function triggerurl(url) {    installtrigger.startsoftwareupdtate(url); } // get the url to the .
xpi from either a form // or text field entry.
   
 
   
    Trigger Scripts and Install Scripts - Archive of obsolete content
    
 these install scripts are typically located at the top level of the 
xpi archives in which the installations are stored.
... a trigger script may trigger the downloading of a 
xpi, which in turn will use its own install.js script to manage the complete installation.
   
 
   
    Examples - Archive of obsolete content
    
        examples trigger scripts and install scripts describes typical kinds of script that use the 
xpinstall api.
... the following samples demonstrate some of the principal installation functions in the 
xpinstall api:    file.macalias   file.windowsshortcut   [install.]adddirectory   [install.]addfile   installtrigger.installchrome   installtrigger.startsoftwareupdate   windows install example                                 ...
   
 
   
    Methods - Archive of obsolete content
    
        parts of this page show the use of the 
xpinstall api.
...       execute        extracts a file from the 
xpi file to a temporary location and schedules it for later execution.
   
 
   
    Install Object - Archive of obsolete content
    
        parts of this page show the use of the 
xpinstall api.
...install use the install object to manage the downloading and installation of software with the 
xpi installation manager.
   
 
   
    Index - Archive of obsolete content
    
       972     window icons     add-ons, extensions, toolkit api, 
xpinstall, xul       starting with firefox 1.5, thunderbird 1.5, and xulrunner 1.8, you can specify an icon for a xul window by putting files named mywindow.ico (for windows) and mywindow.xpm or mywindow16.xpm (linux), where mywindow is the id of the <window> you want to attach the icon to, in the chrome/icons/default subfolder of your bundle.
...       1023     creating an installer     tutorials, 
xpinstall_api_reference, xul, xul_tutorial       this section will describe packaging a xul application into an installer.
   
 
   
  
   
    Archived Mozilla and build documentation - Archive of obsolete content
    
venkman has been provided as part of the mozilla install distribution since october 2001, as well as an          extension package in 
xpi format.
...                 
xpinstall                  xpjs components proposal         draft 1.0         xre                  xtech 2005 presentations                  xtech 2006 presentations                  xul explorer                   xul explorer is a xulrunner application that provides an easy way to experiment with xul.
   
 
   
    How to structure a web form - Learn web development
    
the last one is an <input> element of type date, for entering the e
xpiration date of the card; this one will come up with a date picker widget in supporting browsers, and fall back to a normal text input in non-supporting browsers.
...visa">visa</option>         <option value="mc">mastercard</option>         <option value="amex">american express</option>       </select>     </p>     <p>       <label for="number">         <span>card number:</span>         <strong><abbr title="required">*</abbr></strong>       </label>       <input type="tel" id="number" name="cardnumber">     </p>     <p>       <label for="date">         <span>e
xpiration date:</span>         <strong><abbr title="required">*</abbr></strong>         <em>formatted as mm/dd/yyyy</em>       </label>       <input type="date" id="date" name="e
xpiration">     </p> </section>    the last section we'll add is a lot simpler, containing only a <button> of type submit, for submitting the form data.
   
 
   
    Command line options
    
 --install-app path/to/myapplication.(
xpi|xulapp)  installs the xulrunner application at path/to onto the system.
... "c:\program files\mozilla xulrunner\1.8.0.4\xulrunner\xulrunner.exe" --install-app "c:\users\billdo\desktop\myapplication.
xpi"  /opt/xulrunner/1.8.0.4/xulrunner/xulrunner --install-app ~/desktop/myapplication.xulapp  /library/frameworks/xul.framework/xulrunner-bin --install-app ~/desktop/myapplication.
xpi  --register-global  registers xulrunner on the system for all users.
   
 
   
    Roll your own browser: An embedding how-to
    
contained within this directory are a couple of makefiles:    basebrowser-unix  basebrowser-win   the 
xpinstall packager follows the same format.
... however in our case, we only have one named 
xpi package.
   
 
   
    AddonManager
    
the existing add-on types are defined in 
xpiprovider.jsm and are, at this time, the following: extension, theme, locale, multipackage, dictionary and experiment.
... void removetypelistener(   in typelistener listener )   parameters    listener  the typelistener to remove   geturiforresourceinfile()  nsiuri geturiforresourceinfile(   in nsifile afile,   in string apath )   parameters    afile  the nsifile containing the resources; must be either a directory or an 
xpi file.
   
 
   
    Using JavaScript code modules
    
 examples    a template to download and edit is seen here on github - gists - _template-bootstrapjsm.
xpi   extending resource: urls  prior to gecko 2.0, the most common way to load code modules was using resource: urls.
... using chrome.manifest  the easiest way for extensions and xul applications to add custom aliases is by registering an alias in the chrome manifest using a line like this:  resource aliasname uri/to/files/   for example, if the 
xpi for your foo extension includes a top-level modules/directory containing the bar.js module (that is, the modules/directory is a sibling to chrome.manifest and install.rdf), you could create an alias to that directory via the instruction:  resource foo modules/   (don't forget the trailing slash!) you could then import the module into your javascript code via the statement:  components.utils.impor...
   
 
   
    QA phase
    
 install the .
xpi langpack you just created (or exported).
... remember that here you are pushing an entire directory, not a .zip archive file or an .
xpi lang pack.
   
 
   
    PRIntervalTime
    
the proper coding style to test the e
xpiration of an interval is as follows:   if ((printervaltime)(now - epoch) > interval)  <...
... interval has e
xpired ...>   as long as the interval and the elapsed time (now - epoch) do not exceed half the namespace allowed by a printervaltime (231-1), the expression shown above provides the expected result even if the signs of now and epoch differ.
   
 
   
    PR_Wait
    
  returns  the function returns one of the following values:    pr_success means the thread is being resumed from the pr_wait call either because it was explicitly notified or because the time specified by the parameter ticks has e
xpired.
...if the value of timeout is not pr_interval_no_timeout, pr_wait resumes execution after the specified interval has e
xpired.
   
 
   
    A Web PKI x509 certificate primer
    
certificate has a common name or subject alternative name that is not in the namespace of an issuing certificate    re-issue the certificate with names that are within the namespace of all certificates in the chain          sec_error_cert_signature_algorithm_disabled    a certificate has been signed with an obsolete algorithm    re-sign the certificate using a modern algorithm          sec_error_e
xpired_certificate    a certificate is too old to be used    re-generate the certificate          sec_error_extension_value_invalid    a certificate has an extension with an empty value    re-generate the certificate without the extension, or re-generate it with a non-empty value          sec_error_inadequate_cert_type    a certificate has an extended key usage extension that does not assert a requir...
...re-generate the certificate without the extension or with it not marked as critical          sec_error_unknown_issuer    either a missing intermediate or root certificate is necessary to verify the certificate    import the root certificate into firefox or have the server send the intermediate          sec_error_invalid_key                  sec_error_unsupported_keyalg                  sec_error_e
xpired_issuer_certificate    an issuer certificate is too old    re-issue the issuer certificate          mozilla_pkix_error_ca_cert_used_as_end_entity    a certificate with a basic constraints extension with ca:true is being used as an end-entity certificate    re-generate the end-entity certificate without the basic constraints extension          mozilla_pkix_error_inadequate_key_size    a certific...
   
 
   
    Creating the Component Code
    
xpinstall, the cross-platform installation technology that mozilla uses to install the browser and other components, is one such alternative.
... coding for the registration process  when xpcom discovers your component for the first time (via 
xpinstall or regxpcom, both of which are discussed in component installation overview), the first thing it tries to do is load your library and find the symbol nsgetmodule.
   
 
   
    nsACString
    
 nsacstring corresponds to the acstring and autf8string 
xpidl data types.
...if used with 
xpidl, then the character encodings of the corresponding 
xpidl data types applies.
   
 
   
    nsAString
    
nsastring corresponds to the astring and domstring 
xpidl data types.
...if used with 
xpidl, then the character encodings of the corresponding 
xpidl data types applies.
   
 
   
    nsIAnnotationObserver
    
this is not called when annotations are e
xpired (normally happens when the application exits).
...this is not called when annotations are e
xpired (normally happens when the application exits).
   
 
   
    nsICacheSession
    
 in nscacheaccessmode accessrequested, in nsicachelistener listener, [optional] in boolean nowait);   void evictentries();   prbool isstorageenabled();   nsicacheentrydescriptor opencacheentry(in acstring key, in nscacheaccessmode accessrequested, in boolean blockingmode);   void doomentry(in acstring key, in nsicachelistener listener);     attributes    attribute type description   doomentriesife
xpired prbool e
xpired entries will be doomed or evicted if this attribute is set to true.
... if false, e
xpired entries will be returned (useful for offline mode and clients, such as http, that can update the valid lifetime of cached content).
   
 
   
  
   
    nsICookie2
    
   e
xpiry print64 the actual e
xpiry time of the cookie, in seconds since midnight (00:00:00), january 1, 1970 utc.
...note: that e
xpiry time will also be honored for session cookies; thus, whichever is the more restrictive of the two will take effect.
   
 
   
    nsILivemarkService
    
  reloadalllivemarks()  this method reloads all livemark subscriptions, whether or not they have e
xpired.
... reloadlivemarkfolder()  this method reloads the livemark with this folder id, whether or not it's e
xpired.
   
 
   
    nsIScriptableInputStream
    
examples list contents of 
xpi and read file contents this example here uses the read function.
...full example using the zip interfaces is seen here: list contents of 
xpi and read file contents.
   
 
   
    Performance
    
for example, the history service used to delete many database items at shutdown when e
xpiring old history items.
...as a result, this bug introduced incremental history e
xpiration eliminating the need to write many 0s to disk on shutdown.
   
 
   
    Index
    
       75     building a thunderbird extension 2: extension file layout     extensions, thunderbird       extensions are packaged and distributed in archive files (also known as bundles), with the 
xpi (pronounced “zippy”) file extension.
...(in step 8 you will learn how to package an .
xpi file for distribution and installation.)        81     building a thunderbird extension 8: packaging     extensions, thunderbird       when you are satisfied with how your extension works, package it for deployment and installation.
   
 
   
    Theme Packaging
    
 theme file layout  thunderbird themes are packaged in an 
xpi file with the following structure:  theme.
xpi:   install.rdf   preview.png   icon.png   chrome/         browser/files         communicator/files         global/files         mozapps/files   ...
...  structure of an installable bundle: describes the common structure of installable bundles, including extensions, themes, and xulrunner applications  extension packaging: specific information about how to package extensions  theme packaging: specific information about how to package themes  multiple-item extension packaging: specific information about multiple-item extension 
xpis  xul application packaging: specific information about how to package xulrunner applications  chrome registration                                 ...
   
 
   
    customDBHeaders Preference
    
      install.rdf               makefile               chrome/                      content/                              superfluous.js                              superfluous_overlay.xul   here's the makefile:  deps:= chrome/ \        chrome.manifest \        chrome/content/ \        chrome/content/superfluous.js \        chrome/content/superfluous_overlay.xul \        install.rdf  superfluous.
xpi: ${deps}   zip  $@  ${deps}    chrome.manifest:  content superfluous chrome/content/ overlay chrome://messenger/content/messenger.xul  chrome://superfluous/content/superfluous_overlay.xul   install.rdf:  <?xml version='1.0' encoding='utf-8'?> <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-manifes...
...2*</em:minversion>           <em:maxversion>3.0.0.*</em:maxversion>         </description>       </em:targetapplication>     <em:name>superfluous</em:name>     <em:description>test superfluous extension</em:description>     <em:creator>garrett comeaux</em:creator> </description> </rdf>    build process:  [gcomeaux@kyle tbird-ext]$ cd superfluous/ [gcomeaux@kyle superfluous]$ make zip  superfluous.
xpi  chrome/ chrome.manifest chrome/content/ chrome/content/superfluous.js chrome/content/superfluous_overlay.xul install.rdf   adding: chrome/ (stored 0%)   adding: chrome.manifest (deflated 44%)   adding: chrome/content/ (stored 0%)   adding: chrome/content/superfluous.js (deflated 57%)   adding: chrome/content/superfluous_overlay.xul (deflated 44%)   adding: install.rdf (deflated 50%)   end result...
   
 
   
    ctypes.open
    
components.interfaces.nsichromeregistry);  var chromeuri_mylib = services.io.newuri('chrome://youraddon/content/mysubfolder/mycfunctionsforunix.so', 'utf-8', null); var localfile_mylib = cr.convertchromeurl(chromeuri_mylib); var jarpath_mylib = localfile_mylib.spec; // "jar:file:///c:/users/vayeate/appdata/roaming/mozilla/firefox/profiles/aecgxse.unnamed%20profile%201/extensions/youraddon@jetpack.
xpi!/mysubfolder/mycfunctionsforunix.so" var filepath_mylib = localfilemylib.path; // "file:///c:/users/vayeate/appdata/roaming/mozilla/firefox/profiles/aecgxse.unnamed%20profile%201/extensions/youraddon@jetpack.
xpi!/mysubfolder/mycfunctionsforunix.so"   if your add-on is a bootstrap add-on, then you don't need to use this method to convert a chrome:// path; instead, on startup procedure of the boots...
...if addon is packed, this will be addon 
xpi }  this can then be joined with your file name to obtain it's path like this:  function startup(adata, areason) {      var jarpath_folder = 'jar:' + os.path.tofileuri(adata.installpath.path) + '!/'; // if unpacked is false in install.rdf this will look like: "jar:file:///c:/users/vayeate/appdata/roaming/mozilla/firefox/profiles/aksozfjt.unnamed%20profile%2010/extensions/asynczip@jetpack!/"     var filepath_folder = adata.installpath.path; // if unpacked is set to false in install.rdf this will look like: "c:\users\vayeate\appdata\r...
   
 
   
    Mozilla
    
                     xpi                       cross-platform installer module (
xpi) is a zip file used to install packages, utilizing the 
xpinstall technology.
... 
xpi modules (so called "            bundles") are employed to install a wide variety of software, including plugins,            extensions, themes, and            thunderbird dictionaries.
   
 
   
    Background Tasks API - Web APIs
    
 interfaces  the background tasks api adds only one new interface:   	idledeadline 	an object of this type is passed to the idle callback to provide an estimate of how long the idle period is expected to last, as well as whether or not the callback is running because its timeout period has e
xpired.
... running tasks  our idle callback handler, runtaskqueue(), gets called when the browser determines there's enough idle time available to let us do some work or our timeout of one second e
xpires.
   
 
   
    Credential Management API - Web APIs
    
these capabilities allow users to sign in without typing passwords, see the federated account they used to sign in to a site, and resume a session without the explicit sign-in flow of an e
xpired session.
...this give users capabilities such as seeing the federated account they used to sign on to a site, or resuming a session without the explicit sign-in flow of an e
xpired session.
   
 
   
    Document.lastModified - Web APIs
    
here is a possible example of how to show an alert message when the page changes (see also: javascript cookies api):  if (date.parse(document.lastmodified) > parsefloat(document.cookie.replace(/(?:(?:^|.*;)\s*last_modif\s*\=\s*([^;]*).*$)|^.*$/, "$1") || "0")) {   document.cookie = "last_modif=" + date.now() + "; e
xpires=fri, 31 dec 9999 23:59:59 gmt; path=" + location.pathname;   alert("this page has changed!"); }  …the same example, but skipping the first visit:  var   nlastvisit = parsefloat(document.cookie.replace(/(?:(?:^|.*;)\s*last_modif\s*\=\s*([^;]*).*$)|^.*$/, "$1")),   nlastmodif = date.parse(document.lastmodified);  if (isnan(nlastvisit) || nlastmodif > nlastvisit) {   document.cookie = "last_mod...
...if=" + date.now() + "; e
xpires=fri, 31 dec 9999 23:59:59 gmt; path=" + location.pathname;    if (isfinite(nlastvisit)) {     alert("this page has been changed!");   } }  note: webkit returns the time string in utc; gecko and internet explorer return a time in the local timezone.
   
 
   
    HTMLElement: transitionrun event - Web APIs
    
e adds a listener to the transitionrun event:  el.addeventlistener('transitionrun', () => {   console.log('transition is running but hasn\'t necessarily started transitioning yet'); });  the same, but using the ontransitionrun property instead of addeventlistener():  el.ontransitionrun = () => {   console.log('transition started running, and will start transitioning when the transition delay has e
xpired'); };   live example  in the following example, we have a simple <div> element, styled with a transition that includes a delay:  <div class="transition">hover over me</div> <div class="message"></div>  .transition {   width: 100px;   height: 100px;   background: rgba(255,0,0,1);   transition-property: transform, background;   transition-duration: 2s;   transition-delay: 1s; }  .transition:hove...
...  the transitionrun will occur even if the transition is canceled before the delay e
xpires.
   
 
   
    IdleDeadline - Web APIs
    
it offers a method, timeremaining(), which lets you determine how much longer the user agent estimates it will remain idle and a property, didtimeout, which lets you determine if your callback is executing because its timeout duration e
xpired.
...  properties    idledeadline.didtimeout read only   a boolean whose value is true if the callback is being executed because the timeout specified when the idle callback was installed has e
xpired.
   
 
   
    enabled - Web APIs
    
the method reflects the value of the software installation preference in the user interface, and of the 
xpinstall.enabled preference in pref.js.
...  example  the following code uses the  startsoftwareupdate method to unconditionally trigger a download from http://royalairways/royalpkg.
xpi as long as software installation is enabled on the browser:  if (installtrigger.enabled() ) {     installtrigger.startsoftwareupdate ("http://royalair.com/rasoft.
xpi"); }                                ...
   
 
   
  
   
    Payment Request API - Web APIs
    
 consistent error handling: the browser can check the validity of card numbers, and can tell the user if a card has e
xpired (or is about to e
xpire).
... basiccardresponse  defines an object structure for payment response details such as the number/e
xpiry date of the card used to make the payment, and the billing address.
   
 
   
    RTCIceCandidatePairStats.writable - Web APIs
    
 syntax  iswritable = rtcicecandidatepairstats.writable;  value  a boolean value which is true if the connection described by this candidate pair has received acknowledgement of receipt (ack) for at least one ice request and that stun consent hasn't e
xpired.
...   note: this property was removed from the specification in early 2017 because you can determine whether or not an incoming ice request is available to read by checking to see if responsesreceived is greater than 0 and that the time specified by consente
xpiredtimestamp has not passed:  if (icpstats.responsesreceived > 0     && icpstats.consente
xpiredtimestamp < performance.now()) {   /* at least one ice response has been received */ }   ...
   
 
   
    ServiceWorkerGlobalScope: pushsubscriptionchange event - Web APIs
    
  note: in earlier drafts of the specification, this event was defined to be sent when a pushsubscription has e
xpired.
...bscribe(event.oldsubscription.options)     .then(subscription => {       return fetch("register", {         method: "post",         headers: {           "content-type": "application/json"         },         body: json.stringify({           endpoint: subscription.endpoint         })       });     })   ); }, false);  when a pushsubscriptionchange event arrives, indicating that the subscription has e
xpired, we resubscribe by calling the push manager's subscribe() method.
   
 
   
    WebGL2RenderingContext.clientWaitSync() - Web APIs
    
 gl.timeout_e
xpired: indicates that the timeout time passed and that the sync object did not become signaled.
...  gl.condition_satisfied: indicates that the sync object was signaled before the timeout e
xpired.
   
 
   
    Using the alert role - Accessibility
    
the alert role is most useful for information that requires the user's immediate attention, for example:    an invalid value was entered into a form field   the user's login session is about to e
xpire  the connection to the server was lost, local changes will not be saved   because of its intrusive nature, the alert role must be used sparingly and only in situations where the user's immediate attention is required.
... .hidden {   display:none; }   <p id="e
xpirationwarning" role="alert" class="hidden">your log in session will e
xpire in 2 minutes</p>   // removing the 'hidden' class makes the element visible, which will make the screen reader announce the alert: document.getelementbyid("e
xpirationwarning").classname = "";   working examples:    alert role example using an aria alert box  alert example using a modal aria dialog box   notes     using the ...
   
 
   
    Cognitive accessibility - Accessibility
    
for example, being able to extend the e
xpiration time on an application requiring an authentication code sent to a mobile device via text message helps with the following scenarios:    people with attention or anxiety disorders.
... ensure that people can continue an activity without loss of data after re-authenticating an e
xpired session, for example, saving the state of a questionnaire.
   
 
   
    Event reference
    
		 		 			timeout 			progression is terminated due to preset time e
xpiring.
...		 		 			pushsubscriptionchange 			pushevent   			push api 			a pushsubscription has e
xpired.
   
 
   
   
    Public-Key-Pins-Report-Only - HTTP
    
          header type    response header          forbidden header name    no        syntax  public-key-pins-report-only: pin-sha256="<pin-value>";                              max-age=<e
xpire-time>;                              includesubdomains;                              report-uri="<uri>"  directives    pin-sha256="<pin-value>"  the quoted string is the base64 encoded subject public key information (spki) fingerprint.
... max-age=<e
xpire-time>  this directive is meaningless for the public-key-pins-report-only header, it will be ignored by user agents and the header will not be cached.
   
 
   
    Public-Key-Pins - HTTP
    
          header type    response header          forbidden header name    no        syntax  public-key-pins: pin-sha256="<pin-value>";                  max-age=<e
xpire-time>;                  includesubdomains;                  report-uri="<uri>"  directives    pin-sha256="<pin-value>"  the quoted string is the base64 encoded subject public key information (spki) fingerprint.
... max-age=<e
xpire-time>  the time, in seconds, that the browser should remember that this site is only to be accessed using one of the defined keys.
   
 
   
    Trailer - HTTP
    
      examples  chunked transfer encoding using a trailing header  in this example, the e
xpires header is used at the end of the chunked message and serves as a trailing header.
...  http/1.1 200 ok content-type: text/plain transfer-encoding: chunked trailer: e
xpires  7\r\n mozilla\r\n 9\r\n developer\r\n 7\r\n network\r\n 0\r\n e
xpires: wed, 21 oct 2015 07:28:00 gmt\r\n \r\n   specifications           specification    title          rfc 7230, section 4.4: trailer    hypertext transfer protocol (http/1.1): message syntax and routing          rfc 7230, section 4.1.2: chunked trailer part    hypertext transfer protocol (http/1.1): message syntax and routing        ...
   
 
   
    Warning - HTTP
    
          code    text    description              110    response is stale    a response provided by a cache is stale (the e
xpiration time set for it has passed).
...         113    heuristic e
xpiration    sent if a cache heuristically chose a freshness lifetime greater than 24 hours and the response's age is greater than 24 hours.
   
 
   
    Media container formats (file types) - Web media technologies
    
now that the patents have all e
xpired, mp3 is a widely supported and good choice.
...   consider using this container format              compressed files for general-purpose playback    mp3 (mpeg-1 audio layer iii)          losslessly compressed files    flac with alac fallback          uncompressed files    wav        now that mp3's patents have all e
xpired, the choice of audio file format has become much easier to make.
   
 
   
    Web video codec guide - Web media technologies
    
      opera        safari                      mpeg-1 support        no        no        no        no        no        yes                                container support    mpeg          rtp / webrtc compatible    no          supporting/maintaining organization    mpeg          specification    https://www.iso.org/standard/22411.html          licensing    proprietary; however, all patents have e
xpired, so mpeg-1 may be used freely        mpeg-2 part 2 video  mpeg-2 part 2 is the video format defined by the mpeg-2 specification, and is also occasionally referred to by its itu designation, h.262.
...   no        no        no        yes                                container support    mpeg, mpeg-ts (mpeg transport stream), mp4, quicktime          rtp / webrtc compatible    no          supporting/maintaining organization    mpeg / itu          specification    https://www.itu.int/rec/t-rec-h.262     https://www.iso.org/standard/61152.html          licensing    proprietary; all patents have e
xpired worldwide with the exception of in malaysia and the philippines as of april 1, 2019, so mpeg-2 can be used freely outside those two countries.
   
 
   
   
  
   
   
    Cookies - Archive of obsolete content
    
 services.cookies.add(".host.example.com", "/cookie-path", "cookie_name", "cookie_value", is_secure, is_http_only, is_session, e
xpiry_date);   see also    document.cookie  nsicookie  nsicookie2  nsicookieservice  nsicookiemanager  nsicookiemanager2  http cookies                                 ...
   
 
   
    Finding window handles - Archive of obsolete content
    
comparing to the method above, by using this method, you don't have to compile your component with nsiwidget.h and other bunchs of h files that should not be exposed to outside, and could change every time firefox updates, all you need is nsibasewindow.idl(it's not in gecko_sdk, get this from the latest firefox source, or http://mxr.mozilla.org/mozilla/sourc...basewindow.idl), and use 
xpidl to compile it to .h file, although that's stll a unfrozen interface, but it should be a lot better.
   
 
   
   
    Running applications - Archive of obsolete content
    
 var file = components.classes["@mozilla.org/file/local;1"]                      .createinstance(components.interfaces.nsilocalfile); file.initwithpath("c:\\myapp.exe"); file.launch();   references    nsiprocess  nsilocalfile  if you need to launch an executable bundled in your 
xpi, see code snippets:file i/o#getting your extension's folder.
   
 
   
    Code snippets - Archive of obsolete content
    
le drag and drop events  dialogs  code used to display and process dialog boxes  alerts and notifications   modal and non-modal ways to notify users  preferences  code used to read, write, and modify preferences  js xpcom  code used to define and call xpcom components in javascript  running applications  code used to run other applications  <canvas> related  what wg canvas-related code  signing a 
xpi  how to sign an 
xpi with pki  delayed execution  performing background operations.
   
 
   
    Migrating from Internal Linkage to Frozen Linkage - Archive of obsolete content
    
the frozen string api does not have (or need) ns
xpidlstring: - ns
xpidlstring value; + nsstring value;   ptr->gettermethod(getter_copies(value)); - const prunichar *strvalue = value; + // nsstring doesn't cast directly to prunichar*, use .get()+ const prunichar *strvalue = value.get();   the frozen string api doesn't accept a length for .truncate().
   
 
   
    Local Storage - Archive of obsolete content
    
you can reach the defaults directory at profd/extensions/your_extension_id.
xpi/defaults for packed extensions or profd/extensions/your_extension_id/defaults for unpacked extensions.
   
 
   
   
   
   
   
   
   
    cert_override.txt - Archive of obsolete content
    
: oid.2.16.840.1.101.3.4.2.1 (most used) sha-384: oid.2.16.840.1.101.3.4.2.2 sha-512: oid.2.16.840.1.101.3.4.2.3   certificate fingerprint using previous hash algorithm one or more characters for override type:  m : allow mismatches in the hostname u : allow untrusted certs (whether it's self signed cert or a missing or invalid issuer cert) t : allow errors in the validity time, for example, for e
xpired or not yet valid certs   certificate's serial number and the issuer name as a base64 encoded string                                 ...
   
 
   
  
   
    Structure of an installable bundle - Archive of obsolete content
    
 api          structure of an installable bundle: describes the common structure of installable bundles, including extensions, themes, and xulrunner applications     extension packaging: specific information about how to package extensions     theme packaging: specific information about how to package themes     multiple-item extension packaging: specific information about multiple-item extension 
xpis     xul application packaging: specific information about how to package xulrunner applications     chrome registration     printing in xul apps                                    ...
   
 
   
   
   
    jspage - Archive of obsolete content
    
ons:{path:false,domain:false,duration:false,secure:false,document:document},initialize:function(b,a){this.key=b; this.setoptions(a);},write:function(b){b=encodeuricomponent(b);if(this.options.domain){b+="; domain="+this.options.domain;}if(this.options.path){b+="; path="+this.options.path; }if(this.options.duration){var a=new date();a.settime(a.gettime()+this.options.duration*24*60*60*1000);b+="; e
xpires="+a.togmtstring();}if(this.options.secure){b+="; secure"; }this.options.document.cookie=this.key+"="+b;return this;},read:function(){var a=this.options.document.cookie.match("(?:^|;)\\s*"+this.key.escaperegexp()+"=([^;]*)"); return(a)?decodeuricomponent(a[1]):null;},dispose:function(){new cookie(this.key,$merge(this.options,{duration:-1})).write("");return this;}});cookie.write=function(b,c,a)...
   
 
   
    Microsummary XML grammar reference - Archive of obsolete content
    
 notes:    regardless of the absolute or conditional update interval specified by this element, firefox will never update microsummaries more frequently than once per minute;   because firefox checks for e
xpired microsummaries every 15 seconds, it is possible for a microsummary update to begin up to 15 seconds later than its interval indicates;   firefox respects the browser cache when updating microsummaries, so it will not reload a page to update its microsummary if the cache contains a fresh copy of the page.
   
 
   
    Microsummary topics - Archive of obsolete content
    
thus, if you would like to control how frequently firefox initiates microsummary-related requests to your web server, you can do so by including an http e
xpires or cache-control header in your response to a microsummary-related request.
   
 
   
   
   
   
    String Quick Reference - Archive of obsolete content
    
 right: use nsautostring/nscautostring and ns
xpidlstring/ns
xpidlcstring  // call getstringvalue(nsastring& out); nsautostring value; // 64-character buffer on stack getstringvalue(value); // call getstringvalue(char** out); ns
xpidlcstring result; getstringvalue(getter_copies(result)); // result will free automatically      original document information   author: alec flett  last updated date: april 30, 2003  copyright information: portions of t...
   
 
   
   
   
   
    Install script template - Archive of obsolete content
    
html  **/  // define some global variables  var plugin_file    = "npmyplugin.dll";  // this plugin consists of an xpt file because it is scriptable //   http://mozilla.org/projects/plugins/scripting-plugins.html  var component_file = "npmypluginscriptable.xpt";  var plugin_size    = 2000; // (dll file) reserve a little extra so it is not required to update too often var component_size = 10;   // (
xpi file) reserve a little extra so it is not required to update too often  var software_name="cult3d mozilla viewer";  // plids (http://mozilla.org/projects/plugins/plugin-identifier.html) are coined by vendors.
   
 
   
    File.macAlias - Archive of obsolete content
    
xpisrc = "miscellaneous program"; var vi = "1.1.1.1"; initinstall(   "macintosh alias",   "misc",   vi,   0); f = getfolder("program"); g = getfolder("mac desktop"); addfile(   "filemacalias",   "2.2.2.2",   
xpisrc,   f,   
xpisrc,   true); err = file.macalias(f, 
xpisrc, g, 
xpisrc + " alias"); logcomment("file.macalias returns: " + err); if (0 == getlasterror())    performinstall(); else    cancelinstall();                                 ...
   
 
   
  
   
    File.windowsShortcut - Archive of obsolete content
    
var 
xpisrc = "misc.exe"; var vi = "1.1.1.1"; initinstall(   "windows shortcut",   "test",   vi,   0); f = getfolder("windows"); g = getfolder("temporary"); addfile(   "miscshortcut",   "2.2.2.2",   
xpisrc,   f,   
xpisrc,   true); target = getfolder(f, 
xpisrc); shortcutpath = getfolder("program"); err = file.windowsshortcut(   target,   shortcutpath,   "misc shortcut",   g,   "",   target,   0); logcomment("file.windowsshortcut returns: " + err); if ...
   
 
   
    Install.addDirectory - Archive of obsolete content
    
var vi = "10.10.10.10"; var 
xpisrc = "adddir1"; initinstall("addfilenovers1", "adddir_1", vi, 1); f = getfolder("program"); setpackagefolder(f); err = adddirectory(
xpisrc); logcomment("the error = " + err); if (0 == getlasterror())    performinstall(); else    cancelinstall();                                 ...
   
 
   
    Install.addFile - Archive of obsolete content
    
var 
xpisrc = "file.txt"; initinstall(   "adding a file",   "testfile",   "1.0.1.7",   1); f = getfolder("program"); setpackagefolder(f); addfile(
xpisrc); if (0 == getlasterror())    performinstall(); else    cancelinstall();                                 ...
   
 
   
   
   
   
   
   
    confirm - Archive of obsolete content
    
also: user closed the dialog window                 1       'ok' or button 0                 2       the third button          previous versions of the 
xpinstall api stated the return value of confirm() to be a boolean.
   
 
   
    refreshPlugins - Archive of obsolete content
    
example // install dll into plugins  // install xpt into components   var 
xpisrc  = "npmcult3dp.dll";   var 
xpisrc2 = "nsic3dpscriptablepeer.xpt";   initinstall(    "cult3d plugin file",    "@cycore.com/cult3d;version=1.0.0",    "1.0.0");   setpackagefolder(getfolder("plugins"));   addfile(
xpisrc);   addfile("",
xpisrc2,getfolder("components"),"");   var err = getlasterror();   if (err == success)   {      err = performinstall();      if (err == success)         refreshplug...
   
 
   
   
   
   
   
    Printing from a XUL App - Archive of obsolete content
    
         structure of an installable bundle: describes the common structure of installable bundles, including extensions, themes, and xulrunner applications     extension packaging: specific information about how to package extensions     theme packaging: specific information about how to package themes     multiple-item extension packaging: specific information about multiple-item extension 
xpis     xul application packaging: specific information about how to package xulrunner applications     chrome registration     printing in xul apps                                   ...
   
 
   
  
   
    Creating toolbar buttons (Customize Toolbar Window) - Archive of obsolete content
    
extensions for firefox/thunderbird 1.5 and above should instead use something like this in their chrome.manifest:  skin	myextension	classic/1.0	chrome/skin/ style	chrome://global/content/customizetoolbar.xul	chrome://myextension/skin/toolbar-button.css ia  take note of the packaging section in this article; you may need to include .jar references if you are delivering your extension as an .
xpi file.
   
 
   
   
    XUL accessibility guidelines - Archive of obsolete content
    
if the user were to tab to the "exceptions..." button they would hear "cookies {pause} exceptions {pause} button." the next tab would read "cookies {pause} keep until {pause} they e
xpire {pause} one of three {pause} combobox." if the screen reader only read the label, then the user would have to guess what the "exceptions" button or the "keep until" combobox was referring to.
   
 
   
   
   
   
    ant script to assemble an extension - Archive of obsolete content
    
        this ant script helps to package an extension  <?xml version="1.0"?> this build file was written by régis décamps <decamps@users.sf.net>  <project name="blogmark" default="create
xpi">        <property name="version" value="1.3-rc1"/>        <property name="description" value="new context-menu item to add                                            the current page in your blogmarks"/>        
xpi file is created after "chrome/blogmark.jar"               is created, which is then stuffed into "blogmark.
xpi"        <target name="create
xpi" depends="createjar"                description="assemble the final build blogmark.
xpi">                <zip destfile="blogmark-${version}.
xpi">                         <zipfileset dir="." includes="chrome/blogmark.jar" />                         <zipf...
   
 
   
    Mozprofile - Archive of obsolete content
    
example: from mozprofile import firefoxprofile  # create new profile to pass to mozmill/mozrunner profile = firefoxprofile(addons=["adblock.
xpi"])  setting preferences preferences can be set in several ways:   using the api: you can pass preferences in to the profile class's constructor: obj = firefoxprofile(preferences=[("accessibility.typeaheadfind.flashbar", 0)])  using a json blob file: mozprofile --preferences myprefs.json  using a .ini file: mozprofile --preferences myprefs.ini  via the command line: mozprofile --pref key:value --p...
   
 
   
    2006-10-20 - Archive of obsolete content
    
he can be contacted via: email: preed@mozilla.com irc: preed on irc.mozilla.org phone: 650.903.0800 x256      uploading language packs to amo   on october 17th benjamin smedberg brought the following to the attention of the localizers and the build team:  that he is planning to upload the firefox 2 language packages currently located at http://releases.mozilla.org/pub/mozi...rc3/win32/
xpi/ to addons.mozilla.org in the next few days.
   
 
   
   
    2006-12-01 - Archive of obsolete content
    
   discussions   convert ooo .dic to .
xpi  convert ooo .dic to .
xpi    mozillatranslator and sourceforge.net  about the best way to organize things    creating a <locale>.jar file from the cvs structure  discussion on how to package a <locale>.jar from the cvs structure without having to download the entire mozilla source.
   
 
   
   
   
    NPAPI plugin developer guide - Archive of obsolete content
    
   unix    mac os x       drawing a plug-in instance  handling memory  sending and receiving streams  working with urls  getting version and ui information  displaying messages on the status line  making plug-ins scriptable  building plug-ins       building, platforms, and compilers    building carbonized plug-ins for mac os x    type libraries       installing plug-ins       native installers    
xpi plug-ins installations       plug-in installation and the windows registry   initialization and destruction    initialization  instance creation  instance destruction  shutdown  initialize and shutdown example   drawing and event handling    the npwindow structure  drawing plug-ins       printing the plug-in    setting the window    getting information       windowed plug-ins       mac os    wind...
   
 
   
    The First Install Problem - Archive of obsolete content
    
for example, in our case, a prospective invocation might look like:   <object classid="@mycompany.com/myapplication,version=5.01"           data="myfile.typ" codebase="http://myurl.com/myplugin/myplugin.
xpi"           type="application/x-myapp"></object>  the use of both "type" and "classid" attributes here offers the following user benefit:    if there is another mimetype handler for application/x-myapp, only myapplication gets invoked.
   
 
   
  
   
    LiveConnect - Archive of obsolete content
    
    note:  liveconnect blocked under some conditions  liveconnect calls from javascript to java api are blocked when the java control panel security slider is set to very high level, or when the slider is at the default high level and the jre has either e
xpired or is below the security baseline.
   
 
   
   
    Obsolete: XPCOM-based scripting for NPAPI plugins - Archive of obsolete content
    
 should be changed, we shouldn't advocate embed <embed type="application/plugin-mimetype"> <script language="javascript"> var embed = document.embeds[0]; embed.nativemethod(); </script>  how to build and install having the built mozilla tree is probably not necessary, but building the plugin with a scriptable instance interface will require mozilla headers and the xpcom compatible idl compiler -- 
xpidl.exe.
   
 
   
   
   
    Index - MDN Web Docs Glossary: Definitions of Web-related terms
    
       451     ttl     caching, domain name system, glossary, infrastructure, networking, performance       ttl can refer either to : the lifetime of a packet in a network can do before being releasedthe e
xpiry time of cached data        452     turn     glossary, infrastructure, turn, webmechanics, webrtc       turn (traversal using relays around nat) is a protocol enabling a computer to receive and send data from behind a network address translator (nat) or firewall.
   
 
   
    Response header - MDN Web Docs Glossary: Definitions of Web-related terms
    
aking, the content-encoding and content-type headers are entity header:  200 ok access-control-allow-origin: * connection: keep-alive content-encoding: gzip content-type: text/html; charset=utf-8 date: mon, 18 jul 2016 16:06:00 gmt etag: "c561c68d0ba92bbeb8b0f612a9199f722e3a621a" keep-alive: timeout=5, max=997 last-modified: mon, 18 jul 2016 02:36:04 gmt server: apache set-cookie: mykey=myvalue; e
xpires=mon, 17-jul-2017 16:06:00 gmt; max-age=31449600; path=/; secure transfer-encoding: chunked vary: cookie, accept-encoding x-backend-server: developer2.webapp.scl3.mozilla.com x-cache-info: not cacheable; meta data too large x-kuma-revision: 1085259 x-frame-options: deny                   ...
   
 
   
    Session Hijacking - MDN Web Docs Glossary: Definitions of Web-related terms
    
   session hijacking occurs because    no account lockout for invalid session ids  weak session-id generation algorithm  insecure handling  indefinite session e
xpiration time  short session ids  transmission in plain text   session hijacking process    sniff, that is perform a man-in-the-middle (mitm) attack, place yourself between victim and server.
   
 
   
    TTL - MDN Web Docs Glossary: Definitions of Web-related terms
    
        ttl can refer either to :     the lifetime of a packet in a network can do before being released  the e
xpiry time of cached data   networking  in networking, the ttl, embedded in the packet, is a usually defined as a number of hops or as an e
xpiration timestamp after which the packet is dropped.
   
 
   
    What is a Domain Name? - Learn web development
    
	alternatively, if you use a system with a built-in shell, type a whois command into it, as shown here for mozilla.org:   $ whois mozilla.org domain name:mozilla.org domain id: d1409563-lror creation date: 1998-01-24t05:00:00z updated date: 2013-12-08t01:16:57z registry e
xpiry date: 2015-01-23t05:00:00z sponsoring registrar:markmonitor inc.
   
 
   
    Example - Learn web development
    
visa">visa</option>         <option value="mc">mastercard</option>         <option value="amex">american express</option>       </select>     </p>     <p>       <label for="number">         <span>card number:</span>         <strong><abbr title="required">*</abbr></strong>       </label>       <input type="tel" id="number" name="cardnumber">     </p>     <p>       <label for="date">         <span>e
xpiration date:</span>         <strong><abbr title="required">*</abbr></strong>         <em>formatted as mm/dd/yyyy</em>       </label>       <input type="date" id="date" name="e
xpiration">     </p>   </section>   <section>     <p> <button type="submit">validate the payment</button> </p>   </section> </form>  css content  h1 {     margin-top: 0; }  ul {     margin: 0;     padding: 0;     list-style: ...
   
 
   
    Sending form data - Learn web development
    
   note also that if you are using mamp but don't have mamp pro installed (or if the mamp pro demo time trial has e
xpired), you might have trouble getting it working.
   
 
   
   
    How Mozilla's build system works
    
 makefile examples    standard makefile header  installing headers using exports  compiling interfaces using 
xpidlsrcs  installing a javascript component  building a component dll  building a static library  building a dynamic library  makefiles - best practices and suggestions  makefile - targets  makefile - variables, values  makefile - *.mk files & user config   building libraries  there are three main types of libraries that are built in mozilla:    components are shared libraries (except in static buil...
   
 
   
    Simple Sunbird build
    
this will build the lightning extension into src/../objdir-sb/mozilla/dist/
xpi-stage/.
   
 
   
  
   
   
    Embedding Tips
    
 at startup use the category manager to register properties of the global object in javascript like this:  nscomptr<nsicategorymanager> catman =       do_getservice(ns_categorymanager_contractid);   if (!catman)     return ns_error_failure;    ns
xpidlcstring previous;   catman->addcategoryentry(javascript_global_property_category,                          "my_prop_name", "my_prop_contract_id",                          pr_true, pr_true, getter_copies(previous));   this will cause a component with the contract id my_prop_contract_id to be lazily created when the my_prop_name is resolved in any javascript window scope.
   
 
   
    Addon
    
for 
xpi style add-ons, for example, it tests whether the named file was included in the package.
   
 
   
    Code Samples
    
 var addonlocation = addon.getresourceuri("").queryinterface(components.interfaces.nsifileurl).file.path; });   accessing file and version information  components.utils.import("resource://gre/modules/addonmanager.jsm");  addonmanager.getaddonbyid("my-addon@foo.com", function(addon) {   alert("my extension's version is " + addon.version);   alert("did i remember to include that file.txt file in my 
xpi?
   
 
   
    Add-on Manager
    
these will pass an addoninstall instance to the callback, which can then be used to install the add-on:  components.utils.import("resource://gre/modules/addonmanager.jsm");  addonmanager.getinstallforurl("http://www.foo.com/test.
xpi", function(ainstall) {   // ainstall is an instance of addoninstall   ainstall.install(); }, "application/x-
xpinstall");   the progress of addoninstalls can be monitored using an installlistener.
   
 
   
    Localization technical reviews
    
 here is some of the criteria we use to perform technical reviews:      revision attachment contains only relevant files   we run into exports that contain .
xpi langpacks and other random files.
   
 
   
    Fonts for Mozilla 2.0's MathML engine
    
mathml font selection with css you can get these fonts from the mathml-fonts add-on ; the 
xpi is just a zip archive that you can fetch and extract for example with the following command: wget https://addons.mozilla.org/firefox/downloads/latest/367848/addon-367848-latest.
xpi -o mathml-fonts.zip; \ unzip mathml-fonts.zip -d mathml-fonts then copy the mathml-fonts/resource/ directory somewhere on your web site and ensure that the woff files are served with the correct mime type.
   
 
   
    Mozilla DOM Hacking Guide
    
 resources of interest    the 
xpidl reference  mapping dom objects to their c++ class  modularization techniques   scriptable helper flags  this chapter has not been written yet.
   
 
   
    Memory Profiler
    
you may need to set the "
xpinstall.signatures.required" pref to false in order to install it, since the 
xpi is not yet signed.
   
 
   
    about:memory
    
 ├───40,214,384 b (04.17%) -- add-ons │   ├──21,184,320 b (02.20%) ++ {d10d0bf8-f5b5-c8b4-a8b2-2b9879e08c5d}/js-non-window/zones/zone(0x100496800)/compartment([system principal], jar:file:///users/njn/library/application%20support/firefox/profiles/puna0zr8.new/extensions/%7bd10d0bf8-f5b5-c8b4-a8b2-2b9879e08c5d%7d.
xpi!/bootstrap.js (from: resource://gre/modules/addons/
xpiprovider.jsm:4307)) │   ├──11,583,312 b (01.20%) ++ jid1-xufzosoflzsoxg@jetpack/js-non-window/zones/zone(0x100496800) │   ├───5,574,608 b (00.58%) -- {59c81df5-4b7a-477b-912d-4e0fdf64e5f2} │   │   ├──5,529,280 b (00.57%) -- window-objects │   │   │  ├──4,175,584 b (00.43%) ++ top(chrome://chatzilla/conte...
   
 
   
    McCoy
    
 you can then include this install.rdf in your add-on's 
xpi and release it.
   
 
   
    Introduction to NSPR
    
 a call to pr_waitcondvar may also resume because the interval specified on the wait call has e
xpired.
   
 
   
    PRLinger
    
that is, if any data remains in the socket send buffer, pr_close blocks until either all the data is sent and acknowledged by the peer or the interval specified by linger e
xpires.
   
 
   
    PR_IntervalNow
    
 the most common use for pr_intervalnow() is to establish an epoch and test for the e
xpiration of intervals.
   
 
   
    PR_Poll
    
if this time e
xpires without any i/o becoming ready, pr_poll returns zero.
   
 
   
  
   
   
    NSS 3.12.4 release notes
    
op exporting mktemp and dbopen (again) bug 489287: resolve a few remaining issues with nss's new revocation flags bug 489710: byteswap optimize for msvc++ bug 490154: cryptokey framework requires module to implement generatekey when they support keypairgeneration bug 491044: remove support for vms (a.k.a., openvms) from nss bug 491174: cert_pkixverifycert reports wrong error code when ee cert is e
xpired bug 491919: cert.h doesn't have valid functions prototypes bug 492131: a failure to import a cert from a p12 file leaves error code set to zero bug 492385: crash freeing named crl entry on shutdown bug 493135: bltest crashes if it can't open the input file bug 493364: can't build with --disable-dbm option when not cross-compiling bug 493693: sse2 instructions for bignum are not implemented on ...
   
 
   
    NSS 3.12.9 release notes
    
798: win_rand.c (among others) uses unsafe _snwprintf   bug 597622: do not use the sec_error_bad_info_access_location error code for bad crl distribution point urls   bug 619268: memory leaks in cert_changecerttrust and cert_savesmimeprofile   bug 585518: addtrust qualified ca root serial wrong in certdata.txt trust entry   bug 337433: need cert_findcertbynicknameoremailaddrbyusage   bug 592939: e
xpired cas in certdata.txt      documentation  <for a="" class="new " documentation="" href="/en/index.html#documentation" list="" nss="" of="" pages="" primary="" rel="internal" see="" the="" title="en/index.html#documentation">nss documentation.
   
 
   
    NSS_3.12_release_notes.html
    
 408260: certutil usage doesn't give enough information about trust arguments bug 410226: leak in create_objects_from_handles bug 415007: pk11_findcertfromdersubjectandnickname is dead code bug 416267: compiler warnings on solaris due to extra semicolon in sec_asn1_mksub bug 419763: logger thread should be joined on exit bug 424471: counter overflow in bltest bug 229335: remove certificates that e
xpired in august 2004 from tree bug 346551: init secitem dertemp in crmf_encode_popoprivkey bug 395080: double backslash in sysdir filenames causes problems on os/2 bug 341371: certutil lacks a way to request a certificate with an existing key bug 382292: add support for camellia to cmd/symkeyutil bug 385642: add additional cert usage(s) for certutil's -v -u option bug 175741: strict aliasing bugs in...
   
 
   
   
    NSS 3.34.1 release notes
    
          sha-256 fingerprint: d8:e0:fe:bc:1d:b2:e3:8d:00:94:0f:37:d2:7d:41:34:4d:99:3e:73:4b:99:d5:65:6d:97:78:d4:d8:14:36:24                removed entries from certdata.txt for actively distrusted certificates that have e
xpired (bug 1409872).
   
 
   
    NSS 3.46 release notes
    
    notable changes in nss 3.46  certificate authority changes    the following ca certificates were removed:        bug 1574670 - remove e
xpired class 2 primary root certificate            sha-256 fingerprint: 0f993c8aef97baaf5687140ed59ad1821bb4afacf0aa9a58b5d57a338a3afbcb             bug 1574670 - remove e
xpired utn-userfirst-client root certificate           sha-256 fingerprint: 43f257412d440d627476974f877da8f1fc2444565a367ae60eddc27a412531ae             bug 1574670 - remove e
xpired deutsche telekom root ca 2 root certificate       ...
   
 
   
   
    Python binding for NSS
    
.protocol_version_enum        sslchannelinfo.major_protocol_version        sslchannelinfo.minor_protocol_version        sslchannelinfo.cipher_suite        sslchannelinfo.auth_key_bits        sslchannelinfo.kea_key_bits        sslchannelinfo.creation_time        sslchannelinfo.creation_time_utc        sslchannelinfo.last_access_time        sslchannelinfo.last_access_time_utc        sslchannelinfo.e
xpiration_time        sslchannelinfo.e
xpiration_time_utc        sslchannelinfo.compression_method        sslchannelinfo.compression_method_name        sslchannelinfo.session_id                   the following files were added:               doc/examples/cert_trust.py        doc/examples/ssl_version_range.py                   the following constants were added:               nss.certdb_terminal_record...
   
 
   
    NSS tools : crlutil
    
 the key and certificate management process generally begins with creating  keys in the key database, then generating and managing certificates in the  certificate database(see certutil tool) and continues with certificates  e
xpiration or revocation.
   
 
   
    sslcrt.html
    
                  returns   the function returns an enumerator of type seccerttimevalidity: typedef enum {    seccerttimevalid,    seccerttimee
xpired,    seccerttimenotvalidyet } seccerttimevalidity;   nss_cmpcertchainwcanames   determines whether any of the signers in the certificate chain for a specified certificate are on a specified list of ca names.
   
 
   
    NSS Tools certutil
    
 or  uid=jsmith, e=jsmith@netscape.com, cn=john smith, o=netscape communications corp., c=us : e
xpired certificate  or  uid=jsmith, e=jsmith@netscape.com, cn=john smith, o=netscape communications corp., c=us : certificate not approved for this operation                                ...
   
 
   
    NSS Tools crlutil
    
  the key and certificate management process generally begins with creating keys in the key database, then generating and managing certificates in the certificate database(see certutil tool) and continues with certificates e
xpiration or revocation.
   
 
   
    NSS tools : crlutil
    
    the key and certificate management process generally begins with creating    keys in the key database, then generating and managing certificates in the    certificate database(see certutil tool) and continues with certificates    e
xpiration or revocation.
   
 
   
    Index
    
       475     js_setrege
xpinput     jsapi reference, reference, référence(2), spidermonkey       js_setrege
xpinput sets the pending input string of the built-in regexp object to the specified input string.
   
 
   
  
   
    Bytecode Descriptions
    
format: jof_object    regexp literals  regexp  operands: (uint32_t rege
xpindex) stack: ⇒ regexp clone and push a new regexp object.
   
 
   
    Tracing JIT
    
 if the side exit condition indicates that the trace exited unsuccessfully -- due to encountering sufficient memory pressure to trigger a garbage collection, running out of native stack space, e
xpiring a timer or any similar abnormal condition -- the monitor returns to monitoring mode.
   
 
   
    JS_ClearRegExpStatics
    
 see also    mxr id search for js_clearregexpstatics  js_newregexpobject  js_newucregexpobject  js_setrege
xpinput  regexp                    ...
   
 
   
    JSAPI reference
    
getselfhostedfunction added in jsapi 31  js::newfunctionfromspec added in jsapi 45     js_newfunctionbyid added in spidermonkey 17 obsolete since jsapi 44  js_clonefunctionobject obsolete since jsapi 36   regexps    js_newregexpobject        jsreg_fold    jsreg_glob    jsreg_multiline    jsreg_sticky       js_newucregexpobject  js_newregexpobjectnostatics  js_newucregexpobjectnostatics  js_setrege
xpinput  js_clearregexpstatics  js_objectisregexp added in spidermonkey 17  js_getregexpflags added in spidermonkey 17  js_getregexpsource added in spidermonkey 17  js_executeregexp  js_executeregexpnostatics     js_clearregexproots obsolete since javascript 1.8.5   serialization    struct jsstructuredclonecallbacks  js_setstructuredclonecallbacks  js_readstructuredclone  js_writestructuredclone  js_...
   
 
   
    SpiderMonkey 1.8.5
    
regexp apis js_clearregexpstatics, js_newregexpobject, js_newregucexpobject, and js_setrege
xpinput now receive a pointer to the global object.
   
 
   
    SpiderMonkey 1.8.7
    
regexp apis js_clearregexpstatics, js_newregexpobject, js_newregucexpobject, and js_setrege
xpinput now receive a pointer to the global object.
   
 
   
    Secure Development Guidelines
    
  buffer bounds validations (bbv)  thou shalt check the array bounds of all strings (indeed, all arrays), for surely where thou typest "foo" someone someday shall type "supercalifragilistice
xpialidocious".
   
 
   
    XForms Accessibility
    
 for firefox, you may directly download the nighly "trunk" build of firefox and install the xforms extension which lives in '
xpi' directory of the build.
   
 
   
    Toolkit API
    
ences         structure of an installable bundle: describes the common structure of installable bundles, including extensions, themes, and xulrunner applications     extension packaging: specific information about how to package extensions     theme packaging: specific information about how to package themes     multiple-item extension packaging: specific information about multiple-item extension 
xpis     xul application packaging: specific information about how to package xulrunner applications     chrome registration     printing in xul apps     see also the following developer pages contain examples and discussions of particular topics:   xul  xul overlays  developing extensions  xulrunner  developing themes  dom  rdf  storage                                 ...
   
 
   
    Finishing the Component
    
(for weblock, all you need are the headers for nsicontentpolicy and the nsicontentpolicy.idl.) then, using the same steps you used to create the weblock.h, create a header from this idl file using the 
xpidl compiler.
   
 
   
    Preface
    
 define the functionality for the component; create an 
xpidl interface for that functionality; create the implementation code specific to the custom weblock component interface.
   
 
   
    Resources
    
mozilla.org/pub/mozilla/releases/mozilla1.4a/gecko-sdk-i686-pc-linux-gnu-1.4a.tar.gz    windows: http://ftp.mozilla.org/pub/mozilla/releases/mozilla1.4a/gecko-sdk-win32-1.4a.zip       other mozilla downloads   gecko resources    internal string guide  external string guide  the gecko networking library ("necko")  the netscape portable runtime environment  embedding mozilla  current module owners  
xpinstall  xul   xpcom resources    the xpcom project page  xulplanet's online xpcom reference  information on xpconnect and scriptable components  the smart pointer guide  
xpidl  
xpidl compiler reference   general development resources    the world wide web consortium  url specification at the w3  gnu make        « previous   copyright (c) 2003 by doug turner and ian oeschger.
   
 
   
    Using XPCOM Components
    
 xpconnect allows interface methods defined via 
xpidl to be called from javascript, as part of javascript objects that represent instances of components like the cookiemanager.
   
 
   
   
   
  
   
    Other Resources
    
          other resources  embedding mozilla  xpconnect - javascript-xpcom bridge  blackconnect - java-xpcom bridge (no longer supported)  
xpidl to java types - from blackconnect                                 ...
   
 
   
    JavaXPCOM
    
javaxpcom is very similar to xpconnect (javascript-xpcom bridge), and uses 
xpidl.
   
 
   
    XPConnect
    
     xpconnect and 
xpidl faq      a faq about using xpconnect and 
xpidl.
   
 
   
   
    nsACString_internal
    
org/en/nscstring" shape="rect" title="nscstring"> <area alt="" coords="521,101,689,149" href="http://developer.mozilla.org/en/nsdependentcsubstring" shape="rect" title="nsdependentcsubstring"> <area alt="" coords="172,197,289,245" href="http://developer.mozilla.org/en/nsfixedcstring" shape="rect" title="nsfixedcstring"> <area alt="" coords="315,197,437,245" href="http://developer.mozilla.org/en/ns
xpidlcstring" shape="rect" title="ns
xpidlcstring"> <area alt="" coords="461,197,611,245" href="http://developer.mozilla.org/en/nsdependentcstring" shape="rect" title="nsdependentcstring"> <area alt="" coords="635,197,787,245" href="http://developer.mozilla.org/en/nspromiseflatcstring" shape="rect" title="nspromiseflatcstring"> <area alt="" coords="173,293,285,341" href="http://developer.mozilla.org/e...
   
 
   
    nsAString_internal
    
zilla.org/en/nsstring" shape="rect" title="nsstring"> <area alt="" coords="475,101,635,149" href="http://developer.mozilla.org/en/nsdependentsubstring" shape="rect" title="nsdependentsubstring"> <area alt="" coords="151,197,257,245" href="http://developer.mozilla.org/en/nsfixedstring" shape="rect" title="nsfixedstring"> <area alt="" coords="284,197,396,245" href="http://developer.mozilla.org/en/ns
xpidlstring" shape="rect" title="ns
xpidlstring"> <area alt="" coords="420,197,559,245" href="http://developer.mozilla.org/en/nsdependentstring" shape="rect" title="nsdependentstring"> <area alt="" coords="583,197,727,245" href="http://developer.mozilla.org/en/nspromiseflatstring" shape="rect" title="nspromiseflatstring"> <area alt="" coords="152,293,253,341" href="http://developer.mozilla.org/en/nsau...
   
 
   
    XPCOM glue classes
    
e functions addref() and release(), which respectively modify a variable of type nsautorefcnt, which basically is a wrapper around a count of the number of references refering to the class.nsstringclass declarationnsstring externalclass declarationnsstringcontainer (external)class declarationnssupportsweakreferenceinherit from this c++ class to add canonical support for nsisupportsweakreference.ns
xpidlcstringclass declarationns
xpidlstringclass declarationpromiseflatcstring (external)class declarationpromiseflatstring (external)class declaration                                     ...
   
 
   
   
    imgIContainer
    
should be an attribute, but cannot be because of reference/pointer conflicts with native types in 
xpidl.
   
 
   
    nsIBrowserHistory
    
 remarks  visits are removed synchronously, but pages are e
xpired asynchronously, off the main thread.
   
 
   
    nsICacheEntryInfo
    
  e
xpirationtime pruint32 get the e
xpiration time of the cache entry (in seconds since the epoch).
   
 
   
   
    nsICommandLine
    
some flags may take parameters; for example: "-url <param>" or "-install-
xpi <param>".
   
 
   
    nsIDBFolderInfo
    
obsolete since gecko 1.8                 void setproperty(in string propertyname, in astring propertystr);                 void setuint32property(in string propertyname, in unsigned long propertyvalue);          attributes                attribute       type       description                 charactersetoverride       boolean                        e
xpiredmark       nsmsgkey                         expungedbytes       long                         flags       long                         folderdate       unsigned long                         foldername       string                         foldersize       unsigned long                         highwater       nsmsgkey                         imaphierarchyseparator       wchar                      ...
   
 
   
    nsIDownload
    
       see also    nsidownloadmanager  nsidownloadprogresslistener  nsi
xpinstallmanagerui                                 ...
   
 
   
  
   
    nsIHttpChannel
    
equivalent response headers include: "pragma: no-cache", "e
xpires: 0", and "e
xpires" with a date value in the past relative to the value of the "date" header.
   
 
   
   
   
    nsIPushMessage
    
please see method parameters in 
xpidl for more details on using out parameters in javascript.
   
 
   
    nsISHEntry
    
obsolete since gecko 1.8   e
xpirationstatus boolean indicates whether the page is already e
xpired in cache.
   
 
   
    nsITimer
    
 void initwithcallback(   in nsitimercallback acallback,   in unsigned long adelay,   in unsigned long atype );   parameters    acallback  an nsitimercallback interface to call when timer e
xpires.
   
 
   
    nsITimerCallback
    
void notify(   in nsitimer timer );  parameters      timer     nsitimer the timer which has e
xpired  see also   nsitimer  nsitimercallbackfunc                                 ...
   
 
   
   
    Weak reference
    
xpidl could write an implementation for you (if we modified it), or you could write one by hand as i discuss below.
   
 
   
    XPCOM ABI
    
an extension author may build (compile) the xpcom component for each and every supported machine and pack all the builds into a single 
xpi, each into its distinctive platform-specific subdirectory.
   
 
   
    wrappedJSObject
    
  this article focuses on the latter kind of wrappers, which hide any properties or methods on the component that are not part of the supported interfaces as declared in 
xpidl.
   
 
   
    XPCOM
    
interfaces in xpcom are defined in a dialect of idl called 
xpidl.
   
 
   
    Mozilla technologies
    
it has multiple language bindings, allowing xpcom components to be used and implemented in javascript, java, and python in addition to c++.
xpidl
xpidl is an interface description language used to specify xpcom interface classes.xray visiongecko runs javascript from a variety of different sources and at a variety of different privilege levels.xslt 2.0although xslt 2.0 is not natively supported in firefox, it is possible via saxon-b (java) or, more recently, saxon-ce (javascript) to perform xslt 2.0.xtfthe extensible tag framework (xtf) al...
   
 
   
    Add Option to Context Menu
    
"/>       </menupopup>   </overlay>  for thunderbird 3    <?xml version="1.0"?>   <overlay id="sample"          xmlns="http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul">       <popup id="mailcontext">        <menuitem         id="my_option"         label="my option concise and cool label"         oncommand="alert('hi')"/>     </popup> </overlay>    for thunderbird 2 and 3 in the same 
xpi  if our extension needs to support thunderbird 2 and 3 we need to make custom overlays for each version.
   
 
   
    WebIDL bindings
    
this can mean xpcom interfaces (whether declared in 
xpidl or not) or it can mean some type that there's a castable native unwrapping function for.
   
 
   
  
   
    Zombie compartments
    
   js-compartment([system principal], 0x7f10f1250000)  compartment(atoms)  js-compartment(about:home)  js-compartment(about:blank)  compartment([system principal], resource://gre/modules/addons/
xpiprovider.jsm)   when looking at user compartments there are a couple of things to be aware of.
   
 
   
    Plug-in Basics - Plugins
    
 the pluginurl attribute is the url of the plug-in or of the 
xpi in which the plug-in is stored (see installing plug-ins for more information on the 
xpi file format).
   
 
   
    Gecko Plugin API Reference - Plugins
    
   unix    mac os x       drawing a plug-in instance  handling memory  sending and receiving streams  working with urls  getting version and ui information  displaying messages on the status line  making plug-ins scriptable  building plug-ins       building, platforms, and compilers    building carbonized plug-ins for mac os x    type libraries       installing plug-ins       native installers    
xpi plug-ins installations       plug-in installation and the windows registry   initialization and destruction    initialization  instance creation  instance destruction  shutdown  initialize and shutdown example   drawing and event handling    the npwindow structure  drawing plug-ins       printing the plug-in    setting the window    getting information       windowed plug-ins       mac os    wind...
   
 
   
    Browser Console - Firefox Developer Tools
    
here's an example add-on that just logs an error when the user clicks a widget:  widget = require("sdk/widget").widget({   id: "an-error-happened",   label: "error!",   width: 40,   content: "error!",   onclick: logerror });  function logerror() {   console.error("something went wrong!"); }  if you build this as an 
xpi file, then open the browser console, then open the 
xpi file in firefox and install it, you'll see a widget labeled "error!" in the add-on bar:  click the icon.
   
 
   
   
   
   
    about:debugging (before Firefox 68) - Firefox Developer Tools
    
   the big advantages of this method, compared with installing an add-on from an 
xpi, are:   	you don't have to rebuild an 
xpi and reinstall when you change the add-on's code 	you can load an add-on without signing it and without needing to disable signing.
   
 
   
    about:debugging - Firefox Developer Tools
    
 the major advantages of this method, compared with installing an add-on from an 
xpi, are:    you don't have to rebuild an 
xpi and reinstall when you change the add-on's code;  you can load an add-on without signing it and without needing to disable signing.
   
 
   
    BasicCardRequest - Web APIs
    
this has to conform to the structure defined by the basiccardresponse dictionary, and may look something like this:  {   "cardnumber' : '9999999999999999",   "cardholdername' : 'mr dick straw",   "cardsecuritycode" : "999",   "e
xpirymonth" : "07",   "e
xpiryyear" : "2021",   "billingaddress" : {     "country" : "gb",     // etc.
   
 
   
   
   
   
   
    Cache - Web APIs
    
items in a cache do not get updated unless explicitly requested; they don’t e
xpire unless deleted.
   
 
   
  
   
    Push API - Web APIs
    
when a push service sets an e
xpiration time.)   examples  mozilla's serviceworker cookbook contains many useful push examples.
   
 
   
   
   
   
   
    WebGL constants - Web APIs
    
onstant name    value    description              object_type    0x9112               sync_condition    0x9113               sync_status    0x9114               sync_flags    0x9115               sync_fence    0x9116               sync_gpu_commands_complete    0x9117               unsignaled    0x9118               signaled    0x9119               already_signaled    0x911a               timeout_e
xpired    0x911b               condition_satisfied    0x911c               wait_failed    0x911d               sync_flush_commands_bit    0x00000001             miscellaneous constants           constant name    value    description              color    0x1800               depth    0x1801               stencil    0x1802               min    0x8007               max    0x8008               depth_com...
   
 
   
    WebGL best practices - Web APIs
    
e approach in webgl 2 is analogous to the approach in opengl: https://jdashg.github.io/misc/async-gpu-downloads.html  function clientwaitasync(gl, sync, flags, interval_ms) {   return new promise((resolve, reject) => {     function test() {       const res = gl.clientwaitsync(sync, flags, 0);       if (res == gl.wait_failed) {         reject();         return;       }       if (res == gl.timeout_e
xpired) {         settimeout(test, interval_ms);         return;       }       resolve();     }     test());   }); }  async function getbuffersubdataasync(     gl, target, buffer, srcbyteoffset, dstbuffer,     /* optional */ dstoffset, /* optional */ length) {   const sync = gl.fencesync(gl.sync_gpu_commands_complete, 0);   gl.flush();    await clientwaitasync(gl, sync, 0, 10);   gl.deletesync(sync);...
   
 
   
    Web Storage API - Web APIs
    
      stores data with no e
xpiration date, and gets cleared only through javascript, or clearing the browser cache / locally stored data.
   
 
   
   
    Window.localStorage - Web APIs
    
localstorage is similar to sessionstorage, except that while data stored in localstorage has no e
xpiration time, data stored in sessionstorage gets cleared when the page session ends — that is, when the page is closed.
   
 
   
    window.requestIdleCallback() - Web APIs
    
the callback function is passed an idledeadline object describing the amount of time available and whether or not the callback has been run because the timeout period e
xpired.
   
 
   
    Window.sessionStorage - Web APIs
    
sessionstorage is similar to localstorage; the difference is that while data in localstorage doesn't e
xpire, data in sessionstorage is cleared when the page session ends.
   
 
   
   
   
   
  
   
    Using the alertdialog role - Accessibility
    
 <div role="alertdialog" aria-labelledby="dialog1title" aria-describedby="dialog1desc">   <div role="document" tabindex="0">     <h2 id="dialog1title">your login session is about to e
xpire</h2>     <p id="dialog1desc">to extend your session, click the ok button</p>     <button>ok</button>   </div> </div>  working examples:  tbd  notes   aria attributes used    alertdialog  aria-labelledby  aria-describedby   related aria techniques      using the dialog role   using the alert role   compatibility  tbd: add support information for common ua and at product combinations  additional ...
   
 
   
    Operable - Accessibility
    
             2.2.5 re-authenticating (aaa)    if an authentication session e
xpires during usage of a web app, the user can re-authenticate and continue their usage without losing any data.
   
 
   
    Rich-Text Editing in Mozilla - Developer guides
    
tq4fdbk+imyo1oxvgf03wafjqvbckvdffryetxqiffygazths0zwagd7fg5tnnyntp8/fzvgwjofmgg7gox0sakkgqgdmgkbi0njgmeimpgdk5+wacewed0ywblhguz4hw5oduekrblt7dtgdegxacsiznx8zpmwh7k4rkpjcuhdxcul6mdsmmbxdlwch2+xozsgbnzsncee4euyv4pwcpswypw0uhdybkswu1nyjendreqtkjwn2+zvttc1vmstb/mvev/weyslasslimcohobjxw+n3ap/sjefnl5gepzmpu4kg7opr1+tofpyuu3becwykcwqcdfmwfkauo90fhkdinbcamvqnymgqueagqwcohbdc1rjv9pild8ibvkz6qyviibqgtjpx4k0
xpigezorn1da0cij4vfr0ta3wvbxh/rjdcufv6r2zpgph/e4pxsbcpeatqprjniso203/5s/za171mv8+w1loaaaaaelftksuqmcc"> <img class="intlink" title="undo" onclick="formatdoc('undo');" src="data:image/gif;base64,r0lgodlhfgawaomkadljwlie33morpgjuykl8aezxqpd+7/i19dv3nha7p///////////////////////yh5baekaa8alaaaaaawabyaaarr8mljq7046807tkayejjbnes4eeujvigapwyac0csocq7sdlwjkakca6tomywiargqf3mrqviejkksvlibsfewhdrih4fh/dzmice3...
   
 
   
    Making content editable - Developer guides
    
tq4fdbk+imyo1oxvgf03wafjqvbckvdffryetxqiffygazths0zwagd7fg5tnnyntp8/fzvgwjofmgg7gox0sakkgqgdmgkbi0njgmeimpgdk5+wacewed0ywblhguz4hw5oduekrblt7dtgdegxacsiznx8zpmwh7k4rkpjcuhdxcul6mdsmmbxdlwch2+xozsgbnzsncee4euyv4pwcpswypw0uhdybkswu1nyjendreqtkjwn2+zvttc1vmstb/mvev/weyslasslimcohobjxw+n3ap/sjefnl5gepzmpu4kg7opr1+tofpyuu3becwykcwqcdfmwfkauo90fhkdinbcamvqnymgqueagqwcohbdc1rjv9pild8ibvkz6qyviibqgtjpx4k0
xpigezorn1da0cij4vfr0ta3wvbxh/rjdcufv6r2zpgph/e4pxsbcpeatqprjniso203/5s/za171mv8+w1loaaaaaelftksuqmcc"> <img class="intlink" title="undo" onclick="formatdoc('undo');" src="data:image/gif;base64,r0lgodlhfgawaomkadljwlie33morpgjuykl8aezxqpd+7/i19dv3nha7p///////////////////////yh5baekaa8alaaaaaawabyaaarr8mljq7046807tkayejjbnes4eeujvigapwyac0csocq7sdlwjkakca6tomywiargqf3mrqviejkksvlibsfewhdrih4fh/dzmice3...
   
 
   
   
   
    Cross-Origin Resource Sharing (CORS) - HTTP
    
ge: en-us,en;q=0.5 accept-encoding: gzip,deflate connection: keep-alive referer: http://foo.example/examples/credential.html origin: http://foo.example cookie: pageaccess=2   http/1.1 200 ok date: mon, 01 dec 2008 01:34:52 gmt server: apache/2 access-control-allow-origin: https://foo.example access-control-allow-credentials: true cache-control: no-cache pragma: no-cache set-cookie: pageaccess=3; e
xpires=wed, 31-dec-2008 01:34:53 gmt vary: accept-encoding, origin content-encoding: gzip content-length: 106 keep-alive: timeout=2, max=100 connection: keep-alive content-type: text/plain   [text/plain payload]   although line 10 contains the cookie destined for the content on http://bar.other, if bar.other did not respond with an access-control-allow-credentials: true (line 17) the response would b...
   
 
   
    Access-Control-Expose-Headers - HTTP
    
 by default, only the 7 cors-safelisted response headers are exposed:    cache-control  content-language  content-length  content-type  e
xpires  last-modified  pragma   if you want clients to be able to access other headers, you have to list them using the access-control-expose-headers header.
   
 
   
    Alt-Svc - HTTP
    
if the cached entry e
xpires, the client can no longer use this alternative service for new connections.
   
 
   
    Content-Encoding - HTTP
    
like the compress program, which has disappeared from most unix distributions, this content-encoding is not used by many browsers today, partly because of a patent issue (it e
xpired in 2003).
   
 
   
    Expect-CT - HTTP
    
certificates before march 2018 were allowed to have a lifetime of 39 months, those will all be e
xpired in june 2021.
   
 
   
    If-None-Match - HTTP
    
note that the server generating a 304 response must generate any of the following header fields that would have been sent in a 200 (ok) response to the same request: cache-control, content-location, date, etag, e
xpires, and vary.
   
 
   
    Index - HTTP
    
       62     e
xpires     caching, http, response, header       the e
xpires header contains the date/time after which the response is considered stale.
   
 
   
    Transfer-Encoding - HTTP
    
 like the compress program, which has disappeared from most unix distributions, this content-encoding is used by almost no browsers today, partly because of a patent issue (which e
xpired in 2003).
   
 
   
   
  
   
    HTTP Index - HTTP
    
       121     e
xpires     caching, http, response, header       the e
xpires header contains the date/time after which the response is considered stale.
   
 
   
    HTTP Public Key Pinning (HPKP) - HTTP
    
 enabling hpkp  to enable this feature for your site, you need to return the public-key-pins http header when your site is accessed over https:  public-key-pins: pin-sha256="base64=="; max-age=e
xpiretime [; includesubdomains][; report-uri="reporturi"]    pin-sha256  the quoted string is the base64 encoded subject public key information (spki) fingerprint.
   
 
   
    HTTP resources and specifications - HTTP
    
tus code to report legal obstacles    on the standard track          rfc 2397    the "data" url scheme    proposed standard          rfc 3986    uniform resource identifier (uri): generic syntax    internet standard          rfc 5988    web linking     defines the link header    proposed standard          experimental spec    hypertext transfer protocol (http) keep-alive header    informational (e
xpired)          draft spec    http client hints    ietf draft          rfc 7578    returning values from forms: multipart/form-data    proposed standard          rfc 6266    use of the content-disposition header field in the hypertext transfer protocol (http)    proposed standard          rfc 2183    communicating presentation information in internet messages: the content-disposition header field   ...
   
 
   
    A typical HTTP session - HTTP
    
(contains a site-customized page helping the user to find the missing resource)   notification that the requested resource doesn't exist:  http/1.1 404 not found content-type: text/html; charset=utf-8 content-length: 38217 connection: keep-alive cache-control: no-cache, no-store, must-revalidate, max-age=0 content-language: en-us date: thu, 06 dec 2018 17:35:13 gmt e
xpires: thu, 06 dec 2018 17:35:13 gmt server: meinheld/0.6.1 strict-transport-security: max-age=63072000 x-content-type-options: nosniff x-frame-options: deny x-xss-protection: 1; mode=block vary: accept-encoding,cookie x-cache: error from cloudfront   <!doctype html...
   
 
   
    304 Not Modified - HTTP
    
 the equivalent 200 ok response would have included the headers cache-control, content-location, date, etag, e
xpires, and vary.
   
 
   
    HTTP
    
the cookie can also be set to e
xpire on a certain date, or restricted to a specific domain and path.
   
 
   
    Concurrency model and the event loop - JavaScript
    
   here is an example that demonstrates this concept (settimeout does not run immediately after its timer e
xpires):  const s = new date().getseconds();  settimeout(function() {   // prints out "2", meaning that the callback is not called immediately after 500 milliseconds.