line breaks
This commit is contained in:
parent
ecf33b18df
commit
04c87cbfa6
@ -115,6 +115,8 @@ static int scan_day(struct scan *const scan, union date32 date,
|
|||||||
const char *const buffer) {
|
const char *const buffer) {
|
||||||
const char *YYCURSOR, *YYMARKER, *yyt1, *yyt2, *yyt3, *s0, *s1, *t0, *t1;
|
const char *YYCURSOR, *YYMARKER, *yyt1, *yyt2, *yyt3, *s0, *s1, *t0, *t1;
|
||||||
enum YYCONDTYPE condition = yycline;
|
enum YYCONDTYPE condition = yycline;
|
||||||
|
/* All '\n' might overflow on last, but it wouldn't matter because there's
|
||||||
|
no content. */
|
||||||
size_t line = 1;
|
size_t line = 1;
|
||||||
char datestr[12] = {0};
|
char datestr[12] = {0};
|
||||||
const char *fail = "perhaps a bat?";
|
const char *fail = "perhaps a bat?";
|
||||||
@ -220,8 +222,8 @@ static int scan_day(struct scan *const scan, union date32 date,
|
|||||||
case TREE_ABSENT:
|
case TREE_ABSENT:
|
||||||
*pi = (size_t)(ed - scan->edits.array.data); break;
|
*pi = (size_t)(ed - scan->edits.array.data); break;
|
||||||
}
|
}
|
||||||
fprintf(stderr, "%s[%zu]: new edit from %"
|
fprintf(stderr, "%s[%zu]: new remark from %"
|
||||||
PRIu32 "-%" PRIu32 "-%" PRIu32 " stored at %zu.\n",
|
PRIu32 "-%.2" PRIu32 "-%.2" PRIu32 " stored at %zu.\n",
|
||||||
datestr, line, ed->edit.year, ed->edit.month, ed->edit.day, *pi);
|
datestr, line, ed->edit.year, ed->edit.month, ed->edit.day, *pi);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
@ -231,8 +233,6 @@ static int scan_day(struct scan *const scan, union date32 date,
|
|||||||
const struct pair keyword = pair(s0, s1);
|
const struct pair keyword = pair(s0, s1);
|
||||||
const union line64 key = { { (uint32_t)line, date } };
|
const union line64 key = { { (uint32_t)line, date } };
|
||||||
size_t i, *pi;
|
size_t i, *pi;
|
||||||
if(line > UINT32_MAX)
|
|
||||||
{ errno = ERANGE; fail = "too many lines of text"; goto catch; }
|
|
||||||
/*fprintf(stderr, "map: <<%.*s>> out of %s\n", (int)(s1 - s0), s0,
|
/*fprintf(stderr, "map: <<%.*s>> out of %s\n", (int)(s1 - s0), s0,
|
||||||
pair_map_table_to_string(&scan->places.map));*/
|
pair_map_table_to_string(&scan->places.map));*/
|
||||||
if(!(i = pair_map_table_get(&scan->places.map, keyword)))
|
if(!(i = pair_map_table_get(&scan->places.map, keyword)))
|
||||||
@ -287,9 +287,6 @@ static int scan_day(struct scan *const scan, union date32 date,
|
|||||||
const struct pair keyword = pair(s0, s1);
|
const struct pair keyword = pair(s0, s1);
|
||||||
const union line64 key = { { (uint32_t)line, date } };
|
const union line64 key = { { (uint32_t)line, date } };
|
||||||
size_t i, *pi;
|
size_t i, *pi;
|
||||||
//fixme: verify way before
|
|
||||||
if(line > UINT32_MAX)
|
|
||||||
{ errno = ERANGE; fail = "too many lines of text"; goto catch; }
|
|
||||||
if(!(i = pair_map_table_get(&scan->sources.map, keyword)))
|
if(!(i = pair_map_table_get(&scan->sources.map, keyword)))
|
||||||
{ fail = "keyword not introduced"; goto catch; }
|
{ fail = "keyword not introduced"; goto catch; }
|
||||||
switch(linemap_tree_bulk_assign(&scan->sources.dates, key, &pi)) {
|
switch(linemap_tree_bulk_assign(&scan->sources.dates, key, &pi)) {
|
||||||
@ -327,8 +324,6 @@ static int scan_day(struct scan *const scan, union date32 date,
|
|||||||
const struct pair keyword = pair(s0, s1);
|
const struct pair keyword = pair(s0, s1);
|
||||||
const union line64 key = { { (uint32_t)line, date } };
|
const union line64 key = { { (uint32_t)line, date } };
|
||||||
size_t idx, *pidx;
|
size_t idx, *pidx;
|
||||||
if(line > UINT32_MAX)
|
|
||||||
{ errno = ERANGE; fail = "too many lines of text"; goto catch; }
|
|
||||||
if(!(idx = pair_map_table_get(&scan->scores.map, keyword)))
|
if(!(idx = pair_map_table_get(&scan->scores.map, keyword)))
|
||||||
{ fail = "keyword not introduced"; goto catch; }
|
{ fail = "keyword not introduced"; goto catch; }
|
||||||
if(scan->scores.array.data[idx].last.u32 >= date.u32)
|
if(scan->scores.array.data[idx].last.u32 >= date.u32)
|
||||||
@ -392,7 +387,6 @@ static int scan_day(struct scan *const scan, union date32 date,
|
|||||||
<glider_type> ws* @s0 semilabel @s1 ";" => glider_reg {
|
<glider_type> ws* @s0 semilabel @s1 ";" => glider_reg {
|
||||||
const union line64 key = {{ (uint32_t)line, date }};
|
const union line64 key = {{ (uint32_t)line, date }};
|
||||||
assert(!new_glider);
|
assert(!new_glider);
|
||||||
if(line > UINT32_MAX) { fail = "line overflow"; goto catch; }
|
|
||||||
switch(glider_tree_bulk_assign(&scan->gliders, key, &new_glider)) {
|
switch(glider_tree_bulk_assign(&scan->gliders, key, &new_glider)) {
|
||||||
case TREE_PRESENT: fail = "duplicate"; case TREE_ERROR: goto catch;
|
case TREE_PRESENT: fail = "duplicate"; case TREE_ERROR: goto catch;
|
||||||
case TREE_ABSENT: break;
|
case TREE_ABSENT: break;
|
||||||
@ -462,7 +456,6 @@ static int scan_day(struct scan *const scan, union date32 date,
|
|||||||
<flight_type> ws* @s0 semilabel @s1 ";" => flight_reg {
|
<flight_type> ws* @s0 semilabel @s1 ";" => flight_reg {
|
||||||
const union line64 key = {{ (uint32_t)line, date }};
|
const union line64 key = {{ (uint32_t)line, date }};
|
||||||
assert(!new_flight);
|
assert(!new_flight);
|
||||||
if(line > UINT32_MAX) { fail = "line overflow"; goto catch; }
|
|
||||||
switch(flight_tree_bulk_assign(&scan->flights, key, &new_flight)) {
|
switch(flight_tree_bulk_assign(&scan->flights, key, &new_flight)) {
|
||||||
case TREE_PRESENT: fail = "duplicate key";
|
case TREE_PRESENT: fail = "duplicate key";
|
||||||
case TREE_ERROR: goto catch;
|
case TREE_ERROR: goto catch;
|
||||||
|
Loading…
Reference in New Issue
Block a user