1. 02 Dec, 2017 2 commits
    • Serhiy Storchaka's avatar
      bpo-32197: Try to fix a compiler error on OS X introduced in bpo-32030. (#4681) · 13badcbc
      Serhiy Storchaka authored
      * Revert "bpo-32030: _PyPathConfig_Init() sets home and program_name (#4673)"
      
      This reverts commit af5a8950.
      
      * Revert "bpo-32030: Fix config_get_program_name() on macOS (#4669)"
      
      This reverts commit e23c06e2.
      
      * Revert "bpo-32030: Add Python/pathconfig.c (#4668)"
      
      This reverts commit 0ea395ae.
      
      * Revert "bpo-32030: Don't call _PyPathConfig_Fini() in Py_FinalizeEx() (#4667)"
      
      This reverts commit ebac19da.
      
      * Revert "bpo-32030: Fix Py_GetPath(): init program_name (#4665)"
      
      This reverts commit 9ac3d888.
      13badcbc
    • Victor Stinner's avatar
      bpo-32030: _PyPathConfig_Init() sets home and program_name (#4673) · af5a8950
      Victor Stinner authored
      _PyPathConfig_Init() now also initialize home and program_name:
      
      * Rename existing _PyPathConfig_Init() to _PyPathConfig_Calculate().
        Add a new _PyPathConfig_Init() function in pathconfig.c which
        handles the _Py_path_config variable and call
        _PyPathConfig_Calculate().
      * Add home and program_name fields to _PyPathConfig.home
      * _PyPathConfig_Init() now initialize home and program_name
        from main_config
      * Py_SetProgramName(), Py_SetPythonHome() and Py_GetPythonHome() now
        calls Py_FatalError() on failure, instead of silently ignoring
        failures.
      * config_init_home() now gets directly _Py_path_config.home to only
        get the value set by Py_SetPythonHome(), or NULL if
        Py_SetPythonHome() was not called.
      * config_get_program_name() now gets directly
        _Py_path_config.program_name to only get the value set by
        Py_SetProgramName(), or NULL if Py_SetProgramName() was not called.
      * pymain_init_python() doesn't call Py_SetProgramName() anymore,
        _PyPathConfig_Init() now always sets the program name
      * Call _PyMainInterpreterConfig_Read() in
        pymain_parse_cmdline_envvars_impl() to control the memory allocator
      * C API documentation: it's no more safe to call Py_GetProgramName()
        before Py_Initialize().
      af5a8950
  2. 01 Dec, 2017 10 commits
    • Victor Stinner's avatar
    • Victor Stinner's avatar
      bpo-32030: Add Python/pathconfig.c (#4668) · 0ea395ae
      Victor Stinner authored
      * Factorize code from PC/getpathp.c and Modules/getpath.c to remove
        duplicated code
      * rename pathconfig_clear() to _PyPathConfig_Clear()
      * Inline _PyPathConfig_Fini() in pymain_impl() and then remove it,
        since it's a oneliner
      0ea395ae
    • Victor Stinner's avatar
      bpo-32030: Don't call _PyPathConfig_Fini() in Py_FinalizeEx() (#4667) · ebac19da
      Victor Stinner authored
      Changes:
      
      * _PyPathConfig_Fini() cannot be called in Py_FinalizeEx().
        Py_Initialize() and Py_Finalize() can be called multiple times, but
        it must not "forget" parameters set by Py_SetProgramName(),
        Py_SetPath() or Py_SetPythonHome(), whereas _PyPathConfig_Fini()
        clear all these parameters.
      * config_get_program_name() and calculate_program_full_path() now
        also decode paths using Py_DecodeLocale() to use the
        surrogateescape error handler, rather than decoding using
        mbstowcs() which is strict.
      * Change _Py_CheckPython3() prototype: () => (void)
      * Truncate a few lines which were too long
      ebac19da
    • Victor Stinner's avatar
      bpo-32030: Fix Py_GetPath(): init program_name (#4665) · 9ac3d888
      Victor Stinner authored
      * _PyMainInterpreterConfig_ReadEnv() now sets program_name from
        environment variables and pymain_parse_envvars() implements the
        falls back on argv[0].
      * Remove _PyMain.program_name: use the program_name from
        _PyMainInterpreterConfig
      * Move the Py_SetProgramName() call back to pymain_init_python(),
        just before _Py_InitializeCore().
      * pathconfig_global_init() now also calls
        _PyMainInterpreterConfig_Read() to set program_name if it isn't set
        yet
      * Cleanup PyCalculatePath: pass main_config to subfunctions to get
        directly fields from main_config (home, module_search_path_env and
        program_name)
      9ac3d888
    • Victor Stinner's avatar
      bpo-32030: Cleanup "path config" code (#4663) · b64de46a
      Victor Stinner authored
      * Rename PyPathConfig structure to _PyPathConfig and move it to
        Include/internal/pystate.h
      * Rename path_config to _Py_path_config
      * _PyPathConfig: Rename program_name field to program_full_path
      * Add assert(str != NULL); to _PyMem_RawWcsdup(), _PyMem_RawStrdup()
        and _PyMem_Strdup().
      * Rename calculate_path() to pathconfig_global_init(). The function
        now does nothing if it's already initiallized.
      b64de46a
    • John Chen's avatar
      8f5c28b1
    • xdegaye's avatar
      bpo-28668: test.support.requires_multiprocessing_queue is removed (GH-4560) · bf2b65e4
      xdegaye authored
      Skip tests with test.support.import_module('multiprocessing.synchronize')
      instead when the semaphore implementation is broken or missing.
      bf2b65e4
    • Serhiy Storchaka's avatar
    • Serhiy Storchaka's avatar
      bpo-10544: Deprecate "yield" in comprehensions and generator expressions. (GH-4579) · 73a7e9b1
      Serhiy Storchaka authored
      The current behaviour of yield expressions inside comprehensions  and
      generator expressions is essentially an accident of implementation - it
      arises implicitly from the way the compiler handles yield expressions inside
      nested functions and generators.
      
      Since the current behaviour wasn't deliberately designed, and is inherently
      confusing, we're deprecating it, with no current plans to reintroduce it.
      Instead, our advice will be to use a named nested generator definition
      for cases where this behaviour is desired.
      73a7e9b1
    • Nir Soffer's avatar
      bpo-32186: Release the GIL during lseek and fstat (#4652) · 6a894816
      Nir Soffer authored
      In _io_FileIO_readall_impl(), lseek() and _Py_fstat_noraise() were called
      without releasing the GIL. This can cause all threads to hang for
      unlimited time when calling FileIO.read() and the NFS server is not
      accessible.
      6a894816
  3. 30 Nov, 2017 9 commits
  4. 29 Nov, 2017 10 commits
  5. 28 Nov, 2017 9 commits