-
-
Notifications
You must be signed in to change notification settings - Fork 496
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
Seems to not discard the rest of a long line? #145
Comments
Hmm, it's a fair question. However, I'm not sure silently discarding the rest of the line is better than returning an error (and inih will keep parsing on error by default). I guess we could discard the rest of the line to avoid unexpected behaviour, and still return an error? |
I guess that works, too. Only that "not having read all the texts" is not as severe as a format error or handler-returned error. And currently inih does not provide any other information about the error type (similar to errno). Anyway, the rest of a long line should be regarded no matter what, in case those texts represent another valid section or key-value entry, thus contaminating the result. |
Could use some test cases like this:
and see if
with this test program #include <stdio.h>
#include <ini.h>
int handler(void *user, const char *s, const char *n, const char *v)
{
printf("section: %s, name: %s, value: %s\n", s, n, v);
return 1;
}
int main (int argc, char *argv[])
{
printf("%d\n", ini_parse("testini.ini", handler, NULL));
return 0;
} |
Thanks for this. I don't have time to fix this properly now, but I'd be happy to review a quality PR (code and tests) to address this. I think we should probably discard the rest of the line, keep parsing, and return an error. However, it's a little bit tricky. We need to distinguish the case where the last line in the file doesn't have a Also note that |
I have made an attempt here #181 but I couldn't find a clean solution with the limitation of only using |
The problem:
The issue assumes we are dealing with a long line in an ini file.
In line 136,
reader
(fgets
) will readmax_line
chars. If using a heap, then in line 139 and forward, the heap will resize and all the rest of the line will be read:inih/ini.c
Lines 136 to 141 in 5e1d9e2
But, in the default case with a stack (fixed size array),
fgets
will readmax_line
and do nothing with the rest of the line, which I think will stay in the input stream. Then, in the next iteration of while on line 136,fgets
will continue to read that rest of the line, but inih treats those text as the next line. The code will most likely find no:
or=
in those text, thus report an error on line #(line number of the long line + 1).Discussion:
So, is this expected behavior, or should inih discard the rest of a lone line? The latter might be something like this:
The text was updated successfully, but these errors were encountered: