opt
/
alt
/
python310
/
lib64
/
python3.10
/
distutils
/
Go to Home Directory
+
Upload
Create File
root@0UT1S:~$
Execute
By Order of Mr.0UT1S
[DIR] ..
N/A
[DIR] __pycache__
N/A
[DIR] command
N/A
README
244 bytes
Rename
Delete
__init__.py
541 bytes
Rename
Delete
_msvccompiler.py
19.54 KB
Rename
Delete
archive_util.py
8.37 KB
Rename
Delete
bcppcompiler.py
14.54 KB
Rename
Delete
ccompiler.py
46.31 KB
Rename
Delete
cmd.py
17.66 KB
Rename
Delete
config.py
4.71 KB
Rename
Delete
core.py
8.67 KB
Rename
Delete
cygwinccompiler.py
16.00 KB
Rename
Delete
debug.py
139 bytes
Rename
Delete
dep_util.py
3.41 KB
Rename
Delete
dir_util.py
7.60 KB
Rename
Delete
dist.py
49.20 KB
Rename
Delete
errors.py
3.49 KB
Rename
Delete
extension.py
10.28 KB
Rename
Delete
fancy_getopt.py
17.37 KB
Rename
Delete
file_util.py
7.96 KB
Rename
Delete
filelist.py
12.53 KB
Rename
Delete
log.py
1.92 KB
Rename
Delete
msvc9compiler.py
29.74 KB
Rename
Delete
msvccompiler.py
22.99 KB
Rename
Delete
spawn.py
4.55 KB
Rename
Delete
sysconfig.py
12.26 KB
Rename
Delete
text_file.py
12.19 KB
Rename
Delete
unixccompiler.py
14.96 KB
Rename
Delete
util.py
20.54 KB
Rename
Delete
version.py
12.22 KB
Rename
Delete
versionpredicate.py
5.01 KB
Rename
Delete
"""distutils.pypirc Provides the PyPIRCCommand class, the base class for the command classes that uses .pypirc in the distutils.command package. """ import os from configparser import RawConfigParser from distutils.cmd import Command DEFAULT_PYPIRC = """\ [distutils] index-servers = pypi [pypi] username:%s password:%s """ class PyPIRCCommand(Command): """Base command that knows how to handle the .pypirc file """ DEFAULT_REPOSITORY = 'https://upload.pypi.org/legacy/' DEFAULT_REALM = 'pypi' repository = None realm = None user_options = [ ('repository=', 'r', "url of repository [default: %s]" % \ DEFAULT_REPOSITORY), ('show-response', None, 'display full response text from server')] boolean_options = ['show-response'] def _get_rc_file(self): """Returns rc file path.""" return os.path.join(os.path.expanduser('~'), '.pypirc') def _store_pypirc(self, username, password): """Creates a default .pypirc file.""" rc = self._get_rc_file() with os.fdopen(os.open(rc, os.O_CREAT | os.O_WRONLY, 0o600), 'w') as f: f.write(DEFAULT_PYPIRC % (username, password)) def _read_pypirc(self): """Reads the .pypirc file.""" rc = self._get_rc_file() if os.path.exists(rc): self.announce('Using PyPI login from %s' % rc) repository = self.repository or self.DEFAULT_REPOSITORY config = RawConfigParser() config.read(rc) sections = config.sections() if 'distutils' in sections: # let's get the list of servers index_servers = config.get('distutils', 'index-servers') _servers = [server.strip() for server in index_servers.split('\n') if server.strip() != ''] if _servers == []: # nothing set, let's try to get the default pypi if 'pypi' in sections: _servers = ['pypi'] else: # the file is not properly defined, returning # an empty dict return {} for server in _servers: current = {'server': server} current['username'] = config.get(server, 'username') # optional params for key, default in (('repository', self.DEFAULT_REPOSITORY), ('realm', self.DEFAULT_REALM), ('password', None)): if config.has_option(server, key): current[key] = config.get(server, key) else: current[key] = default # work around people having "repository" for the "pypi" # section of their config set to the HTTP (rather than # HTTPS) URL if (server == 'pypi' and repository in (self.DEFAULT_REPOSITORY, 'pypi')): current['repository'] = self.DEFAULT_REPOSITORY return current if (current['server'] == repository or current['repository'] == repository): return current elif 'server-login' in sections: # old format server = 'server-login' if config.has_option(server, 'repository'): repository = config.get(server, 'repository') else: repository = self.DEFAULT_REPOSITORY return {'username': config.get(server, 'username'), 'password': config.get(server, 'password'), 'repository': repository, 'server': server, 'realm': self.DEFAULT_REALM} return {} def _read_pypi_response(self, response): """Read and decode a PyPI HTTP response.""" import cgi content_type = response.getheader('content-type', 'text/plain') encoding = cgi.parse_header(content_type)[1].get('charset', 'ascii') return response.read().decode(encoding) def initialize_options(self): """Initialize options.""" self.repository = None self.realm = None self.show_response = 0 def finalize_options(self): """Finalizes options.""" if self.repository is None: self.repository = self.DEFAULT_REPOSITORY if self.realm is None: self.realm = self.DEFAULT_REALM
Save