diff options
author | Jack Jansen <jack.jansen@cwi.nl> | 2004-02-28 23:18:43 (GMT) |
---|---|---|
committer | Jack Jansen <jack.jansen@cwi.nl> | 2004-02-28 23:18:43 (GMT) |
commit | 192bd966ad6ed452f264f97bba2e50351eb09fca (patch) | |
tree | b07c8b13663765f8289046e920e6a1c40b095130 /Lib/plat-mac/pimp.py | |
parent | afd63b9c4050f59ed81c964b9dcb5fd2639a390a (diff) | |
download | cpython-192bd966ad6ed452f264f97bba2e50351eb09fca.zip cpython-192bd966ad6ed452f264f97bba2e50351eb09fca.tar.gz cpython-192bd966ad6ed452f264f97bba2e50351eb09fca.tar.bz2 |
getDefaultDatabase() should be a toplevel function, not a method of the
preferences object.
Diffstat (limited to 'Lib/plat-mac/pimp.py')
-rw-r--r-- | Lib/plat-mac/pimp.py | 94 |
1 files changed, 46 insertions, 48 deletions
diff --git a/Lib/plat-mac/pimp.py b/Lib/plat-mac/pimp.py index fc97ea3..131d5b0 100644 --- a/Lib/plat-mac/pimp.py +++ b/Lib/plat-mac/pimp.py @@ -46,6 +46,51 @@ DEFAULT_BUILDDIR='/tmp' DEFAULT_INSTALLDIR=distutils.sysconfig.get_python_lib() DEFAULT_PIMPDATABASE_FMT="http://www.python.org/packman/version-%s/%s-%s-%s-%s-%s.plist" +def getDefaultDatabase(experimental=False): + if experimental: + status = "exp" + else: + status = "prod" + + major, minor, micro, state, extra = sys.version_info + pyvers = '%d.%d' % (major, minor) + if state != 'final': + pyvers = pyvers + '%s%d' % (state, extra) + + longplatform = distutils.util.get_platform() + osname, release, machine = longplatform.split('-') + # For some platforms we may want to differentiate between + # installation types + if osname == 'darwin': + if sys.prefix.startswith('/System/Library/Frameworks/Python.framework'): + osname = 'darwin_apple' + elif sys.prefix.startswith('/Library/Frameworks/Python.framework'): + osname = 'darwin_macpython' + # Otherwise we don't know... + # Now we try various URLs by playing with the release string. + # We remove numbers off the end until we find a match. + rel = release + while True: + url = DEFAULT_PIMPDATABASE_FMT % (PIMP_VERSION, status, pyvers, osname, rel, machine) + try: + urllib2.urlopen(url) + except urllib2.HTTPError, arg: + pass + else: + break + if not rel: + # We're out of version numbers to try. Use the + # full release number, this will give a reasonable + # error message later + url = DEFAULT_PIMPDATABASE_FMT % (PIMP_VERSION, status, pyvers, osname, release, machine) + break + idx = rel.rfind('.') + if idx < 0: + rel = '' + else: + rel = rel[:idx] + return url + def _cmd(output, dir, *cmditems): """Internal routine to run a shell command in a given directory.""" @@ -163,7 +208,7 @@ class PimpPreferences: if not buildDir: buildDir = DEFAULT_BUILDDIR if not pimpDatabase: - pimpDatabase = self.getDefaultDatabase() + pimpDatabase = getDefaultDatabase() self.setInstallDir(installDir) self.flavorOrder = flavorOrder self.downloadDir = downloadDir @@ -185,53 +230,6 @@ class PimpPreferences: def isUserInstall(self): return self.installDir != DEFAULT_INSTALLDIR - - def getDefaultDatabase(self, experimental=False): - if experimental: - status = "exp" - else: - status = "prod" - - major, minor, micro, state, extra = sys.version_info - pyvers = '%d.%d' % (major, minor) - if state != 'final': - pyvers = pyvers + '%s%d' % (state, extra) - - longplatform = distutils.util.get_platform() - osname, release, machine = longplatform.split('-') - # For some platforms we may want to differentiate between - # installation types - if osname == 'darwin': - if sys.prefix.startswith('/System/Library/Frameworks/Python.framework'): - osname = 'darwin_apple' - elif sys.prefix.startswith('/Library/Frameworks/Python.framework'): - osname = 'darwin_macpython' - # Otherwise we don't know... - # Now we try various URLs by playing with the release string. - # We remove numbers off the end until we find a match. - rel = release - while True: - url = DEFAULT_PIMPDATABASE_FMT % (PIMP_VERSION, status, pyvers, osname, rel, machine) - try: - urllib2.urlopen(url) - except urllib2.HTTPError, arg: - print 'getDefaultDatabase: cannot open', url - print 'error', arg - pass - else: - break - if not rel: - # We're out of version numbers to try. Use the - # full release number, this will give a reasonable - # error message later - url = DEFAULT_PIMPDATABASE_FMT % (PIMP_VERSION, status, pyvers, osname, release, machine) - break - idx = rel.rfind('.') - if idx < 0: - rel = '' - else: - rel = rel[:idx] - return url def check(self): """Check that the preferences make sense: directories exist and are |