Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

sqlite3: fix parser #661

Draft
wants to merge 28 commits into
base: master
Choose a base branch
from
Draft
Changes from 1 commit
Commits
Show all changes
28 commits
Select commit Hold shift + click to select a range
7be80d4
Complete SQLite database parsing
pepijnve Feb 17, 2023
59110ce
fixup: lazy db.pages
milahu Apr 2, 2023
4149848
num_ptrmap_entries_max
milahu Apr 2, 2023
6dcc498
idx_first_ptrmap_page
milahu Apr 2, 2023
11e27ef
idx_lock_byte_page
milahu Apr 2, 2023
8a61bd9
maximum number of ptrmap entries
milahu Apr 2, 2023
0920225
original docstrings for overflow sizes
milahu Apr 2, 2023
d172110
idx_last_ptrmap_page
milahu Apr 2, 2023
7b697c6
Revert "fixup: lazy db.pages"
milahu Apr 2, 2023
9ee9660
fix variable_size for string
milahu Apr 2, 2023
7751c10
add comments: Workaround for string encoding
milahu Apr 2, 2023
8a55c0b
rename variable_size to len_blob_string
milahu Apr 2, 2023
7a6b573
add enum serial_type_size
milahu Apr 2, 2023
aab41dc
disable enum enum serial_type_size
milahu Apr 2, 2023
78d5f66
idx_lock_byte_page
milahu Apr 2, 2023
f47b57b
idx_first_ptrmap_page
milahu Apr 2, 2023
aa12bc5
idx_last_ptrmap_page
milahu Apr 2, 2023
cb15b1e
if false
milahu Apr 2, 2023
4e4bb1f
Revert "Revert "fixup: lazy db.pages""
milahu Apr 2, 2023
f580fab
default_page_cache_size
milahu Apr 2, 2023
cd187d3
if false
milahu Apr 2, 2023
879ec36
Revert "Revert "Revert "fixup: lazy db.pages"""
milahu Apr 2, 2023
7b130de
fix doc url
milahu Apr 3, 2023
14bb013
add docs
milahu Apr 3, 2023
c49c457
add docs + example python code for large db
milahu Apr 3, 2023
a055f99
rename page types to *_page
milahu Apr 3, 2023
2aeb203
fix: ofs_content is relative to page
milahu Apr 10, 2023
22c4801
fix pointer_map_page
milahu Apr 12, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
fixup: lazy db.pages
  • Loading branch information
milahu committed Apr 2, 2023
commit 59110cec94aa6c0e187dcf330cca64539f343c65
33 changes: 22 additions & 11 deletions database/sqlite3.ksy
Original file line number Diff line number Diff line change
@@ -37,20 +37,31 @@ seq:
type: database_header
instances:
pages:
type:
switch-on: '(_index == header.lock_byte_page_index ? 0 : _index >= header.first_ptrmap_page_index and _index <= header.last_ptrmap_page_index ? 1 : 2)'
cases:
0: lock_byte_page(_index + 1)
1: ptrmap_page(_index + 1)
# TODO: Free pages and cell overflow pages are incorrectly interpreted as btree pages
# This is unfortunate, but unavoidable since there's no way to recognize these types at
# this point in the parser.
2: btree_page(_index + 1)
pos: 0
size: header.page_size
type: page(_index + 1, header.page_size * _index)
repeat: expr
repeat-expr: header.num_pages
types:
page:
params:
- id: page_number
type: s4
- id: ofs_body
type: s4
instances:
page_index:
value: 'page_number - 1'
body:
pos: ofs_body
size: _root.header.page_size
type:
switch-on: '(page_index == _root.header.lock_byte_page_index ? 0 : page_index >= _root.header.first_ptrmap_page_index and page_index <= _root.header.last_ptrmap_page_index ? 1 : 2)'
cases:
0: lock_byte_page(page_number)
1: ptrmap_page(page_number)
# TODO: Free pages and cell overflow pages are incorrectly interpreted as btree pages
# This is unfortunate, but unavoidable since there's no way to recognize these types at
# this point in the parser.
2: btree_page(page_number)
database_header:
seq:
- id: magic