Home | History | Annotate | Download | only in library
      1 :mod:`compileall` --- Byte-compile Python libraries
      2 ===================================================
      3 
      4 .. module:: compileall
      5    :synopsis: Tools for byte-compiling all Python source files in a directory tree.
      6 
      7 **Source code:** :source:`Lib/compileall.py`
      8 
      9 --------------
     10 
     11 This module provides some utility functions to support installing Python
     12 libraries.  These functions compile Python source files in a directory tree.
     13 This module can be used to create the cached byte-code files at library
     14 installation time, which makes them available for use even by users who don't
     15 have write permission to the library directories.
     16 
     17 
     18 Command-line use
     19 ----------------
     20 
     21 This module can work as a script (using :program:`python -m compileall`) to
     22 compile Python sources.
     23 
     24 .. program:: compileall
     25 
     26 .. cmdoption:: directory ...
     27                file ...
     28 
     29    Positional arguments are files to compile or directories that contain
     30    source files, traversed recursively.  If no argument is given, behave as if
     31    the command line was ``-l <directories from sys.path>``.
     32 
     33 .. cmdoption:: -l
     34 
     35    Do not recurse into subdirectories, only compile source code files directly
     36    contained in the named or implied directories.
     37 
     38 .. cmdoption:: -f
     39 
     40    Force rebuild even if timestamps are up-to-date.
     41 
     42 .. cmdoption:: -q
     43 
     44    Do not print the list of files compiled. If passed once, error messages will
     45    still be printed. If passed twice (``-qq``), all output is suppressed.
     46 
     47 .. cmdoption:: -d destdir
     48 
     49    Directory prepended to the path to each file being compiled.  This will
     50    appear in compilation time tracebacks, and is also compiled in to the
     51    byte-code file, where it will be used in tracebacks and other messages in
     52    cases where the source file does not exist at the time the byte-code file is
     53    executed.
     54 
     55 .. cmdoption:: -x regex
     56 
     57    regex is used to search the full path to each file considered for
     58    compilation, and if the regex produces a match, the file is skipped.
     59 
     60 .. cmdoption:: -i list
     61 
     62    Read the file ``list`` and add each line that it contains to the list of
     63    files and directories to compile.  If ``list`` is ``-``, read lines from
     64    ``stdin``.
     65 
     66 .. cmdoption:: -b
     67 
     68    Write the byte-code files to their legacy locations and names, which may
     69    overwrite byte-code files created by another version of Python.  The default
     70    is to write files to their :pep:`3147` locations and names, which allows
     71    byte-code files from multiple versions of Python to coexist.
     72 
     73 .. cmdoption:: -r
     74 
     75    Control the maximum recursion level for subdirectories.
     76    If this is given, then ``-l`` option will not be taken into account.
     77    :program:`python -m compileall <directory> -r 0` is equivalent to
     78    :program:`python -m compileall <directory> -l`.
     79 
     80 .. cmdoption:: -j N
     81 
     82    Use *N* workers to compile the files within the given directory.
     83    If ``0`` is used, then the result of :func:`os.cpu_count()`
     84    will be used.
     85 
     86 .. cmdoption:: --invalidation-mode [timestamp|checked-hash|unchecked-hash]
     87 
     88    Control how the generated byte-code files are invalidated at runtime.
     89    The ``timestamp`` value, means that ``.pyc`` files with the source timestamp
     90    and size embedded will be generated. The ``checked-hash`` and
     91    ``unchecked-hash`` values cause hash-based pycs to be generated. Hash-based
     92    pycs embed a hash of the source file contents rather than a timestamp. See
     93    :ref:`pyc-invalidation` for more information on how Python validates
     94    bytecode cache files at runtime.
     95    The default is ``timestamp`` if the :envvar:`SOURCE_DATE_EPOCH` environment
     96    variable is not set, and ``checked-hash`` if the ``SOURCE_DATE_EPOCH``
     97    environment variable is set.
     98 
     99 .. versionchanged:: 3.2
    100    Added the ``-i``, ``-b`` and ``-h`` options.
    101 
    102 .. versionchanged:: 3.5
    103    Added the  ``-j``, ``-r``, and ``-qq`` options.  ``-q`` option
    104    was changed to a multilevel value.  ``-b`` will always produce a
    105    byte-code file ending in ``.pyc``, never ``.pyo``.
    106 
    107 .. versionchanged:: 3.7
    108    Added the ``--invalidation-mode`` option.
    109 
    110 
    111 There is no command-line option to control the optimization level used by the
    112 :func:`compile` function, because the Python interpreter itself already
    113 provides the option: :program:`python -O -m compileall`.
    114 
    115 Public functions
    116 ----------------
    117 
    118 .. function:: compile_dir(dir, maxlevels=10, ddir=None, force=False, rx=None, quiet=0, legacy=False, optimize=-1, workers=1, invalidation_mode=py_compile.PycInvalidationMode.TIMESTAMP)
    119 
    120    Recursively descend the directory tree named by *dir*, compiling all :file:`.py`
    121    files along the way. Return a true value if all the files compiled successfully,
    122    and a false value otherwise.
    123 
    124    The *maxlevels* parameter is used to limit the depth of the recursion; it
    125    defaults to ``10``.
    126 
    127    If *ddir* is given, it is prepended to the path to each file being compiled
    128    for use in compilation time tracebacks, and is also compiled in to the
    129    byte-code file, where it will be used in tracebacks and other messages in
    130    cases where the source file does not exist at the time the byte-code file is
    131    executed.
    132 
    133    If *force* is true, modules are re-compiled even if the timestamps are up to
    134    date.
    135 
    136    If *rx* is given, its search method is called on the complete path to each
    137    file considered for compilation, and if it returns a true value, the file
    138    is skipped.
    139 
    140    If *quiet* is ``False`` or ``0`` (the default), the filenames and other
    141    information are printed to standard out. Set to ``1``, only errors are
    142    printed. Set to ``2``, all output is suppressed.
    143 
    144    If *legacy* is true, byte-code files are written to their legacy locations
    145    and names, which may overwrite byte-code files created by another version of
    146    Python.  The default is to write files to their :pep:`3147` locations and
    147    names, which allows byte-code files from multiple versions of Python to
    148    coexist.
    149 
    150    *optimize* specifies the optimization level for the compiler.  It is passed to
    151    the built-in :func:`compile` function.
    152 
    153    The argument *workers* specifies how many workers are used to
    154    compile files in parallel. The default is to not use multiple workers.
    155    If the platform can't use multiple workers and *workers* argument is given,
    156    then sequential compilation will be used as a fallback.  If *workers* is
    157    lower than ``0``, a :exc:`ValueError` will be raised.
    158 
    159    *invalidation_mode* should be a member of the
    160    :class:`py_compile.PycInvalidationMode` enum and controls how the generated
    161    pycs are invalidated at runtime.
    162 
    163    .. versionchanged:: 3.2
    164       Added the *legacy* and *optimize* parameter.
    165 
    166    .. versionchanged:: 3.5
    167       Added the *workers* parameter.
    168 
    169    .. versionchanged:: 3.5
    170       *quiet* parameter was changed to a multilevel value.
    171 
    172    .. versionchanged:: 3.5
    173       The *legacy* parameter only writes out ``.pyc`` files, not ``.pyo`` files
    174       no matter what the value of *optimize* is.
    175 
    176    .. versionchanged:: 3.6
    177       Accepts a :term:`path-like object`.
    178 
    179    .. versionchanged:: 3.7
    180       The *invalidation_mode* parameter was added.
    181 
    182 .. function:: compile_file(fullname, ddir=None, force=False, rx=None, quiet=0, legacy=False, optimize=-1, invalidation_mode=py_compile.PycInvalidationMode.TIMESTAMP)
    183 
    184    Compile the file with path *fullname*. Return a true value if the file
    185    compiled successfully, and a false value otherwise.
    186 
    187    If *ddir* is given, it is prepended to the path to the file being compiled
    188    for use in compilation time tracebacks, and is also compiled in to the
    189    byte-code file, where it will be used in tracebacks and other messages in
    190    cases where the source file does not exist at the time the byte-code file is
    191    executed.
    192 
    193    If *rx* is given, its search method is passed the full path name to the
    194    file being compiled, and if it returns a true value, the file is not
    195    compiled and ``True`` is returned.
    196 
    197    If *quiet* is ``False`` or ``0`` (the default), the filenames and other
    198    information are printed to standard out. Set to ``1``, only errors are
    199    printed. Set to ``2``, all output is suppressed.
    200 
    201    If *legacy* is true, byte-code files are written to their legacy locations
    202    and names, which may overwrite byte-code files created by another version of
    203    Python.  The default is to write files to their :pep:`3147` locations and
    204    names, which allows byte-code files from multiple versions of Python to
    205    coexist.
    206 
    207    *optimize* specifies the optimization level for the compiler.  It is passed to
    208    the built-in :func:`compile` function.
    209 
    210    *invalidation_mode* should be a member of the
    211    :class:`py_compile.PycInvalidationMode` enum and controls how the generated
    212    pycs are invalidated at runtime.
    213 
    214    .. versionadded:: 3.2
    215 
    216    .. versionchanged:: 3.5
    217       *quiet* parameter was changed to a multilevel value.
    218 
    219    .. versionchanged:: 3.5
    220       The *legacy* parameter only writes out ``.pyc`` files, not ``.pyo`` files
    221       no matter what the value of *optimize* is.
    222 
    223    .. versionchanged:: 3.7
    224       The *invalidation_mode* parameter was added.
    225 
    226 .. function:: compile_path(skip_curdir=True, maxlevels=0, force=False, quiet=0, legacy=False, optimize=-1, invalidation_mode=py_compile.PycInvalidationMode.TIMESTAMP)
    227 
    228    Byte-compile all the :file:`.py` files found along ``sys.path``. Return a
    229    true value if all the files compiled successfully, and a false value otherwise.
    230 
    231    If *skip_curdir* is true (the default), the current directory is not included
    232    in the search.  All other parameters are passed to the :func:`compile_dir`
    233    function.  Note that unlike the other compile functions, ``maxlevels``
    234    defaults to ``0``.
    235 
    236    .. versionchanged:: 3.2
    237       Added the *legacy* and *optimize* parameter.
    238 
    239    .. versionchanged:: 3.5
    240       *quiet* parameter was changed to a multilevel value.
    241 
    242    .. versionchanged:: 3.5
    243       The *legacy* parameter only writes out ``.pyc`` files, not ``.pyo`` files
    244       no matter what the value of *optimize* is.
    245 
    246    .. versionchanged:: 3.7
    247       The *invalidation_mode* parameter was added.
    248 
    249 To force a recompile of all the :file:`.py` files in the :file:`Lib/`
    250 subdirectory and all its subdirectories::
    251 
    252    import compileall
    253 
    254    compileall.compile_dir('Lib/', force=True)
    255 
    256    # Perform same compilation, excluding files in .svn directories.
    257    import re
    258    compileall.compile_dir('Lib/', rx=re.compile(r'[/\\][.]svn'), force=True)
    259 
    260    # pathlib.Path objects can also be used.
    261    import pathlib
    262    compileall.compile_dir(pathlib.Path('Lib/'), force=True)
    263 
    264 .. seealso::
    265 
    266    Module :mod:`py_compile`
    267       Byte-compile a single source file.
    268