diff options
-rw-r--r-- | gears/SConscript | 10 | ||||
-rw-r--r-- | gears/SConscript.browser | 1 | ||||
-rwxr-xr-x | gears/SConscript.inputs | 9 | ||||
-rw-r--r-- | gears/SConscript.installers | 31 |
4 files changed, 51 insertions, 0 deletions
diff --git a/gears/SConscript b/gears/SConscript index 902495b..881c021 100644 --- a/gears/SConscript +++ b/gears/SConscript @@ -139,6 +139,10 @@ env.Replace( FF_XPI = '$INSTALLER_OUTDIR/${INSTALLER_BASENAME}.xpi', WIN32_INSTALLER_MSI = '$INSTALLER_OUTDIR/${INSTALLER_BASENAME}.msi', WINCE_INSTALLER_CAB = '$INSTALLER_OUTDIR/${INSTALLER_BASENAME}.cab', + # Keyston SF Metapackage installer, bundled with Keystone as part of a + # DMG. + SF_KEYSTONE_INSTALLER_DMG = '$INSTALLER_OUTDIR/${INSTALLER_BASENAME}.dmg', + SF_KEYSTONE_INSTALLER_MPKG = '$INSTALLER_OUTDIR/Safari/${FRIENDLY_NAME}.mpkg', SF_INSTALLER_PLUGIN_BUNDLE = '$INSTALLER_OUTDIR/Safari/StatsPane.bundle', SF_PLUGIN_BUNDLE = '$INSTALLER_OUTDIR/Safari/Gears.bundle', @@ -724,6 +728,12 @@ elif env['OS'] == 'osx': '-DGEARS_ENABLER_PATH="$SF_INPUTMANAGER_BUNDLE"', '-DGEARS_PLUGIN_PATH="$SF_PLUGIN_PROXY_BUNDLE"', '-DGEARS_INSTALLER_OUT_DIR="$INSTALLER_OUTDIR/Safari"', + + # Keystone + '-DKEYSTONE_BASE_DIR="$MAIN_DIR/$PRIVATE_THIRD_PARTY_DIR/googlemac/Releases/Keystone/"', + '-DGEARS_INSTALLER_PACKAGE="$SF_INSTALLER_PKG"', + '-DGEARS_GENFILES_DIR="$SF_OUTDIR/genfiles"', + '-DGEARS_TOOLS_DIR="$MAIN_DIR/$PRIVATE_DIR/tools"', ], ) if not env['OFFICIAL_BUILD']: diff --git a/gears/SConscript.browser b/gears/SConscript.browser index cb853d7..176d8c7 100644 --- a/gears/SConscript.browser +++ b/gears/SConscript.browser @@ -389,6 +389,7 @@ outputs = {} # genfiles/%: %.m4 m4s = [env.M4(*PatternRule('$GENFILES_DIR/${SOURCE.filebase}', src)) for src in GetInputs('$BROWSER_M4SRCS')] +outputs['M4S'] = m4s # genfiles/%.html: %.html_m4 html_m4s = [env.M4( diff --git a/gears/SConscript.inputs b/gears/SConscript.inputs index d6accaa..d0a885a 100755 --- a/gears/SConscript.inputs +++ b/gears/SConscript.inputs @@ -136,6 +136,15 @@ env.Append(SF_M4SRCS = [ ]) #----------------------------------------------------------------------------- +# Keystone + +env.Append(SF_M4SRCS = [ + '$PRIVATE_DIR/tools/osx/installer/InstallationCheck.strings.m4', + '$PRIVATE_DIR/tools/osx/installer/keystone_installer.packproj.m4', + '$PRIVATE_DIR/tools/osx/installer/postflight.sh.m4', +]) + +#----------------------------------------------------------------------------- # mozjs bindings mozjs_sources = [ diff --git a/gears/SConscript.installers b/gears/SConscript.installers index c528985..e55dd6d 100644 --- a/gears/SConscript.installers +++ b/gears/SConscript.installers @@ -339,6 +339,36 @@ def SafariInstallerPackage(): return pkg safari_installer_package = SafariInstallerPackage() +def SafariKeystoneInstaller(): + if not os.path.exists(env.Dir('#/$PRIVATE_DIR').abspath): + print 'Skipping Safari Keystone installer. Required sources are not public.' + return [] + + env.Append(CREATE_DISK_IMAGE = + "/usr/bin/hdiutil create -ov -imagekey zlib-level=9 -fs HFS+" + " -format UDZO -volname '$FRIENDLY_NAME ${VERSION}'" + " -srcfolder '${INSTALLER_OUTDIR}/Safari/dmg/' -scrub" + " -nocrossdev '${SF_KEYSTONE_INSTALLER_DMG}'" + ) + + pkg = env.Iceberg(env.Dir('${SF_KEYSTONE_INSTALLER_MPKG}'), + ['$SF_OUTDIR/genfiles/keystone_installer.packproj']) + env.Depends(pkg, GetInputs('$SF_M4S')) + env.Depends(pkg, safari_installer_package) + + dirsrcs = [ + ('/', [pkg]), + ('/.keystone_install', + ['$PRIVATE_DIR/tools/osx/installer/keystone_install']), + ] + dmg = env.DirBuilder('$INSTALLER_OUTDIR/Safari/dmg', dirsrcs) + env.AddPostAction(dmg, 'chmod +x ${TARGET.base}/.keystone_install') + # hdiutil is crashy under leopard, so try twice. + env.AddPostAction(dmg, '$CREATE_DISK_IMAGE || $CREATE_DISK_IMAGE') + + return dmg +safari_keystone_installer = SafariKeystoneInstaller() + installers = [] if 'FF3' in env['VALID_BROWSERS']: installers += firefox_installer @@ -350,6 +380,7 @@ if 'SF' in env['VALID_BROWSERS']: safari_installer_plugin_bundle, safari_installer_package, safari_input_manager_bundle, + safari_keystone_installer, ] if env['OS'] == 'win32': installers += win32_installer |