Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
P
protobuf
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
submodule
protobuf
Commits
c0f673d0
Commit
c0f673d0
authored
Jan 13, 2015
by
Tres Seaver
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'update-ez_setup' into straddle_py2_py3
parents
f1eae1a1
7c7f06c5
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
278 additions
and
230 deletions
+278
-230
ez_setup.py
python/ez_setup.py
+278
-230
No files found.
python/ez_setup.py
100755 → 100644
View file @
c0f673d0
#!python
# This file was obtained from:
# http://peak.telecommunity.com/dist/ez_setup.py
# on 2011/1/21.
#!/usr/bin/env python
"""Bootstrap setuptools installation
If you want to use setuptools in your package's setup.py, just
include this
file in the same directory
with it,
and add this to the top of your setup.py::
To use setuptools in your package's setup.py,
include this
file in the same directory and add this to the top of your setup.py::
from ez_setup import use_setuptools
use_setuptools()
If you want t
o require a specific version of setuptools, set a download
mirror, or use an alternate download directory,
you can do so by supplying
T
o require a specific version of setuptools, set a download
mirror, or use an alternate download directory,
simply supply
the appropriate options to ``use_setuptools()``.
This file can also be run as a script to install or upgrade setuptools.
"""
import
os
import
shutil
import
sys
DEFAULT_VERSION
=
"0.6c11"
DEFAULT_URL
=
"http://pypi.python.org/packages/
%
s/s/setuptools/"
%
sys
.
version
[:
3
]
md5_data
=
{
'setuptools-0.6b1-py2.3.egg'
:
'8822caf901250d848b996b7f25c6e6ca'
,
'setuptools-0.6b1-py2.4.egg'
:
'b79a8a403e4502fbb85ee3f1941735cb'
,
'setuptools-0.6b2-py2.3.egg'
:
'5657759d8a6d8fc44070a9d07272d99b'
,
'setuptools-0.6b2-py2.4.egg'
:
'4996a8d169d2be661fa32a6e52e4f82a'
,
'setuptools-0.6b3-py2.3.egg'
:
'bb31c0fc7399a63579975cad9f5a0618'
,
'setuptools-0.6b3-py2.4.egg'
:
'38a8c6b3d6ecd22247f179f7da669fac'
,
'setuptools-0.6b4-py2.3.egg'
:
'62045a24ed4e1ebc77fe039aa4e6f7e5'
,
'setuptools-0.6b4-py2.4.egg'
:
'4cb2a185d228dacffb2d17f103b3b1c4'
,
'setuptools-0.6c1-py2.3.egg'
:
'b3f2b5539d65cb7f74ad79127f1a908c'
,
'setuptools-0.6c1-py2.4.egg'
:
'b45adeda0667d2d2ffe14009364f2a4b'
,
'setuptools-0.6c10-py2.3.egg'
:
'ce1e2ab5d3a0256456d9fc13800a7090'
,
'setuptools-0.6c10-py2.4.egg'
:
'57d6d9d6e9b80772c59a53a8433a5dd4'
,
'setuptools-0.6c10-py2.5.egg'
:
'de46ac8b1c97c895572e5e8596aeb8c7'
,
'setuptools-0.6c10-py2.6.egg'
:
'58ea40aef06da02ce641495523a0b7f5'
,
'setuptools-0.6c11-py2.3.egg'
:
'2baeac6e13d414a9d28e7ba5b5a596de'
,
'setuptools-0.6c11-py2.4.egg'
:
'bd639f9b0eac4c42497034dec2ec0c2b'
,
'setuptools-0.6c11-py2.5.egg'
:
'64c94f3bf7a72a13ec83e0b24f2749b2'
,
'setuptools-0.6c11-py2.6.egg'
:
'bfa92100bd772d5a213eedd356d64086'
,
'setuptools-0.6c2-py2.3.egg'
:
'f0064bf6aa2b7d0f3ba0b43f20817c27'
,
'setuptools-0.6c2-py2.4.egg'
:
'616192eec35f47e8ea16cd6a122b7277'
,
'setuptools-0.6c3-py2.3.egg'
:
'f181fa125dfe85a259c9cd6f1d7b78fa'
,
'setuptools-0.6c3-py2.4.egg'
:
'e0ed74682c998bfb73bf803a50e7b71e'
,
'setuptools-0.6c3-py2.5.egg'
:
'abef16fdd61955514841c7c6bd98965e'
,
'setuptools-0.6c4-py2.3.egg'
:
'b0b9131acab32022bfac7f44c5d7971f'
,
'setuptools-0.6c4-py2.4.egg'
:
'2a1f9656d4fbf3c97bf946c0a124e6e2'
,
'setuptools-0.6c4-py2.5.egg'
:
'8f5a052e32cdb9c72bcf4b5526f28afc'
,
'setuptools-0.6c5-py2.3.egg'
:
'ee9fd80965da04f2f3e6b3576e9d8167'
,
'setuptools-0.6c5-py2.4.egg'
:
'afe2adf1c01701ee841761f5bcd8aa64'
,
'setuptools-0.6c5-py2.5.egg'
:
'a8d3f61494ccaa8714dfed37bccd3d5d'
,
'setuptools-0.6c6-py2.3.egg'
:
'35686b78116a668847237b69d549ec20'
,
'setuptools-0.6c6-py2.4.egg'
:
'3c56af57be3225019260a644430065ab'
,
'setuptools-0.6c6-py2.5.egg'
:
'b2f8a7520709a5b34f80946de5f02f53'
,
'setuptools-0.6c7-py2.3.egg'
:
'209fdf9adc3a615e5115b725658e13e2'
,
'setuptools-0.6c7-py2.4.egg'
:
'5a8f954807d46a0fb67cf1f26c55a82e'
,
'setuptools-0.6c7-py2.5.egg'
:
'45d2ad28f9750e7434111fde831e8372'
,
'setuptools-0.6c8-py2.3.egg'
:
'50759d29b349db8cfd807ba8303f1902'
,
'setuptools-0.6c8-py2.4.egg'
:
'cba38d74f7d483c06e9daa6070cce6de'
,
'setuptools-0.6c8-py2.5.egg'
:
'1721747ee329dc150590a58b3e1ac95b'
,
'setuptools-0.6c9-py2.3.egg'
:
'a83c4020414807b496e4cfbe08507c03'
,
'setuptools-0.6c9-py2.4.egg'
:
'260a2be2e5388d66bdaee06abec6342a'
,
'setuptools-0.6c9-py2.5.egg'
:
'fe67c3e5a17b12c0e7c541b7ea43a8e6'
,
'setuptools-0.6c9-py2.6.egg'
:
'ca37b1ff16fa2ede6e19383e7b59245a'
,
}
import
sys
,
os
try
:
from
hashlib
import
md5
except
ImportError
:
from
md5
import
md5
def
_validate_md5
(
egg_name
,
data
):
if
egg_name
in
md5_data
:
digest
=
md5
(
data
)
.
hexdigest
()
if
digest
!=
md5_data
[
egg_name
]:
print
>>
sys
.
stderr
,
(
"md5 validation of
%
s failed! (Possible download problem?)"
%
egg_name
)
sys
.
exit
(
2
)
return
data
def
use_setuptools
(
version
=
DEFAULT_VERSION
,
download_base
=
DEFAULT_URL
,
to_dir
=
os
.
curdir
,
download_delay
=
15
):
"""Automatically find/download setuptools and make it available on sys.path
`version` should be a valid setuptools version number that is available
as an egg for download under the `download_base` URL (which should end with
a '/'). `to_dir` is the directory where setuptools will be downloaded, if
it is not already available. If `download_delay` is specified, it should
be the number of seconds that will be paused before initiating a download,
should one be required. If an older version of setuptools is installed,
this routine will print a message to ``sys.stderr`` and raise SystemExit in
an attempt to abort the calling script.
import
tempfile
import
zipfile
import
optparse
import
subprocess
import
platform
import
textwrap
import
contextlib
from
distutils
import
log
try
:
from
urllib.request
import
urlopen
except
ImportError
:
from
urllib2
import
urlopen
try
:
from
site
import
USER_SITE
except
ImportError
:
USER_SITE
=
None
DEFAULT_VERSION
=
"11.3.1"
DEFAULT_URL
=
"https://pypi.python.org/packages/source/s/setuptools/"
def
_python_cmd
(
*
args
):
"""
was_imported
=
'pkg_resources'
in
sys
.
modules
or
'setuptools'
in
sys
.
modules
def
do_download
():
egg
=
download_setuptools
(
version
,
download_base
,
to_dir
,
download_delay
)
sys
.
path
.
insert
(
0
,
egg
)
import
setuptools
;
setuptools
.
bootstrap_install_from
=
egg
try
:
import
pkg_resources
except
ImportError
:
return
do_download
()
try
:
return
do_download
()
pkg_resources
.
require
(
"setuptools>="
+
version
);
return
except
pkg_resources
.
VersionConflict
,
e
:
if
was_imported
:
print
>>
sys
.
stderr
,
(
"The required version of setuptools (>=
%
s) is not available, and
\n
"
"can't be installed while this script is running. Please install
\n
"
" a more recent version first, using 'easy_install -U setuptools'."
"
\n\n
(Currently using
%
r)"
)
%
(
version
,
e
.
args
[
0
])
sys
.
exit
(
2
)
except
pkg_resources
.
DistributionNotFound
:
pass
Return True if the command succeeded.
"""
args
=
(
sys
.
executable
,)
+
args
return
subprocess
.
call
(
args
)
==
0
del
pkg_resources
,
sys
.
modules
[
'pkg_resources'
]
# reload ok
return
do_download
()
def
download_setuptools
(
version
=
DEFAULT_VERSION
,
download_base
=
DEFAULT_URL
,
to_dir
=
os
.
curdir
,
delay
=
15
):
"""Download setuptools from a specified location and return its filename
def
_install
(
archive_filename
,
install_args
=
()):
with
archive_context
(
archive_filename
):
# installing
log
.
warn
(
'Installing Setuptools'
)
if
not
_python_cmd
(
'setup.py'
,
'install'
,
*
install_args
):
log
.
warn
(
'Something went wrong during the installation.'
)
log
.
warn
(
'See the error message above.'
)
# exitcode will be 2
return
2
`version` should be a valid setuptools version number that is available
as an egg for download under the `download_base` URL (which should end
with a '/'). `to_dir` is the directory where the egg will be downloaded.
`delay` is the number of seconds to pause before an actual download attempt.
"""
import
urllib2
,
shutil
egg_name
=
"setuptools-
%
s-py
%
s.egg"
%
(
version
,
sys
.
version
[:
3
])
url
=
download_base
+
egg_name
saveto
=
os
.
path
.
join
(
to_dir
,
egg_name
)
src
=
dst
=
None
if
not
os
.
path
.
exists
(
saveto
):
# Avoid repeated downloads
try
:
from
distutils
import
log
if
delay
:
log
.
warn
(
"""
---------------------------------------------------------------------------
This script requires setuptools version
%
s to run (even to display
help). I will attempt to download it for you (from
%
s), but
you may need to enable firewall access for this script first.
I will start the download in
%
d seconds.
(Note: if this machine does not have network access, please obtain the file
%
s
and place it in this directory before rerunning this script.)
---------------------------------------------------------------------------"""
,
version
,
download_base
,
delay
,
url
);
from
time
import
sleep
;
sleep
(
delay
)
log
.
warn
(
"Downloading
%
s"
,
url
)
src
=
urllib2
.
urlopen
(
url
)
# Read/write all in one block, so we don't create a corrupt file
# if the download is interrupted.
data
=
_validate_md5
(
egg_name
,
src
.
read
())
dst
=
open
(
saveto
,
"wb"
);
dst
.
write
(
data
)
finally
:
if
src
:
src
.
close
()
if
dst
:
dst
.
close
()
return
os
.
path
.
realpath
(
saveto
)
def
_build_egg
(
egg
,
archive_filename
,
to_dir
):
with
archive_context
(
archive_filename
):
# building an egg
log
.
warn
(
'Building a Setuptools egg in
%
s'
,
to_dir
)
_python_cmd
(
'setup.py'
,
'-q'
,
'bdist_egg'
,
'--dist-dir'
,
to_dir
)
# returning the result
log
.
warn
(
egg
)
if
not
os
.
path
.
exists
(
egg
):
raise
IOError
(
'Could not build the egg.'
)
class
ContextualZipFile
(
zipfile
.
ZipFile
):
"""
Supplement ZipFile class to support context manager for Python 2.6
"""
def
__enter__
(
self
):
return
self
def
__exit__
(
self
,
type
,
value
,
traceback
):
self
.
close
()
def
__new__
(
cls
,
*
args
,
**
kwargs
):
"""
Construct a ZipFile or ContextualZipFile as appropriate
"""
if
hasattr
(
zipfile
.
ZipFile
,
'__exit__'
):
return
zipfile
.
ZipFile
(
*
args
,
**
kwargs
)
return
super
(
ContextualZipFile
,
cls
)
.
__new__
(
cls
)
@contextlib.contextmanager
def
archive_context
(
filename
):
# extracting the archive
tmpdir
=
tempfile
.
mkdtemp
()
log
.
warn
(
'Extracting in
%
s'
,
tmpdir
)
old_wd
=
os
.
getcwd
()
try
:
os
.
chdir
(
tmpdir
)
with
ContextualZipFile
(
filename
)
as
archive
:
archive
.
extractall
()
# going in the directory
subdir
=
os
.
path
.
join
(
tmpdir
,
os
.
listdir
(
tmpdir
)[
0
])
os
.
chdir
(
subdir
)
log
.
warn
(
'Now working in
%
s'
,
subdir
)
yield
finally
:
os
.
chdir
(
old_wd
)
shutil
.
rmtree
(
tmpdir
)
def
_do_download
(
version
,
download_base
,
to_dir
,
download_delay
):
egg
=
os
.
path
.
join
(
to_dir
,
'setuptools-
%
s-py
%
d.
%
d.egg'
%
(
version
,
sys
.
version_info
[
0
],
sys
.
version_info
[
1
]))
if
not
os
.
path
.
exists
(
egg
):
archive
=
download_setuptools
(
version
,
download_base
,
to_dir
,
download_delay
)
_build_egg
(
egg
,
archive
,
to_dir
)
sys
.
path
.
insert
(
0
,
egg
)
# Remove previously-imported pkg_resources if present (see
# https://bitbucket.org/pypa/setuptools/pull-request/7/ for details).
if
'pkg_resources'
in
sys
.
modules
:
del
sys
.
modules
[
'pkg_resources'
]
import
setuptools
setuptools
.
bootstrap_install_from
=
egg
def
use_setuptools
(
version
=
DEFAULT_VERSION
,
download_base
=
DEFAULT_URL
,
to_dir
=
os
.
curdir
,
download_delay
=
15
):
to_dir
=
os
.
path
.
abspath
(
to_dir
)
rep_modules
=
'pkg_resources'
,
'setuptools'
imported
=
set
(
sys
.
modules
)
.
intersection
(
rep_modules
)
try
:
import
pkg_resources
except
ImportError
:
return
_do_download
(
version
,
download_base
,
to_dir
,
download_delay
)
try
:
pkg_resources
.
require
(
"setuptools>="
+
version
)
return
except
pkg_resources
.
DistributionNotFound
:
return
_do_download
(
version
,
download_base
,
to_dir
,
download_delay
)
except
pkg_resources
.
VersionConflict
as
VC_err
:
if
imported
:
msg
=
textwrap
.
dedent
(
"""
The required version of setuptools (>={version}) is not available,
and can't be installed while this script is running. Please
install a more recent version first, using
'easy_install -U setuptools'.
(Currently using {VC_err.args[0]!r})
"""
)
.
format
(
VC_err
=
VC_err
,
version
=
version
)
sys
.
stderr
.
write
(
msg
)
sys
.
exit
(
2
)
# otherwise, reload ok
del
pkg_resources
,
sys
.
modules
[
'pkg_resources'
]
return
_do_download
(
version
,
download_base
,
to_dir
,
download_delay
)
def
_clean_check
(
cmd
,
target
):
"""
Run the command to download target. If the command fails, clean up before
re-raising the error.
"""
try
:
subprocess
.
check_call
(
cmd
)
except
subprocess
.
CalledProcessError
:
if
os
.
access
(
target
,
os
.
F_OK
):
os
.
unlink
(
target
)
raise
def
download_file_powershell
(
url
,
target
):
"""
Download the file at url to target using Powershell (which will validate
trust). Raise an exception if the command cannot complete.
"""
target
=
os
.
path
.
abspath
(
target
)
ps_cmd
=
(
"[System.Net.WebRequest]::DefaultWebProxy.Credentials = "
"[System.Net.CredentialCache]::DefaultCredentials; "
"(new-object System.Net.WebClient).DownloadFile(
%(url)
r,
%(target)
r)"
%
vars
()
)
cmd
=
[
'powershell'
,
'-Command'
,
ps_cmd
,
]
_clean_check
(
cmd
,
target
)
def
has_powershell
():
if
platform
.
system
()
!=
'Windows'
:
return
False
cmd
=
[
'powershell'
,
'-Command'
,
'echo test'
]
with
open
(
os
.
path
.
devnull
,
'wb'
)
as
devnull
:
try
:
subprocess
.
check_call
(
cmd
,
stdout
=
devnull
,
stderr
=
devnull
)
except
Exception
:
return
False
return
True
download_file_powershell
.
viable
=
has_powershell
def
download_file_curl
(
url
,
target
):
cmd
=
[
'curl'
,
url
,
'--silent'
,
'--output'
,
target
]
_clean_check
(
cmd
,
target
)
def
has_curl
():
cmd
=
[
'curl'
,
'--version'
]
with
open
(
os
.
path
.
devnull
,
'wb'
)
as
devnull
:
try
:
subprocess
.
check_call
(
cmd
,
stdout
=
devnull
,
stderr
=
devnull
)
except
Exception
:
return
False
return
True
download_file_curl
.
viable
=
has_curl
def
download_file_wget
(
url
,
target
):
cmd
=
[
'wget'
,
url
,
'--quiet'
,
'--output-document'
,
target
]
_clean_check
(
cmd
,
target
)
def
has_wget
():
cmd
=
[
'wget'
,
'--version'
]
with
open
(
os
.
path
.
devnull
,
'wb'
)
as
devnull
:
try
:
subprocess
.
check_call
(
cmd
,
stdout
=
devnull
,
stderr
=
devnull
)
except
Exception
:
return
False
return
True
download_file_wget
.
viable
=
has_wget
def
download_file_insecure
(
url
,
target
):
"""
Use Python to download the file, even though it cannot authenticate the
connection.
"""
src
=
urlopen
(
url
)
try
:
# Read all the data in one block.
data
=
src
.
read
()
finally
:
src
.
close
()
# Write all the data in one block to avoid creating a partial file.
with
open
(
target
,
"wb"
)
as
dst
:
dst
.
write
(
data
)
download_file_insecure
.
viable
=
lambda
:
True
def
get_best_downloader
():
downloaders
=
(
download_file_powershell
,
download_file_curl
,
download_file_wget
,
download_file_insecure
,
)
viable_downloaders
=
(
dl
for
dl
in
downloaders
if
dl
.
viable
())
return
next
(
viable_downloaders
,
None
)
def
download_setuptools
(
version
=
DEFAULT_VERSION
,
download_base
=
DEFAULT_URL
,
to_dir
=
os
.
curdir
,
delay
=
15
,
downloader_factory
=
get_best_downloader
):
"""
Download setuptools from a specified location and return its filename
`version` should be a valid setuptools version number that is available
as an sdist for download under the `download_base` URL (which should end
with a '/'). `to_dir` is the directory where the egg will be downloaded.
`delay` is the number of seconds to pause before an actual download
attempt.
``downloader_factory`` should be a function taking no arguments and
returning a function for downloading a URL to a target.
"""
# making sure we use the absolute path
to_dir
=
os
.
path
.
abspath
(
to_dir
)
zip_name
=
"setuptools-
%
s.zip"
%
version
url
=
download_base
+
zip_name
saveto
=
os
.
path
.
join
(
to_dir
,
zip_name
)
if
not
os
.
path
.
exists
(
saveto
):
# Avoid repeated downloads
log
.
warn
(
"Downloading
%
s"
,
url
)
downloader
=
downloader_factory
()
downloader
(
url
,
saveto
)
return
os
.
path
.
realpath
(
saveto
)
def
_build_install_args
(
options
):
"""
Build the arguments to 'python setup.py install' on the setuptools package
"""
return
[
'--user'
]
if
options
.
user_install
else
[]
def
_parse_args
():
"""
Parse the command line for options
"""
parser
=
optparse
.
OptionParser
()
parser
.
add_option
(
'--user'
,
dest
=
'user_install'
,
action
=
'store_true'
,
default
=
False
,
help
=
'install in user site package (requires Python 2.6 or later)'
)
parser
.
add_option
(
'--download-base'
,
dest
=
'download_base'
,
metavar
=
"URL"
,
default
=
DEFAULT_URL
,
help
=
'alternative URL from where to download the setuptools package'
)
parser
.
add_option
(
'--insecure'
,
dest
=
'downloader_factory'
,
action
=
'store_const'
,
const
=
lambda
:
download_file_insecure
,
default
=
get_best_downloader
,
help
=
'Use internal, non-validating downloader'
)
parser
.
add_option
(
'--version'
,
help
=
"Specify which version to download"
,
default
=
DEFAULT_VERSION
,
)
options
,
args
=
parser
.
parse_args
()
# positional arguments are ignored
return
options
def
main
(
argv
,
version
=
DEFAULT_VERSION
):
def
main
():
"""Install or upgrade setuptools and EasyInstall"""
try
:
import
setuptools
except
ImportError
:
egg
=
None
try
:
egg
=
download_setuptools
(
version
,
delay
=
0
)
sys
.
path
.
insert
(
0
,
egg
)
from
setuptools.command.easy_install
import
main
return
main
(
list
(
argv
)
+
[
egg
])
# we're done here
finally
:
if
egg
and
os
.
path
.
exists
(
egg
):
os
.
unlink
(
egg
)
else
:
if
setuptools
.
__version__
==
'0.0.1'
:
print
>>
sys
.
stderr
,
(
"You have an obsolete version of setuptools installed. Please
\n
"
"remove it from your system entirely before rerunning this script."
options
=
_parse_args
()
archive
=
download_setuptools
(
version
=
options
.
version
,
download_base
=
options
.
download_base
,
downloader_factory
=
options
.
downloader_factory
,
)
sys
.
exit
(
2
)
req
=
"setuptools>="
+
version
import
pkg_resources
try
:
pkg_resources
.
require
(
req
)
except
pkg_resources
.
VersionConflict
:
try
:
from
setuptools.command.easy_install
import
main
except
ImportError
:
from
easy_install
import
main
main
(
list
(
argv
)
+
[
download_setuptools
(
delay
=
0
)])
sys
.
exit
(
0
)
# try to force an exit
else
:
if
argv
:
from
setuptools.command.easy_install
import
main
main
(
argv
)
else
:
print
"Setuptools version"
,
version
,
"or greater has been installed."
print
'(Run "ez_setup.py -U setuptools" to reinstall or upgrade.)'
def
update_md5
(
filenames
):
"""Update our built-in md5 registry"""
import
re
for
name
in
filenames
:
base
=
os
.
path
.
basename
(
name
)
f
=
open
(
name
,
'rb'
)
md5_data
[
base
]
=
md5
(
f
.
read
())
.
hexdigest
()
f
.
close
()
data
=
[
"
%
r:
%
r,
\n
"
%
it
for
it
in
md5_data
.
items
()]
data
.
sort
()
repl
=
""
.
join
(
data
)
import
inspect
srcfile
=
inspect
.
getsourcefile
(
sys
.
modules
[
__name__
])
f
=
open
(
srcfile
,
'rb'
);
src
=
f
.
read
();
f
.
close
()
match
=
re
.
search
(
"
\n
md5_data = {
\n
([^}]+)}"
,
src
)
if
not
match
:
print
>>
sys
.
stderr
,
"Internal error!"
sys
.
exit
(
2
)
src
=
src
[:
match
.
start
(
1
)]
+
repl
+
src
[
match
.
end
(
1
):]
f
=
open
(
srcfile
,
'w'
)
f
.
write
(
src
)
f
.
close
()
return
_install
(
archive
,
_build_install_args
(
options
))
if
__name__
==
'__main__'
:
if
len
(
sys
.
argv
)
>
2
and
sys
.
argv
[
1
]
==
'--md5update'
:
update_md5
(
sys
.
argv
[
2
:])
else
:
main
(
sys
.
argv
[
1
:])
if
__name__
==
'__main__'
:
sys
.
exit
(
main
())
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment