Kaydet (Commit) 4db86bc1 authored tarafından Steve Dower's avatar Steve Dower

Changes pyvenv.cfg trick into an actual sys.path file.

üst 783c9ef8
...@@ -29,13 +29,13 @@ Supported Versions ...@@ -29,13 +29,13 @@ Supported Versions
As specified in :pep:`11`, a Python release only supports a Windows platform As specified in :pep:`11`, a Python release only supports a Windows platform
while Microsoft considers the platform under extended support. This means that while Microsoft considers the platform under extended support. This means that
Python 3.5 supports Windows Vista and newer. If you require Windows XP support Python 3.6 supports Windows Vista and newer. If you require Windows XP support
then please install Python 3.4. then please install Python 3.4.
Installation Steps Installation Steps
------------------ ------------------
Four Python 3.5 installers are available for download - two each for the 32-bit Four Python 3.6 installers are available for download - two each for the 32-bit
and 64-bit versions of the interpreter. The *web installer* is a small initial and 64-bit versions of the interpreter. The *web installer* is a small initial
download, and it will automatically download the required components as download, and it will automatically download the required components as
necessary. The *offline installer* includes the components necessary for a necessary. The *offline installer* includes the components necessary for a
...@@ -193,13 +193,13 @@ of available options is shown below. ...@@ -193,13 +193,13 @@ of available options is shown below.
For example, to silently install a default, system-wide Python installation, For example, to silently install a default, system-wide Python installation,
you could use the following command (from an elevated command prompt):: you could use the following command (from an elevated command prompt)::
python-3.5.0.exe /quiet InstallAllUsers=1 PrependPath=1 Include_test=0 python-3.6.0.exe /quiet InstallAllUsers=1 PrependPath=1 Include_test=0
To allow users to easily install a personal copy of Python without the test To allow users to easily install a personal copy of Python without the test
suite, you could provide a shortcut with the following command. This will suite, you could provide a shortcut with the following command. This will
display a simplified initial page and disallow customization:: display a simplified initial page and disallow customization::
python-3.5.0.exe InstallAllUsers=0 Include_launcher=0 Include_test=0 python-3.6.0.exe InstallAllUsers=0 Include_launcher=0 Include_test=0
SimpleInstall=1 SimpleInstallDescription="Just for me, no test suite." SimpleInstall=1 SimpleInstallDescription="Just for me, no test suite."
(Note that omitting the launcher also omits file associations, and is only (Note that omitting the launcher also omits file associations, and is only
...@@ -234,13 +234,13 @@ where a large number of installations are going to be performed it is very ...@@ -234,13 +234,13 @@ where a large number of installations are going to be performed it is very
useful to have a locally cached copy. useful to have a locally cached copy.
Execute the following command from Command Prompt to download all possible Execute the following command from Command Prompt to download all possible
required files. Remember to substitute ``python-3.5.0.exe`` for the actual required files. Remember to substitute ``python-3.6.0.exe`` for the actual
name of your installer, and to create layouts in their own directories to name of your installer, and to create layouts in their own directories to
avoid collisions between files with the same name. avoid collisions between files with the same name.
:: ::
python-3.5.0.exe /layout [optional target directory] python-3.6.0.exe /layout [optional target directory]
You may also specify the ``/quiet`` option to hide the progress display. You may also specify the ``/quiet`` option to hide the progress display.
...@@ -345,7 +345,7 @@ User level and the System level, or temporarily in a command prompt. ...@@ -345,7 +345,7 @@ User level and the System level, or temporarily in a command prompt.
To temporarily set environment variables, open Command Prompt and use the To temporarily set environment variables, open Command Prompt and use the
:command:`set` command:: :command:`set` command::
C:\>set PATH=C:\Program Files\Python 3.5;%PATH% C:\>set PATH=C:\Program Files\Python 3.6;%PATH%
C:\>set PYTHONPATH=%PYTHONPATH%;C:\My_python_lib C:\>set PYTHONPATH=%PYTHONPATH%;C:\My_python_lib
C:\>python C:\>python
...@@ -401,10 +401,10 @@ Finding the Python executable ...@@ -401,10 +401,10 @@ Finding the Python executable
Besides using the automatically created start menu entry for the Python Besides using the automatically created start menu entry for the Python
interpreter, you might want to start Python in the command prompt. The interpreter, you might want to start Python in the command prompt. The
installer for Python 3.5 and later has an option to set that up for you. installer for Python 3.6 has an option to set that up for you.
On the first page of the installer, an option labelled "Add Python 3.5 to On the first page of the installer, an option labelled "Add Python to PATH"
PATH" can be selected to have the installer add the install location into the may be selected to have the installer add the install location into the
:envvar:`PATH`. The location of the :file:`Scripts\\` folder is also added. :envvar:`PATH`. The location of the :file:`Scripts\\` folder is also added.
This allows you to type :command:`python` to run the interpreter, and This allows you to type :command:`python` to run the interpreter, and
:command:`pip` for the package installer. Thus, you can also execute your :command:`pip` for the package installer. Thus, you can also execute your
...@@ -418,7 +418,7 @@ of your Python installation, delimited by a semicolon from other entries. An ...@@ -418,7 +418,7 @@ of your Python installation, delimited by a semicolon from other entries. An
example variable could look like this (assuming the first two entries already example variable could look like this (assuming the first two entries already
existed):: existed)::
C:\WINDOWS\system32;C:\WINDOWS;C:\Program Files\Python 3.5 C:\WINDOWS\system32;C:\WINDOWS;C:\Program Files\Python 3.6
.. _launcher: .. _launcher:
...@@ -720,7 +720,15 @@ installation directory. So, if you had installed Python to ...@@ -720,7 +720,15 @@ installation directory. So, if you had installed Python to
:file:`C:\\Python\\Lib\\` and third-party modules should be stored in :file:`C:\\Python\\Lib\\` and third-party modules should be stored in
:file:`C:\\Python\\Lib\\site-packages\\`. :file:`C:\\Python\\Lib\\site-packages\\`.
This is how :data:`sys.path` is populated on Windows: To completely override :data:`sys.path`, create a text file named ``'sys.path'``
containing a list of paths alongside the Python executable. This will ignore all
registry settings and environment variables, enable isolated mode, disable
importing :mod:`site`, and fill :data:`sys.path` with exactly the paths listed
in the file. Paths may be absolute or relative to the directory containing the
file.
When the ``'sys.path'`` file is missing, this is how :data:`sys.path` is
populated on Windows:
* An empty entry is added at the start, which corresponds to the current * An empty entry is added at the start, which corresponds to the current
directory. directory.
...@@ -755,10 +763,6 @@ directory one level above the executable, the following variations apply: ...@@ -755,10 +763,6 @@ directory one level above the executable, the following variations apply:
path is used instead of the path to the main executable when deducing the path is used instead of the path to the main executable when deducing the
home location. home location.
* If ``applocal`` is set to true, the ``home`` property or the main executable
is always used as the home path, and all environment variables or registry
values affecting the path are ignored. The landmark file is not checked.
The end result of all this is: The end result of all this is:
* When running :file:`python.exe`, or any other .exe in the main Python * When running :file:`python.exe`, or any other .exe in the main Python
...@@ -777,13 +781,11 @@ The end result of all this is: ...@@ -777,13 +781,11 @@ The end result of all this is:
For those who want to bundle Python into their application or distribution, the For those who want to bundle Python into their application or distribution, the
following advice will prevent conflicts with other installations: following advice will prevent conflicts with other installations:
* Include a ``pyvenv.cfg`` file alongside your executable containing * Include a ``sys.path`` file alongside your executable containing the
``applocal = true``. This will ensure that your own directory will be used to directories to include. This will ignore user site-packages and other paths
resolve paths even if you have included the standard library in a ZIP file. listed in the registry or in environment variables.
It will also ignore user site-packages and other paths listed in the
registry.
* If you are loading :file:`python3.dll` or :file:`python35.dll` in your own * If you are loading :file:`python3.dll` or :file:`python36.dll` in your own
executable, explicitly call :c:func:`Py_SetPath` or (at least) executable, explicitly call :c:func:`Py_SetPath` or (at least)
:c:func:`Py_SetProgramName` before :c:func:`Py_Initialize`. :c:func:`Py_SetProgramName` before :c:func:`Py_Initialize`.
...@@ -801,6 +803,11 @@ Otherwise, your users may experience problems using your application. Note that ...@@ -801,6 +803,11 @@ Otherwise, your users may experience problems using your application. Note that
the first suggestion is the best, as the other may still be susceptible to the first suggestion is the best, as the other may still be susceptible to
non-standard paths in the registry and user site-packages. non-standard paths in the registry and user site-packages.
.. versionchanged:: 3.6
Adds ``sys.path`` file support and removes ``applocal`` option from
``pyvenv.cfg``.
Additional modules Additional modules
================== ==================
...@@ -900,7 +907,7 @@ directly accessed by end-users. ...@@ -900,7 +907,7 @@ directly accessed by end-users.
When extracted, the embedded distribution is (almost) fully isolated from the When extracted, the embedded distribution is (almost) fully isolated from the
user's system, including environment variables, system registry settings, and user's system, including environment variables, system registry settings, and
installed packages. The standard library is included as pre-compiled and installed packages. The standard library is included as pre-compiled and
optimized ``.pyc`` files in a ZIP, and ``python3.dll``, ``python35.dll``, optimized ``.pyc`` files in a ZIP, and ``python3.dll``, ``python36.dll``,
``python.exe`` and ``pythonw.exe`` are all provided. Tcl/tk (including all ``python.exe`` and ``pythonw.exe`` are all provided. Tcl/tk (including all
dependants, such as Idle), pip and the Python documentation are not included. dependants, such as Idle), pip and the Python documentation are not included.
......
...@@ -463,12 +463,6 @@ def venv(known_paths): ...@@ -463,12 +463,6 @@ def venv(known_paths):
system_site = value.lower() system_site = value.lower()
elif key == 'home': elif key == 'home':
sys._home = value sys._home = value
elif key == 'applocal' and value.lower() == 'true':
# App-local installs use the exe_dir as prefix,
# not one level higher, and do not use system
# site packages.
site_prefix = exe_dir
system_site = 'false'
sys.prefix = sys.exec_prefix = site_prefix sys.prefix = sys.exec_prefix = site_prefix
......
This diff is collapsed.
...@@ -69,7 +69,7 @@ ...@@ -69,7 +69,7 @@
<PreprocessorDefinitions>_USRDLL;Py_BUILD_CORE;Py_ENABLE_SHARED;MS_DLL_ID="$(SysWinVer)";%(PreprocessorDefinitions)</PreprocessorDefinitions> <PreprocessorDefinitions>_USRDLL;Py_BUILD_CORE;Py_ENABLE_SHARED;MS_DLL_ID="$(SysWinVer)";%(PreprocessorDefinitions)</PreprocessorDefinitions>
</ClCompile> </ClCompile>
<Link> <Link>
<AdditionalDependencies>ws2_32.lib;%(AdditionalDependencies)</AdditionalDependencies> <AdditionalDependencies>shlwapi.lib;ws2_32.lib;%(AdditionalDependencies)</AdditionalDependencies>
<BaseAddress>0x1e000000</BaseAddress> <BaseAddress>0x1e000000</BaseAddress>
</Link> </Link>
</ItemDefinitionGroup> </ItemDefinitionGroup>
......
...@@ -46,6 +46,10 @@ EXCLUDE_FILE_FROM_LIBS = { ...@@ -46,6 +46,10 @@ EXCLUDE_FILE_FROM_LIBS = {
'python3stub', 'python3stub',
} }
EXCLUDED_FILES = {
'pyshellext',
}
def is_not_debug(p): def is_not_debug(p):
if DEBUG_RE.search(p.name): if DEBUG_RE.search(p.name):
return False return False
...@@ -53,7 +57,7 @@ def is_not_debug(p): ...@@ -53,7 +57,7 @@ def is_not_debug(p):
if TKTCL_RE.search(p.name): if TKTCL_RE.search(p.name):
return False return False
return p.stem.lower() not in DEBUG_FILES return p.stem.lower() not in DEBUG_FILES and p.stem.lower() not in EXCLUDED_FILES
def is_not_debug_or_python(p): def is_not_debug_or_python(p):
return is_not_debug(p) and not PYTHON_DLL_RE.search(p.name) return is_not_debug(p) and not PYTHON_DLL_RE.search(p.name)
...@@ -209,8 +213,9 @@ def main(): ...@@ -209,8 +213,9 @@ def main():
copied = copy_to_layout(temp / t.rstrip('/'), rglob(s, p, c)) copied = copy_to_layout(temp / t.rstrip('/'), rglob(s, p, c))
print('Copied {} files'.format(copied)) print('Copied {} files'.format(copied))
with open(str(temp / 'pyvenv.cfg'), 'w') as f: with open(str(temp / 'sys.path'), 'w') as f:
print('applocal = true', file=f) print('python{0.major}{0.minor}.zip'.format(sys.version_info), file=f)
print('.', file=f)
if out: if out:
total = copy_to_layout(out, rglob(temp, '**/*', None)) total = copy_to_layout(out, rglob(temp, '**/*', None))
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment