summaryrefslogtreecommitdiffstats
path: root/o3d/installer
diff options
context:
space:
mode:
authorgspencer@google.com <gspencer@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2009-08-06 22:17:39 +0000
committergspencer@google.com <gspencer@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2009-08-06 22:17:39 +0000
commit6a60ae4c2967bae910cbd1a1ff5a53c5f7d78a19 (patch)
treeac02524310011c60f7d4f5255f1df5b592b4ca5c /o3d/installer
parent05c453db1e7a357eb2cc1b6ac67ff32a5256bb19 (diff)
downloadchromium_src-6a60ae4c2967bae910cbd1a1ff5a53c5f7d78a19.zip
chromium_src-6a60ae4c2967bae910cbd1a1ff5a53c5f7d78a19.tar.gz
chromium_src-6a60ae4c2967bae910cbd1a1ff5a53c5f7d78a19.tar.bz2
This completes the building of o3d.msi from the GYP build.
Review URL: http://codereview.chromium.org/164044 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@22680 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'o3d/installer')
-rw-r--r--o3d/installer/installer.gyp42
-rw-r--r--o3d/installer/win/build.scons35
-rw-r--r--o3d/installer/win/custom_actions.cc1
-rw-r--r--o3d/installer/win/installer.gyp302
-rw-r--r--o3d/installer/win/o3d.wxs (renamed from o3d/installer/win/o3d_plugin.wxs)2
-rw-r--r--o3d/installer/win/o3dextras.wxs (renamed from o3d/installer/win/o3d_extras.wxs)0
6 files changed, 364 insertions, 18 deletions
diff --git a/o3d/installer/installer.gyp b/o3d/installer/installer.gyp
new file mode 100644
index 0000000..426d153
--- /dev/null
+++ b/o3d/installer/installer.gyp
@@ -0,0 +1,42 @@
+# Copyright (c) 2009 The Chromium Authors. All rights reserved.
+# Use of this source code is governed by a BSD-style license that can be
+# found in the LICENSE file.
+
+{
+ 'variables': {
+ 'chromium_code': 1,
+ },
+ 'includes': [
+ '../build/common.gypi',
+ ],
+ 'targets': [
+ {
+ 'target_name': 'installer',
+ 'type': 'none',
+ 'conditions': [
+ ['OS=="win"',
+ {
+ 'dependencies': [
+ 'win/installer.gyp:installer',
+ 'win/installer.gyp:extras_installer',
+ ],
+ },
+ ],
+ ['OS=="mac"',
+ {
+ 'dependencies': [
+ 'mac/installer.gyp:installer',
+ ],
+ },
+ ],
+ ['OS=="unix"',
+ {
+ 'dependencies': [
+ 'linux/installer.gyp:installer',
+ ],
+ },
+ ],
+ ],
+ },
+ ],
+}
diff --git a/o3d/installer/win/build.scons b/o3d/installer/win/build.scons
index 29f72a8..8f05cc8 100644
--- a/o3d/installer/win/build.scons
+++ b/o3d/installer/win/build.scons
@@ -165,6 +165,7 @@ docs_path = env.File('$SCONSTRUCT_DIR/installer/win/docs.url')
rep_path = env.File('$ARTIFACTS_DIR/reporter.exe')
dbl_path = env.File('$SCONSTRUCT_DIR/installer/win/driver_blacklist.txt')
get_extras_path = env.File('$ARTIFACTS_DIR/getextras.exe')
+custom_actions_path = env.File('$ARTIFACTS_DIR/cactions.dll')
# Tell wix to include the software renderer IFF it's there.
software_renderer_path = \
@@ -176,32 +177,33 @@ cactions_dll_path = env.File('$ARTIFACTS_DIR/cactions.dll')
# Pass flags to the wix compiler.
env.Append(WIXCANDLEFLAGS = [
- '-dNppProductGuid=' + o3d_npp_product_guid,
- '-dNppVersion=' + dotnppversion,
+ '-dCustomActionsPath=' + custom_actions_path,
+ '-dD3DXGuid=' + d3dx_guid,
+ '-dDBLGuid=' + o3d_driver_blacklist_guid,
+ '-dDBLPath=' + dbl_path.abspath,
'-dDeprecatedUpgradeCode=' + bad_old_o3d_upgrade_code,
- '-dNppUpgradeCode=' + o3d_npp_upgrade_code,
- '-dNppPackageGuid=' + o3d_npp_package_guid,
- '-dNppComponentGuid=' + o3d_npp_component_guid,
- '-dSoftwareRendererGuid=' + o3d_software_renderer_guid,
- '-dSoftwareRendererPath=' + software_renderer_path,
- '-dIncludeSoftwareRenderer=%s' % include_software_renderer,
- '-dNPPluginPath=' + npplugin_path.abspath,
+ '-dGetExtrasGuid=' + o3d_get_extras_guid,
+ '-dGetExtrasPath=' + get_extras_path.abspath,
'-dIEPluginPath=' + ieplugin_path.abspath,
'-dIepComponentGuid=' + o3d_iep_component_guid,
- '-dD3DXGuid=' + d3dx_guid,
+ '-dIncludeSoftwareRenderer=%s' % include_software_renderer,
+ '-dNPPluginPath=' + npplugin_path.abspath,
+ '-dNppComponentGuid=' + o3d_npp_component_guid,
'-dNppGoogleUpdateRegGuid=' + o3d_npp_google_update_reg_component_guid,
'-dNppGoogleUpdateRegKey=' + o3d_npp_reg_key,
'-dNppGoogleUpdateStateRegKey=' + o3d_npp_state_reg_key,
+ '-dNppPackageGuid=' + o3d_npp_package_guid,
+ '-dNppProductGuid=' + o3d_npp_product_guid,
+ '-dNppUpgradeCode=' + o3d_npp_upgrade_code,
+ '-dNppVersion=' + dotnppversion,
'-dRepGuid=' + o3d_reporter_guid,
- '-dDBLGuid=' + o3d_driver_blacklist_guid,
'-dRepPath=' + rep_path.abspath,
- '-dDBLPath=' + dbl_path.abspath,
- '-dGetExtrasGuid=' + o3d_get_extras_guid,
- '-dGetExtrasPath=' + get_extras_path.abspath,
+ '-dSoftwareRendererGuid=' + o3d_software_renderer_guid,
+ '-dSoftwareRendererPath=' + software_renderer_path,
])
# Build installer
-installer_msi = env.WiX('o3d.msi', ['o3d_plugin.wxs'])
+installer_msi = env.WiX('o3d.msi', ['o3d.wxs'])
# Make sure that the plugin dll has been built before building the installer.
# Make sure that the custom action dll has been built before building the
@@ -238,8 +240,7 @@ if os.path.exists(dx_redist_path.abspath):
])
# Build the installer
- extras_msi = env.WiX('o3dextras.msi', ['o3d_extras.wxs'])
+ extras_msi = env.WiX('o3dextras.msi', ['o3dextras.wxs'])
# copy to artifacts
env.Replicate('$ARTIFACTS_DIR', extras_msi)
-
diff --git a/o3d/installer/win/custom_actions.cc b/o3d/installer/win/custom_actions.cc
index 658d5b7..0f57d95 100644
--- a/o3d/installer/win/custom_actions.cc
+++ b/o3d/installer/win/custom_actions.cc
@@ -247,6 +247,7 @@ HRESULT SetCustomUpdateError(MSIHANDLE installer_handle,
return hr;
}
}
+ return S_OK;
}
// Check whether DirectX version 9.0c or higher is installed and
diff --git a/o3d/installer/win/installer.gyp b/o3d/installer/win/installer.gyp
new file mode 100644
index 0000000..9ea9145
--- /dev/null
+++ b/o3d/installer/win/installer.gyp
@@ -0,0 +1,302 @@
+# Copyright (c) 2009 The Chromium Authors. All rights reserved.
+# Use of this source code is governed by a BSD-style license that can be
+# found in the LICENSE file.
+
+{
+ 'variables': {
+ 'chromium_code': 1,
+ 'wixdir': 'third_party\\wix_2_0_4221\\files',
+ 'dx_redist_path': '../../../o3d-internal/third_party/dx_nov_2007_redist',
+ 'dx_redist_exists': '<!(python ../../build/file_exists.py ../../../o3d-internal/third_party/dx_nov_2007_redist/d3dx9_36.dll)',
+ 'guidgen': '..\\..\\nbguidgen\\win\\nbguidgen.exe',
+ 'nppversion': '<!(python ../../plugin/version_info.py --commaversion)',
+ 'dotnppversion': '<!(python ../../plugin/version_info.py --version)',
+
+ # Unique guid for o3d namespace
+ 'o3d_namespace_guid': 'B445DBAE-F5F9-435A-9A9B-088261CDF00A',
+
+ # Changing the following values would break upgrade paths, so we hard-code the
+ # values instead of generating them.
+ 'bad_old_o3d_upgrade_code': 'dc819ed6-4155-3cff-b580-45626aed5848',
+ 'o3d_extras_google_update_guid': '{34B2805D-C72C-4f81-AED5-5A22D1E092F1}',
+ 'o3d_extras_upgrade_code': 'c271f2f0-c7ad-3bc9-8216-211436aa2244',
+ 'o3d_npp_google_update_guid': '{70308795-045C-42da-8F4E-D452381A7459}',
+ 'o3d_npp_upgrade_code': '0f098121-2876-3c23-bd4c-501220ecbb42',
+
+ # We don't actually want the extras version to update by itself;
+ # it should change only when we actually add something to the
+ # installer or change the d3dx9 version. This version is
+ # therefore independent of the o3d plugin and sdk versions.
+ 'extrasversion': '0,1,1,0',
+ 'dotextrasversion': '0.1.1.0',
+
+ # Registry paths for Google Update
+ 'google_update_reg_path': 'Software\\Google\\Update\\Clients\\',
+ 'google_update_state_reg_path': 'Software\\Google\\Update\\ClientState\\',
+ },
+ 'includes': [
+ '../../build/common.gypi',
+ ],
+ 'targets': [
+ {
+ 'target_name': 'cactions',
+ 'type': 'shared_library',
+ 'sources': [
+ 'custom_actions.cc',
+ ],
+ 'include_dirs': [
+ '$(DXSDK_DIR)/Include',
+ '../..',
+ '../../..',
+ '<(INTERMEDIATE_DIR)',
+ ],
+ 'defines': [
+ 'NOMINMAX',
+ 'WIN32',
+ 'WIN32_LEAN_AND_MEAN',
+ '_ATL_SECURE_NO_WARNINGS',
+ '_CRT_SECURE_NO_DEPRECATE',
+ '_UNICODE', # turn on unicode
+ '_WIN32_WINNT=0x0600',
+ '_WINDOWS',
+ ],
+ 'libraries': [
+ '-ladvapi32.lib',
+ '"$(DXSDK_DIR)/Lib/x86/dxguid.lib"',
+ '-lmsi.lib',
+ '-lole32.lib',
+ '-loleaut32.lib',
+ '-lshell32.lib',
+ '-lshlwapi.lib',
+ '-luser32.lib',
+ ],
+ # Disable the #pragma deprecated warning because
+ # ATL seems to use deprecated CRT libs.
+ 'msvs_disabled_warnings': [4995],
+ 'msvs_configuration_attributes': {
+ 'UseOfATL': '1', # 1 = static link to ATL, 2 = dynamic link
+ },
+ 'copies': [
+ {
+ 'destination': '<(PRODUCT_DIR)',
+ 'files': [
+ 'cactions.dll',
+ ],
+ },
+ ],
+ },
+ {
+ 'target_name': 'installer',
+ 'type': 'none',
+ 'variables': {
+ 'candle_exe': '../../../<(wixdir)/candle.exe',
+ 'light_exe': '../../../<(wixdir)/light.exe',
+ 'custom_actions_path': '<(PRODUCT_DIR)/cactions.dll',
+ 'd3dx_guid': '<!(<(guidgen) <(o3d_namespace_guid) d3dx-<(nppversion))',
+ 'dbl_path': '../../installer/win/driver_blacklist.txt',
+ 'dx_redist_guid': '<!(<(guidgen) <(o3d_namespace_guid) '
+ 'dx_redist-<(nppversion))',
+ 'get_extras_path': '<(PRODUCT_DIR)/getextras.exe',
+ 'ieplugin_path': '<(PRODUCT_DIR)/o3d_host.dll',
+ 'include_software_renderer':
+ '<!(python ../../build/file_exists.py '
+ '../../../<(swiftshaderdir)/swiftshader_d3d9.dll)',
+ 'npplugin_path': '<(PRODUCT_DIR)/npo3dautoplugin.dll',
+ 'o3d_driver_blacklist_guid': '<!(<(guidgen) <(o3d_namespace_guid) '
+ 'o3d_driver_blacklist-<(nppversion))',
+ 'o3d_get_extras_guid':
+ '<!(<(guidgen) <(o3d_namespace_guid) extras_installer-)',
+ 'o3d_iep_component_guid': '<!(<(guidgen) <(o3d_namespace_guid) '
+ 'o3d_ieplugin_component-<(nppversion))',
+ 'o3d_npp_component_guid': '<!(<(guidgen) <(o3d_namespace_guid) '
+ 'o3d_npplugin_component-<(nppversion))',
+ 'o3d_npp_google_update_reg_component_guid':
+ '<!(<(guidgen) <(o3d_namespace_guid) '
+ 'o3d_user_google_update_reg_component-<(nppversion))',
+ 'o3d_npp_package_guid': '<!(<(guidgen) <(o3d_namespace_guid) o3d_package-<(nppversion))',
+ 'o3d_npp_product_guid': '<!(<(guidgen) <(o3d_namespace_guid) o3d_product-<(nppversion))',
+ 'o3d_npp_reg_key':
+ '<(google_update_reg_path)<(o3d_npp_google_update_guid)',
+ 'o3d_npp_state_reg_key':
+ '<(google_update_state_reg_path)<(o3d_npp_google_update_guid)',
+ 'o3d_reporter_guid':
+ '<!(<(guidgen) <(o3d_namespace_guid) o3d_reporter-<(nppversion))',
+ 'o3d_software_renderer_guid': '<!(<(guidgen) <(o3d_namespace_guid) '
+ 'o3d_software_renderer-<(nppversion))',
+ 'rep_path': '<(PRODUCT_DIR)/reporter.exe',
+ 'software_renderer_path':
+ '../../../<(swiftshaderdir)/swiftshader_d3d9.dll',
+ },
+ 'dependencies': [
+ '../../converter/converter.gyp:o3dConverter',
+ '../../breakpad/breakpad.gyp:reporter',
+ '../../google_update/google_update.gyp:getextras',
+ '../../documentation/documentation.gyp:*',
+ '../../plugin/plugin.gyp:npo3dautoplugin',
+ '../../plugin/plugin.gyp:o3d_host',
+ '../../samples/samples.gyp:samples',
+ 'cactions',
+ ],
+ 'rules': [
+ {
+ 'rule_name': 'candle',
+ 'extension': 'wxs',
+ 'process_outputs_as_sources': 1,
+ 'inputs': [
+ '<(candle_exe)',
+ '../../installer/win/docs.url',
+ '<(PRODUCT_DIR)/cactions.dll',
+ '<(PRODUCT_DIR)/cg.dll',
+ '<(PRODUCT_DIR)/cgGL.dll',
+ '<(PRODUCT_DIR)/cgc.exe',
+ '<(PRODUCT_DIR)/o3dConditioner.exe',
+ '<(dbl_path)',
+ '<(get_extras_path)',
+ '<(ieplugin_path)',
+ '<(npplugin_path)',
+ '<(rep_path)',
+ ],
+ 'outputs': [
+ '<(RULE_INPUT_ROOT).wixobj',
+ ],
+ 'action': [
+ '<(candle_exe)',
+ '-nologo',
+ '-dCustomActionsPath=<(custom_actions_path)',
+ '-dD3DXGuid=<(d3dx_guid)',
+ '-dDBLGuid=<(o3d_driver_blacklist_guid)',
+ '-dDBLPath=<(dbl_path)',
+ '-dDeprecatedUpgradeCode=<(bad_old_o3d_upgrade_code)',
+ '-dGetExtrasGuid=<(o3d_get_extras_guid)',
+ '-dGetExtrasPath=<(get_extras_path)',
+ '-dIEPluginPath=<(ieplugin_path)',
+ '-dIepComponentGuid=<(o3d_iep_component_guid)',
+ '-dIncludeSoftwareRenderer=include_software_renderer',
+ '-dNPPluginPath=<(npplugin_path)',
+ '-dNppComponentGuid=<(o3d_npp_component_guid)',
+ '-dNppGoogleUpdateRegGuid=<(o3d_npp_google_update_reg_component_guid)',
+ '-dNppGoogleUpdateRegKey=<(o3d_npp_reg_key)',
+ '-dNppGoogleUpdateStateRegKey=<(o3d_npp_state_reg_key)',
+ '-dNppPackageGuid=<(o3d_npp_package_guid)',
+ '-dNppProductGuid=<(o3d_npp_product_guid)',
+ '-dNppUpgradeCode=<(o3d_npp_upgrade_code)',
+ '-dNppVersion=<(dotnppversion)',
+ '-dRepGuid=<(o3d_reporter_guid)',
+ '-dRepPath=<(rep_path)',
+ '-dSoftwareRendererGuid=<(o3d_software_renderer_guid)',
+ '-dSoftwareRendererPath=<(software_renderer_path)',
+ '-o',
+ '<(RULE_INPUT_ROOT).wixobj',
+ '<(RULE_INPUT_PATH)',
+ ],
+ 'message': 'Generating installer from <(RULE_INPUT_PATH)',
+ },
+ {
+ 'rule_name': 'light',
+ 'extension': 'wixobj',
+ 'process_outputs_as_sources': 1,
+ 'inputs': [
+ '<(light_exe)',
+ ],
+ 'outputs': [
+ '<(PRODUCT_DIR)/<(RULE_INPUT_ROOT).msi',
+ ],
+ 'action': [
+ '<(light_exe)',
+ '-nologo',
+ '-out',
+ '<(PRODUCT_DIR)/<(RULE_INPUT_ROOT).msi',
+ '<(RULE_INPUT_PATH)',
+ ],
+ 'message': 'Linking installer from <(RULE_INPUT_PATH)',
+ },
+ ],
+ 'sources': [
+ 'o3d.wxs',
+ ],
+ },
+ ],
+ 'conditions': [
+ ['"<(dx_redist_exists)" == "True"',
+ {
+ 'targets': [
+ {
+ 'target_name': 'extras_installer',
+ 'type': 'none',
+ 'variables': {
+ 'candle_exe': '../../../<(wixdir)/candle.exe',
+ 'light_exe': '../../../<(wixdir)/light.exe',
+ 'o3d_extras_d3dx_component_guid': '<!(<(guidgen) <(o3d_namespace_guid) '
+ 'o3d_extras_d3dx_component-<(nppversion))',
+ 'o3d_extras_package_guid': '<!(<(guidgen) <(o3d_namespace_guid) '
+ 'o3d_extras_package-<(extrasversion))',
+ 'o3d_extras_product_guid': '<!(<(guidgen) <(o3d_namespace_guid) '
+ 'o3d_extras_product-<(extrasversion))',
+ 'o3d_extras_reg_key':
+ '<(google_update_reg_path)<(o3d_extras_google_update_guid)',
+ },
+ 'rules': [
+ {
+ 'rule_name': 'candle',
+ 'extension': 'wxs',
+ 'process_outputs_as_sources': 1,
+ 'inputs': [
+ '<(candle_exe)',
+ ],
+ 'outputs': [
+ '<(RULE_INPUT_ROOT).wixobj',
+ ],
+ 'action': [
+ '<(candle_exe)',
+ '-nologo',
+ '-dDxRedistPath=<(dx_redist_path)',
+ '-dExtrasD3DXComponentGuid=<(o3d_extras_d3dx_component_guid)',
+ '-dExtrasGoogleUpdateRegGuid=<(o3d_extras_google_update_guid)',
+ '-dExtrasGoogleUpdateRegKey=<(o3d_extras_reg_key)',
+ '-dExtrasPackageGuid=<(o3d_extras_package_guid)',
+ '-dExtrasProductGuid=<(o3d_extras_product_guid)',
+ '-dExtrasUpgradeCode=<(o3d_extras_upgrade_code)',
+ '-dExtrasVersion=<(dotextrasversion)',
+ '-o',
+ '<(RULE_INPUT_ROOT).wixobj',
+ '<(RULE_INPUT_PATH)',
+ ],
+ 'message': 'Generating extras installer from <(RULE_INPUT_PATH)',
+ },
+ {
+ 'rule_name': 'light',
+ 'extension': 'wixobj',
+ 'process_outputs_as_sources': 1,
+ 'inputs': [
+ '<(light_exe)',
+ ],
+ 'outputs': [
+ '<(PRODUCT_DIR)/<(RULE_INPUT_ROOT).msi',
+ ],
+ 'action': [
+ '<(light_exe)',
+ '-nologo',
+ '-out',
+ '<(PRODUCT_DIR)/<(RULE_INPUT_ROOT).msi',
+ '<(RULE_INPUT_PATH)',
+ ],
+ 'message': 'Linking extras installer from <(RULE_INPUT_PATH)',
+ },
+ ],
+ 'sources': [
+ 'o3dextras.wxs',
+ ],
+ },
+ ],
+ },
+ {
+ 'targets': [
+ {
+ 'target_name': 'extras_installer',
+ 'type': 'none',
+ },
+ ],
+ },
+ ],
+ ],
+}
diff --git a/o3d/installer/win/o3d_plugin.wxs b/o3d/installer/win/o3d.wxs
index 5d3f114..534c639 100644
--- a/o3d/installer/win/o3d_plugin.wxs
+++ b/o3d/installer/win/o3d.wxs
@@ -309,7 +309,7 @@ Wix script for building o3d installer.
<Binary
Id='CustomActions'
- SourceFile='cactions.dll' />
+ SourceFile='$(var.CustomActionsPath)' />
<!-- Custom action for telling Google Update to install d3dx if necessary. -->
<CustomAction
diff --git a/o3d/installer/win/o3d_extras.wxs b/o3d/installer/win/o3dextras.wxs
index 9568236..9568236 100644
--- a/o3d/installer/win/o3d_extras.wxs
+++ b/o3d/installer/win/o3dextras.wxs