author | Mark Banner <standard8@mozilla.com> |
Wed, 16 Jul 2014 15:15:07 +0100 | |
changeset 194394 | 6dc734bab5380344f1df6a3fe2e31b7d3cd70d2b |
parent 194393 | e280e3ce940b8d4207640457cda1a26ad8f7199d |
child 194395 | ceef79a9fcb90302422541f72e92aadcfae767c9 |
push id | 27145 |
push user | kwierso@gmail.com |
push date | Thu, 17 Jul 2014 00:08:55 +0000 |
treeherder | mozilla-central@8e8f3ba64655 [default view] [failures only] |
perfherder | [talos] [build metrics] [platform microbench] (compared to previous push) |
reviewers | dolske, jesup, glandium, gijs |
bugs | 1017273 |
milestone | 33.0a1 |
first release with | nightly linux32
nightly linux64
nightly mac
nightly win32
nightly win64
|
last release without | nightly linux32
nightly linux64
nightly mac
nightly win32
nightly win64
|
--- a/browser/app/profile/firefox.js +++ b/browser/app/profile/firefox.js @@ -1506,21 +1506,26 @@ pref("pdfjs.previousHandler.alwaysAskBef pref("shumway.disabled", true); #endif // The maximum amount of decoded image data we'll willingly keep around (we // might keep around more than this, but we'll try to get down to this value). // (This is intentionally on the high side; see bug 746055.) pref("image.mem.max_decoded_image_kb", 256000); -#ifdef MOZ_LOOP +// Enable by default on nightly and aurora. +#ifndef RELEASE_BUILD +pref("loop.enabled", true); +#else +pref("loop.enabled", false); +#endif + pref("loop.server", "https://loop.services.mozilla.com"); pref("loop.do_not_disturb", false); pref("loop.ringtone", "chrome://browser/content/loop/shared/sounds/Firefox-Long.ogg"); -#endif // serverURL to be assigned by services team pref("services.push.serverURL", "wss://push.services.mozilla.com/"); // Default social providers pref("social.manifest.facebook", "{\"origin\":\"https://www.facebook.com\",\"name\":\"Facebook Share\",\"shareURL\":\"https://www.facebook.com/sharer/sharer.php?u=%{url}\",\"iconURL\":\"%2F9hAAAAX0lEQVQ4jWP4%2F%2F8%2FAyUYTFhHzjgDxP9JxGeQDSBVMxgTbUBCxer%2Fr999%2BQ8DJBuArJksA9A10s8AXIBoA0B%2BR%2FY%2FjD%2BEwoBoA1yT5v3PbdmCE8MAshhID%2FUMoDgzUYIBj0Cgi7ar4coAAAAASUVORK5CYII%3D\",\"icon32URL\":\"\", \"icon64URL\":\"\", \"description\":\"Easily share the web to your Facebook friends.\",\"author\":\"Facebook\",\"homepageURL\":\"https://www.facebook.com\",\"builtin\":\"true\",\"version\":1}"); pref("social.sidebar.unload_timeout_ms", 10000);
--- a/browser/base/content/browser-loop.js +++ b/browser/base/content/browser-loop.js @@ -31,12 +31,17 @@ XPCOMUtils.defineLazyModuleGetter(this, "about:looppanel", null, callback); }, /** * Triggers the initialization of the loop service. Called by * delayedStartup. */ initialize: function() { + if (!Services.prefs.getBoolPref("loop.enabled")) { + CustomizableUI.getWidget("loop-call-button").forWindow(window).node.hidden = true; + return; + } + MozLoopService.initialize(); }, }; })();
--- a/browser/base/content/browser.js +++ b/browser/base/content/browser.js @@ -167,19 +167,17 @@ let gInitialPages = [ "about:sessionrestore" ]; #include browser-addons.js #include browser-customization.js #include browser-feeds.js #include browser-fullScreen.js #include browser-fullZoom.js -#ifdef MOZ_LOOP #include browser-loop.js -#endif #include browser-places.js #include browser-plugins.js #include browser-safebrowsing.js #include browser-social.js #include browser-tabPreviews.js #include browser-tabview.js #include browser-thumbnails.js #include browser-webrtcUI.js @@ -1183,19 +1181,17 @@ var gBrowserInit = { gSyncUI.init(); gFxAccounts.init(); #endif #ifdef MOZ_DATA_REPORTING gDataNotificationInfoBar.init(); #endif -#ifdef MOZ_LOOP LoopUI.initialize(); -#endif gBrowserThumbnails.init(); // Add Devtools menuitems and listeners gDevToolsBrowser.registerBrowserWindow(window); window.addEventListener("mousemove", MousePosTracker, false); window.addEventListener("dragover", MousePosTracker, false);
--- a/browser/base/content/browser.xul +++ b/browser/base/content/browser.xul @@ -262,29 +262,27 @@ side="right" type="arrow" hidden="true" flip="slide" rolluponmousewheel="true" noautofocus="true" position="topcenter topright"/> -#ifdef MOZ_LOOP <panel id="loop-notification-panel" class="loop-panel social-panel" type="arrow" hidden="true" noautofocus="true"/> <panel id="loop-panel" class="loop-panel social-panel" type="arrow" orient="horizontal" hidden="true"/> -#endif <menupopup id="toolbar-context-menu" onpopupshowing="onViewToolbarsPopupShowing(event, document.getElementById('viewToolbarsMenuSeparator'));"> <menuitem oncommand="gCustomizeMode.addToPanel(document.popupNode)" accesskey="&customizeMenu.moveToPanel.accesskey;" label="&customizeMenu.moveToPanel.label;" contexttype="toolbaritem" class="customize-context-moveToPanel"/> @@ -668,21 +666,17 @@ Should you need to add items to the toolbar here, make sure to also add them to the default placements of buttons in CustomizableUI.jsm, so the customization code doesn't get confused. --> <toolbar id="nav-bar" class="toolbar-primary chromeclass-toolbar" aria-label="&navbarCmd.label;" fullscreentoolbar="true" mode="icons" customizable="true" iconsize="small" -#ifdef MOZ_LOOP defaultset="urlbar-container,search-container,webrtc-status-button,bookmarks-menu-button,downloads-button,home-button,loop-call-button,social-share-button,social-toolbar-item" -#else - defaultset="urlbar-container,search-container,webrtc-status-button,bookmarks-menu-button,downloads-button,home-button,social-share-button,social-toolbar-item" -#endif customizationtarget="nav-bar-customization-target" overflowable="true" overflowbutton="nav-bar-overflow-button" overflowtarget="widget-overflow-list" overflowpanel="widget-overflow" context="toolbar-context-menu"> <hbox id="nav-bar-customization-target" flex="1"> @@ -806,32 +800,30 @@ tooltiptext="&webrtcIndicatorButton.tooltip;" cui-areatype="toolbar" overflows="false"> <menupopup onpopupshowing="WebrtcIndicator.fillPopup(this);" onpopuphiding="WebrtcIndicator.clearPopup(this);" oncommand="WebrtcIndicator.menuCommand(event.target);"/> </toolbarbutton> -#ifdef MOZ_LOOP <!-- XXX Bug 1013989 will provide a label for the button --> <!-- This uses badged to be compatible with the social api code it shares. We may also want it to be badged in the future, for notification purposes. --> <toolbarbutton id="loop-call-button" class="toolbarbutton-1 chromeclass-toolbar-additional" persist="class" type="badged" removable="true" tooltiptext="&loopCallButton.tooltip;" oncommand="LoopUI.openCallPanel(event);" cui-areatype="toolbar" > </toolbarbutton> -#endif <toolbarbutton id="bookmarks-menu-button" class="toolbarbutton-1 chromeclass-toolbar-additional" persist="class" removable="true" type="menu-button" label="&bookmarksMenuButton.label;" tooltip="dynamic-shortcut-tooltip"
--- a/browser/components/about/AboutRedirector.cpp +++ b/browser/components/about/AboutRedirector.cpp @@ -92,26 +92,24 @@ static RedirEntry kRedirMap[] = { nsIAboutModule::ALLOW_SCRIPT }, #endif { "accounts", "chrome://browser/content/aboutaccounts/aboutaccounts.xhtml", nsIAboutModule::ALLOW_SCRIPT }, { "app-manager", "chrome://browser/content/devtools/app-manager/index.xul", nsIAboutModule::ALLOW_SCRIPT }, { "customizing", "chrome://browser/content/customizableui/aboutCustomizing.xul", nsIAboutModule::ALLOW_SCRIPT }, -#ifdef MOZ_LOOP { "loopconversation", "chrome://browser/content/loop/conversation.html", nsIAboutModule::URI_SAFE_FOR_UNTRUSTED_CONTENT | nsIAboutModule::ALLOW_SCRIPT | nsIAboutModule::HIDE_FROM_ABOUTABOUT }, { "looppanel", "chrome://browser/content/loop/panel.html", nsIAboutModule::URI_SAFE_FOR_UNTRUSTED_CONTENT | nsIAboutModule::ALLOW_SCRIPT | nsIAboutModule::HIDE_FROM_ABOUTABOUT }, -#endif }; static const int kRedirTotal = ArrayLength(kRedirMap); static nsAutoCString GetAboutModuleName(nsIURI *aURI) { nsAutoCString path; aURI->GetPath(path);
--- a/browser/components/build/nsModule.cpp +++ b/browser/components/build/nsModule.cpp @@ -107,20 +107,18 @@ static const mozilla::Module::ContractID { NS_ABOUT_MODULE_CONTRACTID_PREFIX "preferences", &kNS_BROWSER_ABOUT_REDIRECTOR_CID }, { NS_ABOUT_MODULE_CONTRACTID_PREFIX "downloads", &kNS_BROWSER_ABOUT_REDIRECTOR_CID }, { NS_ABOUT_MODULE_CONTRACTID_PREFIX "accounts", &kNS_BROWSER_ABOUT_REDIRECTOR_CID }, #ifdef MOZ_SERVICES_HEALTHREPORT { NS_ABOUT_MODULE_CONTRACTID_PREFIX "healthreport", &kNS_BROWSER_ABOUT_REDIRECTOR_CID }, #endif { NS_ABOUT_MODULE_CONTRACTID_PREFIX "app-manager", &kNS_BROWSER_ABOUT_REDIRECTOR_CID }, { NS_ABOUT_MODULE_CONTRACTID_PREFIX "customizing", &kNS_BROWSER_ABOUT_REDIRECTOR_CID }, -#ifdef MOZ_LOOP { NS_ABOUT_MODULE_CONTRACTID_PREFIX "looppanel", &kNS_BROWSER_ABOUT_REDIRECTOR_CID }, { NS_ABOUT_MODULE_CONTRACTID_PREFIX "loopconversation", &kNS_BROWSER_ABOUT_REDIRECTOR_CID }, -#endif #if defined(XP_WIN) { NS_IEHISTORYENUMERATOR_CONTRACTID, &kNS_WINIEHISTORYENUMERATOR_CID }, #elif defined(XP_MACOSX) { NS_SHELLSERVICE_CONTRACTID, &kNS_SHELLSERVICE_CID }, #endif { nullptr } };
--- a/browser/components/customizableui/content/panelUI.inc.xul +++ b/browser/components/customizableui/content/panelUI.inc.xul @@ -136,19 +136,17 @@ label="&showAllBookmarks2.label;" class="subviewbutton panel-subview-footer" command="Browser:ShowAllBookmarks" onclick="PanelUI.hide();"/> </panelview> <panelview id="PanelUI-socialapi" flex="1"/> -#ifdef MOZ_LOOP <panelview id="PanelUI-loopapi" flex="1"/> -#endif <panelview id="PanelUI-feeds" flex="1" oncommand="FeedHandler.subscribeToFeed(null, event);"> <label value="&feedsMenu.label;" class="panel-subview-header"/> </panelview> <panelview id="PanelUI-helpView" flex="1" class="PanelUI-subView"> <label value="&helpMenu.label;" class="panel-subview-header"/> <vbox id="PanelUI-helpItems" class="panel-subview-body"/>
--- a/browser/components/customizableui/src/CustomizableUI.jsm +++ b/browser/components/customizableui/src/CustomizableUI.jsm @@ -201,19 +201,17 @@ let CustomizableUIInternal = { overflowable: true, defaultPlacements: [ "urlbar-container", "search-container", "webrtc-status-button", "bookmarks-menu-button", "downloads-button", "home-button", -#ifdef MOZ_LOOP "loop-call-button", -#endif "social-share-button", ], defaultCollapsed: false, }, true); #ifndef XP_MACOSX this.registerArea(CustomizableUI.AREA_MENUBAR, { legacy: true, type: CustomizableUI.TYPE_TOOLBAR,
--- a/browser/components/loop/MozLoopService.jsm +++ b/browser/components/loop/MozLoopService.jsm @@ -444,16 +444,21 @@ let MozLoopServiceInternal = { * Public API */ this.MozLoopService = { /** * Initialized the loop service, and starts registration with the * push and loop servers. */ initialize: function() { + // Don't do anything if loop is not enabled. + if (!Services.prefs.getBoolPref("loop.enabled")) { + return; + } + // If expiresTime is in the future then kick-off registration. if (MozLoopServiceInternal.urlExpiryTimeIsInFuture()) { this._startInitializeTimer(); } }, /** * Internal function, exposed for testing purposes only. Used to start the @@ -476,16 +481,21 @@ this.MozLoopService = { * with the Loop server. It will return early if already registered. * * @param {Object} mockPushHandler Optional, test-only mock push handler. Used * to allow mocking of the MozLoopPushHandler. * @returns {Promise} a promise that is resolved with no params on completion, or * rejected with an error code or string. */ register: function(mockPushHandler) { + // Don't do anything if loop is not enabled. + if (!Services.prefs.getBoolPref("loop.enabled")) { + throw new Error("Loop is not enabled"); + } + return MozLoopServiceInternal.promiseRegisteredWithServers(mockPushHandler); }, /** * Used to note a call url expiry time. If the time is later than the current * latest expiry time, then the stored expiry time is increased. For times * sooner, this function is a no-op; this ensures we always have the latest * expiry time for a url.
--- a/browser/components/moz.build +++ b/browser/components/moz.build @@ -5,31 +5,29 @@ # file, You can obtain one at http://mozilla.org/MPL/2.0/. PARALLEL_DIRS += [ 'about', 'customizableui', 'dirprovider', 'downloads', 'feeds', + 'loop', 'places', 'preferences', 'privatebrowsing', 'search', 'sessionstore', 'shell', 'sidebar', 'tabview', 'translation', 'migration', ] -if CONFIG['MOZ_LOOP']: - PARALLEL_DIRS += ['loop'] - DIRS += ['build'] XPIDL_SOURCES += [ 'nsIBrowserGlue.idl', 'nsIBrowserHandler.idl', ] XPIDL_MODULE = 'browsercompsbase'
--- a/browser/themes/linux/browser.css +++ b/browser/themes/linux/browser.css @@ -1599,22 +1599,20 @@ richlistitem[type~="action"][actiontype= -moz-image-region: rect(28px, 28px, 42px, 14px); } /* Popup blocker button */ #page-report-button { list-style-image: url("chrome://browser/skin/Info.png"); } -%ifdef MOZ_LOOP /* Loop */ #loop-call-button { list-style-image: url("chrome://global/skin/loop/loop-call.png"); } -%endif /* social share panel */ .social-share-frame { background: linear-gradient(to bottom, rgba(242,242,242,.99), rgba(242,242,242,.95)); border-left: 1px solid #f8f8f8; width: 330px; height: 150px;
--- a/browser/themes/osx/browser.css +++ b/browser/themes/osx/browser.css @@ -2221,23 +2221,21 @@ richlistitem[type~="action"][actiontype= } #page-report-button:hover:active, #page-report-button[open="true"] { -moz-image-region: rect(0, 64px, 32px, 32px); } } -%ifdef MOZ_LOOP /* Loop */ /* XXX - probably need retina images here */ #loop-call-button { list-style-image: url("chrome://global/skin/loop/loop-call.png"); } -%endif /* social share panel */ .social-share-frame { background: linear-gradient(to bottom, rgba(242,242,242,.99), rgba(242,242,242,.95)); border-left: 1px solid #f8f8f8; width: 330px; height: 150px; /* we resize our panels dynamically, make it look nice */
--- a/browser/themes/windows/browser.css +++ b/browser/themes/windows/browser.css @@ -1535,23 +1535,20 @@ richlistitem[type~="action"][actiontype= -moz-image-region: rect(0, 32px, 16px, 16px); } #page-report-button:hover:active, #page-report-button[open="true"] { -moz-image-region: rect(0, 48px, 16px, 32px); } - -%ifdef MOZ_LOOP /* Loop */ #loop-call-button { list-style-image: url("chrome://global/skin/loop/loop-call.png"); } -%endif /* social share panel */ #social-share-panel > iframe { background: linear-gradient(to bottom, #f0f4f7, #fafbfc); width: 300px; height: 150px; }
--- a/configure.in +++ b/configure.in @@ -3887,17 +3887,16 @@ VPX_AS_CONVERSION= VPX_ASM_SUFFIX= VPX_X86_ASM= VPX_ARM_ASM= LIBJPEG_TURBO_AS= LIBJPEG_TURBO_ASFLAGS= LIBJPEG_TURBO_X86_ASM= LIBJPEG_TURBO_X64_ASM= LIBJPEG_TURBO_ARM_ASM= -MOZ_LOOP=$NIGHTLY_BUILD MOZ_PERMISSIONS=1 MOZ_PLACES=1 MOZ_SOCIAL=1 MOZ_PREF_EXTENSIONS=1 MOZ_PROFILELOCKING=1 MOZ_REFLOW_PERF= MOZ_SAFE_BROWSING= MOZ_HELP_VIEWER= @@ -8345,22 +8344,16 @@ MOZ_ARG_DISABLE_BOOL(ctypes, [ --disable-ctypes Disable js-ctypes], BUILD_CTYPES=, BUILD_CTYPES=1) AC_SUBST(BUILD_CTYPES) if test "$BUILD_CTYPES"; then AC_DEFINE(BUILD_CTYPES) fi -dnl Build Loop if required -AC_SUBST(MOZ_LOOP) -if test "$MOZ_LOOP"; then - AC_DEFINE(MOZ_LOOP) -fi - dnl Build Places if required if test "$MOZ_PLACES"; then AC_DEFINE(MOZ_PLACES) fi dnl Build SocialAPI if required if test "$MOZ_SOCIAL"; then AC_DEFINE(MOZ_SOCIAL)
--- a/dom/media/MediaManager.cpp +++ b/dom/media/MediaManager.cpp @@ -1474,30 +1474,27 @@ MediaManager::GetUserMedia(bool aPrivile #if defined(ANDROID) && !defined(MOZ_WIDGET_GONK) if (c.mPicture) { // ShowFilePickerForMimeType() must run on the Main Thread! (on Android) NS_DispatchToMainThread(runnable); return NS_OK; } #endif nsIURI* docURI = aWindow->GetDocumentURI(); -#ifdef MOZ_LOOP - { - bool isLoop = false; - nsCOMPtr<nsIURI> loopURI; - nsresult rv = NS_NewURI(getter_AddRefs(loopURI), "about:loopconversation"); - NS_ENSURE_SUCCESS(rv, rv); - rv = docURI->EqualsExceptRef(loopURI, &isLoop); - NS_ENSURE_SUCCESS(rv, rv); - if (isLoop) { - aPrivileged = true; - } + bool isLoop = false; + nsCOMPtr<nsIURI> loopURI; + nsresult rv = NS_NewURI(getter_AddRefs(loopURI), "about:loopconversation"); + NS_ENSURE_SUCCESS(rv, rv); + rv = docURI->EqualsExceptRef(loopURI, &isLoop); + NS_ENSURE_SUCCESS(rv, rv); + + if (isLoop) { + aPrivileged = true; } -#endif // XXX No full support for picture in Desktop yet (needs proper UI) if (aPrivileged || (c.mFake && !Preferences::GetBool("media.navigator.permission.fake"))) { mMediaThread->Dispatch(runnable, NS_DISPATCH_NORMAL); } else { bool isHTTPS = false; if (docURI) {