Software: Apache. PHP/5.5.15 uname -a: Windows NT SVR-DMZ 6.1 build 7600 (Windows Server 2008 R2 Enterprise Edition) i586 SYSTEM Safe-mode: OFF (not secure) C:\Intranet\C\Archivos de programa\Mozilla Firefox\components\ drwxrwxrwx |
Viewing file: nsBrowserGlue.js (31.56 KB) -rw-rw-rw- Select action/file-type: (+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) | //@line 39 "e:\fx19rel\WINNT_5.2_Depend\mozilla\browser\components\nsBrowserGlue.js" const Ci = Components.interfaces; const Cc = Components.classes; const Cr = Components.results; const Cu = Components.utils; Cu.import("resource://gre/modules/XPCOMUtils.jsm"); Cu.import("resource:///modules/distribution.js"); const PREF_EM_NEW_ADDONS_LIST = "extensions.newAddons"; // Check to see if bookmarks need backing up once per // day on 1 hour idle. const BOOKMARKS_ARCHIVE_IDLE_TIME = 60 * 60; // Backup bookmarks once every 24 hours. const BOOKMARKS_ARCHIVE_INTERVAL = 86400 * 1000; // Factory object const BrowserGlueServiceFactory = { _instance: null, createInstance: function (outer, iid) { if (outer != null) throw Components.results.NS_ERROR_NO_AGGREGATION; return this._instance == null ? this._instance = new BrowserGlue() : this._instance; } }; // Constructor function BrowserGlue() { this._init(); } BrowserGlue.prototype = { __prefs: null, get _prefs() { if (!this.__prefs) this.__prefs = Cc["@mozilla.org/preferences-service;1"]. getService(Ci.nsIPrefBranch); return this.__prefs; }, _saveSession: false, _setPrefToSaveSession: function() { var prefBranch = Cc["@mozilla.org/preferences-service;1"]. getService(Ci.nsIPrefBranch); prefBranch.setBoolPref("browser.sessionstore.resume_session_once", true); }, // nsIObserver implementation observe: function(subject, topic, data) { switch(topic) { case "xpcom-shutdown": this._dispose(); break; case "quit-application": this._onProfileShutdown(); break; case "prefservice:after-app-defaults": this._onAppDefaults(); break; case "final-ui-startup": this._onProfileStartup(); break; case "sessionstore-windows-restored": this._onBrowserStartup(); break; case "browser:purge-session-history": // reset the console service's error buffer const cs = Cc["@mozilla.org/consoleservice;1"]. getService(Ci.nsIConsoleService); cs.logStringMessage(null); // clear the console (in case it's open) cs.reset(); break; case "quit-application-requested": this._onQuitRequest(subject, data); break; case "quit-application-granted": if (this._saveSession) { this._setPrefToSaveSession(); } break; case "session-save": this._setPrefToSaveSession(); subject.QueryInterface(Ci.nsISupportsPRBool); subject.data = true; break; case "idle": if (this.idleService.idleTime > BOOKMARKS_ARCHIVE_IDLE_TIME * 1000) { // Back up bookmarks. this._archiveBookmarks(); } break; } }, // initialization (called on application startup) _init: function() { // observer registration const osvr = Cc['@mozilla.org/observer-service;1']. getService(Ci.nsIObserverService); osvr.addObserver(this, "quit-application", false); osvr.addObserver(this, "xpcom-shutdown", false); osvr.addObserver(this, "prefservice:after-app-defaults", false); osvr.addObserver(this, "final-ui-startup", false); osvr.addObserver(this, "sessionstore-windows-restored", false); osvr.addObserver(this, "browser:purge-session-history", false); osvr.addObserver(this, "quit-application-requested", false); osvr.addObserver(this, "quit-application-granted", false); osvr.addObserver(this, "session-save", false); }, // cleanup (called on application shutdown) _dispose: function() { // observer removal const osvr = Cc['@mozilla.org/observer-service;1']. getService(Ci.nsIObserverService); osvr.removeObserver(this, "quit-application"); osvr.removeObserver(this, "xpcom-shutdown"); osvr.removeObserver(this, "prefservice:after-app-defaults"); osvr.removeObserver(this, "final-ui-startup"); osvr.removeObserver(this, "sessionstore-windows-restored"); osvr.removeObserver(this, "browser:purge-session-history"); osvr.removeObserver(this, "quit-application-requested"); osvr.removeObserver(this, "quit-application-granted"); osvr.removeObserver(this, "session-save"); }, _onAppDefaults: function() { // apply distribution customizations (prefs) // other customizations are applied in _onProfileStartup() var distro = new DistributionCustomizer(); distro.applyPrefDefaults(); }, // profile startup handler (contains profile initialization routines) _onProfileStartup: function() { this.Sanitizer.onStartup(); // check if we're in safe mode var app = Cc["@mozilla.org/xre/app-info;1"].getService(Ci.nsIXULAppInfo). QueryInterface(Ci.nsIXULRuntime); if (app.inSafeMode) { var ww = Cc["@mozilla.org/embedcomp/window-watcher;1"]. getService(Ci.nsIWindowWatcher); ww.openWindow(null, "chrome://browser/content/safeMode.xul", "_blank", "chrome,centerscreen,modal,resizable=no", null); } // initialize Places this._initPlaces(); // apply distribution customizations // prefs are applied in _onAppDefaults() var distro = new DistributionCustomizer(); distro.applyCustomizations(); // handle any UI migration this._migrateUI(); const osvr = Cc['@mozilla.org/observer-service;1']. getService(Ci.nsIObserverService); osvr.notifyObservers(null, "browser-ui-startup-complete", ""); }, // profile shutdown handler (contains profile cleanup routines) _onProfileShutdown: function() { this._shutdownPlaces(); this.idleService.removeIdleObserver(this, BOOKMARKS_ARCHIVE_IDLE_TIME); this.Sanitizer.onShutdown(); }, // Browser startup complete. All initial windows have opened. _onBrowserStartup: function() { // Show about:rights notification, if needed. if (this._shouldShowRights()) this._showRightsNotification(); var prefBranch = Cc["@mozilla.org/preferences-service;1"]. getService(Ci.nsIPrefBranch); // If new add-ons were installed during startup open the add-ons manager. if (prefBranch.prefHasUserValue(PREF_EM_NEW_ADDONS_LIST)) { var args = Cc["@mozilla.org/supports-array;1"]. createInstance(Ci.nsISupportsArray); var str = Cc["@mozilla.org/supports-string;1"]. createInstance(Ci.nsISupportsString); str.data = ""; args.AppendElement(str); var str = Cc["@mozilla.org/supports-string;1"]. createInstance(Ci.nsISupportsString); str.data = prefBranch.getCharPref(PREF_EM_NEW_ADDONS_LIST); args.AppendElement(str); const EMURL = "chrome://mozapps/content/extensions/extensions.xul"; const EMFEATURES = "chrome,menubar,extra-chrome,toolbar,dialog=no,resizable"; var ww = Cc["@mozilla.org/embedcomp/window-watcher;1"]. getService(Ci.nsIWindowWatcher); ww.openWindow(null, EMURL, "_blank", EMFEATURES, args); prefBranch.clearUserPref(PREF_EM_NEW_ADDONS_LIST); } }, _onQuitRequest: function(aCancelQuit, aQuitType) { // If user has already dismissed quit request, then do nothing if ((aCancelQuit instanceof Ci.nsISupportsPRBool) && aCancelQuit.data) return; var wm = Cc["@mozilla.org/appshell/window-mediator;1"]. getService(Ci.nsIWindowMediator); var windowcount = 0; var pagecount = 0; var browserEnum = wm.getEnumerator("navigator:browser"); while (browserEnum.hasMoreElements()) { windowcount++; var browser = browserEnum.getNext(); var tabbrowser = browser.document.getElementById("content"); if (tabbrowser) pagecount += tabbrowser.browsers.length; } this._saveSession = false; if (pagecount < 2) return; if (aQuitType != "restart") aQuitType = "quit"; var prefBranch = Cc["@mozilla.org/preferences-service;1"]. getService(Ci.nsIPrefBranch); var showPrompt = true; try { // browser.warnOnQuit is a hidden global boolean to override all quit prompts // browser.warnOnRestart specifically covers app-initiated restarts where we restart the app // browser.tabs.warnOnClose is the global "warn when closing multiple tabs" pref var sessionWillBeSaved = prefBranch.getIntPref("browser.startup.page") == 3 || prefBranch.getBoolPref("browser.sessionstore.resume_session_once"); if (sessionWillBeSaved || !prefBranch.getBoolPref("browser.warnOnQuit")) showPrompt = false; else if (aQuitType == "restart") showPrompt = prefBranch.getBoolPref("browser.warnOnRestart"); else showPrompt = prefBranch.getBoolPref("browser.tabs.warnOnClose"); } catch (ex) {} if (!showPrompt) return false; var buttonChoice = 0; var bundleService = Cc["@mozilla.org/intl/stringbundle;1"]. getService(Ci.nsIStringBundleService); var quitBundle = bundleService.createBundle("chrome://browser/locale/quitDialog.properties"); var brandBundle = bundleService.createBundle("chrome://branding/locale/brand.properties"); var appName = brandBundle.GetStringFromName("brandShortName"); var quitDialogTitle = quitBundle.formatStringFromName(aQuitType + "DialogTitle", [appName], 1); var message; if (aQuitType == "restart") message = quitBundle.formatStringFromName("messageRestart", [appName], 1); else if (windowcount == 1) message = quitBundle.formatStringFromName("messageNoWindows", [appName], 1); else message = quitBundle.formatStringFromName("message", [appName], 1); var promptService = Cc["@mozilla.org/embedcomp/prompt-service;1"]. getService(Ci.nsIPromptService); var flags = promptService.BUTTON_TITLE_IS_STRING * promptService.BUTTON_POS_0 + promptService.BUTTON_TITLE_IS_STRING * promptService.BUTTON_POS_1 + promptService.BUTTON_POS_0_DEFAULT; var neverAsk = {value:false}; var button0Title, button2Title; var button1Title = quitBundle.GetStringFromName("cancelTitle"); var neverAskText = quitBundle.GetStringFromName("neverAsk"); if (aQuitType == "restart") button0Title = quitBundle.GetStringFromName("restartTitle"); else { flags += promptService.BUTTON_TITLE_IS_STRING * promptService.BUTTON_POS_2; button0Title = quitBundle.GetStringFromName("saveTitle"); button2Title = quitBundle.GetStringFromName("quitTitle"); } buttonChoice = promptService.confirmEx(null, quitDialogTitle, message, flags, button0Title, button1Title, button2Title, neverAskText, neverAsk); switch (buttonChoice) { case 2: // Quit if (neverAsk.value) prefBranch.setBoolPref("browser.tabs.warnOnClose", false); break; case 1: // Cancel aCancelQuit.QueryInterface(Ci.nsISupportsPRBool); aCancelQuit.data = true; break; case 0: // Save & Quit this._saveSession = true; if (neverAsk.value) { if (aQuitType == "restart") prefBranch.setBoolPref("browser.warnOnRestart", false); else { // always save state when shutting down prefBranch.setIntPref("browser.startup.page", 3); } } break; } }, /* * _shouldShowRights - Determines if the user should be shown the * about:rights notification. The notification should *not* be shown if * we've already shown the current version, or if the override pref says to * never show it. The notification *should* be shown if it's never been seen * before, if a newer version is available, or if the override pref says to * always show it. */ _shouldShowRights : function () { // Look for an unconditional override pref. If set, do what it says. // (true --> never show, false --> always show) try { return !this._prefs.getBoolPref("browser.rights.override"); } catch (e) { } // Ditto, for the legacy EULA pref. try { return !this._prefs.getBoolPref("browser.EULA.override"); } catch (e) { } //@line 391 "e:\fx19rel\WINNT_5.2_Depend\mozilla\browser\components\nsBrowserGlue.js" // Look to see if the user has seen the current version or not. var currentVersion = this._prefs.getIntPref("browser.rights.version"); try { return !this._prefs.getBoolPref("browser.rights." + currentVersion + ".shown"); } catch (e) { } // Legacy: If the user accepted a EULA, we won't annoy them with the // equivalent about:rights page until the version changes. try { return !this._prefs.getBoolPref("browser.EULA." + currentVersion + ".accepted"); } catch (e) { } // We haven't shown the notification before, so do so now. return true; }, _showRightsNotification : function () { // Stick the notification onto the selected tab of the active browser window. var win = this._getMostRecentBrowserWindow(); var browser = win.gBrowser; // for closure in notification bar callback var notifyBox = browser.getNotificationBox(); var bundleService = Cc["@mozilla.org/intl/stringbundle;1"]. getService(Ci.nsIStringBundleService); var brandBundle = bundleService.createBundle("chrome://branding/locale/brand.properties"); var rightsBundle = bundleService.createBundle("chrome://browser/locale/aboutRights.properties"); var buttonLabel = rightsBundle.GetStringFromName("buttonLabel"); var buttonAccessKey = rightsBundle.GetStringFromName("buttonAccessKey"); var productName = brandBundle.GetStringFromName("brandFullName"); var notifyText = rightsBundle.formatStringFromName("notifyText", [productName], 1); var buttons = [ { label: buttonLabel, accessKey: buttonAccessKey, popup: null, callback: function(aNotificationBar, aButton) { browser.selectedTab = browser.addTab("about:rights"); } } ]; // Set pref to indicate we've shown the notification. var currentVersion = this._prefs.getIntPref("browser.rights.version"); this._prefs.setBoolPref("browser.rights." + currentVersion + ".shown", true); var box = notifyBox.appendNotification(notifyText, "about-rights", null, notifyBox.PRIORITY_INFO_LOW, buttons); box.persistence = 3; // // arbitrary number, just so bar sticks around for a bit }, // returns the (cached) Sanitizer constructor get Sanitizer() { if(typeof(Sanitizer) != "function") { // we should dynamically load the script Cc["@mozilla.org/moz/jssubscript-loader;1"]. getService(Ci.mozIJSSubScriptLoader). loadSubScript("chrome://browser/content/sanitize.js", null); } return Sanitizer; }, _idleService: null, get idleService() { if (!this._idleService) this._idleService = Cc["@mozilla.org/widget/idleservice;1"]. getService(Ci.nsIIdleService); return this._idleService; }, /** * Initialize Places * - imports the bookmarks html file if bookmarks datastore is empty * * These prefs are set by the backend services upon creation (or recreation) * of the Places db: * - browser.places.importBookmarksHTML * Set to false by the history service to indicate we need to re-import. * - browser.places.smartBookmarksVersion * Set during HTML import to indicate that Smart Bookmarks were created. * Set to -1 to disable Smart Bookmarks creation. * Set to 0 to restore current Smart Bookmarks. * * These prefs are set up by the frontend: * - browser.bookmarks.restore_default_bookmarks * Set to true by safe-mode dialog to indicate we must restore default * bookmarks. */ _initPlaces: function bg__initPlaces() { // we need to instantiate the history service before checking // the browser.places.importBookmarksHTML pref, as // nsNavHistory::ForceMigrateBookmarksDB() will set that pref // if we need to force a migration (due to a schema change) var histsvc = Cc["@mozilla.org/browser/nav-history-service;1"]. getService(Ci.nsINavHistoryService); var prefBranch = Cc["@mozilla.org/preferences-service;1"]. getService(Ci.nsIPrefBranch); var importBookmarks = false; var restoreDefaultBookmarks = false; try { restoreDefaultBookmarks = prefBranch.getBoolPref("browser.bookmarks.restore_default_bookmarks"); } catch(ex) {} if (restoreDefaultBookmarks) { // Ensure that we already have a bookmarks backup for today this._archiveBookmarks(); // we will restore bookmarks from html importBookmarks = true; } else { try { importBookmarks = prefBranch.getBoolPref("browser.places.importBookmarksHTML"); } catch(ex) {} } if (!importBookmarks) { // Call it here for Fx3 profiles created before the Places folder // has been added, otherwise it's called during import. this.ensurePlacesDefaultQueriesInitialized(); } else { // get latest backup Cu.import("resource://gre/modules/utils.js"); var bookmarksFile = PlacesUtils.getMostRecentBackup(); if (!restoreDefaultBookmarks && bookmarksFile && bookmarksFile.leafName.match("\.json$")) { // restore a JSON backup PlacesUtils.restoreBookmarksFromJSONFile(bookmarksFile); } else { // if there's no JSON backup or we are restoring default bookmarks // ensurePlacesDefaultQueriesInitialized() is called by import. prefBranch.setIntPref("browser.places.smartBookmarksVersion", 0); var dirService = Cc["@mozilla.org/file/directory_service;1"]. getService(Ci.nsIProperties); var bookmarksFile = dirService.get("BMarks", Ci.nsILocalFile); if (restoreDefaultBookmarks || !bookmarksFile.exists()) { // get bookmarks.html file from default profile folder bookmarksFile = dirService.get("profDef", Ci.nsILocalFile); bookmarksFile.append("bookmarks.html"); } // import the file try { var importer = Cc["@mozilla.org/browser/places/import-export-service;1"]. getService(Ci.nsIPlacesImportExportService); importer.importHTMLFromFile(bookmarksFile, true /* overwrite existing */); } catch (err) { // Report the error, but ignore it. Cu.reportError(err); } prefBranch.setBoolPref("browser.places.importBookmarksHTML", false); if (restoreDefaultBookmarks) prefBranch.setBoolPref("browser.bookmarks.restore_default_bookmarks", false); } } // Initialize bookmark archiving on idle. // Once a day, either on idle or shutdown, bookmarks are backed up. this.idleService.addIdleObserver(this, BOOKMARKS_ARCHIVE_IDLE_TIME); }, /** * Places shut-down tasks * - back up and archive bookmarks * - export bookmarks as HTML, if so configured * * Note: quit-application-granted notification is received twice * so replace this method with a no-op when first called. */ _shutdownPlaces: function bg__shutdownPlaces() { // Backup and archive Places bookmarks. this._archiveBookmarks(); // Backup bookmarks to bookmarks.html to support apps that depend // on the legacy format. var prefs = Cc["@mozilla.org/preferences-service;1"]. getService(Ci.nsIPrefBranch); var autoExportHTML = false; try { autoExportHTML = prefs.getBoolPref("browser.bookmarks.autoExportHTML"); } catch(ex) { Components.utils.reportError(ex); } if (autoExportHTML) { Cc["@mozilla.org/browser/places/import-export-service;1"]. getService(Ci.nsIPlacesImportExportService). backupBookmarksFile(); } }, /** * Back up and archive bookmarks */ _archiveBookmarks: function nsBrowserGlue__archiveBookmarks() { Cu.import("resource://gre/modules/utils.js"); var lastBackup = PlacesUtils.getMostRecentBackup(); // Backup bookmarks if there aren't any backups or // they haven't been backed up in the last 24 hrs. if (!lastBackup || Date.now() - lastBackup.lastModifiedTime > BOOKMARKS_ARCHIVE_INTERVAL) { var maxBackups = 5; var prefs = Cc["@mozilla.org/preferences-service;1"]. getService(Ci.nsIPrefBranch); try { maxBackups = prefs.getIntPref("browser.bookmarks.max_backups"); } catch(ex) {} PlacesUtils.archiveBookmarksFile(maxBackups, false /* don't force */); } }, _migrateUI: function bg__migrateUI() { var prefBranch = Cc["@mozilla.org/preferences-service;1"].getService(Ci.nsIPrefBranch); var migration = 0; try { migration = prefBranch.getIntPref("browser.migration.version"); } catch(ex) {} if (migration == 0) { // this code should always migrate pre-FF3 profiles to the current UI state // grab the localstore.rdf and make changes needed for new UI this._rdf = Cc["@mozilla.org/rdf/rdf-service;1"].getService(Ci.nsIRDFService); this._dataSource = this._rdf.GetDataSource("rdf:local-store"); this._dirty = false; let currentsetResource = this._rdf.GetResource("currentset"); let toolbars = ["nav-bar", "toolbar-menubar", "PersonalToolbar"]; for (let i = 0; i < toolbars.length; i++) { let toolbar = this._rdf.GetResource("chrome://browser/content/browser.xul#" + toolbars[i]); let currentset = this._getPersist(toolbar, currentsetResource); if (!currentset) { // toolbar isn't customized if (i == 0) // new button is in the defaultset, nothing to migrate break; continue; } if (/(?:^|,)unified-back-forward-button(?:$|,)/.test(currentset)) // new button is already there, nothing to migrate break; if (/(?:^|,)back-button(?:$|,)/.test(currentset)) { let newset = currentset.replace(/(^|,)back-button($|,)/, "$1unified-back-forward-button,back-button$2") this._setPersist(toolbar, currentsetResource, newset); // done migrating break; } } // force the RDF to be saved if (this._dirty) this._dataSource.QueryInterface(Ci.nsIRDFRemoteDataSource).Flush(); // free up the RDF service this._rdf = null; this._dataSource = null; // update the migration version prefBranch.setIntPref("browser.migration.version", 1); } }, _getPersist: function bg__getPersist(aSource, aProperty) { var target = this._dataSource.GetTarget(aSource, aProperty, true); if (target instanceof Ci.nsIRDFLiteral) return target.Value; return null; }, _setPersist: function bg__setPersist(aSource, aProperty, aTarget) { this._dirty = true; try { var oldTarget = this._dataSource.GetTarget(aSource, aProperty, true); if (oldTarget) { if (aTarget) this._dataSource.Change(aSource, aProperty, oldTarget, this._rdf.GetLiteral(aTarget)); else this._dataSource.Unassert(aSource, aProperty, oldTarget); } else { this._dataSource.Assert(aSource, aProperty, this._rdf.GetLiteral(aTarget), true); } } catch(ex) {} }, // ------------------------------ // public nsIBrowserGlue members // ------------------------------ sanitize: function(aParentWindow) { this.Sanitizer.sanitize(aParentWindow); }, ensurePlacesDefaultQueriesInitialized: function() { const SMART_BOOKMARKS_VERSION = 1; const SMART_BOOKMARKS_ANNO = "Places/SmartBookmark"; const SMART_BOOKMARKS_PREF = "browser.places.smartBookmarksVersion"; // XXX should this be a pref? see bug #399268 const MAX_RESULTS = 10; var prefBranch = Cc["@mozilla.org/preferences-service;1"]. getService(Ci.nsIPrefBranch); // get current smart bookmarks version // By default, if the pref is not set up, we must create Smart Bookmarks var smartBookmarksCurrentVersion = 0; try { smartBookmarksCurrentVersion = prefBranch.getIntPref(SMART_BOOKMARKS_PREF); } catch(ex) {} // bail out if we don't have to create or update Smart Bookmarks if (smartBookmarksCurrentVersion == -1 || smartBookmarksCurrentVersion >= SMART_BOOKMARKS_VERSION) return; var bmsvc = Cc["@mozilla.org/browser/nav-bookmarks-service;1"]. getService(Ci.nsINavBookmarksService); var annosvc = Cc["@mozilla.org/browser/annotation-service;1"]. getService(Ci.nsIAnnotationService); var callback = { _placesBundle: Cc["@mozilla.org/intl/stringbundle;1"]. getService(Ci.nsIStringBundleService). createBundle("chrome://browser/locale/places/places.properties"), _uri: function(aSpec) { return Cc["@mozilla.org/network/io-service;1"]. getService(Ci.nsIIOService). newURI(aSpec, null, null); }, runBatched: function() { var smartBookmarks = []; var bookmarksMenuIndex = 0; var bookmarksToolbarIndex = 0; // MOST VISITED var smart = {queryId: "MostVisited", // don't change this itemId: null, title: this._placesBundle.GetStringFromName("mostVisitedTitle"), uri: this._uri("place:queryType=" + Ci.nsINavHistoryQueryOptions.QUERY_TYPE_HISTORY + "&sort=" + Ci.nsINavHistoryQueryOptions.SORT_BY_VISITCOUNT_DESCENDING + "&maxResults=" + MAX_RESULTS), parent: bmsvc.toolbarFolder, position: bookmarksToolbarIndex++}; smartBookmarks.push(smart); // RECENTLY BOOKMARKED smart = {queryId: "RecentlyBookmarked", // don't change this itemId: null, title: this._placesBundle.GetStringFromName("recentlyBookmarkedTitle"), uri: this._uri("place:folder=BOOKMARKS_MENU" + "&folder=UNFILED_BOOKMARKS" + "&folder=TOOLBAR" + "&queryType=" + Ci.nsINavHistoryQueryOptions.QUERY_TYPE_BOOKMARKS + "&sort=" + Ci.nsINavHistoryQueryOptions.SORT_BY_DATEADDED_DESCENDING + "&excludeItemIfParentHasAnnotation=livemark%2FfeedURI" + "&maxResults=" + MAX_RESULTS + "&excludeQueries=1"), parent: bmsvc.bookmarksMenuFolder, position: bookmarksMenuIndex++}; smartBookmarks.push(smart); // RECENT TAGS smart = {queryId: "RecentTags", // don't change this itemId: null, title: this._placesBundle.GetStringFromName("recentTagsTitle"), uri: this._uri("place:"+ "type=" + Ci.nsINavHistoryQueryOptions.RESULTS_AS_TAG_QUERY + "&sort=" + Ci.nsINavHistoryQueryOptions.SORT_BY_LASTMODIFIED_DESCENDING + "&maxResults=" + MAX_RESULTS), parent: bmsvc.bookmarksMenuFolder, position: bookmarksMenuIndex++}; smartBookmarks.push(smart); var smartBookmarkItemIds = annosvc.getItemsWithAnnotation(SMART_BOOKMARKS_ANNO, {}); // set current itemId, parent and position if Smart Bookmark exists for each(var itemId in smartBookmarkItemIds) { var queryId = annosvc.getItemAnnotation(itemId, SMART_BOOKMARKS_ANNO); for (var i = 0; i < smartBookmarks.length; i++){ if (smartBookmarks[i].queryId == queryId) { smartBookmarks[i].itemId = itemId; smartBookmarks[i].parent = bmsvc.getFolderIdForItem(itemId); smartBookmarks[i].position = bmsvc.getItemIndex(itemId); // remove current item, since it will be replaced bmsvc.removeItem(itemId); break; } // We don't remove old Smart Bookmarks because user could still // find them useful, or could have personalized them. // Instead we remove the Smart Bookmark annotation. if (i == smartBookmarks.length - 1) annosvc.removeItemAnnotation(itemId, SMART_BOOKMARKS_ANNO); } } // create smart bookmarks for each(var smartBookmark in smartBookmarks) { smartBookmark.itemId = bmsvc.insertBookmark(smartBookmark.parent, smartBookmark.uri, smartBookmark.position, smartBookmark.title); annosvc.setItemAnnotation(smartBookmark.itemId, SMART_BOOKMARKS_ANNO, smartBookmark.queryId, 0, annosvc.EXPIRE_NEVER); } // If we are creating all Smart Bookmarks from ground up, add a // separator below them in the bookmarks menu. if (smartBookmarkItemIds.length == 0) bmsvc.insertSeparator(bmsvc.bookmarksMenuFolder, bookmarksMenuIndex); } }; try { bmsvc.runInBatchMode(callback, null); } catch(ex) { Components.utils.reportError(ex); } finally { prefBranch.setIntPref(SMART_BOOKMARKS_PREF, SMART_BOOKMARKS_VERSION); prefBranch.QueryInterface(Ci.nsIPrefService).savePrefFile(null); } }, //@line 848 "e:\fx19rel\WINNT_5.2_Depend\mozilla\browser\components\nsBrowserGlue.js" // this returns the most recent non-popup browser window _getMostRecentBrowserWindow : function () { var wm = Cc["@mozilla.org/appshell/window-mediator;1"]. getService(Components.interfaces.nsIWindowMediator); //@line 870 "e:\fx19rel\WINNT_5.2_Depend\mozilla\browser\components\nsBrowserGlue.js" var windowList = wm.getZOrderDOMWindowEnumerator("navigator:browser", true); if (!windowList.hasMoreElements()) return null; var win = windowList.getNext(); while (win.document.documentElement.getAttribute("chromehidden")) { if (!windowList.hasMoreElements()) return null; win = windowList.getNext(); } //@line 882 "e:\fx19rel\WINNT_5.2_Depend\mozilla\browser\components\nsBrowserGlue.js" return win; }, // for XPCOM classDescription: "Firefox Browser Glue Service", classID: Components.ID("{eab9012e-5f74-4cbc-b2b5-a590235513cc}"), contractID: "@mozilla.org/browser/browserglue;1", QueryInterface: XPCOMUtils.generateQI([Ci.nsIObserver, Ci.nsISupportsWeakReference, Ci.nsIBrowserGlue]), // redefine the default factory for XPCOMUtils _xpcom_factory: BrowserGlueServiceFactory, // get this contractID registered for certain categories via XPCOMUtils _xpcom_categories: [ // make BrowserGlue a startup observer { category: "app-startup", service: true } ] } //module initialization function NSGetModule(aCompMgr, aFileSpec) { return XPCOMUtils.generateModule([BrowserGlue]); } |
:: Command execute :: | |
--[ c99shell v. 1.0 pre-release build #13 powered by Captain Crunch Security Team | http://ccteam.ru | Generation time: 0.0312 ]-- |