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
aecc2d14
Commit
aecc2d14
authored
Dec 03, 2002
by
Jeremy Hylton
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Sync fsdump.py between ZODB3 and ZODB4,
adding Dumper class to ZODB4.
parent
6da12c56
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
15 additions
and
15 deletions
+15
-15
src/ZODB/fsdump.py
src/ZODB/fsdump.py
+15
-15
No files found.
src/ZODB/fsdump.py
View file @
aecc2d14
from
ZODB.FileStorage
import
FileIterator
from
ZODB.FileStorage
import
FileIterator
from
ZODB.TimeStamp
import
TimeStamp
from
ZODB.TimeStamp
import
TimeStamp
from
ZODB.utils
import
U
64
from
ZODB.utils
import
u
64
from
ZODB.tests.StorageTestBase
import
zodb_unpickle
from
ZODB.tests.StorageTestBase
import
zodb_unpickle
from
cPickle
import
Unpickler
from
cPickle
import
Unpickler
...
@@ -42,10 +42,10 @@ def fsdump(path, file=None, with_offset=1):
...
@@ -42,10 +42,10 @@ def fsdump(path, file=None, with_offset=1):
for
trans
in
iter
:
for
trans
in
iter
:
if
with_offset
:
if
with_offset
:
print
>>
file
,
"Trans #%05d tid=%016x time=%s offset=%d"
%
\
print
>>
file
,
"Trans #%05d tid=%016x time=%s offset=%d"
%
\
(
i
,
U
64
(
trans
.
tid
),
str
(
TimeStamp
(
trans
.
tid
)),
trans
.
_pos
)
(
i
,
u
64
(
trans
.
tid
),
str
(
TimeStamp
(
trans
.
tid
)),
trans
.
_pos
)
else
:
else
:
print
>>
file
,
"Trans #%05d tid=%016x time=%s"
%
\
print
>>
file
,
"Trans #%05d tid=%016x time=%s"
%
\
(
i
,
U
64
(
trans
.
tid
),
str
(
TimeStamp
(
trans
.
tid
)))
(
i
,
u
64
(
trans
.
tid
),
str
(
TimeStamp
(
trans
.
tid
)))
print
>>
file
,
"
\
t
status=%s user=%s description=%s"
%
\
print
>>
file
,
"
\
t
status=%s user=%s description=%s"
%
\
(
`trans.status`
,
trans
.
user
,
trans
.
description
)
(
`trans.status`
,
trans
.
user
,
trans
.
description
)
j
=
0
j
=
0
...
@@ -67,11 +67,11 @@ def fsdump(path, file=None, with_offset=1):
...
@@ -67,11 +67,11 @@ def fsdump(path, file=None, with_offset=1):
if
rec
.
data_txn
:
if
rec
.
data_txn
:
# XXX It would be nice to print the transaction number
# XXX It would be nice to print the transaction number
# (i) but it would be too expensive to keep track of.
# (i) but it would be too expensive to keep track of.
bp
=
"bp=%016x"
%
U
64
(
rec
.
data_txn
)
bp
=
"bp=%016x"
%
u
64
(
rec
.
data_txn
)
else
:
else
:
bp
=
""
bp
=
""
print
>>
file
,
" data #%05d oid=%016x %sclass=%s %s"
%
\
print
>>
file
,
" data #%05d oid=%016x %sclass=%s %s"
%
\
(
j
,
U
64
(
rec
.
oid
),
version
,
fullclass
,
bp
)
(
j
,
u
64
(
rec
.
oid
),
version
,
fullclass
,
bp
)
j
+=
1
j
+=
1
print
>>
file
print
>>
file
i
+=
1
i
+=
1
...
@@ -83,7 +83,7 @@ from ZODB.FileStorage import DATA_HDR, DATA_HDR_LEN
...
@@ -83,7 +83,7 @@ from ZODB.FileStorage import DATA_HDR, DATA_HDR_LEN
def
fmt
(
p64
):
def
fmt
(
p64
):
# Return a nicely formatted string for a packaged 64-bit value
# Return a nicely formatted string for a packaged 64-bit value
return
"%016x"
%
U
64
(
p64
)
return
"%016x"
%
u
64
(
p64
)
class
Dumper
:
class
Dumper
:
"""A very verbose dumper for debuggin FileStorage problems."""
"""A very verbose dumper for debuggin FileStorage problems."""
...
@@ -105,12 +105,12 @@ class Dumper:
...
@@ -105,12 +105,12 @@ class Dumper:
if
not
h
:
if
not
h
:
return
False
return
False
tid
,
stlen
,
status
,
ul
,
dl
,
el
=
struct
.
unpack
(
TRANS_HDR
,
h
)
tid
,
stlen
,
status
,
ul
,
dl
,
el
=
struct
.
unpack
(
TRANS_HDR
,
h
)
end
=
pos
+
U
64
(
stlen
)
end
=
pos
+
u
64
(
stlen
)
print
>>
self
.
dest
,
"="
*
60
print
>>
self
.
dest
,
"="
*
60
print
>>
self
.
dest
,
"offset: %d"
%
pos
print
>>
self
.
dest
,
"offset: %d"
%
pos
print
>>
self
.
dest
,
"end pos: %d"
%
end
print
>>
self
.
dest
,
"end pos: %d"
%
end
print
>>
self
.
dest
,
"transaction id: %s"
%
fmt
(
tid
)
print
>>
self
.
dest
,
"transaction id: %s"
%
fmt
(
tid
)
print
>>
self
.
dest
,
"trec len: %d"
%
U
64
(
stlen
)
print
>>
self
.
dest
,
"trec len: %d"
%
u
64
(
stlen
)
print
>>
self
.
dest
,
"status: %r"
%
status
print
>>
self
.
dest
,
"status: %r"
%
status
user
=
descr
=
extra
=
""
user
=
descr
=
extra
=
""
if
ul
:
if
ul
:
...
@@ -125,7 +125,7 @@ class Dumper:
...
@@ -125,7 +125,7 @@ class Dumper:
while
self
.
file
.
tell
()
<
end
:
while
self
.
file
.
tell
()
<
end
:
self
.
dump_data
(
pos
)
self
.
dump_data
(
pos
)
stlen2
=
self
.
file
.
read
(
8
)
stlen2
=
self
.
file
.
read
(
8
)
print
>>
self
.
dest
,
"redundant trec len: %d"
%
U
64
(
stlen2
)
print
>>
self
.
dest
,
"redundant trec len: %d"
%
u
64
(
stlen2
)
return
True
return
True
def
dump_data
(
self
,
tloc
):
def
dump_data
(
self
,
tloc
):
...
@@ -133,23 +133,23 @@ class Dumper:
...
@@ -133,23 +133,23 @@ class Dumper:
h
=
self
.
file
.
read
(
DATA_HDR_LEN
)
h
=
self
.
file
.
read
(
DATA_HDR_LEN
)
assert
len
(
h
)
==
DATA_HDR_LEN
assert
len
(
h
)
==
DATA_HDR_LEN
oid
,
revid
,
sprev
,
stloc
,
vlen
,
sdlen
=
struct
.
unpack
(
DATA_HDR
,
h
)
oid
,
revid
,
sprev
,
stloc
,
vlen
,
sdlen
=
struct
.
unpack
(
DATA_HDR
,
h
)
dlen
=
U
64
(
sdlen
)
dlen
=
u
64
(
sdlen
)
print
>>
self
.
dest
,
"-"
*
60
print
>>
self
.
dest
,
"-"
*
60
print
>>
self
.
dest
,
"offset: %d"
%
pos
print
>>
self
.
dest
,
"offset: %d"
%
pos
print
>>
self
.
dest
,
"oid: %s"
%
fmt
(
oid
)
print
>>
self
.
dest
,
"oid: %s"
%
fmt
(
oid
)
print
>>
self
.
dest
,
"revid: %s"
%
fmt
(
revid
)
print
>>
self
.
dest
,
"revid: %s"
%
fmt
(
revid
)
print
>>
self
.
dest
,
"previous record offset: %d"
%
U
64
(
sprev
)
print
>>
self
.
dest
,
"previous record offset: %d"
%
u
64
(
sprev
)
print
>>
self
.
dest
,
"transaction offset: %d"
%
U
64
(
stloc
)
print
>>
self
.
dest
,
"transaction offset: %d"
%
u
64
(
stloc
)
if
vlen
:
if
vlen
:
pnv
=
self
.
file
.
read
(
8
)
pnv
=
self
.
file
.
read
(
8
)
sprevdata
=
self
.
file
.
read
(
8
)
sprevdata
=
self
.
file
.
read
(
8
)
version
=
self
.
file
.
read
(
vlen
)
version
=
self
.
file
.
read
(
vlen
)
print
>>
self
.
dest
,
"version: %r"
%
version
print
>>
self
.
dest
,
"version: %r"
%
version
print
>>
self
.
dest
,
"non-version data offset: %d"
%
U
64
(
pnv
)
print
>>
self
.
dest
,
"non-version data offset: %d"
%
u
64
(
pnv
)
print
>>
self
.
dest
,
\
print
>>
self
.
dest
,
\
"previous version data offset: %d"
%
U
64
(
sprevdata
)
"previous version data offset: %d"
%
u
64
(
sprevdata
)
print
>>
self
.
dest
,
"len(data): %d"
%
dlen
print
>>
self
.
dest
,
"len(data): %d"
%
dlen
self
.
file
.
read
(
dlen
)
self
.
file
.
read
(
dlen
)
if
not
dlen
:
if
not
dlen
:
sbp
=
self
.
file
.
read
(
8
)
sbp
=
self
.
file
.
read
(
8
)
print
>>
self
.
dest
,
"backpointer: %d"
%
U
64
(
sbp
)
print
>>
self
.
dest
,
"backpointer: %d"
%
u
64
(
sbp
)
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