aboutsummaryrefslogtreecommitdiffstats
path: root/dist/installer
diff options
context:
space:
mode:
authorTim Jenssen <tim.jenssen@digia.com>2013-03-06 18:00:25 +0100
committerTim Jenssen <tim.jenssen@digia.com>2013-03-25 21:36:35 +0100
commitec10e0d79e9cf52b3cac164da5c39accbf4d2b50 (patch)
tree8eeb93dd5f859433d307b43753acf6f00a99327c /dist/installer
parent8d5ae76edaade0ea57de44021341e6cf616ac8fd (diff)
clean up installscript.qs
This makes code sharing between the Qt SDK Qt Creator component and the standalone one much easier. Change-Id: I9573ef24054d88dcabfa89666703f6eada29140c Reviewed-by: Niels Weber <niels.weber@digia.com> Reviewed-by: Eike Ziller <eike.ziller@digia.com>
Diffstat (limited to 'dist/installer')
-rw-r--r--dist/installer/ifw/packages/org.qtproject.qtcreator.application/meta/installscript.qs66
1 files changed, 33 insertions, 33 deletions
diff --git a/dist/installer/ifw/packages/org.qtproject.qtcreator.application/meta/installscript.qs b/dist/installer/ifw/packages/org.qtproject.qtcreator.application/meta/installscript.qs
index 1b46304147..02ea1d2f9c 100644
--- a/dist/installer/ifw/packages/org.qtproject.qtcreator.application/meta/installscript.qs
+++ b/dist/installer/ifw/packages/org.qtproject.qtcreator.application/meta/installscript.qs
@@ -48,8 +48,19 @@ Component.prototype.loaded = function()
Component.prototype.beginInstallation = function()
{
+ component.qtCreatorBinaryPath = installer.value("TargetDir");
+
+ if (installer.value("os") == "win") {
+ component.qtCreatorBinaryPath = component.qtCreatorBinaryPath + "\\bin\\qtcreator.exe";
+ component.qtCreatorBinaryPath = component.qtCreatorBinaryPath.replace(/\//g, "\\");
+ }
+ else if (installer.value("os") == "x11")
+ component.qtCreatorBinaryPath = component.qtCreatorBinaryPath + "/bin/qtcreator";
+ else if (installer.value("os") == "mac")
+ component.qtCreatorBinaryPath = "\"" + component.qtCreatorBinaryPath + "/Qt Creator.app/Contents/MacOS/Qt Creator\"";
+
if ( installer.value("os") === "win" ) {
- component.setStopProcessForUpdateRequest("@TargetDir@/bin/qtcreator.exe", true);
+ component.setStopProcessForUpdateRequest(component.qtCreatorBinaryPath, true);
component.setStopProcessForUpdateRequest("@TargetDir@/bin/linguist.exe", true);
component.setStopProcessForUpdateRequest("@TargetDir@/bin/qmlviewer.exe", true);
}
@@ -62,10 +73,10 @@ registerCommonWindowsFileTypeExtensions = function()
for (var i = 0; i < headerExtensions.length; ++i) {
component.addOperation( "RegisterFileType",
headerExtensions[i],
- "@TargetDir@\\bin\\qtcreator.exe -client '%1'",
+ component.qtCreatorBinaryPath + " -client '%1'",
"C++ Header file",
"text/plain",
- "@TargetDir@\\bin\\qtcreator.exe,3",
+ component.qtCreatorBinaryPath + ",3",
"ProgId=QtProject.QtCreator." + headerExtensions[i]);
}
@@ -74,19 +85,19 @@ registerCommonWindowsFileTypeExtensions = function()
for (var i = 0; i < cppExtensions.length; ++i) {
component.addOperation( "RegisterFileType",
cppExtensions[i],
- "@TargetDir@\\bin\\qtcreator.exe -client '%1'",
+ component.qtCreatorBinaryPath + " -client '%1'",
"C++ Source file",
"text/plain",
- "@TargetDir@\\bin\\qtcreator.exe,2",
+ component.qtCreatorBinaryPath + ",2",
"ProgId=QtProject.QtCreator." + cppExtensions[i]);
}
component.addOperation( "RegisterFileType",
"c",
- "@TargetDir@\\bin\\qtcreator.exe -client '%1'",
+ component.qtCreatorBinaryPath + " -client '%1'",
"C Source file",
"text/plain",
- "@TargetDir@\\bin\\qtcreator.exe,1",
+ component.qtCreatorBinaryPath + ",1",
"ProgId=QtProject.QtCreator.c");
}
@@ -94,38 +105,38 @@ registerWindowsFileTypeExtensions = function()
{
component.addOperation( "RegisterFileType",
"ui",
- "@TargetDir@\\bin\\qtcreator.exe -client '%1'",
+ component.qtCreatorBinaryPath + " -client '%1'",
"Qt UI file",
"text/plain",
- "@TargetDir@\\bin\\qtcreator.exe,4",
+ component.qtCreatorBinaryPath + ",4",
"ProgId=QtProject.QtCreator.ui");
component.addOperation( "RegisterFileType",
"pro",
- "@TargetDir@\\bin\\qtcreator.exe -client '%1'",
+ component.qtCreatorBinaryPath + " -client '%1'",
"Qt Project file",
"text/plain",
- "@TargetDir@\\bin\\qtcreator.exe,5",
+ component.qtCreatorBinaryPath + ",5",
"ProgId=QtProject.QtCreator.pro");
component.addOperation( "RegisterFileType",
"pri",
- "@TargetDir@\\bin\\qtcreator.exe -client '%1'",
+ component.qtCreatorBinaryPath + " -client '%1'",
"Qt Project Include file",
"text/plain",
- "@TargetDir@\\bin\\qtcreator.exe,6",
+ component.qtCreatorBinaryPath + ",6",
"ProgId=QtProject.QtCreator.pri");
component.addOperation( "RegisterFileType",
"qs",
- "@TargetDir@\\bin\\qtcreator.exe -client '%1'",
+ component.qtCreatorBinaryPath + " -client '%1'",
"Qt Script file",
"text/plain",
- "@TargetDir@\\bin\\qtcreator.exe,0",
+ component.qtCreatorBinaryPath + ",0",
"ProgId=QtProject.QtCreator.qs");
component.addOperation( "RegisterFileType",
"qml",
- "@TargetDir@\\bin\\qtcreator.exe -client '%1'",
+ component.qtCreatorBinaryPath + " -client '%1'",
"Qt Quick Markup language file",
"text/plain",
- "@TargetDir@\\bin\\qtcreator.exe,0",
+ component.qtCreatorBinaryPath + ",0",
"ProgId=QtProject.QtCreator.qml");
}
@@ -142,7 +153,7 @@ Component.prototype.createOperations = function()
"@TargetDir@/bin",
"@TargetDir@/bin");
component.addOperation( "CreateShortcut",
- "@TargetDir@\\bin\\qtcreator.exe",
+ component.qtCreatorBinaryPath,
"@StartMenuDir@/Qt Creator.lnk",
"workingDirectory=@homeDir@" );
component.addElevatedOperation("Execute", "{0,3010,1638}", "@TargetDir@\\lib\\vcredist_msvc2010\\vcredist_x86.exe", "/norestart", "/q");
@@ -169,7 +180,7 @@ Component.prototype.createOperations = function()
component.addOperation( "InstallIcons", "@TargetDir@/share/icons" );
component.addOperation( "CreateDesktopEntry",
"QtProject-qtcreator.desktop",
- "Type=Application\nExec=@TargetDir@/bin/qtcreator\nPath=@TargetDir@\nName=Qt Creator\nGenericName=The IDE of choice for Qt development.\nGenericName[de]=Die IDE der Wahl zur Qt Entwicklung\nIcon=QtProject-qtcreator\nTerminal=false\nCategories=Development;IDE;Qt;\nMimeType=text/x-c++src;text/x-c++hdr;text/x-xsrc;application/x-designer;application/vnd.nokia.qt.qmakeprofile;application/vnd.nokia.xml.qt.resource;text/x-qml;"
+ "Type=Application\nExec=" + component.qtCreatorBinaryPath + "\nPath=@TargetDir@\nName=Qt Creator\nGenericName=The IDE of choice for Qt development.\nGenericName[de]=Die IDE der Wahl zur Qt Entwicklung\nIcon=QtProject-qtcreator\nTerminal=false\nCategories=Development;IDE;Qt;\nMimeType=text/x-c++src;text/x-c++hdr;text/x-xsrc;application/x-designer;application/vnd.nokia.qt.qmakeprofile;application/vnd.nokia.xml.qt.resource;text/x-qml;"
);
}
}
@@ -189,20 +200,9 @@ Component.prototype.installationFinished = function()
{
try {
if (component.installed && installer.isInstaller() && installer.status == QInstaller.Success) {
- var isLaunchQtCreatorCheckBoxChecked = component.userInterface( "LaunchQtCreatorCheckBoxForm" ).launchQtCreatorCheckBox.checked;
- if (isLaunchQtCreatorCheckBoxChecked) {
-
- var qtCreatorBinary = installer.value("TargetDir");
- if (installer.value("os") == "win")
- qtCreatorBinary = qtCreatorBinary + "\\bin\\qtcreator.exe";
- else if (installer.value("os") == "x11")
- qtCreatorBinary = qtCreatorBinary + "/bin/qtcreator";
- else if (installer.value("os") == "mac")
- qtCreatorBinary = "\"" + qtCreatorBinary + "/Qt Creator.app/Contents/MacOS/Qt Creator\"";
-
- if (installer.executeDetached)
- installer.executeDetached(qtCreatorBinary);
- }
+ var isLaunchQtCreatorCheckBoxChecked = component.userInterface("LaunchQtCreatorCheckBoxForm").launchQtCreatorCheckBox.checked;
+ if (isLaunchQtCreatorCheckBoxChecked)
+ installer.executeDetached(component.qtCreatorBinaryPath);
}
} catch(e) {
print(e);