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
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
nexedi
ZODB
Commits
3c4eefe9
Commit
3c4eefe9
authored
Sep 07, 2000
by
Jim Fulton
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
See 1.37.12.8
parent
8fc09c11
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
38 additions
and
27 deletions
+38
-27
src/ZODB/FileStorage.py
src/ZODB/FileStorage.py
+38
-27
No files found.
src/ZODB/FileStorage.py
View file @
3c4eefe9
...
@@ -184,7 +184,7 @@
...
@@ -184,7 +184,7 @@
# may have a back pointer to a version record or to a non-version
# may have a back pointer to a version record or to a non-version
# record.
# record.
#
#
__version__
=
'$Revision: 1.4
7
$'
[
11
:
-
2
]
__version__
=
'$Revision: 1.4
8
$'
[
11
:
-
2
]
import
struct
,
time
,
os
,
bpthread
,
string
,
base64
,
sys
import
struct
,
time
,
os
,
bpthread
,
string
,
base64
,
sys
from
struct
import
pack
,
unpack
from
struct
import
pack
,
unpack
...
@@ -298,10 +298,13 @@ class FileStorage(BaseStorage.BaseStorage):
...
@@ -298,10 +298,13 @@ class FileStorage(BaseStorage.BaseStorage):
self
.
_pos
,
self
.
_oid
,
tid
=
read_index
(
self
.
_pos
,
self
.
_oid
,
tid
=
read_index
(
file
,
file_name
,
index
,
vindex
,
tindex
,
stop
,
file
,
file_name
,
index
,
vindex
,
tindex
,
stop
,
ltid
=
ltid
,
start
=
start
,
maxoid
=
maxoid
,
ltid
=
ltid
,
start
=
start
,
maxoid
=
maxoid
,
read_only
=
read_only
,
)
)
else
:
else
:
self
.
_pos
,
self
.
_oid
,
tid
=
read_index
(
self
.
_pos
,
self
.
_oid
,
tid
=
read_index
(
file
,
file_name
,
index
,
vindex
,
tindex
,
stop
)
file
,
file_name
,
index
,
vindex
,
tindex
,
stop
,
read_only
=
read_only
,
)
self
.
_ts
=
tid
=
TimeStamp
(
tid
)
self
.
_ts
=
tid
=
TimeStamp
(
tid
)
t
=
time
.
time
()
t
=
time
.
time
()
...
@@ -522,15 +525,18 @@ class FileStorage(BaseStorage.BaseStorage):
...
@@ -522,15 +525,18 @@ class FileStorage(BaseStorage.BaseStorage):
if
tstatus
!=
'u'
:
if
tstatus
!=
'u'
:
# Yee ha! We can quit
# Yee ha! We can quit
break
break
elif
h
[
16
:
24
]
==
pnv
:
# The following optimization fails miserably
# This is the first current record, so unmark it.
# if, for some reason, an object is written twice
# Note that we don't need to check if this was
# in the same transaction!
# undone. If it *was* undone, then there must
#elif h[16:24] == pnv and pnv != z64:
# be a later record that is the first record, or
# # This is the first current record, so unmark it.
# there isn't a current record. In either case,
# # Note that we don't need to check if this was
# we can't be in this branch. :)
# # undone. If it *was* undone, then there must
del
current_oids
[
oid
]
# # be a later record that is the first record, or
# # there isn't a current record. In either case,
# # we can't be in this branch. :)
# del current_oids[oid]
spos
=
h
[
-
8
:]
spos
=
h
[
-
8
:]
srcpos
=
U64
(
spos
)
srcpos
=
U64
(
spos
)
...
@@ -997,7 +1003,7 @@ class FileStorage(BaseStorage.BaseStorage):
...
@@ -997,7 +1003,7 @@ class FileStorage(BaseStorage.BaseStorage):
_lock_release
=
self
.
_lock_release
_lock_release
=
self
.
_lock_release
index
,
vindex
,
tindex
,
tvindex
=
self
.
_newIndexes
()
index
,
vindex
,
tindex
,
tvindex
=
self
.
_newIndexes
()
name
=
self
.
__name__
name
=
self
.
__name__
file
=
open
(
name
,
'r
+
b'
)
file
=
open
(
name
,
'rb'
)
stop
=
`apply(TimeStamp, time.gmtime(t)[:5]+(t%60,))`
stop
=
`apply(TimeStamp, time.gmtime(t)[:5]+(t%60,))`
if
stop
==
z64
:
raise
FileStorageError
,
'Invalid pack time'
if
stop
==
z64
:
raise
FileStorageError
,
'Invalid pack time'
...
@@ -1016,7 +1022,9 @@ class FileStorage(BaseStorage.BaseStorage):
...
@@ -1016,7 +1022,9 @@ class FileStorage(BaseStorage.BaseStorage):
locked
=
0
locked
=
0
packpos
,
maxoid
,
ltid
=
read_index
(
packpos
,
maxoid
,
ltid
=
read_index
(
file
,
name
,
index
,
vindex
,
tindex
,
stop
)
file
,
name
,
index
,
vindex
,
tindex
,
stop
,
read_only
=
1
,
)
if
self
.
_redundant_pack
(
file
,
packpos
):
if
self
.
_redundant_pack
(
file
,
packpos
):
raise
FileStorageError
,
(
raise
FileStorageError
,
(
...
@@ -1522,7 +1530,7 @@ def recover(file_name):
...
@@ -1522,7 +1530,7 @@ def recover(file_name):
def
read_index
(
file
,
name
,
index
,
vindex
,
tindex
,
stop
=
'
\
377
'
*
8
,
def
read_index
(
file
,
name
,
index
,
vindex
,
tindex
,
stop
=
'
\
377
'
*
8
,
ltid
=
z64
,
start
=
4L
,
maxoid
=
z64
,
recover
=
0
):
ltid
=
z64
,
start
=
4L
,
maxoid
=
z64
,
recover
=
0
,
read_only
=
0
):
read
=
file
.
read
read
=
file
.
read
seek
=
file
.
seek
seek
=
file
.
seek
...
@@ -1534,7 +1542,7 @@ def read_index(file, name, index, vindex, tindex, stop='\377'*8,
...
@@ -1534,7 +1542,7 @@ def read_index(file, name, index, vindex, tindex, stop='\377'*8,
seek
(
0
)
seek
(
0
)
if
read
(
4
)
!=
packed_version
:
raise
FileStorageFormatError
,
name
if
read
(
4
)
!=
packed_version
:
raise
FileStorageFormatError
,
name
else
:
else
:
file
.
write
(
packed_version
)
if
not
read_only
:
file
.
write
(
packed_version
)
return
4L
,
maxoid
,
ltid
return
4L
,
maxoid
,
ltid
index_get
=
index
.
get
index_get
=
index
.
get
...
@@ -1551,9 +1559,10 @@ def read_index(file, name, index, vindex, tindex, stop='\377'*8,
...
@@ -1551,9 +1559,10 @@ def read_index(file, name, index, vindex, tindex, stop='\377'*8,
h
=
read
(
23
)
h
=
read
(
23
)
if
not
h
:
break
if
not
h
:
break
if
len
(
h
)
!=
23
:
if
len
(
h
)
!=
23
:
warn
(
'%s truncated at %s'
,
name
,
pos
)
if
not
read_only
:
seek
(
pos
)
warn
(
'%s truncated at %s'
,
name
,
pos
)
file
.
truncate
()
seek
(
pos
)
file
.
truncate
()
break
break
tid
,
stl
,
status
,
ul
,
dl
,
el
=
unpack
(
">8s8scHHH"
,
h
)
tid
,
stl
,
status
,
ul
,
dl
,
el
=
unpack
(
">8s8scHHH"
,
h
)
...
@@ -1569,9 +1578,10 @@ def read_index(file, name, index, vindex, tindex, stop='\377'*8,
...
@@ -1569,9 +1578,10 @@ def read_index(file, name, index, vindex, tindex, stop='\377'*8,
# Hm, the data were truncated or the checkpoint flag wasn't
# Hm, the data were truncated or the checkpoint flag wasn't
# cleared. They may also be corrupted,
# cleared. They may also be corrupted,
# in which case, we don't want to totally lose the data.
# in which case, we don't want to totally lose the data.
warn
(
"%s truncated, possibly due to damaged records at %s"
,
if
not
read_only
:
name
,
pos
)
warn
(
"%s truncated, possibly due to damaged records at %s"
,
_truncate
(
file
,
name
,
pos
)
name
,
pos
)
_truncate
(
file
,
name
,
pos
)
break
break
if
status
not
in
' up'
:
if
status
not
in
' up'
:
...
@@ -1589,11 +1599,12 @@ def read_index(file, name, index, vindex, tindex, stop='\377'*8,
...
@@ -1589,11 +1599,12 @@ def read_index(file, name, index, vindex, tindex, stop='\377'*8,
# reasonable:
# reasonable:
if
file_size
-
rtl
<
pos
or
rtl
<
23
:
if
file_size
-
rtl
<
pos
or
rtl
<
23
:
nearPanic
(
'%s has invalid transaction header at %s'
,
name
,
pos
)
nearPanic
(
'%s has invalid transaction header at %s'
,
name
,
pos
)
warn
(
"It appears that there is invalid data at the end of the "
if
not
read_only
:
"file, possibly due to a system crash. %s truncated "
warn
(
"It appears that there is invalid data at the end of "
"to recover from bad data at end."
"the file, possibly due to a system crash. %s "
%
name
)
"truncated to recover from bad data at end."
_truncate
(
file
,
name
,
pos
)
%
name
)
_truncate
(
file
,
name
,
pos
)
break
break
else
:
else
:
if
recover
:
return
pos
,
None
,
None
if
recover
:
return
pos
,
None
,
None
...
@@ -1648,7 +1659,7 @@ def read_index(file, name, index, vindex, tindex, stop='\377'*8,
...
@@ -1648,7 +1659,7 @@ def read_index(file, name, index, vindex, tindex, stop='\377'*8,
if
index_get
(
oid
,
0
)
!=
prev
:
if
index_get
(
oid
,
0
)
!=
prev
:
if
prev
:
if
prev
:
if
recover
:
return
tpos
,
None
,
None
if
recover
:
return
tpos
,
None
,
None
panic
(
"%s incorrect previous pointer at %s"
,
name
,
pos
)
error
(
"%s incorrect previous pointer at %s"
,
name
,
pos
)
else
:
else
:
warn
(
"%s incorrect previous pointer at %s"
,
name
,
pos
)
warn
(
"%s incorrect previous pointer at %s"
,
name
,
pos
)
...
...
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