author Ting-Yuan Huang <thuang@mozilla.com>
Wed, 30 Oct 2013 15:21:52 -0400
changeset 152813 08826e162b8a57ae2776750028fccdc95cc916b9
parent 150263 d8109ff79880146b99fa165468154560ae2e1483
child 170971 8693eace6c33818c0a31f5db65e846ecdf64bae5
permissions -rw-r--r--
Bug 920992 - Specify alignments explicitly in assembly codes. r=derf

/* This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this file,
 * You can obtain one at http://mozilla.org/MPL/2.0/. */

this.EXPORTED_SYMBOLS = ["WebappRT"];

const Cc = Components.classes;
const Ci = Components.interfaces;
const Cu = Components.utils;


XPCOMUtils.defineLazyGetter(this, "FileUtils", function() {
  return FileUtils;

this.WebappRT = {
  _config: null,

  get config() {
    if (this._config)
      return this._config;

    let webappFile = FileUtils.getFile("AppRegD", ["webapp.json"]);

    let inputStream = Cc["@mozilla.org/network/file-input-stream;1"].
    inputStream.init(webappFile, -1, 0, Ci.nsIFileInputStream.CLOSE_ON_EOF);
    let json = Cc["@mozilla.org/dom/json;1"].createInstance(Ci.nsIJSON);
    let config = json.decodeFromStream(inputStream, webappFile.fileSize);

    return this._config = config;

  // This exists to support test mode, which installs webapps after startup.
  // Ideally we wouldn't have to have a setter, as tests can just delete
  // the getter and then set the property.  But the object to which they set it
  // will have a reference to its global object, so our reference to it
  // will leak that object (per bug 780674).  The setter enables us to clone
  // the new value so we don't actually retain a reference to it.
  set config(newVal) {
    this._config = JSON.parse(JSON.stringify(newVal));

  get launchURI() {
    let manifest = this.localeManifest;
    return manifest.fullLaunchPath();

  get localeManifest() {
    return new ManifestHelper(this.config.app.manifest,