This issue tracker has been migrated to GitHub, and is currently read-only.
For more information, see the GitHub FAQs in the Python's Developer Guide.

classification
Title: Type: Improve -x option documentation enhancement needs patch Documentation, Windows Python 3.10
process
Status: Resolution: open docs@python docs@python, paul.moore, serhiy.storchaka, steve.dower, tim.golden, vstinner, zach.ware normal newcomer friendly

Created on 2017-11-24 06:26 by serhiy.storchaka, last changed 2022-04-11 14:58 by admin.

Messages (5)
msg306878 - (view) Author: Serhiy Storchaka (serhiy.storchaka) * Date: 2017-11-24 06:26
The documentation of the -x option is virtually not existing. The current short line of the description was enough to me for understanding what is the purpose of this option and how it can be used (I didn't use Windows for more than 10 years). But I was surprised not founding more detailed information about this feature in the documentation. Definitely it should be better documented. Most of users will have no ideas about this feature.

The purpose of this option is turning Python scripts into Windows batch files which can be ran as other executables. Similarly as adding she-bang and setting the executable bit allows to run them on Unix. The extension of the Python script should be changed to ".bat", and the following line should be added at the start of the script:

@path\to\python -x %0 %* & exit /b

Or

@py -3 -x %0 %* & exit /b

Unlike a she-bang line which is a Python comment, this line is not valid Python syntax, and the -x option is used for skipping it.
msg307190 - (view) Author: STINNER Victor (vstinner) * Date: 2017-11-28 23:29
I don't know if "@path\to\python -x %0 %* & exit /b" and "@py -3 -x %0 %* & exit /b" are correct and well supported on all recent Windows versions.

Apart of that, I like your new documentation :-)
msg307203 - (view) Author: Steve Dower (steve.dower) * Date: 2017-11-29 02:58
Those examples look fine to me
msg307212 - (view) Author: Serhiy Storchaka (serhiy.storchaka) * Date: 2017-11-29 08:07
AFAIK this should work in Windows XP. And maybe even in Windows 2000.
msg379721 - (view) Author: STINNER Victor (vstinner) * Date: 2020-10-27 03:10
The -x command line option is now stored as PyConfig.skip_source_first_line, documented as:
"Skip the first line of the source?"
https://docs.python.org/dev/c-api/init_config.html#c.PyConfig.skip_source_first_line

Include/cpython/initconfig.h contains a longer comment:

/* Skip the first line of the source ('run_filename' parameter),
allowing use of non-Unix forms of "#!cmd".
This is intended for a DOS specific hack only.

Set by the -x command line option. */
int skip_source_first_line;
History
Date User Action Args