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

Document and improve abstract reader/writer interface #208

Open
wants to merge 26 commits into
base: dev
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
26 commits
Select commit Hold shift + click to select a range
0ff814d
CI: add dependabot configuration
pjonsson Nov 2, 2023
2265e82
CI: add Github CI
pjonsson Nov 2, 2023
ad60cea
follow-up commit to 75eaa19
lightyear15 Feb 13, 2024
8907f20
Tests: disable the C90 test
thiagomacieira May 2, 2024
89723e2
CI: Get Homebrew to use a bottle (precompiled) Qt
thiagomacieira May 2, 2024
f9fd089
CI: remove Valgrind on macOS: it doesn't work
thiagomacieira May 2, 2024
e9963de
CI/Makefile: do allow Qt 6
thiagomacieira May 2, 2024
6550f66
CI: unbreak macOS: need to have CXX set
thiagomacieira May 2, 2024
a38a520
CI: Run the configure step in verbose mode and print the config output
thiagomacieira May 2, 2024
5d167a0
Makefile: disable cJSON support when building without math support
thiagomacieira May 1, 2024
722318d
add required SECURITY.md file for OSSF Scorecard compliance
rdower May 3, 2024
b4e1cc7
CI: add 'permissions' token to the GitHub actions file
thiagomacieira May 13, 2024
f994144
cborparser: Move parser initialisation to common routine.
sjlongland Jun 30, 2021
167eef6
cborparser: Document `cbor_parser_init_reader`.
sjlongland Jun 30, 2021
286d132
cbor: Document the reader interface.
sjlongland Jun 30, 2021
3394f51
cborparser: Pass CborValue to operation routines.
sjlongland Jul 2, 2021
b7287ff
cborparser: Move `ops` outside of `union`
sjlongland Jul 2, 2021
da482b2
cborparser: Move the reader context to CborParser.
sjlongland Jul 2, 2021
72d59f1
cborparser: Update documentation
sjlongland Jul 3, 2021
1ef9a05
reader unit tests: Simplify the example reader
sjlongland Jul 3, 2021
b4b41d3
cborencoder: Document the write callback function.
sjlongland Jul 3, 2021
914bee9
examples: Add buffered writer example.
sjlongland Jul 7, 2021
34e931e
examples: Add buffered reader example
sjlongland Jul 7, 2021
0c17e0f
cbor.h, cborencoder.c: Migrate documentation for encoder functions
sjlongland Sep 7, 2021
a4a6364
cbor.h, cborparser.c: Migrate parser documentation.
sjlongland Sep 7, 2021
427e009
parser unit tests: Do not use `auto`, use reinterpret_cast
sjlongland Sep 7, 2021
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
cborparser: Move the reader context to CborParser.
  • Loading branch information
sjlongland committed Jun 21, 2024
commit da482b2780e8c06e9e68c5be1897fb9c2fbea77f
2 changes: 1 addition & 1 deletion src/cborparser.c
Original file line number Diff line number Diff line change
Expand Up @@ -381,7 +381,7 @@ CborError cbor_parser_init_reader(const struct CborParserOperations *ops, CborPa
cbor_parser_init_common(parser, it);
parser->ops = ops;
parser->flags = CborParserFlag_ExternalSource;
it->source.token = token;
parser->data.ctx = token;
return preparse_value(it);
}

Expand Down
8 changes: 4 additions & 4 deletions tests/parser/tst_parser.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -766,20 +766,20 @@ struct Input {

static const CborParserOperations byteArrayOps = {
/* can_read_bytes = */ [](const CborValue *value, size_t len) {
auto input = static_cast<Input *>(value->source.token);
auto input = static_cast<Input *>(value->parser->data.ctx);
return input->data.size() - input->consumed >= int(len);
},
/* read_bytes = */ [](const CborValue *value, void *dst, size_t offset, size_t len) {
auto input = static_cast<Input *>(value->source.token);
auto input = static_cast<Input *>(value->parser->data.ctx);
return memcpy(dst, input->data.constData() + input->consumed + offset, len);
},
/* advance_bytes = */ [](CborValue *value, size_t len) {
auto input = static_cast<Input *>(value->source.token);
auto input = static_cast<Input *>(value->parser->data.ctx);
input->consumed += int(len);
},
/* transfer_string = */ [](CborValue *value, const void **userptr, size_t offset, size_t len) {
// ###
auto input = static_cast<Input *>(value->source.token);
auto input = static_cast<Input *>(value->parser->data.ctx);
if (input->data.size() - input->consumed < int(len + offset))
return CborErrorUnexpectedEOF;
input->consumed += int(offset);
Expand Down