This commit is contained in:
ton
2024-10-07 10:13:40 +07:00
parent aa1631742f
commit 3a7d696db6
9729 changed files with 1832837 additions and 161742 deletions

View File

@@ -1,24 +1,30 @@
from distutils import log
import distutils.command.install_scripts as orig
from __future__ import annotations
import os
import sys
from .._path import ensure_directory
from ..dist import Distribution
import distutils.command.install_scripts as orig
from distutils import log
class install_scripts(orig.install_scripts):
"""Do normal script install, plus any egg_info wrapper scripts"""
distribution: Distribution # override distutils.dist.Distribution with setuptools.dist.Distribution
def initialize_options(self):
orig.install_scripts.initialize_options(self)
self.no_ep = False
def run(self):
def run(self) -> None:
self.run_command("egg_info")
if self.distribution.scripts:
orig.install_scripts.run(self) # run first to set up self.outfiles
else:
self.outfiles = []
self.outfiles: list[str] = []
if self.no_ep:
# don't install entry point scripts into .egg file!
return
@@ -27,6 +33,7 @@ class install_scripts(orig.install_scripts):
def _install_ep_scripts(self):
# Delay import side-effects
from pkg_resources import Distribution, PathMetadata
from . import easy_install as ei
ei_cmd = self.get_finalized_command("egg_info")
@@ -57,10 +64,10 @@ class install_scripts(orig.install_scripts):
target = os.path.join(self.install_dir, script_name)
self.outfiles.append(target)
encoding = None if "b" in mode else "utf-8"
mask = current_umask()
if not self.dry_run:
ensure_directory(target)
f = open(target, "w" + mode)
f.write(contents)
f.close()
with open(target, "w" + mode, encoding=encoding) as f:
f.write(contents)
chmod(target, 0o777 - mask)