mirror of
https://github.com/python/cpython.git
synced 2025-09-23 08:53:45 +00:00
* Make it easier to build custom installers (such as a 3-way universal build)
* Upgrade bzip dependency to 1.0.5
This commit is contained in:
parent
a9cfbded4b
commit
c66ced30be
2 changed files with 200 additions and 182 deletions
|
@ -61,12 +61,25 @@ DEPSRC = os.path.join(WORKDIR, 'third-party')
|
||||||
DEPSRC = os.path.expanduser('~/Universal/other-sources')
|
DEPSRC = os.path.expanduser('~/Universal/other-sources')
|
||||||
|
|
||||||
# Location of the preferred SDK
|
# Location of the preferred SDK
|
||||||
|
if int(os.uname()[2].split('.')[0]) == 8:
|
||||||
|
# Explicitly use the 10.4u (universal) SDK when
|
||||||
|
# building on 10.4, the system headers are not
|
||||||
|
# useable for a universal build
|
||||||
SDKPATH = "/Developer/SDKs/MacOSX10.4u.sdk"
|
SDKPATH = "/Developer/SDKs/MacOSX10.4u.sdk"
|
||||||
#SDKPATH = "/"
|
else:
|
||||||
|
SDKPATH = "/"
|
||||||
|
|
||||||
universal_opts_map = { '32-bit': ('i386', 'ppc',),
|
universal_opts_map = { '32-bit': ('i386', 'ppc',),
|
||||||
'64-bit': ('x86_64', 'ppc64',),
|
'64-bit': ('x86_64', 'ppc64',),
|
||||||
|
'intel': ('i386', 'x86_64'),
|
||||||
|
'3-way': ('ppc', 'i386', 'x86_64'),
|
||||||
'all': ('i386', 'ppc', 'x86_64', 'ppc64',) }
|
'all': ('i386', 'ppc', 'x86_64', 'ppc64',) }
|
||||||
|
default_target_map = {
|
||||||
|
'64-bit': '10.5',
|
||||||
|
'3-way': '10.5',
|
||||||
|
'intel': '10.5',
|
||||||
|
'all': '10.5',
|
||||||
|
}
|
||||||
|
|
||||||
UNIVERSALOPTS = tuple(universal_opts_map.keys())
|
UNIVERSALOPTS = tuple(universal_opts_map.keys())
|
||||||
|
|
||||||
|
@ -104,11 +117,14 @@ USAGE = textwrap.dedent("""\
|
||||||
# [The recipes are defined here for convenience but instantiated later after
|
# [The recipes are defined here for convenience but instantiated later after
|
||||||
# command line options have been processed.]
|
# command line options have been processed.]
|
||||||
def library_recipes():
|
def library_recipes():
|
||||||
return [
|
result = []
|
||||||
|
|
||||||
|
if DEPTARGET < '10.5':
|
||||||
|
result.extend([
|
||||||
dict(
|
dict(
|
||||||
name="Bzip2 1.0.4",
|
name="Bzip2 1.0.5",
|
||||||
url="http://www.bzip.org/1.0.4/bzip2-1.0.4.tar.gz",
|
url="http://www.bzip.org/1.0.5/bzip2-1.0.5.tar.gz",
|
||||||
checksum='fc310b254f6ba5fbb5da018f04533688',
|
checksum='3c15a0c8d1d3ee1c46a1634d00617b1a',
|
||||||
configure=None,
|
configure=None,
|
||||||
install='make install PREFIX=%s/usr/local/ CFLAGS="-arch %s -isysroot %s"'%(
|
install='make install PREFIX=%s/usr/local/ CFLAGS="-arch %s -isysroot %s"'%(
|
||||||
shellQuote(os.path.join(WORKDIR, 'libraries')),
|
shellQuote(os.path.join(WORKDIR, 'libraries')),
|
||||||
|
@ -142,7 +158,6 @@ def library_recipes():
|
||||||
'http://ftp.gnu.org/pub/gnu/readline/readline-5.1-patches/readline51-004',
|
'http://ftp.gnu.org/pub/gnu/readline/readline-5.1-patches/readline51-004',
|
||||||
]
|
]
|
||||||
),
|
),
|
||||||
|
|
||||||
dict(
|
dict(
|
||||||
name="SQLite 3.6.11",
|
name="SQLite 3.6.11",
|
||||||
url="http://www.sqlite.org/sqlite-3.6.11.tar.gz",
|
url="http://www.sqlite.org/sqlite-3.6.11.tar.gz",
|
||||||
|
@ -155,7 +170,6 @@ def library_recipes():
|
||||||
'--disable-tcl',
|
'--disable-tcl',
|
||||||
]
|
]
|
||||||
),
|
),
|
||||||
|
|
||||||
dict(
|
dict(
|
||||||
name="NCurses 5.5",
|
name="NCurses 5.5",
|
||||||
url="http://ftp.gnu.org/pub/gnu/ncurses/ncurses-5.5.tar.gz",
|
url="http://ftp.gnu.org/pub/gnu/ncurses/ncurses-5.5.tar.gz",
|
||||||
|
@ -185,6 +199,9 @@ def library_recipes():
|
||||||
getVersion(),
|
getVersion(),
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
|
])
|
||||||
|
|
||||||
|
result.extend([
|
||||||
dict(
|
dict(
|
||||||
name="Sleepycat DB 4.7.25",
|
name="Sleepycat DB 4.7.25",
|
||||||
url="http://download.oracle.com/berkeley-db/db-4.7.25.tar.gz",
|
url="http://download.oracle.com/berkeley-db/db-4.7.25.tar.gz",
|
||||||
|
@ -195,11 +212,14 @@ def library_recipes():
|
||||||
'--includedir=/usr/local/include/db4',
|
'--includedir=/usr/local/include/db4',
|
||||||
]
|
]
|
||||||
),
|
),
|
||||||
]
|
])
|
||||||
|
|
||||||
|
return result
|
||||||
|
|
||||||
|
|
||||||
# Instructions for building packages inside the .mpkg.
|
# Instructions for building packages inside the .mpkg.
|
||||||
PKG_RECIPES = [
|
def pkg_recipes():
|
||||||
|
result = [
|
||||||
dict(
|
dict(
|
||||||
name="PythonFramework",
|
name="PythonFramework",
|
||||||
long_name="Python Framework",
|
long_name="Python Framework",
|
||||||
|
@ -266,6 +286,10 @@ PKG_RECIPES = [
|
||||||
source="/empty-dir",
|
source="/empty-dir",
|
||||||
required=False,
|
required=False,
|
||||||
),
|
),
|
||||||
|
]
|
||||||
|
|
||||||
|
if DEPTARGET < '10.4':
|
||||||
|
result.append(
|
||||||
dict(
|
dict(
|
||||||
name="PythonSystemFixes",
|
name="PythonSystemFixes",
|
||||||
long_name="Fix system Python",
|
long_name="Fix system Python",
|
||||||
|
@ -279,7 +303,8 @@ PKG_RECIPES = [
|
||||||
source="/empty-dir",
|
source="/empty-dir",
|
||||||
required=False,
|
required=False,
|
||||||
)
|
)
|
||||||
]
|
)
|
||||||
|
return result
|
||||||
|
|
||||||
def fatal(msg):
|
def fatal(msg):
|
||||||
"""
|
"""
|
||||||
|
@ -327,10 +352,10 @@ def checkEnvironment():
|
||||||
"""
|
"""
|
||||||
|
|
||||||
if platform.system() != 'Darwin':
|
if platform.system() != 'Darwin':
|
||||||
fatal("This script should be run on a Mac OS X 10.4 system")
|
fatal("This script should be run on a Mac OS X 10.4 (or later) system")
|
||||||
|
|
||||||
if platform.release() <= '8.':
|
if int(platform.release().split('.')[0]) <= 8:
|
||||||
fatal("This script should be run on a Mac OS X 10.4 system")
|
fatal("This script should be run on a Mac OS X 10.4 (or later) system")
|
||||||
|
|
||||||
if not os.path.exists(SDKPATH):
|
if not os.path.exists(SDKPATH):
|
||||||
fatal("Please install the latest version of Xcode and the %s SDK"%(
|
fatal("Please install the latest version of Xcode and the %s SDK"%(
|
||||||
|
@ -360,6 +385,7 @@ def parseOptions(args=None):
|
||||||
print "Additional arguments"
|
print "Additional arguments"
|
||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
|
|
||||||
|
deptarget = None
|
||||||
for k, v in options:
|
for k, v in options:
|
||||||
if k in ('-h', '-?', '--help'):
|
if k in ('-h', '-?', '--help'):
|
||||||
print USAGE
|
print USAGE
|
||||||
|
@ -379,11 +405,16 @@ def parseOptions(args=None):
|
||||||
|
|
||||||
elif k in ('--dep-target', ):
|
elif k in ('--dep-target', ):
|
||||||
DEPTARGET=v
|
DEPTARGET=v
|
||||||
|
deptarget=v
|
||||||
|
|
||||||
elif k in ('--universal-archs', ):
|
elif k in ('--universal-archs', ):
|
||||||
if v in UNIVERSALOPTS:
|
if v in UNIVERSALOPTS:
|
||||||
UNIVERSALARCHS = v
|
UNIVERSALARCHS = v
|
||||||
ARCHLIST = universal_opts_map[UNIVERSALARCHS]
|
ARCHLIST = universal_opts_map[UNIVERSALARCHS]
|
||||||
|
if deptarget is None:
|
||||||
|
# Select alternate default deployment
|
||||||
|
# target
|
||||||
|
DEPTARGET = default_target_map.get(v, '10.3')
|
||||||
else:
|
else:
|
||||||
raise NotImplementedError, v
|
raise NotImplementedError, v
|
||||||
|
|
||||||
|
@ -873,7 +904,7 @@ def makeMpkgPlist(path):
|
||||||
IFPkgFlagPackageLocation='%s-%s.pkg'%(item['name'], getVersion()),
|
IFPkgFlagPackageLocation='%s-%s.pkg'%(item['name'], getVersion()),
|
||||||
IFPkgFlagPackageSelection='selected'
|
IFPkgFlagPackageSelection='selected'
|
||||||
)
|
)
|
||||||
for item in PKG_RECIPES
|
for item in pkg_recipes()
|
||||||
],
|
],
|
||||||
IFPkgFormatVersion=0.10000000149011612,
|
IFPkgFormatVersion=0.10000000149011612,
|
||||||
IFPkgFlagBackgroundScaling="proportional",
|
IFPkgFlagBackgroundScaling="proportional",
|
||||||
|
@ -900,7 +931,7 @@ def buildInstaller():
|
||||||
pkgroot = os.path.join(outdir, 'Python.mpkg', 'Contents')
|
pkgroot = os.path.join(outdir, 'Python.mpkg', 'Contents')
|
||||||
pkgcontents = os.path.join(pkgroot, 'Packages')
|
pkgcontents = os.path.join(pkgroot, 'Packages')
|
||||||
os.makedirs(pkgcontents)
|
os.makedirs(pkgcontents)
|
||||||
for recipe in PKG_RECIPES:
|
for recipe in pkg_recipes():
|
||||||
packageFromRecipe(pkgcontents, recipe)
|
packageFromRecipe(pkgcontents, recipe)
|
||||||
|
|
||||||
rsrcDir = os.path.join(pkgroot, 'Resources')
|
rsrcDir = os.path.join(pkgroot, 'Resources')
|
||||||
|
@ -948,9 +979,9 @@ def buildDMG():
|
||||||
shutil.rmtree(outdir)
|
shutil.rmtree(outdir)
|
||||||
|
|
||||||
imagepath = os.path.join(outdir,
|
imagepath = os.path.join(outdir,
|
||||||
'python-%s-macosx'%(getFullVersion(),))
|
'python-%s-macosx%s'%(getFullVersion(),DEPTARGET))
|
||||||
if INCLUDE_TIMESTAMP:
|
if INCLUDE_TIMESTAMP:
|
||||||
imagepath = imagepath + '%04d-%02d-%02d'%(time.localtime()[:3])
|
imagepath = imagepath + '-%04d-%02d-%02d'%(time.localtime()[:3])
|
||||||
imagepath = imagepath + '.dmg'
|
imagepath = imagepath + '.dmg'
|
||||||
|
|
||||||
os.mkdir(outdir)
|
os.mkdir(outdir)
|
||||||
|
@ -1054,11 +1085,8 @@ def main():
|
||||||
print >> fp, "# By:", pwd.getpwuid(os.getuid()).pw_gecos
|
print >> fp, "# By:", pwd.getpwuid(os.getuid()).pw_gecos
|
||||||
fp.close()
|
fp.close()
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# And copy it to a DMG
|
# And copy it to a DMG
|
||||||
buildDMG()
|
buildDMG()
|
||||||
|
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
main()
|
main()
|
||||||
|
|
|
@ -16,16 +16,6 @@ FWK="/Library/Frameworks/Python.framework/Versions/@PYVER@"
|
||||||
-x badsyntax -x site-packages \
|
-x badsyntax -x site-packages \
|
||||||
"${FWK}/lib/python${PYVER}"
|
"${FWK}/lib/python${PYVER}"
|
||||||
|
|
||||||
"${FWK}/bin/python@PYVER@" -Wi -tt \
|
|
||||||
"${FWK}/lib/python${PYVER}/compileall.py" \
|
|
||||||
-x badsyntax -x site-packages \
|
|
||||||
"${FWK}/Mac/Tools"
|
|
||||||
|
|
||||||
"${FWK}/bin/python@PYVER@" -Wi -tt -O \
|
|
||||||
"${FWK}/lib/python${PYVER}/compileall.py" \
|
|
||||||
-x badsyntax -x site-packages \
|
|
||||||
"${FWK}/Mac/Tools"
|
|
||||||
|
|
||||||
chgrp -R admin "${FWK}"
|
chgrp -R admin "${FWK}"
|
||||||
chmod -R g+w "${FWK}"
|
chmod -R g+w "${FWK}"
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue