Current Path: > > opt > alt > python-internal > lib64 > > > python3.11 > distutils >
Operation : Linux premium131.web-hosting.com 4.18.0-553.44.1.lve.el8.x86_64 #1 SMP Thu Mar 13 14:29:12 UTC 2025 x86_64 Software : Apache Server IP : 162.0.232.56 | Your IP: 216.73.216.111 Domains : 1034 Domain(s) Permission : [ 0755 ]
Name | Type | Size | Last Modified | Actions |
---|---|---|---|---|
__pycache__ | Directory | - | - | |
command | Directory | - | - | |
README | File | 244 bytes | June 03 2025 18:38:25. | |
__init__.py | File | 541 bytes | June 03 2025 18:38:25. | |
_msvccompiler.py | File | 20007 bytes | June 03 2025 18:38:25. | |
archive_util.py | File | 8572 bytes | June 03 2025 18:38:25. | |
bcppcompiler.py | File | 14894 bytes | June 03 2025 18:38:25. | |
ccompiler.py | File | 47418 bytes | June 03 2025 18:38:25. | |
cmd.py | File | 18079 bytes | June 03 2025 18:38:25. | |
config.py | File | 4951 bytes | June 03 2025 18:38:25. | |
core.py | File | 8876 bytes | June 03 2025 18:38:25. | |
cygwinccompiler.py | File | 16380 bytes | June 03 2025 18:38:25. | |
debug.py | File | 139 bytes | June 03 2025 18:38:25. | |
dep_util.py | File | 3491 bytes | June 03 2025 18:38:25. | |
dir_util.py | File | 7778 bytes | June 03 2025 18:38:25. | |
dist.py | File | 50385 bytes | June 03 2025 18:38:25. | |
errors.py | File | 3577 bytes | June 03 2025 18:38:25. | |
extension.py | File | 10529 bytes | June 03 2025 18:38:25. | |
fancy_getopt.py | File | 17784 bytes | June 03 2025 18:38:25. | |
file_util.py | File | 8148 bytes | June 03 2025 18:38:25. | |
filelist.py | File | 12832 bytes | June 03 2025 18:38:25. | |
log.py | File | 1969 bytes | June 03 2025 18:38:25. | |
msvc9compiler.py | File | 30453 bytes | June 03 2025 18:38:25. | |
msvccompiler.py | File | 23527 bytes | June 03 2025 18:38:25. | |
spawn.py | File | 4660 bytes | June 03 2025 18:38:25. | |
sysconfig.py | File | 12435 bytes | June 03 2025 18:38:25. | |
text_file.py | File | 12483 bytes | June 03 2025 18:38:25. | |
unixccompiler.py | File | 15318 bytes | July 23 2025 09:44:15. | |
util.py | File | 21032 bytes | June 03 2025 18:38:25. | |
version.py | File | 12514 bytes | June 03 2025 18:38:25. | |
versionpredicate.py | File | 5133 bytes | June 03 2025 18:38:25. |
"""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 import warnings 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.""" with warnings.catch_warnings(): warnings.simplefilter("ignore", DeprecationWarning) 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
SILENT KILLER Tool