-
Notifications
You must be signed in to change notification settings - Fork 185
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
Feature: parser function for string access by pointer #125
Comments
The problem I have to solve is that "pointer to the actual data" may not be a simple thing, especially in constrained devices. Take the example of Zephyr: instead of one buffer containing all data (a "linear" buffer), the data received from the network is stored in a |
@thiagomacieira Thanks for the clarification! I understand that my request might not be as simple as I've thought it to be :) Please let me know if I can help you in some way with testing. |
I'd second this FR, for the non-stream parsing use case. The library is great for stream parsing, but for the case where I have the entire CBOR object available, extracting the byte/text strings comes with a penalty of an extra copy or allocation plus copy. When I have the entire object, the string is in a contiguous chunk and readily available, so I only need to know where it starts and its length, which the decoder knows of already. |
That is true and the API I designed works for when the entire message is available in a contiguous chunk. It's not so good when that isn't the case. I've managed to make it work with an arbtrary Qt's |
any news with respect to this? would it be possible to expose: This could be a good workaround AFAIK and would allow direct access to a pointer to the start of the string. |
The problem is committing to an API that isn't long-term supportable, especially on small, RTOSes where the buffer may not be a contiguous chunk of memory. |
yes, I understand that.. but enforcing copies is even worse for small devices.. |
I know. Adding something under conditional compilation is the same as you performing the hack: I won't support you if it breaks later when we have a stable API. |
I'm also very keen to see this functionality (for me, direct pointer access is not necessary but memory must be stack/static only). Can I suggest a string iterator which allows you to read chunks of a string up to a maximum length? For example: // pretend that an iterator 'it' already exists
char small_buffer[32];
CborStringIterator string_it;
size_t actual_chunk_size = 0;
cbor_create_string_iterator(&it, &string_it); // 'it' currently points to a text string or byte string
while (!cbor_string_iterator_at_end(&string_it)) {
cbor_string_iterator_copy_and_advance(&string_it, small_buffer, 32, &actual_chunk_size);
for (size_t i=0; i<actual_chunk_size; i++) {
// 0 <= actual chunk size <= 32
do_some_work(small_buffer[i]);
}
} This way the alignment of any chunks is not relevant; the copy function can return any number of bytes up to a maximum. |
It is a good idea but I would open another feature request for that case. |
Please open a new request for that, but please explain how |
I'm also looking for direct access to a byte string pointer with definite length. I would have thought this is a common use case somehow. |
Somewhat. I did hack around that issue for my own code... |
I have a few use cases where I have a CBOR stream with a rather large byte strings. Having a function to get a pointer and length to these byte string would help saving some memory as a buffer to temporarily copy the data to is not required. Something like
would be perfect. This could return an
CborErrorUnknownLength
when a chunked string is passed.My main use case is a COSE library where I want to retrieve the payload without having to copy the to another buffer. Simply accessing it with a pointer is preferred to save memory on a constraint device.
I'm willing to contribute the code myself, but I need a few pointers on how to get the pointer to the actual data.
The text was updated successfully, but these errors were encountered: