Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
Z
ZODB
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
Nicolas Wavrant
ZODB
Commits
e03aa4de
Commit
e03aa4de
authored
Jun 12, 2000
by
Shane Hathaway
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
This adds the ability to grab ZClass definitions from the root
database rather than the mounted database.
parent
52870161
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
42 additions
and
7 deletions
+42
-7
src/ZODB/Mount.py
src/ZODB/Mount.py
+42
-7
No files found.
src/ZODB/Mount.py
View file @
e03aa4de
...
@@ -84,8 +84,8 @@
...
@@ -84,8 +84,8 @@
##############################################################################
##############################################################################
"""Mounted database support
"""Mounted database support
$Id: Mount.py,v 1.
3 2000/06/09 14:38:01
shane Exp $"""
$Id: Mount.py,v 1.
4 2000/06/12 14:45:19
shane Exp $"""
__version__
=
'$Revision: 1.
3
$'
[
11
:
-
2
]
__version__
=
'$Revision: 1.
4
$'
[
11
:
-
2
]
import
Globals
,
thread
,
Persistence
,
Acquisition
import
Globals
,
thread
,
Persistence
,
Acquisition
import
ExtensionClass
,
string
,
time
,
sys
import
ExtensionClass
,
string
,
time
,
sys
...
@@ -100,6 +100,22 @@ dbs = {}
...
@@ -100,6 +100,22 @@ dbs = {}
# dblock is locked every time dbs is accessed.
# dblock is locked every time dbs is accessed.
dblock
=
thread
.
allocate_lock
()
dblock
=
thread
.
allocate_lock
()
try
:
# Make special provisions for ZClasses if we're in a Zope
# installation.
from
Zope.ClassFactory
import
ClassFactory
def
RootDefsClassFactory
(
jar
,
module
,
name
):
# Use the class definitions given at
# the root of the Zope installation.
while
hasattr
(
jar
,
'_mount_parent_jar'
):
jar
=
jar
.
_mount_parent_jar
return
ClassFactory
(
jar
,
module
,
name
)
except
:
ClassFactory
=
None
RootDefsClassFactory
=
None
class
MountPoint
(
Persistence
.
Persistent
,
Acquisition
.
Implicit
):
class
MountPoint
(
Persistence
.
Persistent
,
Acquisition
.
Implicit
):
'''The base class for a Zope object which, when traversed,
'''The base class for a Zope object which, when traversed,
accesses a different database.
accesses a different database.
...
@@ -111,7 +127,7 @@ class MountPoint(Persistence.Persistent, Acquisition.Implicit):
...
@@ -111,7 +127,7 @@ class MountPoint(Persistence.Persistent, Acquisition.Implicit):
_v_close_db
=
0
_v_close_db
=
0
_v_connect_error
=
None
_v_connect_error
=
None
def
__init__
(
self
,
path
,
params
=
None
):
def
__init__
(
self
,
path
,
params
=
None
,
classDefsFromRoot
=
1
):
'''
'''
@arg path The path within the mounted database from which
@arg path The path within the mounted database from which
to derive the root.
to derive the root.
...
@@ -122,7 +138,11 @@ class MountPoint(Persistence.Persistent, Acquisition.Implicit):
...
@@ -122,7 +138,11 @@ class MountPoint(Persistence.Persistent, Acquisition.Implicit):
database, MountPoint will detect the matching params
database, MountPoint will detect the matching params
and use the existing database. Include the class name of
and use the existing database. Include the class name of
the storage. For example,
the storage. For example,
ZEO params might be "ZODB.ZEO localhost 1081".
ZEO params might be "ZODB.ZEOClient localhost 1081".
@arg classDefsFromRoot If true (the default), MountPoint will
try to get ZClass definitions from the root database rather
than the mounted database.
'''
'''
# The only reason we need a __mountpoint_id is to
# The only reason we need a __mountpoint_id is to
# be sure we don't close a database prematurely when
# be sure we don't close a database prematurely when
...
@@ -135,6 +155,7 @@ class MountPoint(Persistence.Persistent, Acquisition.Implicit):
...
@@ -135,6 +155,7 @@ class MountPoint(Persistence.Persistent, Acquisition.Implicit):
params
=
self
.
__mountpoint_id
params
=
self
.
__mountpoint_id
self
.
_params
=
repr
(
params
)
self
.
_params
=
repr
(
params
)
self
.
_path
=
path
self
.
_path
=
path
self
.
_classDefsFromRoot
=
classDefsFromRoot
def
_createDB
(
self
):
def
_createDB
(
self
):
'''Gets the database object, usually by creating a Storage object
'''Gets the database object, usually by creating a Storage object
...
@@ -155,8 +176,12 @@ class MountPoint(Persistence.Persistent, Acquisition.Implicit):
...
@@ -155,8 +176,12 @@ class MountPoint(Persistence.Persistent, Acquisition.Implicit):
db
=
self
.
_createDB
()
db
=
self
.
_createDB
()
newMount
=
1
newMount
=
1
dbs
[
params
]
=
(
db
,
{
self
.
__mountpoint_id
:
1
})
dbs
[
params
]
=
(
db
,
{
self
.
__mountpoint_id
:
1
})
import
Zope.ClassFactory
db
.
setClassFactory
(
Zope
.
ClassFactory
.
ClassFactory
)
if
RootDefsClassFactory
is
not
None
and
\
getattr
(
self
,
'_classDefsFromRoot'
,
1
):
db
.
setClassFactory
(
RootDefsClassFactory
)
elif
ClassFactory
is
not
None
:
db
.
setClassFactory
(
ClassFactory
)
else
:
else
:
db
,
mounts
=
dbInfo
db
,
mounts
=
dbInfo
# Be sure this object is in the list of mount points.
# Be sure this object is in the list of mount points.
...
@@ -182,7 +207,10 @@ class MountPoint(Persistence.Persistent, Acquisition.Implicit):
...
@@ -182,7 +207,10 @@ class MountPoint(Persistence.Persistent, Acquisition.Implicit):
# This mount point has been deleted.
# This mount point has been deleted.
del
data
.
_v__object_deleted__
del
data
.
_v__object_deleted__
self
.
_v_close_db
=
1
self
.
_v_close_db
=
1
data
.
_p_jar
.
close
()
conn
=
data
.
_p_jar
try
:
del
conn
.
_mount_parent_jar
except
KeyError
:
pass
conn
.
close
()
self
.
_v_data
=
None
self
.
_v_data
=
None
if
self
.
_v_close_db
:
if
self
.
_v_close_db
:
# Stop using this database. Close it if no other
# Stop using this database. Close it if no other
...
@@ -218,6 +246,11 @@ class MountPoint(Persistence.Persistent, Acquisition.Implicit):
...
@@ -218,6 +246,11 @@ class MountPoint(Persistence.Persistent, Acquisition.Implicit):
# Get _p_jar from parent.
# Get _p_jar from parent.
self
.
_p_jar
=
jar
=
parent
.
_p_jar
self
.
_p_jar
=
jar
=
parent
.
_p_jar
conn
=
db
.
open
(
version
=
jar
.
getVersion
())
conn
=
db
.
open
(
version
=
jar
.
getVersion
())
# Add an attribute to the connection which
# makes it possible for us to find the primary
# database connection. See ClassFactoryForMount().
conn
.
_mount_parent_jar
=
jar
try
:
try
:
jar
.
onCloseCallback
(
self
.
_close
)
jar
.
onCloseCallback
(
self
.
_close
)
obj
=
self
.
_getMountRoot
(
conn
.
root
())
obj
=
self
.
_getMountRoot
(
conn
.
root
())
...
@@ -226,6 +259,7 @@ class MountPoint(Persistence.Persistent, Acquisition.Implicit):
...
@@ -226,6 +259,7 @@ class MountPoint(Persistence.Persistent, Acquisition.Implicit):
self
.
_v_data
=
(
data
,)
self
.
_v_data
=
(
data
,)
except
:
except
:
# Close the connection before processing the exception.
# Close the connection before processing the exception.
del
conn
.
_mount_parent_jar
conn
.
close
()
conn
.
close
()
raise
raise
if
newMount
:
if
newMount
:
...
@@ -294,3 +328,4 @@ class MountPoint(Persistence.Persistent, Acquisition.Implicit):
...
@@ -294,3 +328,4 @@ class MountPoint(Persistence.Persistent, Acquisition.Implicit):
traceback
.
print_tb
(
exc
[
2
],
100
,
f
)
traceback
.
print_tb
(
exc
[
2
],
100
,
f
)
self
.
_v_connect_error
=
(
exc
[
0
],
exc
[
1
],
f
.
getvalue
())
self
.
_v_connect_error
=
(
exc
[
0
],
exc
[
1
],
f
.
getvalue
())
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