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
5de492bf
Commit
5de492bf
authored
Jun 29, 1999
by
Jim Fulton
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
No longer pass storage to Connection constructor.
Added subtransaction support.
parent
0628569b
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
61 additions
and
15 deletions
+61
-15
src/ZODB/Connection.py
src/ZODB/Connection.py
+61
-15
No files found.
src/ZODB/Connection.py
View file @
5de492bf
...
...
@@ -84,15 +84,16 @@
##############################################################################
"""Database connection support
$Id: Connection.py,v 1.1
0 1999/06/24 20:05:50
jim Exp $"""
__version__
=
'$Revision: 1.1
0
$'
[
11
:
-
2
]
$Id: Connection.py,v 1.1
1 1999/06/29 18:28:16
jim Exp $"""
__version__
=
'$Revision: 1.1
1
$'
[
11
:
-
2
]
from
cPickleCache
import
PickleCache
from
POSException
import
ConflictError
,
ExportError
from
cStringIO
import
StringIO
from
cPickle
import
Unpickler
,
Pickler
from
ExtensionClass
import
Base
import
Transaction
,
string
,
ExportImport
,
sys
,
traceback
import
Transaction
,
string
,
ExportImport
,
sys
,
traceback
,
TmpStore
from
zLOG
import
LOG
,
ERROR
ExtensionKlass
=
Base
.
__class__
...
...
@@ -108,12 +109,11 @@ class Connection(ExportImport.ExportImport):
The Connection manages movement of objects in and out of object storage.
"""
_tmp
=
None
def
__init__
(
self
,
storage
,
version
=
''
,
cache_size
=
400
,
def
__init__
(
self
,
version
=
''
,
cache_size
=
400
,
cache_deactivate_after
=
60
):
"""Create a new Connection"""
self
.
_storage
=
storage
self
.
new_oid
=
storage
.
new_oid
self
.
_version
=
version
self
.
_cache
=
cache
=
PickleCache
(
self
,
cache_size
,
cache_deactivate_after
)
self
.
_incrgc
=
cache
.
incrgc
...
...
@@ -217,6 +217,8 @@ class Connection(ExportImport.ExportImport):
Any objects modified since the last transaction are invalidated.
"""
self
.
_db
=
odb
self
.
_storage
=
s
=
odb
.
_storage
self
.
new_oid
=
s
.
new_oid
self
.
_cache
.
invalidate
(
self
.
_invalidated
)
return
self
...
...
@@ -231,7 +233,7 @@ class Connection(ExportImport.ExportImport):
def
close
(
self
):
self
.
_incrgc
()
self
.
_db
.
_closeConnection
(
self
)
del
self
.
_db
self
.
_db
=
self
.
_storage
=
self
.
_tmp
=
None
def
commit
(
self
,
object
,
transaction
):
oid
=
object
.
_p_oid
...
...
@@ -265,8 +267,7 @@ class Connection(ExportImport.ExportImport):
if
hasattr
(
klass
,
'__getinitargs__'
):
return
oid
try
:
module
=
klass
.
__module__
except
:
module
=
''
module
=
getattr
(
klass
,
'__module__'
,
''
)
if
module
:
klass
=
module
,
klass
.
__name__
return
oid
,
klass
...
...
@@ -285,8 +286,7 @@ class Connection(ExportImport.ExportImport):
object
=
stack
[
-
1
]
del
stack
[
-
1
]
oid
=
object
.
_p_oid
try
:
serial
=
object
.
_p_serial
except
:
serial
=
'
\
0
'
*
8
serial
=
getattr
(
object
,
'_p_serial'
,
'
\
0
\
0
\
0
\
0
\
0
\
0
\
0
\
0
'
)
if
invalid
(
oid
):
raise
ConflictError
,
oid
klass
=
object
.
__class__
...
...
@@ -304,8 +304,7 @@ class Connection(ExportImport.ExportImport):
else
:
args
=
None
# New no-constructor protocol!
try
:
module
=
klass
.
__module__
except
:
module
=
''
module
=
getattr
(
klass
,
'__module__'
,
''
)
if
module
:
klass
=
module
,
klass
.
__name__
state
=
object
.
__getstate__
()
...
...
@@ -324,6 +323,36 @@ class Connection(ExportImport.ExportImport):
return
topoid
def
commit_sub
(
self
,
t
):
tmp
=
self
.
_tmp
if
tmp
is
None
:
return
src
=
self
.
_storage
self
.
_storage
=
tmp
self
.
_tmp
=
None
tmp
.
tpc_begin
(
t
)
load
=
src
.
load
store
=
tmp
.
store
invalidate
=
self
.
_invalidating
.
append
dest
=
self
.
_version
get
=
self
.
_cache
.
get
for
oid
in
src
.
_index
.
keys
():
data
,
serial
=
load
(
oid
,
src
)
s
=
store
(
oid
,
serial
,
data
,
dest
,
t
)
o
=
get
(
oid
,
None
)
if
o
is
not
None
:
o
.
_p_serial
=
s
invalidate
(
oid
)
def
abort_sub
(
self
,
t
):
tmp
=
self
.
_tmp
if
tmp
is
None
:
return
src
=
self
.
_storage
self
.
_tmp
=
None
self
.
_storage
=
tmp
self
.
_cache
.
invalidate
(
src
.
_index
.
keys
())
def
db
(
self
):
return
self
.
_db
def
getVersion
(
self
):
return
self
.
_version
...
...
@@ -357,6 +386,9 @@ class Connection(ExportImport.ExportImport):
state
=
unpickler
.
load
()
except
:
t
,
v
=
sys
.
exc_info
()[:
2
]
LOG
(
'ZODB'
,
ERROR
,
"Couldn't unnpickle %s"
%
`oid`
,
error
=
sys
.
exc_info
())
raise
if
hasattr
(
object
,
'__setstate__'
):
...
...
@@ -372,10 +404,20 @@ class Connection(ExportImport.ExportImport):
cache
.
invalidate
(
self
.
_invalidated
)
cache
.
invalidate
(
self
.
_invalidating
)
def
tpc_begin
(
self
,
transaction
):
def
tpc_begin
(
self
,
transaction
,
sub
=
None
):
if
self
.
_invalid
(
None
):
# Some nitwit invalidated everything!
raise
ConflictError
,
oid
self
.
_invalidating
=
[]
if
sub
:
# Sub-transaction!
_tmp
=
self
.
_tmp
if
_tmp
is
None
:
_tmp
=
TmpStore
.
TmpStore
(
self
.
_version
)
self
.
_tmp
=
self
.
_storage
self
.
_storage
=
_tmp
_tmp
.
registerDB
(
self
.
_db
,
0
)
self
.
_storage
.
tpc_begin
(
transaction
)
def
tpc_finish
(
self
,
transaction
):
...
...
@@ -390,6 +432,10 @@ class Connection(ExportImport.ExportImport):
get_transaction
().
abort
()
self
.
_cache
.
invalidate
(
self
.
_invalidated
)
def
modifiedInVersion
(
self
,
oid
):
try
:
self
.
_db
.
modifiedInVersion
(
oid
)
except
KeyError
:
return
self
.
_version
class
tConnection
(
Connection
):
...
...
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