Portable
parent
6bd59d4de4
commit
2480e640d0
|
@ -16,7 +16,8 @@ Cu.import("resource://gre/modules/AsyncPrefs.jsm");
|
||||||
|
|
||||||
XPCOMUtils.defineLazyServiceGetter(this, "WindowsUIUtils", "@mozilla.org/windows-ui-utils;1", "nsIWindowsUIUtils");
|
XPCOMUtils.defineLazyServiceGetter(this, "WindowsUIUtils", "@mozilla.org/windows-ui-utils;1", "nsIWindowsUIUtils");
|
||||||
XPCOMUtils.defineLazyServiceGetter(this, "AlertsService", "@mozilla.org/alerts-service;1", "nsIAlertsService");
|
XPCOMUtils.defineLazyServiceGetter(this, "AlertsService", "@mozilla.org/alerts-service;1", "nsIAlertsService");
|
||||||
|
XPCOMUtils.defineLazyServiceGetter(this, "winShellService",
|
||||||
|
"@mozilla.org/browser/shell-service;1","nsIWindowsShellService");
|
||||||
// lazy module getters
|
// lazy module getters
|
||||||
[
|
[
|
||||||
["AboutHome", "resource:///modules/AboutHome.jsm"],
|
["AboutHome", "resource:///modules/AboutHome.jsm"],
|
||||||
|
@ -1149,6 +1150,9 @@ BrowserGlue.prototype = {
|
||||||
isDefaultError = true;
|
isDefaultError = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//CENTAURY PORTABLE CODE
|
||||||
|
let isPortable= winShellService.isPortableMode();
|
||||||
|
if (!isPortable) {
|
||||||
if (isDefault) {
|
if (isDefault) {
|
||||||
let now = (Math.floor(Date.now() / 1000)).toString();
|
let now = (Math.floor(Date.now() / 1000)).toString();
|
||||||
Services.prefs.setCharPref("browser.shell.mostRecentDateSetAsDefault", now);
|
Services.prefs.setCharPref("browser.shell.mostRecentDateSetAsDefault", now);
|
||||||
|
@ -1193,7 +1197,7 @@ BrowserGlue.prototype = {
|
||||||
DefaultBrowserCheck.prompt(RecentWindow.getMostRecentBrowserWindow());
|
DefaultBrowserCheck.prompt(RecentWindow.getMostRecentBrowserWindow());
|
||||||
}.bind(this), Ci.nsIThread.DISPATCH_NORMAL);
|
}.bind(this), Ci.nsIThread.DISPATCH_NORMAL);
|
||||||
}
|
}
|
||||||
}
|
}}
|
||||||
|
|
||||||
E10SAccessibilityCheck.onWindowsRestored();
|
E10SAccessibilityCheck.onWindowsRestored();
|
||||||
},
|
},
|
||||||
|
|
|
@ -632,6 +632,7 @@ var gMainPane = {
|
||||||
defaultBrowserBox.hidden = true;
|
defaultBrowserBox.hidden = true;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
if (shellSvc.isPortableMode()) return;
|
||||||
let setDefaultPane = document.getElementById("setDefaultPane");
|
let setDefaultPane = document.getElementById("setDefaultPane");
|
||||||
let isDefault = shellSvc.isDefaultBrowser(false, true);
|
let isDefault = shellSvc.isDefaultBrowser(false, true);
|
||||||
setDefaultPane.selectedIndex = isDefault ? 1 : 0;
|
setDefaultPane.selectedIndex = isDefault ? 1 : 0;
|
||||||
|
@ -651,9 +652,31 @@ var gMainPane = {
|
||||||
alwaysCheckPref.value = true;
|
alwaysCheckPref.value = true;
|
||||||
|
|
||||||
let shellSvc = getShellService();
|
let shellSvc = getShellService();
|
||||||
|
let sPortable;
|
||||||
if (!shellSvc)
|
if (!shellSvc)
|
||||||
return;
|
return;
|
||||||
try {
|
try {
|
||||||
|
isPortable = shellSvc.isPortableMode();
|
||||||
|
if (isPortable) {
|
||||||
|
Components.utils.import("resource:///modules/RecentWindow.jsm");
|
||||||
|
var win = RecentWindow.getMostRecentBrowserWindow();
|
||||||
|
var brandBundle = win.document.getElementById("bundle_brand");
|
||||||
|
var shellBundle = win.document.getElementById("bundle_shell");
|
||||||
|
|
||||||
|
var brandShortName = brandBundle.getString("brandShortName");
|
||||||
|
var promptTitle = shellBundle.getString("PortablemodeTitle");
|
||||||
|
var promptMessage = shellBundle.getFormattedString("PortablemodeMessage",
|
||||||
|
[brandShortName]);
|
||||||
|
// var checkEveryTime = { value: shouldCheck };
|
||||||
|
var ps = Services.prompt;
|
||||||
|
var rv = ps.confirmEx(win, promptTitle, promptMessage,
|
||||||
|
ps.STD_YES_NO_BUTTONS,
|
||||||
|
null, null, null, null, { });//, checkboxLabel, checkEveryTime);
|
||||||
|
if (rv == 0) {
|
||||||
|
shellSvc.cancelPortableMode();
|
||||||
|
isPortable=28;
|
||||||
|
} else return;
|
||||||
|
}
|
||||||
shellSvc.setDefaultBrowser(true, false);
|
shellSvc.setDefaultBrowser(true, false);
|
||||||
} catch (ex) {
|
} catch (ex) {
|
||||||
Cu.reportError(ex);
|
Cu.reportError(ex);
|
||||||
|
@ -662,6 +685,7 @@ var gMainPane = {
|
||||||
|
|
||||||
let selectedIndex = shellSvc.isDefaultBrowser(false, true) ? 1 : 0;
|
let selectedIndex = shellSvc.isDefaultBrowser(false, true) ? 1 : 0;
|
||||||
document.getElementById("setDefaultPane").selectedIndex = selectedIndex;
|
document.getElementById("setDefaultPane").selectedIndex = selectedIndex;
|
||||||
|
if (isPortable==28) Services.startup.quit(Ci.nsIAppStartup.eAttemptQuit | Ci.nsIAppStartup.eRestartNotSameProfile);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
|
@ -11,6 +11,8 @@ interface nsIFile;
|
||||||
[scriptable, uuid(2d1a95e4-5bd8-4eeb-b0a8-c1455fd2a357)]
|
[scriptable, uuid(2d1a95e4-5bd8-4eeb-b0a8-c1455fd2a357)]
|
||||||
interface nsIShellService : nsISupports
|
interface nsIShellService : nsISupports
|
||||||
{
|
{
|
||||||
|
boolean isPortableMode();
|
||||||
|
void cancelPortableMode();
|
||||||
/**
|
/**
|
||||||
* Determines whether or not Firefox is the "Default Browser."
|
* Determines whether or not Firefox is the "Default Browser."
|
||||||
* This is simply whether or not Firefox is registered to handle
|
* This is simply whether or not Firefox is registered to handle
|
||||||
|
|
|
@ -369,6 +369,60 @@ IsDefaultBrowserWin8(bool aCheckAllTypes, bool* aIsDefaultBrowser)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
NS_IMETHODIMP
|
||||||
|
nsWindowsShellService::CancelPortableMode()
|
||||||
|
{
|
||||||
|
nsresult rv;
|
||||||
|
|
||||||
|
nsCOMPtr<nsIFile> portmodemark;
|
||||||
|
|
||||||
|
rv = NS_GetSpecialDirectory(NS_OS_CURRENT_PROCESS_DIR,
|
||||||
|
getter_AddRefs(portmodemark));
|
||||||
|
NS_ENSURE_SUCCESS(rv, rv);
|
||||||
|
|
||||||
|
rv = portmodemark->AppendNative(NS_LITERAL_CSTRING("pmprt.mod"));
|
||||||
|
|
||||||
|
NS_ENSURE_SUCCESS(rv, rv);
|
||||||
|
|
||||||
|
bool fileExists;
|
||||||
|
rv = portmodemark->Exists(&fileExists);
|
||||||
|
|
||||||
|
NS_ENSURE_SUCCESS(rv, rv);
|
||||||
|
if (fileExists)
|
||||||
|
portmodemark->Remove(false);
|
||||||
|
|
||||||
|
return NS_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
NS_IMETHODIMP
|
||||||
|
nsWindowsShellService::IsPortableMode(bool* aIsPortable)
|
||||||
|
{
|
||||||
|
nsresult rv;
|
||||||
|
*aIsPortable=false;
|
||||||
|
|
||||||
|
nsCOMPtr<nsIFile> portmodemark;
|
||||||
|
|
||||||
|
rv = NS_GetSpecialDirectory(NS_OS_CURRENT_PROCESS_DIR,
|
||||||
|
getter_AddRefs(portmodemark));
|
||||||
|
NS_ENSURE_SUCCESS(rv, rv);
|
||||||
|
|
||||||
|
rv = portmodemark->AppendNative(NS_LITERAL_CSTRING("pmprt.mod"));
|
||||||
|
|
||||||
|
NS_ENSURE_SUCCESS(rv, rv);
|
||||||
|
|
||||||
|
bool fileExists;
|
||||||
|
rv = portmodemark->Exists(&fileExists);
|
||||||
|
NS_ENSURE_SUCCESS(rv, rv);
|
||||||
|
|
||||||
|
// nsAutoString path1;
|
||||||
|
// rv = portmodemark->GetPath(path1);
|
||||||
|
// ::MessageBoxW(NULL,path1.get(),L"Teest",MB_OKCANCEL);
|
||||||
|
|
||||||
|
if (fileExists){
|
||||||
|
*aIsPortable=true;
|
||||||
|
}
|
||||||
|
return NS_OK;
|
||||||
|
}
|
||||||
/*
|
/*
|
||||||
* Query's the AAR for the default status.
|
* Query's the AAR for the default status.
|
||||||
* This only checks for BasiliskURL and if aCheckAllTypes is set, then
|
* This only checks for BasiliskURL and if aCheckAllTypes is set, then
|
||||||
|
|
|
@ -40,6 +40,7 @@ Var AddDesktopSC
|
||||||
Var InstallMaintenanceService
|
Var InstallMaintenanceService
|
||||||
Var PageName
|
Var PageName
|
||||||
Var PreventRebootRequired
|
Var PreventRebootRequired
|
||||||
|
Var PrtChkb
|
||||||
|
|
||||||
; By defining NO_STARTMENU_DIR an installer that doesn't provide an option for
|
; By defining NO_STARTMENU_DIR an installer that doesn't provide an option for
|
||||||
; an application's Start Menu PROGRAMS directory and doesn't define the
|
; an application's Start Menu PROGRAMS directory and doesn't define the
|
||||||
|
@ -289,6 +290,15 @@ Section "-Application" APP_IDX
|
||||||
"$(ERROR_CREATE_DIRECTORY_PREFIX)" \
|
"$(ERROR_CREATE_DIRECTORY_PREFIX)" \
|
||||||
"$(ERROR_CREATE_DIRECTORY_SUFFIX)"
|
"$(ERROR_CREATE_DIRECTORY_SUFFIX)"
|
||||||
|
|
||||||
|
${If} $InstallType == ${INSTALLTYPE_PORTABLE}
|
||||||
|
${If} $PrtChkb == 1
|
||||||
|
FileOpen $0 "$INSTDIR\browser\pmprt.mod" w
|
||||||
|
FileClose $0
|
||||||
|
${Else}
|
||||||
|
FileOpen $0 "$INSTDIR\browser\pmundprt.mod" w
|
||||||
|
FileClose $0
|
||||||
|
${EndIf}
|
||||||
|
${Else}
|
||||||
; Register DLLs
|
; Register DLLs
|
||||||
; XXXrstrong - AccessibleMarshal.dll can be used by multiple applications but
|
; XXXrstrong - AccessibleMarshal.dll can be used by multiple applications but
|
||||||
; is only registered for the last application installed. When the last
|
; is only registered for the last application installed. When the last
|
||||||
|
@ -538,6 +548,7 @@ Section "-Application" APP_IDX
|
||||||
${EndIf}
|
${EndIf}
|
||||||
${EndUnless}
|
${EndUnless}
|
||||||
${EndIf}
|
${EndIf}
|
||||||
|
${EndIf}
|
||||||
SectionEnd
|
SectionEnd
|
||||||
|
|
||||||
; Cleanup operations to perform at the end of the installation.
|
; Cleanup operations to perform at the end of the installation.
|
||||||
|
@ -856,6 +867,12 @@ Function leaveOptions
|
||||||
${MUI_INSTALLOPTIONS_READ} $R0 "options.ini" "Field 3" "State"
|
${MUI_INSTALLOPTIONS_READ} $R0 "options.ini" "Field 3" "State"
|
||||||
StrCmp $R0 "1" +1 +2
|
StrCmp $R0 "1" +1 +2
|
||||||
StrCpy $InstallType ${INSTALLTYPE_CUSTOM}
|
StrCpy $InstallType ${INSTALLTYPE_CUSTOM}
|
||||||
|
${MUI_INSTALLOPTIONS_READ} $R0 "options.ini" "Field 6" "State"
|
||||||
|
StrCmp $R0 "1" +1 +2
|
||||||
|
StrCpy $InstallType ${INSTALLTYPE_PORTABLE}
|
||||||
|
${MUI_INSTALLOPTIONS_READ} $R0 "options.ini" "Field 7" "State"
|
||||||
|
StrCmp $R0 "1" +1 +2
|
||||||
|
StrCpy $PrtChkb 1
|
||||||
|
|
||||||
${LeaveOptionsCommon}
|
${LeaveOptionsCommon}
|
||||||
|
|
||||||
|
@ -945,6 +962,7 @@ Function preSummary
|
||||||
DeleteINISec "$PLUGINSDIR\summary.ini" "Field 4"
|
DeleteINISec "$PLUGINSDIR\summary.ini" "Field 4"
|
||||||
|
|
||||||
; Check if it is possible to write to HKLM
|
; Check if it is possible to write to HKLM
|
||||||
|
${If} $InstallType != ${INSTALLTYPE_PORTABLE}
|
||||||
ClearErrors
|
ClearErrors
|
||||||
WriteRegStr HKLM "Software\Mozilla" "${BrandShortName}InstallerTest" "Write Test"
|
WriteRegStr HKLM "Software\Mozilla" "${BrandShortName}InstallerTest" "Write Test"
|
||||||
${Unless} ${Errors}
|
${Unless} ${Errors}
|
||||||
|
@ -991,6 +1009,7 @@ Function preSummary
|
||||||
WriteINIStr "$PLUGINSDIR\summary.ini" "Field $0" Left "0"
|
WriteINIStr "$PLUGINSDIR\summary.ini" "Field $0" Left "0"
|
||||||
WriteINIStr "$PLUGINSDIR\summary.ini" "Field $0" Right "-1"
|
WriteINIStr "$PLUGINSDIR\summary.ini" "Field $0" Right "-1"
|
||||||
${EndIf}
|
${EndIf}
|
||||||
|
${EndIf}
|
||||||
|
|
||||||
!insertmacro MUI_HEADER_TEXT "$(SUMMARY_PAGE_TITLE)" "$(SUMMARY_PAGE_SUBTITLE)"
|
!insertmacro MUI_HEADER_TEXT "$(SUMMARY_PAGE_TITLE)" "$(SUMMARY_PAGE_SUBTITLE)"
|
||||||
|
|
||||||
|
@ -1083,7 +1102,7 @@ Function .onInit
|
||||||
!insertmacro InitInstallOptionsFile "components.ini"
|
!insertmacro InitInstallOptionsFile "components.ini"
|
||||||
!insertmacro InitInstallOptionsFile "summary.ini"
|
!insertmacro InitInstallOptionsFile "summary.ini"
|
||||||
|
|
||||||
WriteINIStr "$PLUGINSDIR\options.ini" "Settings" NumFields "5"
|
WriteINIStr "$PLUGINSDIR\options.ini" "Settings" NumFields "7"
|
||||||
|
|
||||||
WriteINIStr "$PLUGINSDIR\options.ini" "Field 1" Type "label"
|
WriteINIStr "$PLUGINSDIR\options.ini" "Field 1" Type "label"
|
||||||
WriteINIStr "$PLUGINSDIR\options.ini" "Field 1" Text "$(OPTIONS_SUMMARY)"
|
WriteINIStr "$PLUGINSDIR\options.ini" "Field 1" Text "$(OPTIONS_SUMMARY)"
|
||||||
|
@ -1109,6 +1128,14 @@ Function .onInit
|
||||||
WriteINIStr "$PLUGINSDIR\options.ini" "Field 3" Bottom "65"
|
WriteINIStr "$PLUGINSDIR\options.ini" "Field 3" Bottom "65"
|
||||||
WriteINIStr "$PLUGINSDIR\options.ini" "Field 3" State "0"
|
WriteINIStr "$PLUGINSDIR\options.ini" "Field 3" State "0"
|
||||||
|
|
||||||
|
WriteINIStr "$PLUGINSDIR\options.ini" "Field 6" Type "RadioButton"
|
||||||
|
WriteINIStr "$PLUGINSDIR\options.ini" "Field 6" Text "$(OPTION_PORTABLE_RADIO)"
|
||||||
|
WriteINIStr "$PLUGINSDIR\options.ini" "Field 6" Left "0"
|
||||||
|
WriteINIStr "$PLUGINSDIR\options.ini" "Field 6" Right "-1"
|
||||||
|
WriteINIStr "$PLUGINSDIR\options.ini" "Field 6" Top "85"
|
||||||
|
WriteINIStr "$PLUGINSDIR\options.ini" "Field 6" Bottom "95"
|
||||||
|
WriteINIStr "$PLUGINSDIR\options.ini" "Field 6" State "0"
|
||||||
|
|
||||||
WriteINIStr "$PLUGINSDIR\options.ini" "Field 4" Type "label"
|
WriteINIStr "$PLUGINSDIR\options.ini" "Field 4" Type "label"
|
||||||
WriteINIStr "$PLUGINSDIR\options.ini" "Field 4" Text "$(OPTION_STANDARD_DESC)"
|
WriteINIStr "$PLUGINSDIR\options.ini" "Field 4" Text "$(OPTION_STANDARD_DESC)"
|
||||||
WriteINIStr "$PLUGINSDIR\options.ini" "Field 4" Left "15"
|
WriteINIStr "$PLUGINSDIR\options.ini" "Field 4" Left "15"
|
||||||
|
@ -1123,6 +1150,14 @@ Function .onInit
|
||||||
WriteINIStr "$PLUGINSDIR\options.ini" "Field 5" Top "67"
|
WriteINIStr "$PLUGINSDIR\options.ini" "Field 5" Top "67"
|
||||||
WriteINIStr "$PLUGINSDIR\options.ini" "Field 5" Bottom "87"
|
WriteINIStr "$PLUGINSDIR\options.ini" "Field 5" Bottom "87"
|
||||||
|
|
||||||
|
WriteINIStr "$PLUGINSDIR\options.ini" "Field 7" Type "checkbox"
|
||||||
|
WriteINIStr "$PLUGINSDIR\options.ini" "Field 7" Text "$(OPTION_PORTABLE_DESC)"
|
||||||
|
WriteINIStr "$PLUGINSDIR\options.ini" "Field 7" Left "15"
|
||||||
|
WriteINIStr "$PLUGINSDIR\options.ini" "Field 7" Right "-1"
|
||||||
|
WriteINIStr "$PLUGINSDIR\options.ini" "Field 7" Top "97"
|
||||||
|
WriteINIStr "$PLUGINSDIR\options.ini" "Field 7" Bottom "117"
|
||||||
|
WriteINIStr "$PLUGINSDIR\options.ini" "Field 7" State "1"
|
||||||
|
|
||||||
; Setup the shortcuts.ini file for the Custom Shortcuts Page
|
; Setup the shortcuts.ini file for the Custom Shortcuts Page
|
||||||
; Don't offer to install the quick launch shortcut on Windows 7
|
; Don't offer to install the quick launch shortcut on Windows 7
|
||||||
${If} ${AtLeastWin7}
|
${If} ${AtLeastWin7}
|
||||||
|
|
|
@ -25,6 +25,8 @@ setDefaultBrowserMessage=%S is not currently set as your default browser. Would
|
||||||
setDefaultBrowserDontAsk=Always perform this check when starting %S.
|
setDefaultBrowserDontAsk=Always perform this check when starting %S.
|
||||||
setDefaultBrowserAlertConfirm.label=Use %S as my default browser
|
setDefaultBrowserAlertConfirm.label=Use %S as my default browser
|
||||||
setDefaultBrowserAlertNotNow.label=Not now
|
setDefaultBrowserAlertNotNow.label=Not now
|
||||||
|
PortablemodeTitle=Portable Mode
|
||||||
|
PortablemodeMessage=By pressing Yes you switch %S into standart non-portable mode, and browser will restart.
|
||||||
|
|
||||||
desktopBackgroundLeafNameWin=Desktop Background.bmp
|
desktopBackgroundLeafNameWin=Desktop Background.bmp
|
||||||
DesktopBackgroundDownloading=Saving Picture…
|
DesktopBackgroundDownloading=Saving Picture…
|
||||||
|
|
|
@ -77,6 +77,8 @@ OPTION_STANDARD_RADIO=&Standard
|
||||||
# Two lines
|
# Two lines
|
||||||
OPTION_CUSTOM_DESC=You may choose individual options to be installed. Recommended for experienced users.
|
OPTION_CUSTOM_DESC=You may choose individual options to be installed. Recommended for experienced users.
|
||||||
OPTION_CUSTOM_RADIO=&Custom
|
OPTION_CUSTOM_RADIO=&Custom
|
||||||
|
OPTION_PORTABLE_DESC=Such a portable, default browser feature disabled (no-remote).
|
||||||
|
OPTION_PORTABLE_RADIO=&Portable
|
||||||
|
|
||||||
# LOCALIZATION NOTE:
|
# LOCALIZATION NOTE:
|
||||||
# The following text replaces the Install button text on the summary page.
|
# The following text replaces the Install button text on the summary page.
|
||||||
|
|
|
@ -17,6 +17,9 @@ Cu.import("resource://gre/modules/Services.jsm");
|
||||||
XPCOMUtils.defineLazyServiceGetter(this, "AlertsService",
|
XPCOMUtils.defineLazyServiceGetter(this, "AlertsService",
|
||||||
"@mozilla.org/alerts-service;1", "nsIAlertsService");
|
"@mozilla.org/alerts-service;1", "nsIAlertsService");
|
||||||
|
|
||||||
|
XPCOMUtils.defineLazyServiceGetter(this, "winShellService",
|
||||||
|
"@mozilla.org/browser/shell-service;1","nsIWindowsShellService");
|
||||||
|
|
||||||
// Define Lazy Module Getters
|
// Define Lazy Module Getters
|
||||||
[
|
[
|
||||||
["AddonManager", "resource://gre/modules/AddonManager.jsm"],
|
["AddonManager", "resource://gre/modules/AddonManager.jsm"],
|
||||||
|
@ -597,7 +600,9 @@ BrowserGlue.prototype = {
|
||||||
} catch (ex) {
|
} catch (ex) {
|
||||||
isDefaultError = true;
|
isDefaultError = true;
|
||||||
}
|
}
|
||||||
|
//MYPAL PORTABLE CODE
|
||||||
|
let isPortable= winShellService.isPortableMode();
|
||||||
|
if (!isPortable) {
|
||||||
if (isDefault) {
|
if (isDefault) {
|
||||||
let now = (Math.floor(Date.now() / 1000)).toString();
|
let now = (Math.floor(Date.now() / 1000)).toString();
|
||||||
Services.prefs.setCharPref("browser.shell.mostRecentDateSetAsDefault", now);
|
Services.prefs.setCharPref("browser.shell.mostRecentDateSetAsDefault", now);
|
||||||
|
@ -641,7 +646,7 @@ BrowserGlue.prototype = {
|
||||||
ShellService.shouldCheckDefaultBrowser = checkEveryTime.value;
|
ShellService.shouldCheckDefaultBrowser = checkEveryTime.value;
|
||||||
}.bind(this), Ci.nsIThread.DISPATCH_NORMAL);
|
}.bind(this), Ci.nsIThread.DISPATCH_NORMAL);
|
||||||
}
|
}
|
||||||
}
|
}}
|
||||||
},
|
},
|
||||||
|
|
||||||
_onQuitRequest: function BG__onQuitRequest(aCancelQuit, aQuitType) {
|
_onQuitRequest: function BG__onQuitRequest(aCancelQuit, aQuitType) {
|
||||||
|
|
|
@ -10,6 +10,9 @@ Components.utils.import("resource://gre/modules/Services.jsm");
|
||||||
Components.utils.import("resource://gre/modules/LoadContextInfo.jsm");
|
Components.utils.import("resource://gre/modules/LoadContextInfo.jsm");
|
||||||
Components.utils.import("resource://gre/modules/BrowserUtils.jsm");
|
Components.utils.import("resource://gre/modules/BrowserUtils.jsm");
|
||||||
|
|
||||||
|
XPCOMUtils.defineLazyServiceGetter(this, "winShellSvc",
|
||||||
|
"@mozilla.org/browser/shell-service;1","nsIWindowsShellService");
|
||||||
|
|
||||||
var gAdvancedPane = {
|
var gAdvancedPane = {
|
||||||
_inited: false,
|
_inited: false,
|
||||||
|
|
||||||
|
@ -719,6 +722,7 @@ var gAdvancedPane = {
|
||||||
document.getElementById("alwaysCheckDefault").disabled = true;
|
document.getElementById("alwaysCheckDefault").disabled = true;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
if (winShellSvc.isPortableMode()) return;
|
||||||
let selectedIndex =
|
let selectedIndex =
|
||||||
shellSvc.isDefaultBrowser(false, true) ? 1 : 0;
|
shellSvc.isDefaultBrowser(false, true) ? 1 : 0;
|
||||||
setDefaultPane.selectedIndex = selectedIndex;
|
setDefaultPane.selectedIndex = selectedIndex;
|
||||||
|
@ -729,10 +733,33 @@ var gAdvancedPane = {
|
||||||
*/
|
*/
|
||||||
setDefaultBrowser: function()
|
setDefaultBrowser: function()
|
||||||
{
|
{
|
||||||
|
//MYPAL PORTABLE CODE
|
||||||
let shellSvc = getShellService();
|
let shellSvc = getShellService();
|
||||||
|
let sPortable;
|
||||||
if (!shellSvc)
|
if (!shellSvc)
|
||||||
return;
|
return;
|
||||||
try {
|
try {
|
||||||
|
isPortable = winShellSvc.isPortableMode();
|
||||||
|
if (isPortable) {
|
||||||
|
Components.utils.import("resource:///modules/RecentWindow.jsm");
|
||||||
|
var win = RecentWindow.getMostRecentBrowserWindow();
|
||||||
|
var brandBundle = win.document.getElementById("bundle_brand");
|
||||||
|
var shellBundle = win.document.getElementById("bundle_shell");
|
||||||
|
|
||||||
|
var brandShortName = brandBundle.getString("brandShortName");
|
||||||
|
var promptTitle = shellBundle.getString("PortablemodeTitle");
|
||||||
|
var promptMessage = shellBundle.getFormattedString("PortablemodeMessage",
|
||||||
|
[brandShortName]);
|
||||||
|
// var checkEveryTime = { value: shouldCheck };
|
||||||
|
var ps = Services.prompt;
|
||||||
|
var rv = ps.confirmEx(win, promptTitle, promptMessage,
|
||||||
|
ps.STD_YES_NO_BUTTONS,
|
||||||
|
null, null, null, null, { });//, checkboxLabel, checkEveryTime);
|
||||||
|
if (rv == 0) {
|
||||||
|
winShellSvc.cancelPortableMode();
|
||||||
|
isPortable=28;
|
||||||
|
} else return;
|
||||||
|
}
|
||||||
let claimAllTypes = true;
|
let claimAllTypes = true;
|
||||||
#ifdef XP_WIN
|
#ifdef XP_WIN
|
||||||
// In Windows 8+, the UI for selecting default protocol is much
|
// In Windows 8+, the UI for selecting default protocol is much
|
||||||
|
@ -750,6 +777,7 @@ var gAdvancedPane = {
|
||||||
let selectedIndex =
|
let selectedIndex =
|
||||||
shellSvc.isDefaultBrowser(false, true) ? 1 : 0;
|
shellSvc.isDefaultBrowser(false, true) ? 1 : 0;
|
||||||
document.getElementById("setDefaultPane").selectedIndex = selectedIndex;
|
document.getElementById("setDefaultPane").selectedIndex = selectedIndex;
|
||||||
|
if (isPortable==28) Application.quit();
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
|
|
@ -8,6 +8,9 @@
|
||||||
[scriptable, uuid(f8a26b94-49e5-4441-8fbc-315e0b4f22ef)]
|
[scriptable, uuid(f8a26b94-49e5-4441-8fbc-315e0b4f22ef)]
|
||||||
interface nsIWindowsShellService : nsIShellService
|
interface nsIWindowsShellService : nsIShellService
|
||||||
{
|
{
|
||||||
|
//MYPAL PORTABLE CODE
|
||||||
|
boolean isPortableMode();
|
||||||
|
void cancelPortableMode();
|
||||||
/**
|
/**
|
||||||
* Provides the shell service an opportunity to do some Win7+ shortcut
|
* Provides the shell service an opportunity to do some Win7+ shortcut
|
||||||
* maintenance needed on initial startup of the browser.
|
* maintenance needed on initial startup of the browser.
|
||||||
|
|
|
@ -402,6 +402,62 @@ nsWindowsShellService::IsDefaultBrowserVista(bool aCheckAllTypes,
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//MYPAL PORTABLE CODE
|
||||||
|
NS_IMETHODIMP
|
||||||
|
nsWindowsShellService::CancelPortableMode()
|
||||||
|
{
|
||||||
|
nsresult rv;
|
||||||
|
|
||||||
|
nsCOMPtr<nsIFile> portmodemark;
|
||||||
|
|
||||||
|
rv = NS_GetSpecialDirectory(NS_OS_CURRENT_PROCESS_DIR,
|
||||||
|
getter_AddRefs(portmodemark));
|
||||||
|
NS_ENSURE_SUCCESS(rv, rv);
|
||||||
|
|
||||||
|
rv = portmodemark->AppendNative(NS_LITERAL_CSTRING("pmprt.mod"));
|
||||||
|
|
||||||
|
NS_ENSURE_SUCCESS(rv, rv);
|
||||||
|
|
||||||
|
bool fileExists;
|
||||||
|
rv = portmodemark->Exists(&fileExists);
|
||||||
|
|
||||||
|
NS_ENSURE_SUCCESS(rv, rv);
|
||||||
|
if (fileExists)
|
||||||
|
portmodemark->Remove(false);
|
||||||
|
|
||||||
|
return NS_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
NS_IMETHODIMP
|
||||||
|
nsWindowsShellService::IsPortableMode(bool* aIsPortable)
|
||||||
|
{
|
||||||
|
nsresult rv;
|
||||||
|
*aIsPortable=false;
|
||||||
|
|
||||||
|
nsCOMPtr<nsIFile> portmodemark;
|
||||||
|
|
||||||
|
rv = NS_GetSpecialDirectory(NS_OS_CURRENT_PROCESS_DIR,
|
||||||
|
getter_AddRefs(portmodemark));
|
||||||
|
NS_ENSURE_SUCCESS(rv, rv);
|
||||||
|
|
||||||
|
rv = portmodemark->AppendNative(NS_LITERAL_CSTRING("pmprt.mod"));
|
||||||
|
|
||||||
|
NS_ENSURE_SUCCESS(rv, rv);
|
||||||
|
|
||||||
|
bool fileExists;
|
||||||
|
rv = portmodemark->Exists(&fileExists);
|
||||||
|
NS_ENSURE_SUCCESS(rv, rv);
|
||||||
|
|
||||||
|
// nsAutoString path1;
|
||||||
|
// rv = portmodemark->GetPath(path1);
|
||||||
|
// ::MessageBoxW(NULL,path1.get(),L"Teest",MB_OKCANCEL);
|
||||||
|
|
||||||
|
if (fileExists){
|
||||||
|
*aIsPortable=true;
|
||||||
|
}
|
||||||
|
return NS_OK;
|
||||||
|
}
|
||||||
|
|
||||||
NS_IMETHODIMP
|
NS_IMETHODIMP
|
||||||
nsWindowsShellService::IsDefaultBrowser(bool aStartupCheck,
|
nsWindowsShellService::IsDefaultBrowser(bool aStartupCheck,
|
||||||
bool aForAllTypes,
|
bool aForAllTypes,
|
||||||
|
|
|
@ -40,6 +40,7 @@ Var AddDesktopSC
|
||||||
Var InstallMaintenanceService
|
Var InstallMaintenanceService
|
||||||
Var PageName
|
Var PageName
|
||||||
Var PreventRebootRequired
|
Var PreventRebootRequired
|
||||||
|
Var PrtChkb
|
||||||
|
|
||||||
; By defining NO_STARTMENU_DIR an installer that doesn't provide an option for
|
; By defining NO_STARTMENU_DIR an installer that doesn't provide an option for
|
||||||
; an application's Start Menu PROGRAMS directory and doesn't define the
|
; an application's Start Menu PROGRAMS directory and doesn't define the
|
||||||
|
@ -289,6 +290,15 @@ Section "-Application" APP_IDX
|
||||||
"$(ERROR_CREATE_DIRECTORY_PREFIX)" \
|
"$(ERROR_CREATE_DIRECTORY_PREFIX)" \
|
||||||
"$(ERROR_CREATE_DIRECTORY_SUFFIX)"
|
"$(ERROR_CREATE_DIRECTORY_SUFFIX)"
|
||||||
|
|
||||||
|
${If} $InstallType == ${INSTALLTYPE_PORTABLE}
|
||||||
|
${If} $PrtChkb == 1
|
||||||
|
FileOpen $0 "$INSTDIR\browser\pmprt.mod" w
|
||||||
|
FileClose $0
|
||||||
|
${Else}
|
||||||
|
FileOpen $0 "$INSTDIR\browser\pmundprt.mod" w
|
||||||
|
FileClose $0
|
||||||
|
${EndIf}
|
||||||
|
${Else}
|
||||||
; Register DLLs
|
; Register DLLs
|
||||||
; XXXrstrong - AccessibleMarshal.dll can be used by multiple applications but
|
; XXXrstrong - AccessibleMarshal.dll can be used by multiple applications but
|
||||||
; is only registered for the last application installed. When the last
|
; is only registered for the last application installed. When the last
|
||||||
|
@ -538,6 +548,7 @@ Section "-Application" APP_IDX
|
||||||
${EndIf}
|
${EndIf}
|
||||||
${EndUnless}
|
${EndUnless}
|
||||||
${EndIf}
|
${EndIf}
|
||||||
|
${EndIf}
|
||||||
SectionEnd
|
SectionEnd
|
||||||
|
|
||||||
; Cleanup operations to perform at the end of the installation.
|
; Cleanup operations to perform at the end of the installation.
|
||||||
|
@ -856,6 +867,12 @@ Function leaveOptions
|
||||||
${MUI_INSTALLOPTIONS_READ} $R0 "options.ini" "Field 3" "State"
|
${MUI_INSTALLOPTIONS_READ} $R0 "options.ini" "Field 3" "State"
|
||||||
StrCmp $R0 "1" +1 +2
|
StrCmp $R0 "1" +1 +2
|
||||||
StrCpy $InstallType ${INSTALLTYPE_CUSTOM}
|
StrCpy $InstallType ${INSTALLTYPE_CUSTOM}
|
||||||
|
${MUI_INSTALLOPTIONS_READ} $R0 "options.ini" "Field 6" "State"
|
||||||
|
StrCmp $R0 "1" +1 +2
|
||||||
|
StrCpy $InstallType ${INSTALLTYPE_PORTABLE}
|
||||||
|
${MUI_INSTALLOPTIONS_READ} $R0 "options.ini" "Field 7" "State"
|
||||||
|
StrCmp $R0 "1" +1 +2
|
||||||
|
StrCpy $PrtChkb 1
|
||||||
|
|
||||||
${LeaveOptionsCommon}
|
${LeaveOptionsCommon}
|
||||||
|
|
||||||
|
@ -945,6 +962,7 @@ Function preSummary
|
||||||
DeleteINISec "$PLUGINSDIR\summary.ini" "Field 4"
|
DeleteINISec "$PLUGINSDIR\summary.ini" "Field 4"
|
||||||
|
|
||||||
; Check if it is possible to write to HKLM
|
; Check if it is possible to write to HKLM
|
||||||
|
${If} $InstallType != ${INSTALLTYPE_PORTABLE}
|
||||||
ClearErrors
|
ClearErrors
|
||||||
WriteRegStr HKLM "Software\Mozilla" "${BrandShortName}InstallerTest" "Write Test"
|
WriteRegStr HKLM "Software\Mozilla" "${BrandShortName}InstallerTest" "Write Test"
|
||||||
${Unless} ${Errors}
|
${Unless} ${Errors}
|
||||||
|
@ -991,6 +1009,7 @@ Function preSummary
|
||||||
WriteINIStr "$PLUGINSDIR\summary.ini" "Field $0" Left "0"
|
WriteINIStr "$PLUGINSDIR\summary.ini" "Field $0" Left "0"
|
||||||
WriteINIStr "$PLUGINSDIR\summary.ini" "Field $0" Right "-1"
|
WriteINIStr "$PLUGINSDIR\summary.ini" "Field $0" Right "-1"
|
||||||
${EndIf}
|
${EndIf}
|
||||||
|
${EndIf}
|
||||||
|
|
||||||
!insertmacro MUI_HEADER_TEXT "$(SUMMARY_PAGE_TITLE)" "$(SUMMARY_PAGE_SUBTITLE)"
|
!insertmacro MUI_HEADER_TEXT "$(SUMMARY_PAGE_TITLE)" "$(SUMMARY_PAGE_SUBTITLE)"
|
||||||
|
|
||||||
|
@ -1083,7 +1102,7 @@ Function .onInit
|
||||||
!insertmacro InitInstallOptionsFile "components.ini"
|
!insertmacro InitInstallOptionsFile "components.ini"
|
||||||
!insertmacro InitInstallOptionsFile "summary.ini"
|
!insertmacro InitInstallOptionsFile "summary.ini"
|
||||||
|
|
||||||
WriteINIStr "$PLUGINSDIR\options.ini" "Settings" NumFields "5"
|
WriteINIStr "$PLUGINSDIR\options.ini" "Settings" NumFields "7"
|
||||||
|
|
||||||
WriteINIStr "$PLUGINSDIR\options.ini" "Field 1" Type "label"
|
WriteINIStr "$PLUGINSDIR\options.ini" "Field 1" Type "label"
|
||||||
WriteINIStr "$PLUGINSDIR\options.ini" "Field 1" Text "$(OPTIONS_SUMMARY)"
|
WriteINIStr "$PLUGINSDIR\options.ini" "Field 1" Text "$(OPTIONS_SUMMARY)"
|
||||||
|
@ -1109,6 +1128,14 @@ Function .onInit
|
||||||
WriteINIStr "$PLUGINSDIR\options.ini" "Field 3" Bottom "65"
|
WriteINIStr "$PLUGINSDIR\options.ini" "Field 3" Bottom "65"
|
||||||
WriteINIStr "$PLUGINSDIR\options.ini" "Field 3" State "0"
|
WriteINIStr "$PLUGINSDIR\options.ini" "Field 3" State "0"
|
||||||
|
|
||||||
|
WriteINIStr "$PLUGINSDIR\options.ini" "Field 6" Type "RadioButton"
|
||||||
|
WriteINIStr "$PLUGINSDIR\options.ini" "Field 6" Text "$(OPTION_PORTABLE_RADIO)"
|
||||||
|
WriteINIStr "$PLUGINSDIR\options.ini" "Field 6" Left "0"
|
||||||
|
WriteINIStr "$PLUGINSDIR\options.ini" "Field 6" Right "-1"
|
||||||
|
WriteINIStr "$PLUGINSDIR\options.ini" "Field 6" Top "85"
|
||||||
|
WriteINIStr "$PLUGINSDIR\options.ini" "Field 6" Bottom "95"
|
||||||
|
WriteINIStr "$PLUGINSDIR\options.ini" "Field 6" State "0"
|
||||||
|
|
||||||
WriteINIStr "$PLUGINSDIR\options.ini" "Field 4" Type "label"
|
WriteINIStr "$PLUGINSDIR\options.ini" "Field 4" Type "label"
|
||||||
WriteINIStr "$PLUGINSDIR\options.ini" "Field 4" Text "$(OPTION_STANDARD_DESC)"
|
WriteINIStr "$PLUGINSDIR\options.ini" "Field 4" Text "$(OPTION_STANDARD_DESC)"
|
||||||
WriteINIStr "$PLUGINSDIR\options.ini" "Field 4" Left "15"
|
WriteINIStr "$PLUGINSDIR\options.ini" "Field 4" Left "15"
|
||||||
|
@ -1123,6 +1150,14 @@ Function .onInit
|
||||||
WriteINIStr "$PLUGINSDIR\options.ini" "Field 5" Top "67"
|
WriteINIStr "$PLUGINSDIR\options.ini" "Field 5" Top "67"
|
||||||
WriteINIStr "$PLUGINSDIR\options.ini" "Field 5" Bottom "87"
|
WriteINIStr "$PLUGINSDIR\options.ini" "Field 5" Bottom "87"
|
||||||
|
|
||||||
|
WriteINIStr "$PLUGINSDIR\options.ini" "Field 7" Type "checkbox"
|
||||||
|
WriteINIStr "$PLUGINSDIR\options.ini" "Field 7" Text "$(OPTION_PORTABLE_DESC)"
|
||||||
|
WriteINIStr "$PLUGINSDIR\options.ini" "Field 7" Left "15"
|
||||||
|
WriteINIStr "$PLUGINSDIR\options.ini" "Field 7" Right "-1"
|
||||||
|
WriteINIStr "$PLUGINSDIR\options.ini" "Field 7" Top "97"
|
||||||
|
WriteINIStr "$PLUGINSDIR\options.ini" "Field 7" Bottom "117"
|
||||||
|
WriteINIStr "$PLUGINSDIR\options.ini" "Field 7" State "1"
|
||||||
|
|
||||||
; Setup the shortcuts.ini file for the Custom Shortcuts Page
|
; Setup the shortcuts.ini file for the Custom Shortcuts Page
|
||||||
; Don't offer to install the quick launch shortcut on Windows 7
|
; Don't offer to install the quick launch shortcut on Windows 7
|
||||||
${If} ${AtLeastWin7}
|
${If} ${AtLeastWin7}
|
||||||
|
|
|
@ -8,6 +8,8 @@ setDefaultBrowserTitle=Default Browser
|
||||||
setDefaultBrowserMessage=%S is not currently set as your default browser. Would you like to make it your default browser?
|
setDefaultBrowserMessage=%S is not currently set as your default browser. Would you like to make it your default browser?
|
||||||
setDefaultBrowserDontAsk=Always perform this check when starting %S.
|
setDefaultBrowserDontAsk=Always perform this check when starting %S.
|
||||||
alreadyDefaultBrowser=%S is already set as your default browser.
|
alreadyDefaultBrowser=%S is already set as your default browser.
|
||||||
|
PortablemodeTitle=Portable Mode
|
||||||
|
PortablemodeMessage=By pressing Yes you switch %S into standart non-portable mode, and browser will quit.
|
||||||
desktopBackgroundLeafNameWin=Desktop Background.bmp
|
desktopBackgroundLeafNameWin=Desktop Background.bmp
|
||||||
DesktopBackgroundDownloading=Saving Picture…
|
DesktopBackgroundDownloading=Saving Picture…
|
||||||
DesktopBackgroundSet=Set Desktop Background
|
DesktopBackgroundSet=Set Desktop Background
|
||||||
|
|
|
@ -77,6 +77,8 @@ OPTION_STANDARD_RADIO=&Standard
|
||||||
# Two lines
|
# Two lines
|
||||||
OPTION_CUSTOM_DESC=You may choose individual options to be installed. Recommended for experienced users.
|
OPTION_CUSTOM_DESC=You may choose individual options to be installed. Recommended for experienced users.
|
||||||
OPTION_CUSTOM_RADIO=&Custom
|
OPTION_CUSTOM_RADIO=&Custom
|
||||||
|
OPTION_PORTABLE_DESC=Such a portable, default browser feature disabled (no-remote).
|
||||||
|
OPTION_PORTABLE_RADIO=&Portable
|
||||||
|
|
||||||
# LOCALIZATION NOTE:
|
# LOCALIZATION NOTE:
|
||||||
# The following text replaces the Install button text on the summary page.
|
# The following text replaces the Install button text on the summary page.
|
||||||
|
|
|
@ -303,14 +303,14 @@ nsresult InitOSFileConstants()
|
||||||
// some platforms or in non-Firefox embeddings of Gecko).
|
// some platforms or in non-Firefox embeddings of Gecko).
|
||||||
|
|
||||||
GetPathToSpecialDir(NS_OS_TEMP_DIR, paths->tmpDir);
|
GetPathToSpecialDir(NS_OS_TEMP_DIR, paths->tmpDir);
|
||||||
GetPathToSpecialDir(NS_OS_HOME_DIR, paths->homeDir);
|
/* GetPathToSpecialDir(NS_OS_HOME_DIR, paths->homeDir);
|
||||||
GetPathToSpecialDir(NS_OS_DESKTOP_DIR, paths->desktopDir);
|
GetPathToSpecialDir(NS_OS_DESKTOP_DIR, paths->desktopDir);
|
||||||
GetPathToSpecialDir(XRE_USER_APP_DATA_DIR, paths->userApplicationDataDir);
|
GetPathToSpecialDir(XRE_USER_APP_DATA_DIR, paths->userApplicationDataDir);
|
||||||
|
|
||||||
#if defined(XP_WIN)
|
#if defined(XP_WIN)
|
||||||
GetPathToSpecialDir(NS_WIN_APPDATA_DIR, paths->winAppDataDir);
|
GetPathToSpecialDir(NS_WIN_APPDATA_DIR, paths->winAppDataDir);
|
||||||
GetPathToSpecialDir(NS_WIN_PROGRAMS_DIR, paths->winStartMenuProgsDir);
|
GetPathToSpecialDir(NS_WIN_PROGRAMS_DIR, paths->winStartMenuProgsDir);
|
||||||
#endif // defined(XP_WIN)
|
#endif // defined(XP_WIN)*/
|
||||||
|
|
||||||
#if defined(XP_MACOSX)
|
#if defined(XP_MACOSX)
|
||||||
GetPathToSpecialDir(NS_MAC_USER_LIB_DIR, paths->macUserLibDir);
|
GetPathToSpecialDir(NS_MAC_USER_LIB_DIR, paths->macUserLibDir);
|
||||||
|
|
|
@ -4972,6 +4972,10 @@
|
||||||
!define INSTALLTYPE_CUSTOM 2
|
!define INSTALLTYPE_CUSTOM 2
|
||||||
!endif
|
!endif
|
||||||
|
|
||||||
|
!ifndef INSTALLTYPE_PORTABLE
|
||||||
|
!define INSTALLTYPE_PORTABLE 3
|
||||||
|
!endif
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Checks whether to display the current page (e.g. if not performing a custom
|
* Checks whether to display the current page (e.g. if not performing a custom
|
||||||
* install don't display the custom pages).
|
* install don't display the custom pages).
|
||||||
|
@ -5654,6 +5658,7 @@
|
||||||
Push $R9
|
Push $R9
|
||||||
|
|
||||||
IntCmp $InstallType ${INSTALLTYPE_CUSTOM} end +1 +1
|
IntCmp $InstallType ${INSTALLTYPE_CUSTOM} end +1 +1
|
||||||
|
IntCmp $InstallType ${INSTALLTYPE_PORTABLE} end +1 +1
|
||||||
${CanWriteToInstallDir} $R9
|
${CanWriteToInstallDir} $R9
|
||||||
StrCmp "$R9" "false" end +1
|
StrCmp "$R9" "false" end +1
|
||||||
${CheckDiskSpace} $R9
|
${CheckDiskSpace} $R9
|
||||||
|
|
|
@ -112,7 +112,7 @@ public:
|
||||||
private:
|
private:
|
||||||
friend class nsToolkitProfile;
|
friend class nsToolkitProfile;
|
||||||
friend class nsToolkitProfileFactory;
|
friend class nsToolkitProfileFactory;
|
||||||
friend nsresult NS_NewToolkitProfileService(nsIToolkitProfileService**);
|
friend nsresult NS_NewToolkitProfileService(nsIToolkitProfileService**,int);
|
||||||
|
|
||||||
nsToolkitProfileService() :
|
nsToolkitProfileService() :
|
||||||
mDirty(false),
|
mDirty(false),
|
||||||
|
@ -126,7 +126,7 @@ private:
|
||||||
gService = nullptr;
|
gService = nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
nsresult Init();
|
nsresult Init(int portable);
|
||||||
|
|
||||||
nsresult CreateTimesInternal(nsIFile *profileDir);
|
nsresult CreateTimesInternal(nsIFile *profileDir);
|
||||||
|
|
||||||
|
@ -382,8 +382,11 @@ NS_IMPL_ISUPPORTS(nsToolkitProfileService,
|
||||||
nsIToolkitProfileService)
|
nsIToolkitProfileService)
|
||||||
|
|
||||||
nsresult
|
nsresult
|
||||||
nsToolkitProfileService::Init()
|
nsToolkitProfileService::Init(int portable)
|
||||||
{
|
{
|
||||||
|
//MYPAL CODE
|
||||||
|
if(portable>0) return NS_OK;
|
||||||
|
|
||||||
NS_ASSERTION(gDirServiceProvider, "No dirserviceprovider!");
|
NS_ASSERTION(gDirServiceProvider, "No dirserviceprovider!");
|
||||||
nsresult rv;
|
nsresult rv;
|
||||||
|
|
||||||
|
@ -1024,7 +1027,7 @@ nsToolkitProfileFactory::CreateInstance(nsISupports* aOuter, const nsID& aIID,
|
||||||
nsCOMPtr<nsIToolkitProfileService> profileService =
|
nsCOMPtr<nsIToolkitProfileService> profileService =
|
||||||
nsToolkitProfileService::gService;
|
nsToolkitProfileService::gService;
|
||||||
if (!profileService) {
|
if (!profileService) {
|
||||||
nsresult rv = NS_NewToolkitProfileService(getter_AddRefs(profileService));
|
nsresult rv = NS_NewToolkitProfileService(getter_AddRefs(profileService),0);
|
||||||
if (NS_FAILED(rv))
|
if (NS_FAILED(rv))
|
||||||
return rv;
|
return rv;
|
||||||
}
|
}
|
||||||
|
@ -1049,12 +1052,12 @@ NS_NewToolkitProfileFactory(nsIFactory* *aResult)
|
||||||
}
|
}
|
||||||
|
|
||||||
nsresult
|
nsresult
|
||||||
NS_NewToolkitProfileService(nsIToolkitProfileService* *aResult)
|
NS_NewToolkitProfileService(nsIToolkitProfileService* *aResult,int portable)
|
||||||
{
|
{
|
||||||
nsToolkitProfileService* profileService = new nsToolkitProfileService();
|
nsToolkitProfileService* profileService = new nsToolkitProfileService();
|
||||||
if (!profileService)
|
if (!profileService)
|
||||||
return NS_ERROR_OUT_OF_MEMORY;
|
return NS_ERROR_OUT_OF_MEMORY;
|
||||||
nsresult rv = profileService->Init();
|
nsresult rv = profileService->Init(portable);
|
||||||
if (NS_FAILED(rv)) {
|
if (NS_FAILED(rv)) {
|
||||||
NS_ERROR("nsToolkitProfileService::Init failed!");
|
NS_ERROR("nsToolkitProfileService::Init failed!");
|
||||||
delete profileService;
|
delete profileService;
|
||||||
|
|
|
@ -1920,7 +1920,7 @@ static nsAutoCString gResetOldProfileName;
|
||||||
// 6) display the profile-manager UI
|
// 6) display the profile-manager UI
|
||||||
static nsresult
|
static nsresult
|
||||||
SelectProfile(nsIProfileLock* *aResult, nsIToolkitProfileService* aProfileSvc, nsINativeAppSupport* aNative,
|
SelectProfile(nsIProfileLock* *aResult, nsIToolkitProfileService* aProfileSvc, nsINativeAppSupport* aNative,
|
||||||
bool* aStartOffline, nsACString* aProfileName)
|
bool* aStartOffline, nsACString* aProfileName,int prt)
|
||||||
{
|
{
|
||||||
StartupTimeline::Record(StartupTimeline::SELECT_PROFILE);
|
StartupTimeline::Record(StartupTimeline::SELECT_PROFILE);
|
||||||
|
|
||||||
|
@ -1944,6 +1944,39 @@ SelectProfile(nsIProfileLock* *aResult, nsIToolkitProfileService* aProfileSvc, n
|
||||||
gDoMigration = true;
|
gDoMigration = true;
|
||||||
SaveToEnv("MOZ_RESET_PROFILE_RESTART=");
|
SaveToEnv("MOZ_RESET_PROFILE_RESTART=");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//MYPAL PORTABLE CODE START
|
||||||
|
nsCOMPtr<nsIFile> lf;
|
||||||
|
if (prt>0) {
|
||||||
|
//lstrcmpW(L"Teest",L"Teest");
|
||||||
|
|
||||||
|
nsCOMPtr<nsIFile> exeFile;
|
||||||
|
rv = XRE_GetBinaryPath(gArgv[0], getter_AddRefs(exeFile));
|
||||||
|
rv = exeFile->GetParent(getter_AddRefs(lf));
|
||||||
|
lf->AppendNative(*aProfileName);
|
||||||
|
|
||||||
|
// nsAutoString path1;
|
||||||
|
// rv = lf->GetPath(path1);
|
||||||
|
// ::MessageBoxW(NULL,path1.get(),L"Teest",MB_OKCANCEL);
|
||||||
|
|
||||||
|
NS_ENSURE_SUCCESS(rv, rv);
|
||||||
|
|
||||||
|
nsCOMPtr<nsIProfileUnlocker> unlocker;
|
||||||
|
|
||||||
|
bool exists;
|
||||||
|
lf->Exists(&exists);
|
||||||
|
if (!exists) {
|
||||||
|
rv = lf->Create(nsIFile::DIRECTORY_TYPE, 0700);
|
||||||
|
NS_ENSURE_SUCCESS(rv, rv);
|
||||||
|
}
|
||||||
|
|
||||||
|
// If a profile path is specified directory on the command line, then
|
||||||
|
// assume that the temp directory is the same as the given directory.
|
||||||
|
rv = NS_LockProfilePath(lf, lf, getter_AddRefs(unlocker), aResult);
|
||||||
|
if (NS_SUCCEEDED(rv))
|
||||||
|
return rv;
|
||||||
|
return ProfileLockedDialog(lf, lf, unlocker, aNative, aResult);}
|
||||||
|
//MYPAL PORTABLE CODE END
|
||||||
|
|
||||||
// reset-profile and migration args need to be checked before any profiles are chosen below.
|
// reset-profile and migration args need to be checked before any profiles are chosen below.
|
||||||
ar = CheckArg("reset-profile", true);
|
ar = CheckArg("reset-profile", true);
|
||||||
|
@ -1962,7 +1995,7 @@ SelectProfile(nsIProfileLock* *aResult, nsIToolkitProfileService* aProfileSvc, n
|
||||||
gDoMigration = true;
|
gDoMigration = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
nsCOMPtr<nsIFile> lf = GetFileFromEnv("XRE_PROFILE_PATH");
|
lf = GetFileFromEnv("XRE_PROFILE_PATH");
|
||||||
if (lf) {
|
if (lf) {
|
||||||
nsCOMPtr<nsIFile> localDir =
|
nsCOMPtr<nsIFile> localDir =
|
||||||
GetFileFromEnv("XRE_PROFILE_LOCAL_PATH");
|
GetFileFromEnv("XRE_PROFILE_LOCAL_PATH");
|
||||||
|
@ -2728,6 +2761,7 @@ public:
|
||||||
int XRE_main(int argc, char* argv[], const nsXREAppData* aAppData);
|
int XRE_main(int argc, char* argv[], const nsXREAppData* aAppData);
|
||||||
int XRE_mainInit(bool* aExitFlag);
|
int XRE_mainInit(bool* aExitFlag);
|
||||||
int XRE_mainStartup(bool* aExitFlag);
|
int XRE_mainStartup(bool* aExitFlag);
|
||||||
|
int portable();
|
||||||
nsresult XRE_mainRun();
|
nsresult XRE_mainRun();
|
||||||
|
|
||||||
nsCOMPtr<nsINativeAppSupport> mNativeApp;
|
nsCOMPtr<nsINativeAppSupport> mNativeApp;
|
||||||
|
@ -2759,6 +2793,21 @@ public:
|
||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
|
//MYPAL CODE
|
||||||
|
int XREMain::portable(){
|
||||||
|
bool portable;
|
||||||
|
nsCOMPtr<nsIFile> portmodemark;
|
||||||
|
mDirProvider.GetAppDir()->Clone(getter_AddRefs(portmodemark));
|
||||||
|
portmodemark->AppendNative(NS_LITERAL_CSTRING("pmprt.mod"));
|
||||||
|
portmodemark->Exists(&portable);
|
||||||
|
if (portable) return 1;
|
||||||
|
mDirProvider.GetAppDir()->Clone(getter_AddRefs(portmodemark));
|
||||||
|
portmodemark->AppendNative(NS_LITERAL_CSTRING("pmundprt.mod"));
|
||||||
|
portmodemark->Exists(&portable);
|
||||||
|
if (portable) return 2;
|
||||||
|
else return 0;
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* XRE_mainInit - Initial setup and command line parameter processing.
|
* XRE_mainInit - Initial setup and command line parameter processing.
|
||||||
* Main() will exit early if either return value != 0 or if aExitFlag is
|
* Main() will exit early if either return value != 0 or if aExitFlag is
|
||||||
|
@ -3075,6 +3124,9 @@ XREMain::XRE_mainInit(bool* aExitFlag)
|
||||||
} else if (ar == ARG_FOUND) {
|
} else if (ar == ARG_FOUND) {
|
||||||
SaveToEnv("MOZ_NO_REMOTE=1");
|
SaveToEnv("MOZ_NO_REMOTE=1");
|
||||||
}
|
}
|
||||||
|
//MYPAL CODE
|
||||||
|
//lstrcmpW(L"Teest",L"Teest");
|
||||||
|
if (portable()==1) SaveToEnv("MOZ_NO_REMOTE=1");
|
||||||
|
|
||||||
ar = CheckArg("new-instance", true);
|
ar = CheckArg("new-instance", true);
|
||||||
if (ar == ARG_BAD) {
|
if (ar == ARG_BAD) {
|
||||||
|
@ -3467,8 +3519,11 @@ XREMain::XRE_mainStartup(bool* aExitFlag)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
//MYPAL CODE
|
||||||
|
int prt=portable();
|
||||||
|
if (prt>0) mProfileName.Assign("\Profile");
|
||||||
|
|
||||||
rv = NS_NewToolkitProfileService(getter_AddRefs(mProfileSvc));
|
rv = NS_NewToolkitProfileService(getter_AddRefs(mProfileSvc),prt);
|
||||||
if (rv == NS_ERROR_FILE_ACCESS_DENIED) {
|
if (rv == NS_ERROR_FILE_ACCESS_DENIED) {
|
||||||
PR_fprintf(PR_STDERR, "Error: Access was denied while trying to open files in " \
|
PR_fprintf(PR_STDERR, "Error: Access was denied while trying to open files in " \
|
||||||
"your profile directory.\n");
|
"your profile directory.\n");
|
||||||
|
@ -3480,7 +3535,7 @@ XREMain::XRE_mainStartup(bool* aExitFlag)
|
||||||
}
|
}
|
||||||
|
|
||||||
rv = SelectProfile(getter_AddRefs(mProfileLock), mProfileSvc, mNativeApp, &mStartOffline,
|
rv = SelectProfile(getter_AddRefs(mProfileLock), mProfileSvc, mNativeApp, &mStartOffline,
|
||||||
&mProfileName);
|
&mProfileName,prt);
|
||||||
if (rv == NS_ERROR_LAUNCHED_CHILD_PROCESS ||
|
if (rv == NS_ERROR_LAUNCHED_CHILD_PROCESS ||
|
||||||
rv == NS_ERROR_ABORT) {
|
rv == NS_ERROR_ABORT) {
|
||||||
*aExitFlag = true;
|
*aExitFlag = true;
|
||||||
|
|
|
@ -65,7 +65,7 @@ extern bool gIsGtest;
|
||||||
nsresult NS_CreateNativeAppSupport(nsINativeAppSupport* *aResult);
|
nsresult NS_CreateNativeAppSupport(nsINativeAppSupport* *aResult);
|
||||||
|
|
||||||
nsresult
|
nsresult
|
||||||
NS_NewToolkitProfileService(nsIToolkitProfileService* *aResult);
|
NS_NewToolkitProfileService(nsIToolkitProfileService* *aResult,int portable);
|
||||||
|
|
||||||
nsresult
|
nsresult
|
||||||
NS_NewToolkitProfileFactory(nsIFactory* *aResult);
|
NS_NewToolkitProfileFactory(nsIFactory* *aResult);
|
||||||
|
|
|
@ -1375,8 +1375,8 @@ nsXREDirProvider::GetSysUserExtensionsDirectory(nsIFile** aFile)
|
||||||
nsresult rv = GetUserDataDirectoryHome(getter_AddRefs(localDir), false);
|
nsresult rv = GetUserDataDirectoryHome(getter_AddRefs(localDir), false);
|
||||||
NS_ENSURE_SUCCESS(rv, rv);
|
NS_ENSURE_SUCCESS(rv, rv);
|
||||||
|
|
||||||
rv = AppendSysUserExtensionPath(localDir);
|
//rv = AppendSysUserExtensionPath(localDir);
|
||||||
NS_ENSURE_SUCCESS(rv, rv);
|
//NS_ENSURE_SUCCESS(rv, rv);
|
||||||
|
|
||||||
rv = EnsureDirectoryExists(localDir);
|
rv = EnsureDirectoryExists(localDir);
|
||||||
NS_ENSURE_SUCCESS(rv, rv);
|
NS_ENSURE_SUCCESS(rv, rv);
|
||||||
|
|
|
@ -133,6 +133,8 @@ include('/ipc/chromium/chromium-config.mozbuild')
|
||||||
|
|
||||||
FINAL_LIBRARY = 'xul'
|
FINAL_LIBRARY = 'xul'
|
||||||
|
|
||||||
|
DEFINES['MOZ_APP_BASENAME'] = '"%s"' % CONFIG['MOZ_APP_BASENAME']
|
||||||
|
|
||||||
if CONFIG['OS_ARCH'] == 'Linux' and 'lib64' in CONFIG['libdir']:
|
if CONFIG['OS_ARCH'] == 'Linux' and 'lib64' in CONFIG['libdir']:
|
||||||
DEFINES['HAVE_USR_LIB64_DIR'] = True
|
DEFINES['HAVE_USR_LIB64_DIR'] = True
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue