Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
Z
Zope
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
Zope
Commits
6dbe74b5
Commit
6dbe74b5
authored
Apr 05, 2010
by
Tres Seaver
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Cleanup, PEP8, sane variable names.
parent
693a53df
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
124 additions
and
111 deletions
+124
-111
src/App/Extensions.py
src/App/Extensions.py
+124
-111
No files found.
src/App/Extensions.py
View file @
6dbe74b5
...
@@ -10,44 +10,53 @@
...
@@ -10,44 +10,53 @@
# FOR A PARTICULAR PURPOSE
# FOR A PARTICULAR PURPOSE
#
#
##############################################################################
##############################################################################
__doc__
=
'''
Standard routines for handling extensions.
"""
Standard routines for handling extensions.
Extensions currently include external methods and pluggable brains.
Extensions currently include external methods and pluggable brains.
"""
import
imp
import
os
$Id$'''
__version__
=
'$Revision: 1.23 $'
[
11
:
-
2
]
import
os
,
imp
import
Products
import
Products
from
zExceptions
import
NotFound
from
zExceptions
import
NotFound
path_split
=
os
.
path
.
split
path_join
=
os
.
path
.
join
exists
=
os
.
path
.
exists
class
FuncCode
:
class
FuncCode
:
def
__init__
(
self
,
f
,
im
=
0
):
def
__init__
(
self
,
f
,
im
=
0
):
self
.
co_varnames
=
f
.
func_code
.
co_varnames
[
im
:]
self
.
co_varnames
=
f
.
func_code
.
co_varnames
[
im
:]
self
.
co_argcount
=
f
.
func_code
.
co_argcount
-
im
self
.
co_argcount
=
f
.
func_code
.
co_argcount
-
im
def
__cmp__
(
self
,
other
):
def
__cmp__
(
self
,
other
):
if
other
is
None
:
return
1
if
other
is
None
:
try
:
return
cmp
((
self
.
co_argcount
,
self
.
co_varnames
),
return
1
(
other
.
co_argcount
,
other
.
co_varnames
))
try
:
except
:
return
1
return
cmp
((
self
.
co_argcount
,
self
.
co_varnames
),
(
other
.
co_argcount
,
other
.
co_varnames
))
except
:
return
1
def
_getPath
(
home
,
prefix
,
name
,
suffixes
):
def
_getPath
(
home
,
prefix
,
name
,
suffixes
):
d
=
path_join
(
home
,
prefix
)
if
d
==
prefix
:
raise
ValueError
,
(
dir
=
os
.
path
.
join
(
home
,
prefix
)
'The prefix, %s, should be a relative path'
%
prefix
)
if
dir
==
prefix
:
d
=
path_join
(
d
,
name
)
raise
ValueError
(
'The prefix, %s, should be a relative path'
%
prefix
)
if
d
==
name
:
raise
ValueError
,
(
# Paranoia
'The file name, %s, should be a simple file name'
%
name
)
fn
=
os
.
path
.
join
(
dir
,
name
)
for
s
in
suffixes
:
if
fn
==
name
:
if
s
:
s
=
"%s.%s"
%
(
d
,
s
)
# Paranoia
else
:
s
=
d
raise
ValueError
(
'The file name, %s, should be a simple file name'
if
exists
(
s
):
return
s
%
name
)
for
suffix
in
suffixes
:
if
suffix
:
fqn
=
"%s.%s"
%
(
fn
,
suffix
)
else
:
fqn
=
fn
if
os
.
path
.
exists
(
fqn
):
return
fqn
def
getPath
(
prefix
,
name
,
checkProduct
=
1
,
suffixes
=
(
''
,),
cfg
=
None
):
def
getPath
(
prefix
,
name
,
checkProduct
=
1
,
suffixes
=
(
''
,),
cfg
=
None
):
"""Find a file in one of several relative locations
"""Find a file in one of several relative locations
...
@@ -76,69 +85,69 @@ def getPath(prefix, name, checkProduct=1, suffixes=('',), cfg=None):
...
@@ -76,69 +85,69 @@ def getPath(prefix, name, checkProduct=1, suffixes=('',), cfg=None):
the directory containing the directory containing the software
the directory containing the directory containing the software
home, and possibly product areas.
home, and possibly product areas.
"""
"""
d
,
n
=
path_split
(
name
)
dir
,
ignored
=
os
.
path
.
split
(
name
)
if
d
:
raise
ValueError
,
(
if
dir
:
'The file name, %s, should be a simple file name'
%
name
)
raise
ValueError
(
'The file name, %s, should be a simple file name'
%
name
)
result
=
None
result
=
None
if
checkProduct
:
if
checkProduct
:
l
=
name
.
find
(
'.'
)
dot
=
name
.
find
(
'.'
)
if
l
>
0
:
if
dot
>
0
:
p
=
name
[:
l
]
p
roduct
=
name
[:
dot
]
n
=
name
[
l
+
1
:]
extname
=
name
[
dot
+
1
:]
for
product_dir
in
Products
.
__path__
:
for
product_dir
in
Products
.
__path__
:
r
=
_getPath
(
product_dir
,
os
.
path
.
join
(
p
,
prefix
),
n
,
suffixes
)
found
=
_getPath
(
product_dir
,
os
.
path
.
join
(
product
,
prefix
),
if
r
is
not
None
:
result
=
r
extname
,
suffixes
)
if
found
is
not
None
:
if
result
is
None
:
return
found
if
cfg
is
None
:
import
App.config
if
cfg
is
None
:
cfg
=
App
.
config
.
getConfiguration
()
import
App.config
locations
=
[]
cfg
=
App
.
config
.
getConfiguration
()
locations
.
append
(
cfg
.
instancehome
)
sw
=
getattr
(
cfg
,
'softwarehome'
,
None
)
if
sw
is
not
None
:
sw
=
os
.
path
.
dirname
(
sw
)
locations
.
append
(
sw
)
for
home
in
locations
:
r
=
_getPath
(
home
,
prefix
,
name
,
suffixes
)
if
r
is
not
None
:
result
=
r
del
locations
if
result
is
None
:
try
:
l
=
name
.
rfind
(
'.'
)
if
l
>
0
:
realName
=
name
[
l
+
1
:]
toplevel
=
name
[:
l
]
pos
=
toplevel
.
rfind
(
'.'
)
if
pos
>
-
1
:
m
=
__import__
(
toplevel
,
globals
(),
{},
toplevel
[
pos
+
1
:])
else
:
m
=
__import__
(
toplevel
)
d
=
os
.
path
.
join
(
m
.
__path__
[
0
],
prefix
,
realName
)
for
s
in
suffixes
:
if
s
:
s
=
"%s.%s"
%
(
d
,
s
)
else
:
s
=
d
if
os
.
path
.
exists
(
s
):
result
=
s
break
except
:
pass
return
result
locations
=
[
cfg
.
instancehome
]
softwarehome
=
getattr
(
cfg
,
'softwarehome'
,
None
)
if
softwarehome
is
not
None
:
zopehome
=
os
.
path
.
dirname
(
softwarehome
)
locations
.
append
(
zopehome
)
for
home
in
locations
:
found
=
_getPath
(
home
,
prefix
,
name
,
suffixes
)
if
found
is
not
None
:
return
found
try
:
dot
=
name
.
rfind
(
'.'
)
if
dot
>
0
:
realName
=
name
[
dot
+
1
:]
toplevel
=
name
[:
dot
]
rdot
=
toplevel
.
rfind
(
'.'
)
if
rdot
>
-
1
:
module
=
__import__
(
toplevel
,
globals
(),
{},
toplevel
[
rdot
+
1
:])
else
:
module
=
__import__
(
toplevel
)
prefix
=
os
.
path
.
join
(
module
.
__path__
[
0
],
prefix
,
realName
)
for
suffix
in
suffixes
:
if
suffix
:
fn
=
"%s.%s"
%
(
prefix
,
suffix
)
else
:
fn
=
prefix
if
os
.
path
.
exists
(
fn
):
return
fn
except
:
pass
def
getObject
(
module
,
name
,
reload
=
0
,
def
getObject
(
module
,
name
,
reload
=
0
,
# The use of a mutable default is intentional here,
# The use of a mutable default is intentional here,
# because modules is a module cache.
# because modules is a module cache.
modules
=
{}
modules
=
{}
):
):
# The use of modules here is not thread safe, however, there is
# The use of modules here is not thread safe, however, there is
# no real harm in a race condition here. If two threads
# no real harm in a race condition here. If two threads
# update the cache, then one will have simply worked a little
# update the cache, then one will have simply worked a little
...
@@ -151,56 +160,60 @@ def getObject(module, name, reload=0,
...
@@ -151,56 +160,60 @@ def getObject(module, name, reload=0,
base
,
ext
=
os
.
path
.
splitext
(
module
)
base
,
ext
=
os
.
path
.
splitext
(
module
)
if
ext
in
(
'py'
,
'pyc'
):
if
ext
in
(
'py'
,
'pyc'
):
# XXX should never happen; splitext() keeps '.' with the extension
# XXX should never happen; splitext() keeps '.' with the extension
p
=
base
p
refix
=
base
else
:
else
:
p
=
module
prefix
=
module
p
=
getPath
(
'Extensions'
,
p
,
suffixes
=
(
''
,
'py'
,
'pyc'
))
if
p
is
None
:
raise
NotFound
,
(
"The specified module, <em>%s</em>, couldn't be found."
%
module
)
__traceback_info__
=
p
,
module
path
=
getPath
(
'Extensions'
,
prefix
,
suffixes
=
(
''
,
'py'
,
'pyc'
))
if
path
is
None
:
raise
NotFound
(
"The specified module, '%s', couldn't be found."
%
module
)
base
,
ext
=
os
.
path
.
splitext
(
p
)
__traceback_info__
=
path
,
module
base
,
ext
=
os
.
path
.
splitext
(
path
)
if
ext
==
'.pyc'
:
if
ext
==
'.pyc'
:
file
=
open
(
p
,
'rb'
)
file
=
open
(
p
ath
,
'rb'
)
binmod
=
imp
.
load_compiled
(
'Extension'
,
p
,
file
)
binmod
=
imp
.
load_compiled
(
'Extension'
,
path
,
file
)
file
.
close
()
file
.
close
()
m
=
binmod
.
__dict__
module_dict
=
binmod
.
__dict__
else
:
else
:
try
:
execsrc
=
open
(
p
)
try
:
except
:
raise
NotFound
,
(
execsrc
=
open
(
path
)
"The specified module, <em>%s</em>, couldn't be opened."
except
:
%
module
)
raise
NotFound
(
"The specified module, '%s', "
m
=
{}
"couldn't be opened."
%
module
)
exec
execsrc
in
m
module_dict
=
{}
exec
execsrc
in
module_dict
if
old
is
not
None
:
if
old
is
not
None
:
old
.
update
(
m
)
# XXX Accretive??
old
.
update
(
module_dict
)
else
:
else
:
modules
[
module
]
=
m
modules
[
module
]
=
m
odule_dict
try
:
try
:
return
m
[
name
]
return
m
odule_dict
[
name
]
except
KeyError
:
except
KeyError
:
raise
NotFound
,
(
raise
NotFound
(
"The specified object, '%s', was not found "
"The specified object, <em>%s</em>, was not found in module, "
"in module, '%s'."
%
(
name
,
module
))
"<em>%s</em>."
%
(
name
,
module
))
class
NoBrains
:
pass
class
NoBrains
:
pass
def
getBrain
(
module
,
class_name
,
reload
=
0
):
'Check/load a class'
if
not
module
and
not
class_name
:
return
NoBrains
def
getBrain
(
module
,
class_name
,
reload
=
0
,
modules
=
None
):
""" Check/load a class from an extension.
"""
if
not
module
and
not
class_name
:
return
NoBrains
try
:
c
=
getObject
(
module
,
class_name
,
reload
)
if
modules
is
None
:
except
KeyError
,
v
:
c
=
getObject
(
module
,
class_name
,
reload
)
if
v
==
class_name
:
raise
ValueError
,
(
else
:
'The class, %s, is not defined in file, %s'
%
(
class_name
,
module
)
)
c
=
getObject
(
module
,
class_name
,
reload
,
modules
=
modules
)
if
not
hasattr
(
c
,
'__bases__'
):
raise
ValueError
,
(
if
getattr
(
c
,
'__bases__'
,
None
)
is
None
:
'%s, is not a class'
%
class_name
)
raise
ValueError
(
'%s, is not a class'
%
class_name
)
return
c
return
c
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment