Commit ccb4748d authored by Jim Fulton's avatar Jim Fulton

Redid ZServer search to use package path info.

parent aa0d4f47
...@@ -88,39 +88,39 @@ ...@@ -88,39 +88,39 @@
Try to fix up the imports of these to make these dependencies work, Try to fix up the imports of these to make these dependencies work,
localizing the hacks^H^H^H^H^Hchanges here. localizing the hacks^H^H^H^H^Hchanges here.
""" """
import sys import sys, os
def whiff(where): def whiff(where):
if not where: return 0 if not where: return 0
import os, imp import imp
try: m=imp.find_module('ZServer', [where]) try: m=imp.find_module('ZServer', [where])
except: return 0 except: return 0
else: return 1 else: return 1
def fap(where=''): def fap():
# if we are using an old version of Python, our asyncore is likely to # if we are using an old version of Python, our asyncore is likely to
# be out of date. If ZServer is sitting around, we can get a current # be out of date. If ZServer is sitting around, we can get a current
# version of ayncore from it. In any case, if we are going to be used # version of ayncore from it. In any case, if we are going to be used
# with Zope, it's important to use the version from Zope. # with Zope, it's important to use the version from Zope.
try: try:
from ZServer.medusa import asyncore import ZServer
except: except:
# Try a little harder to import ZServer # Try a little harder to import ZServer
import os, imp import os, imp
asyncore = None location = package_home()
location = os.path.split(location)[0]
location = os.path.split(location)[0]
location = os.path.split(location)[0]
for location in where, '.', os.path.join('..','..'):
if whiff(location): if whiff(location):
sys.path.append(location) sys.path.append(location)
try: try:
from ZServer.medusa import asyncore import ZServer
except: except:
import asyncore pass
break
if asyncore is None:
import asyncore import asyncore
if sys.version[:1] < '2' and asyncore.loop.func_code.co_argcount < 3: if sys.version[:1] < '2' and asyncore.loop.func_code.co_argcount < 3:
...@@ -146,3 +146,16 @@ def fap(where=''): ...@@ -146,3 +146,16 @@ def fap(where=''):
except: except:
raise ImportError, 'Cannot import an up-to-date cPickle' raise ImportError, 'Cannot import an up-to-date cPickle'
def package_home():
m=sys.modules[__name__]
if hasattr(m,'__path__'):
r=m.__path__[0]
elif "." in __name__:
from string import rfind
r=sys.modules[__name__[:rfind(__name__,'.')]].__path__[0]
else:
r=__name__
return os.path.join(os.getcwd(), r)
fap()
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment