|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| | is not a string. (#3257) | 
| | 
| 
| 
| 
| | A bunch of code currently uses PyInterpreterState.modules directly instead of PyImport_GetModuleDict(). This complicates efforts to make changes relative to sys.modules. This patch switches to using PyImport_GetModuleDict() uniformly. Also, a number of related uses of sys.modules are updated for uniformity for the same reason.
Note that this code was already reviewed and merged as part of #1638. I reverted that and am now splitting it up into more focused parts. | 
| | 
| 
| | PR #1638, for bpo-28411, causes problems in some (very) edge cases. Until that gets sorted out, we're reverting the merge. PR #3506, a fix on top of #1638, is also getting reverted. | 
| | 
| 
| | sys.modules is the one true source. | 
| | 
| 
| 
| | rather of "char *". | 
| |\ |  | 
| | | |  | 
| |/ |  | 
| | |  | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Known limitations of the current implementation:
- documentation changes are incomplete
- there's a reference leak I haven't tracked down yet
The leak is most visible by running:
  ./python -m test -R3:3 test_importlib
However, you can also see it by running:
  ./python -X showrefcount
Importing the array or _testmultiphase modules, and
then deleting them from both sys.modules and the local
namespace shows significant increases in the total
number of active references each cycle. By contrast,
with _testcapi (which continues to use single-phase
initialisation) the global refcounts stabilise after
a couple of cycles. | 
| | 
| 
| 
| | PyUnicode_FromFormat() failure | 
| | |  | 
| | 
| 
| 
| | PyModule_GetDef() returns an error. | 
| | 
| 
| 
| 
| 
| 
| | in Python/dynload_shlibs.c.
This should fix the remaining importlib test failure on Windows.
Support in AIX and HP-UX will be in a separate checkin. | 
| | 
| 
| 
| 
| 
| 
| | importlib._bootstrap is now frozen into Python/importlib.h and stored
as _frozen_importlib in sys.modules. Py_Initialize() loads the frozen
code along with sys and imp and then uses _frozen_importlib._install()
to set builtins.__import__() w/ _frozen_importlib.__import__(). | 
| | 
| 
| 
| 
| 
| | The name must be encodable to ASCII because dynamic module must have a function
called "PyInit_NAME", they are written in C, and the C language doesn't accept
non-ASCII identifiers. | 
| | 
| 
| 
| | on Windows. | 
| | 
| 
| 
| | Document also that dynamic module names are ASCII only | 
| | 
| 
| 
| 
| 
| 
| | - is_builtin(), init_builtin(), load_builtin() and other builtin related
   functions use Unicode strings, instead of byte strings
 - Rename _PyImport_FixupExtensionUnicode() to _PyImport_FixupExtensionObject()
 - Rename _PyImport_FindExtensionUnicode() to _PyImport_FindExtensionObject() | 
| | 
| 
| 
| | The first argument, fqname, was not used. | 
| | 
| 
| 
| 
| 
| 
| | * Rename _PyImport_FindExtension() to _PyImport_FindExtensionUnicode():
   the filename becomes a Unicode object instead of byte string
 * Rename _PyImport_FixupExtension() to _PyImport_FixupExtensionUnicode():
   the filename becomes a Unicode object instead of byte string | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | svn+ssh://pythondev@svn.python.org/python/trunk
........
  r81029 | antoine.pitrou | 2010-05-09 16:46:46 +0200 (dim., 09 mai 2010) | 3 lines
  Untabify C files. Will watch buildbots.
........ | 
| | |  | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | Changes to make __file__ a proper Unicode object, using the default
filesystem encoding.
This is a bit tricky because the default filesystem encoding isn't
set by the time we import the first modules; at that point we fudge
things a bit.  This is okay since __file__ isn't really used much
except for error reporting.
Tested on OSX and Linux only so far. | 
| | 
| 
| 
| | interpreters. Fixes #698282. Will backport to 2.3. | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | When an extension imports another extension in its
    initXXX() function, the variable _Py_PackageContext is
    prematurely reset to NULL. If the outer extension then
    calls Py_InitModule(), the extension is installed in
    sys.modules without its package name. The
    manifestation of this bug is a "SystemError:
    _PyImport_FixupExtension: module <package>.<extension>
    not loaded".
    To fix this, importdl.c just needs to retain the old
    value of _Py_PackageContext and restore it after the
    initXXX() method is called. The attached patch does this.
    This patch applies to Python 2.1.1 and the current CVS. | 
| | 
| 
| 
| | This should match the situation in the 1.6b1 tree. | 
| | 
| 
| 
| | declarations yet, those come later. | 
| | |  | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | * in import.c, #ifdef out references to dynamic loading based on
  HAVE_DYNAMIC_LOADING
* clean out the platform-specific crud from importdl.c.
  [ maybe fold this function into import.c and drop the importdl.c file? Greg.]
* change GetDynLoadFunc's "funcname" parameter to "shortname". change
  "name" to "fqname" for clarification.
* each GetDynLoadFunc now creates its own funcname value.
  WARNING: as I mentioned previously, we may run into an issue with a
  missing "_" on some platforms. Testing will show this pretty quickly,
  however.
* move pathname munging into dynload_shlib.c | 
| | 
| 
| 
| 
| 
| | (A few nite remain, these will probably disappear soon.)
This is part of a set of patches by Greg Stein. | 
| | 
| 
| 
| 
| 
| 
| | Duzan, for AIX, to support C++ objects with static initializers, when
using the genuine IBM C++ compiler (namely xlC/xlC_r).
See accompanying patches to configure.in and acconfig.h. | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | """
Following up Robin Dunn's troubles with freeze, here's a patch that
fixes an oddity regarding the import logic of shared modules on AIX.
Symbol resolution of shared modules is now handled properly for the cases
when the python library is linked to a binary with an arbitrary name.
This includes the standard python[version] executable, but also applications
that are embedding the python core (i.e. linked with libpython[version].a,
the latter being static or shared).
""" | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | The following patches (relative to 1.5.2b1) enable Python dynamic
loading to work on NetBSD platforms that use ELF (presnetly mips and
alpha systems).  They automaticly determine wether the system is ELF or
a.out rather than using astatic list of platforms so that when other
NetBSD platforms move to ELF, python will continue to work without
change. | 
| | 
| 
| 
| | Donn Cave tells me the PyImport_BeImageID() function isn't needed anymore. | 
| | 
| 
| 
| 
| | names in the source code (they already had those for the linker,
through some smart macros; but the source still had the old, un-Py names). | 
| | |  | 
| | 
| 
| 
| 
| | LoadLibraryEx(pathname, NULL, LOAD_WITH_ALTERED_SEARCH_PATH)
to search dependent DLLs in the directory of the pathname. | 
| | 
| 
| 
| | (Also removed whitespace after # in some BEOS related cpp directives.) | 
| | 
| 
| 
| | function name.  (Vladimir Kushnir by way of Thomas Gellekum.) | 
| | 
| 
| 
| | (Jack Jansen and/or Just van Rossum) | 
| | 
| 
| 
| 
| 
| | This is a patch that Bill Bummgarner did for 1.4 that hasn't made its
way into the distribution yet.  This is important if you want to use
the ObjC module. | 
| | |  | 
| | 
| 
| 
| | inconsistent. | 
| | 
| 
| 
| 
| 
| | the filename contains at least a rudimentary pathname.
(The bad part is that we need to call getcwd() because only a prefix
of ".\\" is not enough -- we prefix the drive letter.) |