aboutsummaryrefslogtreecommitdiffstats
path: root/env/lib/python3.10/site-packages/setuptools/_distutils/command/bdist_msi.py
diff options
context:
space:
mode:
authorLibravatarLibravatar Biswakalyan Bhuyan <biswa@surgot.in> 2022-11-14 16:43:12 +0530
committerLibravatarLibravatar Biswakalyan Bhuyan <biswa@surgot.in> 2022-11-14 16:43:12 +0530
commitd47f8b48935d258f4c5c3e2267911753bebd5214 (patch)
tree3ed04e75bc3fc7c8e4ce618f527565da1df630a1 /env/lib/python3.10/site-packages/setuptools/_distutils/command/bdist_msi.py
parent9468226a9e2e2ab8cdd599f1d8538e860ca86120 (diff)
downloadidcard-d47f8b48935d258f4c5c3e2267911753bebd5214.tar.gz
idcard-d47f8b48935d258f4c5c3e2267911753bebd5214.tar.bz2
idcard-d47f8b48935d258f4c5c3e2267911753bebd5214.zip
id card
Diffstat (limited to 'env/lib/python3.10/site-packages/setuptools/_distutils/command/bdist_msi.py')
-rw-r--r--env/lib/python3.10/site-packages/setuptools/_distutils/command/bdist_msi.py1114
1 files changed, 0 insertions, 1114 deletions
diff --git a/env/lib/python3.10/site-packages/setuptools/_distutils/command/bdist_msi.py b/env/lib/python3.10/site-packages/setuptools/_distutils/command/bdist_msi.py
deleted file mode 100644
index 2f292c9..0000000
--- a/env/lib/python3.10/site-packages/setuptools/_distutils/command/bdist_msi.py
+++ /dev/null
@@ -1,1114 +0,0 @@
-# Copyright (C) 2005, 2006 Martin von Löwis
-# Licensed to PSF under a Contributor Agreement.
-# The bdist_wininst command proper
-# based on bdist_wininst
-"""
-Implements the bdist_msi command.
-"""
-
-import os
-import sys
-import warnings
-from distutils.core import Command
-from distutils.dir_util import remove_tree
-from distutils.sysconfig import get_python_version
-from distutils.version import StrictVersion
-from distutils.errors import DistutilsOptionError
-from distutils.util import get_platform
-from distutils import log
-import msilib
-from msilib import schema, sequence, text
-from msilib import Directory, Feature, Dialog, add_data
-
-
-class PyDialog(Dialog):
- """Dialog class with a fixed layout: controls at the top, then a ruler,
- then a list of buttons: back, next, cancel. Optionally a bitmap at the
- left."""
-
- def __init__(self, *args, **kw):
- """Dialog(database, name, x, y, w, h, attributes, title, first,
- default, cancel, bitmap=true)"""
- super().__init__(*args)
- ruler = self.h - 36
- bmwidth = 152 * ruler / 328
- # if kw.get("bitmap", True):
- # self.bitmap("Bitmap", 0, 0, bmwidth, ruler, "PythonWin")
- self.line("BottomLine", 0, ruler, self.w, 0)
-
- def title(self, title):
- "Set the title text of the dialog at the top."
- # name, x, y, w, h, flags=Visible|Enabled|Transparent|NoPrefix,
- # text, in VerdanaBold10
- self.text("Title", 15, 10, 320, 60, 0x30003, r"{\VerdanaBold10}%s" % title)
-
- def back(self, title, next, name="Back", active=1):
- """Add a back button with a given title, the tab-next button,
- its name in the Control table, possibly initially disabled.
-
- Return the button, so that events can be associated"""
- if active:
- flags = 3 # Visible|Enabled
- else:
- flags = 1 # Visible
- return self.pushbutton(name, 180, self.h - 27, 56, 17, flags, title, next)
-
- def cancel(self, title, next, name="Cancel", active=1):
- """Add a cancel button with a given title, the tab-next button,
- its name in the Control table, possibly initially disabled.
-
- Return the button, so that events can be associated"""
- if active:
- flags = 3 # Visible|Enabled
- else:
- flags = 1 # Visible
- return self.pushbutton(name, 304, self.h - 27, 56, 17, flags, title, next)
-
- def next(self, title, next, name="Next", active=1):
- """Add a Next button with a given title, the tab-next button,
- its name in the Control table, possibly initially disabled.
-
- Return the button, so that events can be associated"""
- if active:
- flags = 3 # Visible|Enabled
- else:
- flags = 1 # Visible
- return self.pushbutton(name, 236, self.h - 27, 56, 17, flags, title, next)
-
- def xbutton(self, name, title, next, xpos):
- """Add a button with a given title, the tab-next button,
- its name in the Control table, giving its x position; the
- y-position is aligned with the other buttons.
-
- Return the button, so that events can be associated"""
- return self.pushbutton(
- name, int(self.w * xpos - 28), self.h - 27, 56, 17, 3, title, next
- )
-
-
-class bdist_msi(Command):
-
- description = "create a Microsoft Installer (.msi) binary distribution"
-
- user_options = [
- ('bdist-dir=', None, "temporary directory for creating the distribution"),
- (
- 'plat-name=',
- 'p',
- "platform name to embed in generated filenames "
- "(default: %s)" % get_platform(),
- ),
- (
- 'keep-temp',
- 'k',
- "keep the pseudo-installation tree around after "
- + "creating the distribution archive",
- ),
- (
- 'target-version=',
- None,
- "require a specific python version" + " on the target system",
- ),
- ('no-target-compile', 'c', "do not compile .py to .pyc on the target system"),
- (
- 'no-target-optimize',
- 'o',
- "do not compile .py to .pyo (optimized) " "on the target system",
- ),
- ('dist-dir=', 'd', "directory to put final built distributions in"),
- ('skip-build', None, "skip rebuilding everything (for testing/debugging)"),
- (
- 'install-script=',
- None,
- "basename of installation script to be run after "
- "installation or before deinstallation",
- ),
- (
- 'pre-install-script=',
- None,
- "Fully qualified filename of a script to be run before "
- "any files are installed. This script need not be in the "
- "distribution",
- ),
- ]
-
- boolean_options = [
- 'keep-temp',
- 'no-target-compile',
- 'no-target-optimize',
- 'skip-build',
- ]
-
- all_versions = [
- '2.0',
- '2.1',
- '2.2',
- '2.3',
- '2.4',
- '2.5',
- '2.6',
- '2.7',
- '2.8',
- '2.9',
- '3.0',
- '3.1',
- '3.2',
- '3.3',
- '3.4',
- '3.5',
- '3.6',
- '3.7',
- '3.8',
- '3.9',
- ]
- other_version = 'X'
-
- def __init__(self, *args, **kw):
- super().__init__(*args, **kw)
- warnings.warn(
- "bdist_msi command is deprecated since Python 3.9, "
- "use bdist_wheel (wheel packages) instead",
- DeprecationWarning,
- 2,
- )
-
- def initialize_options(self):
- self.bdist_dir = None
- self.plat_name = None
- self.keep_temp = 0
- self.no_target_compile = 0
- self.no_target_optimize = 0
- self.target_version = None
- self.dist_dir = None
- self.skip_build = None
- self.install_script = None
- self.pre_install_script = None
- self.versions = None
-
- def finalize_options(self):
- self.set_undefined_options('bdist', ('skip_build', 'skip_build'))
-
- if self.bdist_dir is None:
- bdist_base = self.get_finalized_command('bdist').bdist_base
- self.bdist_dir = os.path.join(bdist_base, 'msi')
-
- short_version = get_python_version()
- if (not self.target_version) and self.distribution.has_ext_modules():
- self.target_version = short_version
-
- if self.target_version:
- self.versions = [self.target_version]
- if (
- not self.skip_build
- and self.distribution.has_ext_modules()
- and self.target_version != short_version
- ):
- raise DistutilsOptionError(
- "target version can only be %s, or the '--skip-build'"
- " option must be specified" % (short_version,)
- )
- else:
- self.versions = list(self.all_versions)
-
- self.set_undefined_options(
- 'bdist',
- ('dist_dir', 'dist_dir'),
- ('plat_name', 'plat_name'),
- )
-
- if self.pre_install_script:
- raise DistutilsOptionError(
- "the pre-install-script feature is not yet implemented"
- )
-
- if self.install_script:
- for script in self.distribution.scripts:
- if self.install_script == os.path.basename(script):
- break
- else:
- raise DistutilsOptionError(
- "install_script '%s' not found in scripts" % self.install_script
- )
- self.install_script_key = None
-
- def run(self):
- if not self.skip_build:
- self.run_command('build')
-
- install = self.reinitialize_command('install', reinit_subcommands=1)
- install.prefix = self.bdist_dir
- install.skip_build = self.skip_build
- install.warn_dir = 0
-
- install_lib = self.reinitialize_command('install_lib')
- # we do not want to include pyc or pyo files
- install_lib.compile = 0
- install_lib.optimize = 0
-
- if self.distribution.has_ext_modules():
- # If we are building an installer for a Python version other
- # than the one we are currently running, then we need to ensure
- # our build_lib reflects the other Python version rather than ours.
- # Note that for target_version!=sys.version, we must have skipped the
- # build step, so there is no issue with enforcing the build of this
- # version.
- target_version = self.target_version
- if not target_version:
- assert self.skip_build, "Should have already checked this"
- target_version = '%d.%d' % sys.version_info[:2]
- plat_specifier = ".%s-%s" % (self.plat_name, target_version)
- build = self.get_finalized_command('build')
- build.build_lib = os.path.join(build.build_base, 'lib' + plat_specifier)
-
- log.info("installing to %s", self.bdist_dir)
- install.ensure_finalized()
-
- # avoid warning of 'install_lib' about installing
- # into a directory not in sys.path
- sys.path.insert(0, os.path.join(self.bdist_dir, 'PURELIB'))
-
- install.run()
-
- del sys.path[0]
-
- self.mkpath(self.dist_dir)
- fullname = self.distribution.get_fullname()
- installer_name = self.get_installer_filename(fullname)
- installer_name = os.path.abspath(installer_name)
- if os.path.exists(installer_name):
- os.unlink(installer_name)
-
- metadata = self.distribution.metadata
- author = metadata.author or metadata.maintainer
- version = metadata.get_version()
- # ProductVersion must be strictly numeric
- # XXX need to deal with prerelease versions
- sversion = "%d.%d.%d" % StrictVersion(version).version
- # Prefix ProductName with Python x.y, so that
- # it sorts together with the other Python packages
- # in Add-Remove-Programs (APR)
- fullname = self.distribution.get_fullname()
- if self.target_version:
- product_name = "Python %s %s" % (self.target_version, fullname)
- else:
- product_name = "Python %s" % (fullname)
- self.db = msilib.init_database(
- installer_name, schema, product_name, msilib.gen_uuid(), sversion, author
- )
- msilib.add_tables(self.db, sequence)
- props = [('DistVersion', version)]
- email = metadata.author_email or metadata.maintainer_email
- if email:
- props.append(("ARPCONTACT", email))
- if metadata.url:
- props.append(("ARPURLINFOABOUT", metadata.url))
- if props:
- add_data(self.db, 'Property', props)
-
- self.add_find_python()
- self.add_files()
- self.add_scripts()
- self.add_ui()
- self.db.Commit()
-
- if hasattr(self.distribution, 'dist_files'):
- tup = 'bdist_msi', self.target_version or 'any', fullname
- self.distribution.dist_files.append(tup)
-
- if not self.keep_temp:
- remove_tree(self.bdist_dir, dry_run=self.dry_run)
-
- def add_files(self):
- db = self.db
- cab = msilib.CAB("distfiles")
- rootdir = os.path.abspath(self.bdist_dir)
-
- root = Directory(db, cab, None, rootdir, "TARGETDIR", "SourceDir")
- f = Feature(db, "Python", "Python", "Everything", 0, 1, directory="TARGETDIR")
-
- items = [(f, root, '')]
- for version in self.versions + [self.other_version]:
- target = "TARGETDIR" + version
- name = default = "Python" + version
- desc = "Everything"
- if version is self.other_version:
- title = "Python from another location"
- level = 2
- else:
- title = "Python %s from registry" % version
- level = 1
- f = Feature(db, name, title, desc, 1, level, directory=target)
- dir = Directory(db, cab, root, rootdir, target, default)
- items.append((f, dir, version))
- db.Commit()
-
- seen = {}
- for feature, dir, version in items:
- todo = [dir]
- while todo:
- dir = todo.pop()
- for file in os.listdir(dir.absolute):
- afile = os.path.join(dir.absolute, file)
- if os.path.isdir(afile):
- short = "%s|%s" % (dir.make_short(file), file)
- default = file + version
- newdir = Directory(db, cab, dir, file, default, short)
- todo.append(newdir)
- else:
- if not dir.component:
- dir.start_component(dir.logical, feature, 0)
- if afile not in seen:
- key = seen[afile] = dir.add_file(file)
- if file == self.install_script:
- if self.install_script_key:
- raise DistutilsOptionError(
- "Multiple files with name %s" % file
- )
- self.install_script_key = '[#%s]' % key
- else:
- key = seen[afile]
- add_data(
- self.db,
- "DuplicateFile",
- [
- (
- key + version,
- dir.component,
- key,
- None,
- dir.logical,
- )
- ],
- )
- db.Commit()
- cab.commit(db)
-
- def add_find_python(self):
- """Adds code to the installer to compute the location of Python.
-
- Properties PYTHON.MACHINE.X.Y and PYTHON.USER.X.Y will be set from the
- registry for each version of Python.
-
- Properties TARGETDIRX.Y will be set from PYTHON.USER.X.Y if defined,
- else from PYTHON.MACHINE.X.Y.
-
- Properties PYTHONX.Y will be set to TARGETDIRX.Y\\python.exe"""
-
- start = 402
- for ver in self.versions:
- install_path = r"SOFTWARE\Python\PythonCore\%s\InstallPath" % ver
- machine_reg = "python.machine." + ver
- user_reg = "python.user." + ver
- machine_prop = "PYTHON.MACHINE." + ver
- user_prop = "PYTHON.USER." + ver
- machine_action = "PythonFromMachine" + ver
- user_action = "PythonFromUser" + ver
- exe_action = "PythonExe" + ver
- target_dir_prop = "TARGETDIR" + ver
- exe_prop = "PYTHON" + ver
- if msilib.Win64:
- # type: msidbLocatorTypeRawValue + msidbLocatorType64bit
- Type = 2 + 16
- else:
- Type = 2
- add_data(
- self.db,
- "RegLocator",
- [
- (machine_reg, 2, install_path, None, Type),
- (user_reg, 1, install_path, None, Type),
- ],
- )
- add_data(
- self.db,
- "AppSearch",
- [(machine_prop, machine_reg), (user_prop, user_reg)],
- )
- add_data(
- self.db,
- "CustomAction",
- [
- (
- machine_action,
- 51 + 256,
- target_dir_prop,
- "[" + machine_prop + "]",
- ),
- (user_action, 51 + 256, target_dir_prop, "[" + user_prop + "]"),
- (
- exe_action,
- 51 + 256,
- exe_prop,
- "[" + target_dir_prop + "]\\python.exe",
- ),
- ],
- )
- add_data(
- self.db,
- "InstallExecuteSequence",
- [
- (machine_action, machine_prop, start),
- (user_action, user_prop, start + 1),
- (exe_action, None, start + 2),
- ],
- )
- add_data(
- self.db,
- "InstallUISequence",
- [
- (machine_action, machine_prop, start),
- (user_action, user_prop, start + 1),
- (exe_action, None, start + 2),
- ],
- )
- add_data(self.db, "Condition", [("Python" + ver, 0, "NOT TARGETDIR" + ver)])
- start += 4
- assert start < 500
-
- def add_scripts(self):
- if self.install_script:
- start = 6800
- for ver in self.versions + [self.other_version]:
- install_action = "install_script." + ver
- exe_prop = "PYTHON" + ver
- add_data(
- self.db,
- "CustomAction",
- [(install_action, 50, exe_prop, self.install_script_key)],
- )
- add_data(
- self.db,
- "InstallExecuteSequence",
- [(install_action, "&Python%s=3" % ver, start)],
- )
- start += 1
- # XXX pre-install scripts are currently refused in finalize_options()
- # but if this feature is completed, it will also need to add
- # entries for each version as the above code does
- if self.pre_install_script:
- scriptfn = os.path.join(self.bdist_dir, "preinstall.bat")
- with open(scriptfn, "w") as f:
- # The batch file will be executed with [PYTHON], so that %1
- # is the path to the Python interpreter; %0 will be the path
- # of the batch file.
- # rem ="""
- # %1 %0
- # exit
- # """
- # <actual script>
- f.write('rem ="""\n%1 %0\nexit\n"""\n')
- with open(self.pre_install_script) as fin:
- f.write(fin.read())
- add_data(self.db, "Binary", [("PreInstall", msilib.Binary(scriptfn))])
- add_data(self.db, "CustomAction", [("PreInstall", 2, "PreInstall", None)])
- add_data(
- self.db,
- "InstallExecuteSequence",
- [("PreInstall", "NOT Installed", 450)],
- )
-
- def add_ui(self):
- db = self.db
- x = y = 50
- w = 370
- h = 300
- title = "[ProductName] Setup"
-
- # see "Dialog Style Bits"
- modal = 3 # visible | modal
- modeless = 1 # visible
- track_disk_space = 32
-
- # UI customization properties
- add_data(
- db,
- "Property",
- # See "DefaultUIFont Property"
- [
- ("DefaultUIFont", "DlgFont8"),
- # See "ErrorDialog Style Bit"
- ("ErrorDialog", "ErrorDlg"),
- ("Progress1", "Install"), # modified in maintenance type dlg
- ("Progress2", "installs"),
- ("MaintenanceForm_Action", "Repair"),
- # possible values: ALL, JUSTME
- ("WhichUsers", "ALL"),
- ],
- )
-
- # Fonts, see "TextStyle Table"
- add_data(
- db,
- "TextStyle",
- [
- ("DlgFont8", "Tahoma", 9, None, 0),
- ("DlgFontBold8", "Tahoma", 8, None, 1), # bold
- ("VerdanaBold10", "Verdana", 10, None, 1),
- ("VerdanaRed9", "Verdana", 9, 255, 0),
- ],
- )
-
- # UI Sequences, see "InstallUISequence Table", "Using a Sequence Table"
- # Numbers indicate sequence; see sequence.py for how these action integrate
- add_data(
- db,
- "InstallUISequence",
- [
- ("PrepareDlg", "Not Privileged or Windows9x or Installed", 140),
- (
- "WhichUsersDlg",
- "Privileged and not Windows9x and not Installed",
- 141,
- ),
- # In the user interface, assume all-users installation if privileged.
- ("SelectFeaturesDlg", "Not Installed", 1230),
- # XXX no support for resume installations yet
- # ("ResumeDlg", "Installed AND (RESUME OR Preselected)", 1240),
- (
- "MaintenanceTypeDlg",
- "Installed AND NOT RESUME AND NOT Preselected",
- 1250,
- ),
- ("ProgressDlg", None, 1280),
- ],
- )
-
- add_data(db, 'ActionText', text.ActionText)
- add_data(db, 'UIText', text.UIText)
- #####################################################################
- # Standard dialogs: FatalError, UserExit, ExitDialog
- fatal = PyDialog(
- db, "FatalError", x, y, w, h, modal, title, "Finish", "Finish", "Finish"
- )
- fatal.title("[ProductName] Installer ended prematurely")
- fatal.back("< Back", "Finish", active=0)
- fatal.cancel("Cancel", "Back", active=0)
- fatal.text(
- "Description1",
- 15,
- 70,
- 320,
- 80,
- 0x30003,
- "[ProductName] setup ended prematurely because of an error. Your system has not been modified. To install this program at a later time, please run the installation again.",
- )
- fatal.text(
- "Description2",
- 15,
- 155,
- 320,
- 20,
- 0x30003,
- "Click the Finish button to exit the Installer.",
- )
- c = fatal.next("Finish", "Cancel", name="Finish")
- c.event("EndDialog", "Exit")
-
- user_exit = PyDialog(
- db, "UserExit", x, y, w, h, modal, title, "Finish", "Finish", "Finish"
- )
- user_exit.title("[ProductName] Installer was interrupted")
- user_exit.back("< Back", "Finish", active=0)
- user_exit.cancel("Cancel", "Back", active=0)
- user_exit.text(
- "Description1",
- 15,
- 70,
- 320,
- 80,
- 0x30003,
- "[ProductName] setup was interrupted. Your system has not been modified. "
- "To install this program at a later time, please run the installation again.",
- )
- user_exit.text(
- "Description2",
- 15,
- 155,
- 320,
- 20,
- 0x30003,
- "Click the Finish button to exit the Installer.",
- )
- c = user_exit.next("Finish", "Cancel", name="Finish")
- c.event("EndDialog", "Exit")
-
- exit_dialog = PyDialog(
- db, "ExitDialog", x, y, w, h, modal, title, "Finish", "Finish", "Finish"
- )
- exit_dialog.title("Completing the [ProductName] Installer")
- exit_dialog.back("< Back", "Finish", active=0)
- exit_dialog.cancel("Cancel", "Back", active=0)
- exit_dialog.text(
- "Description",
- 15,
- 235,
- 320,
- 20,
- 0x30003,
- "Click the Finish button to exit the Installer.",
- )
- c = exit_dialog.next("Finish", "Cancel", name="Finish")
- c.event("EndDialog", "Return")
-
- #####################################################################
- # Required dialog: FilesInUse, ErrorDlg
- inuse = PyDialog(
- db,
- "FilesInUse",
- x,
- y,
- w,
- h,
- 19, # KeepModeless|Modal|Visible
- title,
- "Retry",
- "Retry",
- "Retry",
- bitmap=False,
- )
- inuse.text("Title", 15, 6, 200, 15, 0x30003, r"{\DlgFontBold8}Files in Use")
- inuse.text(
- "Description",
- 20,
- 23,
- 280,
- 20,
- 0x30003,
- "Some files that need to be updated are currently in use.",
- )
- inuse.text(
- "Text",
- 20,
- 55,
- 330,
- 50,
- 3,
- "The following applications are using files that need to be updated by this setup. Close these applications and then click Retry to continue the installation or Cancel to exit it.",
- )
- inuse.control(
- "List",
- "ListBox",
- 20,
- 107,
- 330,
- 130,
- 7,
- "FileInUseProcess",
- None,
- None,
- None,
- )
- c = inuse.back("Exit", "Ignore", name="Exit")
- c.event("EndDialog", "Exit")
- c = inuse.next("Ignore", "Retry", name="Ignore")
- c.event("EndDialog", "Ignore")
- c = inuse.cancel("Retry", "Exit", name="Retry")
- c.event("EndDialog", "Retry")
-
- # See "Error Dialog". See "ICE20" for the required names of the controls.
- error = Dialog(
- db,
- "ErrorDlg",
- 50,
- 10,
- 330,
- 101,
- 65543, # Error|Minimize|Modal|Visible
- title,
- "ErrorText",
- None,
- None,
- )
- error.text("ErrorText", 50, 9, 280, 48, 3, "")
- # error.control("ErrorIcon", "Icon", 15, 9, 24, 24, 5242881, None, "py.ico", None, None)
- error.pushbutton("N", 120, 72, 81, 21, 3, "No", None).event(
- "EndDialog", "ErrorNo"
- )
- error.pushbutton("Y", 240, 72, 81, 21, 3, "Yes", None).event(
- "EndDialog", "ErrorYes"
- )
- error.pushbutton("A", 0, 72, 81, 21, 3, "Abort", None).event(
- "EndDialog", "ErrorAbort"
- )
- error.pushbutton("C", 42, 72, 81, 21, 3, "Cancel", None).event(
- "EndDialog", "ErrorCancel"
- )
- error.pushbutton("I", 81, 72, 81, 21, 3, "Ignore", None).event(
- "EndDialog", "ErrorIgnore"
- )
- error.pushbutton("O", 159, 72, 81, 21, 3, "Ok", None).event(
- "EndDialog", "ErrorOk"
- )
- error.pushbutton("R", 198, 72, 81, 21, 3, "Retry", None).event(
- "EndDialog", "ErrorRetry"
- )
-
- #####################################################################
- # Global "Query Cancel" dialog
- cancel = Dialog(db, "CancelDlg", 50, 10, 260, 85, 3, title, "No", "No", "No")
- cancel.text(
- "Text",
- 48,
- 15,
- 194,
- 30,
- 3,
- "Are you sure you want to cancel [ProductName] installation?",
- )
- # cancel.control("Icon", "Icon", 15, 15, 24, 24, 5242881, None,
- # "py.ico", None, None)
- c = cancel.pushbutton("Yes", 72, 57, 56, 17, 3, "Yes", "No")
- c.event("EndDialog", "Exit")
-
- c = cancel.pushbutton("No", 132, 57, 56, 17, 3, "No", "Yes")
- c.event("EndDialog", "Return")
-
- #####################################################################
- # Global "Wait for costing" dialog
- costing = Dialog(
- db,
- "WaitForCostingDlg",
- 50,
- 10,
- 260,
- 85,
- modal,
- title,
- "Return",
- "Return",
- "Return",
- )
- costing.text(
- "Text",
- 48,
- 15,
- 194,
- 30,
- 3,
- "Please wait while the installer finishes determining your disk space requirements.",
- )
- c = costing.pushbutton("Return", 102, 57, 56, 17, 3, "Return", None)
- c.event("EndDialog", "Exit")
-
- #####################################################################
- # Preparation dialog: no user input except cancellation
- prep = PyDialog(
- db, "PrepareDlg", x, y, w, h, modeless, title, "Cancel", "Cancel", "Cancel"
- )
- prep.text(
- "Description",
- 15,
- 70,
- 320,
- 40,
- 0x30003,
- "Please wait while the Installer prepares to guide you through the installation.",
- )
- prep.title("Welcome to the [ProductName] Installer")
- c = prep.text("ActionText", 15, 110, 320, 20, 0x30003, "Pondering...")
- c.mapping("ActionText", "Text")
- c = prep.text("ActionData", 15, 135, 320, 30, 0x30003, None)
- c.mapping("ActionData", "Text")
- prep.back("Back", None, active=0)
- prep.next("Next", None, active=0)
- c = prep.cancel("Cancel", None)
- c.event("SpawnDialog", "CancelDlg")
-
- #####################################################################
- # Feature (Python directory) selection
- seldlg = PyDialog(
- db, "SelectFeaturesDlg", x, y, w, h, modal, title, "Next", "Next", "Cancel"
- )
- seldlg.title("Select Python Installations")
-
- seldlg.text(
- "Hint",
- 15,
- 30,
- 300,
- 20,
- 3,
- "Select the Python locations where %s should be installed."
- % self.distribution.get_fullname(),
- )
-
- seldlg.back("< Back", None, active=0)
- c = seldlg.next("Next >", "Cancel")
- order = 1
- c.event("[TARGETDIR]", "[SourceDir]", ordering=order)
- for version in self.versions + [self.other_version]:
- order += 1
- c.event(
- "[TARGETDIR]",
- "[TARGETDIR%s]" % version,
- "FEATURE_SELECTED AND &Python%s=3" % version,
- ordering=order,
- )
- c.event("SpawnWaitDialog", "WaitForCostingDlg", ordering=order + 1)
- c.event("EndDialog", "Return", ordering=order + 2)
- c = seldlg.cancel("Cancel", "Features")
- c.event("SpawnDialog", "CancelDlg")
-
- c = seldlg.control(
- "Features",
- "SelectionTree",
- 15,
- 60,
- 300,
- 120,
- 3,
- "FEATURE",
- None,
- "PathEdit",
- None,
- )
- c.event("[FEATURE_SELECTED]", "1")
- ver = self.other_version
- install_other_cond = "FEATURE_SELECTED AND &Python%s=3" % ver
- dont_install_other_cond = "FEATURE_SELECTED AND &Python%s<>3" % ver
-
- c = seldlg.text(
- "Other", 15, 200, 300, 15, 3, "Provide an alternate Python location"
- )
- c.condition("Enable", install_other_cond)
- c.condition("Show", install_other_cond)
- c.condition("Disable", dont_install_other_cond)
- c.condition("Hide", dont_install_other_cond)
-
- c = seldlg.control(
- "PathEdit",
- "PathEdit",
- 15,
- 215,
- 300,
- 16,
- 1,
- "TARGETDIR" + ver,
- None,
- "Next",
- None,
- )
- c.condition("Enable", install_other_cond)
- c.condition("Show", install_other_cond)
- c.condition("Disable", dont_install_other_cond)
- c.condition("Hide", dont_install_other_cond)
-
- #####################################################################
- # Disk cost
- cost = PyDialog(
- db, "DiskCostDlg", x, y, w, h, modal, title, "OK", "OK", "OK", bitmap=False
- )
- cost.text(
- "Title", 15, 6, 200, 15, 0x30003, r"{\DlgFontBold8}Disk Space Requirements"
- )
- cost.text(
- "Description",
- 20,
- 20,
- 280,
- 20,
- 0x30003,
- "The disk space required for the installation of the selected features.",
- )
- cost.text(
- "Text",
- 20,
- 53,
- 330,
- 60,
- 3,
- "The highlighted volumes (if any) do not have enough disk space "
- "available for the currently selected features. You can either "
- "remove some files from the highlighted volumes, or choose to "
- "install less features onto local drive(s), or select different "
- "destination drive(s).",
- )
- cost.control(
- "VolumeList",
- "VolumeCostList",
- 20,
- 100,
- 330,
- 150,
- 393223,
- None,
- "{120}{70}{70}{70}{70}",
- None,
- None,
- )
- cost.xbutton("OK", "Ok", None, 0.5).event("EndDialog", "Return")
-
- #####################################################################
- # WhichUsers Dialog. Only available on NT, and for privileged users.
- # This must be run before FindRelatedProducts, because that will
- # take into account whether the previous installation was per-user
- # or per-machine. We currently don't support going back to this
- # dialog after "Next" was selected; to support this, we would need to
- # find how to reset the ALLUSERS property, and how to re-run
- # FindRelatedProducts.
- # On Windows9x, the ALLUSERS property is ignored on the command line
- # and in the Property table, but installer fails according to the documentation
- # if a dialog attempts to set ALLUSERS.
- whichusers = PyDialog(
- db,
- "WhichUsersDlg",
- x,
- y,
- w,
- h,
- modal,
- title,
- "AdminInstall",
- "Next",
- "Cancel",
- )
- whichusers.title(
- "Select whether to install [ProductName] for all users of this computer."
- )
- # A radio group with two options: allusers, justme
- g = whichusers.radiogroup(
- "AdminInstall", 15, 60, 260, 50, 3, "WhichUsers", "", "Next"
- )
- g.add("ALL", 0, 5, 150, 20, "Install for all users")
- g.add("JUSTME", 0, 25, 150, 20, "Install just for me")
-
- whichusers.back("Back", None, active=0)
-
- c = whichusers.next("Next >", "Cancel")
- c.event("[ALLUSERS]", "1", 'WhichUsers="ALL"', 1)
- c.event("EndDialog", "Return", ordering=2)
-
- c = whichusers.cancel("Cancel", "AdminInstall")
- c.event("SpawnDialog", "CancelDlg")
-
- #####################################################################
- # Installation Progress dialog (modeless)
- progress = PyDialog(
- db,
- "ProgressDlg",
- x,
- y,
- w,
- h,
- modeless,
- title,
- "Cancel",
- "Cancel",
- "Cancel",
- bitmap=False,
- )
- progress.text(
- "Title",
- 20,
- 15,
- 200,
- 15,
- 0x30003,
- r"{\DlgFontBold8}[Progress1] [ProductName]",
- )
- progress.text(
- "Text",
- 35,
- 65,
- 300,
- 30,
- 3,
- "Please wait while the Installer [Progress2] [ProductName]. "
- "This may take several minutes.",
- )
- progress.text("StatusLabel", 35, 100, 35, 20, 3, "Status:")
-
- c = progress.text("ActionText", 70, 100, w - 70, 20, 3, "Pondering...")
- c.mapping("ActionText", "Text")
-
- # c=progress.text("ActionData", 35, 140, 300, 20, 3, None)
- # c.mapping("ActionData", "Text")
-
- c = progress.control(
- "ProgressBar",
- "ProgressBar",
- 35,
- 120,
- 300,
- 10,
- 65537,
- None,
- "Progress done",
- None,
- None,
- )
- c.mapping("SetProgress", "Progress")
-
- progress.back("< Back", "Next", active=False)
- progress.next("Next >", "Cancel", active=False)
- progress.cancel("Cancel", "Back").event("SpawnDialog", "CancelDlg")
-
- ###################################################################
- # Maintenance type: repair/uninstall
- maint = PyDialog(
- db, "MaintenanceTypeDlg", x, y, w, h, modal, title, "Next", "Next", "Cancel"
- )
- maint.title("Welcome to the [ProductName] Setup Wizard")
- maint.text(
- "BodyText",
- 15,
- 63,
- 330,
- 42,
- 3,
- "Select whether you want to repair or remove [ProductName].",
- )
- g = maint.radiogroup(
- "RepairRadioGroup",
- 15,
- 108,
- 330,
- 60,
- 3,
- "MaintenanceForm_Action",
- "",
- "Next",
- )
- # g.add("Change", 0, 0, 200, 17, "&Change [ProductName]")
- g.add("Repair", 0, 18, 200, 17, "&Repair [ProductName]")
- g.add("Remove", 0, 36, 200, 17, "Re&move [ProductName]")
-
- maint.back("< Back", None, active=False)
- c = maint.next("Finish", "Cancel")
- # Change installation: Change progress dialog to "Change", then ask
- # for feature selection
- # c.event("[Progress1]", "Change", 'MaintenanceForm_Action="Change"', 1)
- # c.event("[Progress2]", "changes", 'MaintenanceForm_Action="Change"', 2)
-
- # Reinstall: Change progress dialog to "Repair", then invoke reinstall
- # Also set list of reinstalled features to "ALL"
- c.event("[REINSTALL]", "ALL", 'MaintenanceForm_Action="Repair"', 5)
- c.event("[Progress1]", "Repairing", 'MaintenanceForm_Action="Repair"', 6)
- c.event("[Progress2]", "repairs", 'MaintenanceForm_Action="Repair"', 7)
- c.event("Reinstall", "ALL", 'MaintenanceForm_Action="Repair"', 8)
-
- # Uninstall: Change progress to "Remove", then invoke uninstall
- # Also set list of removed features to "ALL"
- c.event("[REMOVE]", "ALL", 'MaintenanceForm_Action="Remove"', 11)
- c.event("[Progress1]", "Removing", 'MaintenanceForm_Action="Remove"', 12)
- c.event("[Progress2]", "removes", 'MaintenanceForm_Action="Remove"', 13)
- c.event("Remove", "ALL", 'MaintenanceForm_Action="Remove"', 14)
-
- # Close dialog when maintenance action scheduled
- c.event("EndDialog", "Return", 'MaintenanceForm_Action<>"Change"', 20)
- # c.event("NewDialog", "SelectFeaturesDlg", 'MaintenanceForm_Action="Change"', 21)
-
- maint.cancel("Cancel", "RepairRadioGroup").event("SpawnDialog", "CancelDlg")
-
- def get_installer_filename(self, fullname):
- # Factored out to allow overriding in subclasses
- if self.target_version:
- base_name = "%s.%s-py%s.msi" % (
- fullname,
- self.plat_name,
- self.target_version,
- )
- else:
- base_name = "%s.%s.msi" % (fullname, self.plat_name)
- installer_name = os.path.join(self.dist_dir, base_name)
- return installer_name