[Python-bugs-list] [ python-Bugs-661136 ] zipimport does not accept nested pure python imports

SourceForge.net noreply@sourceforge.net
Fri, 03 Jan 2003 10:42:38 -0800


Bugs item #661136, was opened at 2003-01-02 15:54
You can respond by visiting: 
https://sourceforge.net/tracker/?func=detail&atid=105470&aid=661136&group_id=5470

Category: Python Library
Group: Python 2.3
Status: Closed
Resolution: Fixed
Priority: 5
Submitted By: Sandy Norton (sandynorton)
Assigned to: Just van Rossum (jvr)
Summary: zipimport does not accept nested pure python imports

Initial Comment:
I presume this is a big with zipimport. It occurs when
you have a nested pure python package structure. It
doesn't occcur if there are byte-compiled versions in
the zipped directory.



as pure python zipped directory
===============================

Assume mylib.zip is inserted on the sys.path with the
following
directory structure:

mylib.zip
	mod.py
	p1
		__init__.py
		mod.py
		p2
			__init__.py
			mod.py

C:\TMP>ls
mylib.zip

C:\TMP>p
Python 2.3a1 (#38, Jan  1 2003, 16:44:16) [MSC v.1200
32 bit (Intel)] on win32
Type "help", "copyright", "credits" or "license" for
more information.
>>> import sys; sys.path.insert(0, 'c:\tmp\mylib.zip')
>>> import mod
mod
>>> from p1 import mod
Traceback (most recent call last):
  File "<stdin>", line 1, in ?
SystemError:
C:\Engines\python\dist\src\Objects\stringobject.c:3295:
bad argumen
t to internal function
>>> from p1.p2 import mod
Traceback (most recent call last):
  File "<stdin>", line 1, in ?
SystemError:
C:\Engines\python\dist\src\Objects\stringobject.c:3295:
bad argumen
t to internal function
>>>

as plain directory
===================

C:\TMP>p
Python 2.3a1 (#38, Jan  1 2003, 16:44:16) [MSC v.1200
32 bit (Intel)] on win32
Type "help", "copyright", "credits" or "license" for
more information.
>>> import sys
>>> sys.path.insert(0, 'c:\tmp\mylib')
>>> import mod
mod
>>> from p1 import mod
mod1
>>> from p1.p2 import mod
mod2
>>>

as byte-compiled zipped directory
=================================
mylib.zip
	mod.py
	mod.pyc
	p1
		__init__.py
		__init__.pyc
		mod.py
		mod.pyc
		p2
			__init__.py
			__init__.pyc
			mod.py
			mod.pyc

C:\TMP>p
Python 2.3a1 (#38, Jan  1 2003, 16:44:16) [MSC v.1200
32 bit (Intel)] on win32
Type "help", "copyright", "credits" or "license" for
more information.
>>> import sys; sys.path.insert(0, 'c:\tmp\mylib.zip')
>>> import mod
mod
>>> import p1.mod
mod1
>>> import p1.p2.mod
mod2
>>> p1.p2.mod
<module 'p1.p2.mod' from 'c:\tmp\mylib.zip\p1\p2\mod.pyc'>
>>>


----------------------------------------------------------------------

>Comment By: Sandy Norton (sandynorton)
Date: 2003-01-03 18:42

Message:
Logged In: YES 
user_id=378957

My pleasure.

Yes you are right both p1/__init__.py and p1/p2/__init__.py
were empty files. 

Thanks for the quick fix (-:

----------------------------------------------------------------------

Comment By: Just van Rossum (jvr)
Date: 2003-01-03 11:22

Message:
Logged In: YES 
user_id=92689

Ouch, nasty. It's not quite like you describe: the problem
occurs for any *empty* source file (that doesn't have a
matching .pyc in the archive). So I take it your mod.py
wasn't empty but p1/__init__.py and p1/p2/__init__.py were.

Fixed in rev. 1.8 of Modules/zipimport.c

Thanks for reporting this!

----------------------------------------------------------------------

You can respond by visiting: 
https://sourceforge.net/tracker/?func=detail&atid=105470&aid=661136&group_id=5470