From: Kevin Day Date: Wed, 31 Jan 2024 02:07:29 +0000 (-0600) Subject: Update: Wrap up fss_read changes regarding empty Content. X-Git-Url: https://git.kevux.org/?a=commitdiff_plain;h=59d96246dd647c24d6b64350f09654099aa83585;p=fll Update: Wrap up fss_read changes regarding empty Content. This is the follow up to the progress commit f71195801aaea4f1c58fd19875cd8a04d2cbd8bd. Restructure the not used checks to a single location to make reading the code easier. Make sure to only increment the line on empty Content when the empty Content flag is set. --- diff --git a/level_3/fss_read/c/main/process_normal.c b/level_3/fss_read/c/main/process_normal.c index 84a582c..fda5cd2 100644 --- a/level_3/fss_read/c/main/process_normal.c +++ b/level_3/fss_read/c/main/process_normal.c @@ -223,14 +223,29 @@ extern "C" { } if (main->setting.flag & fss_read_main_flag_content_e) { - - // Must process/count line when both Object and Content share the same line but Content is empty. @todo review this block. if (!main->setting.contents.array[at].used) { - if (main->setting.flag & (fss_read_main_flag_empty_e | fss_read_main_flag_object_e)) { - if (!(main->setting.flag & fss_read_main_flag_object_e) || !(main->setting.flag & fss_read_main_flag_object_as_line_e) && (main->setting.flag & fss_read_main_flag_line_single_e)) { + + // Must process/count line when both Object and Content share the same line but Content is empty for single line Content. + if ((main->setting.flag & fss_read_main_flag_line_single_e)) { + if (main->setting.flag & fss_read_main_flag_object_e) { + if (!(main->setting.flag & fss_read_main_flag_object_as_line_e)) { + if (*line == main->setting.line) { + if (main->callback.print_set_end) { + main->callback.print_set_end(&main->program.output); + } + + main->setting.state.status = F_success; + + return; + } + + ++(*line); + } + } + else if (main->setting.flag & fss_read_main_flag_empty_e) { if (*line == main->setting.line) { - if (main->callback.print_set_end) { - main->callback.print_set_end(&main->program.output); + if (main->callback.print_content_empty_set) { + main->callback.print_content_empty_set(&main->program.output); } main->setting.state.status = F_success; @@ -241,6 +256,19 @@ extern "C" { ++(*line); } } + else { + if (main->callback.print_content_empty_set) { + if (*line == main->setting.line) { + main->callback.print_content_empty_set(&main->program.output); + + main->setting.state.status = F_success; + + return; + } + + ++(*line); + } + } main->setting.state.status = F_okay; @@ -250,28 +278,22 @@ extern "C" { f_number_unsigned_t i = 0; if (main->setting.flag & fss_read_main_flag_line_single_e) { - // @fixme review this for when the line is empty. if (*line == main->setting.line) { - if (main->setting.contents.array[at].used) { - while (main->setting.contents.array[at].used) { - - if (main->callback.print_content) { - main->callback.print_content(&main->program.output, main->setting.contents.array[at].array[i], main->setting.quotes_content.array[at].array[i], delimits_content); - } + while (main->setting.contents.array[at].used) { - if (++i >= main->setting.contents.array[at].used) break; + if (main->callback.print_content) { + main->callback.print_content(&main->program.output, main->setting.contents.array[at].array[i], main->setting.quotes_content.array[at].array[i], delimits_content); + } - if (main->callback.print_content_next) { - main->callback.print_content_next(&main->program.output); - } - } // while + if (++i >= main->setting.contents.array[at].used) break; - if (main->callback.print_set_end) { - main->callback.print_set_end(&main->program.output); + if (main->callback.print_content_next) { + main->callback.print_content_next(&main->program.output); } - } - else if (main->callback.print_content_empty_set) { - main->callback.print_content_empty_set(&main->program.output); + } // while + + if (main->callback.print_set_end) { + main->callback.print_set_end(&main->program.output); } main->setting.state.status = F_success; @@ -286,54 +308,49 @@ extern "C" { f_number_unsigned_t j = 0; f_number_unsigned_t k = 0; - if (main->setting.contents.array[at].used) { - for (; i < main->setting.contents.array[at].used; ++i) { + for (; i < main->setting.contents.array[at].used; ++i) { - if (fss_read_signal_check(main)) return; + if (fss_read_signal_check(main)) return; - line_original = *line; - main->setting.range = main->setting.contents.array[at].array[i]; - k = 0; + line_original = *line; + main->setting.range = main->setting.contents.array[at].array[i]; + k = 0; - for (j = main->setting.range.start; j <= main->setting.range.stop; ++j) { + for (j = main->setting.range.start; j <= main->setting.range.stop; ++j) { - if (fss_read_signal_check(main)) return; + if (fss_read_signal_check(main)) return; - if (k < main->setting.comments.used) { - while (main->setting.comments.array[k].stop < j) ++k; + if (k < main->setting.comments.used) { + while (main->setting.comments.array[k].stop < j) ++k; - if (j >= main->setting.comments.array[k].start && j <= main->setting.comments.array[k].stop) { - j = main->setting.comments.array[k++].stop + 1; + if (j >= main->setting.comments.array[k].start && j <= main->setting.comments.array[k].stop) { + j = main->setting.comments.array[k++].stop + 1; - if (j > main->setting.range.stop) break; - } + if (j > main->setting.range.stop) break; } + } - if (main->setting.buffer.string[j] == f_string_eol_s.string[0]) { - if (*line == main->setting.line) { - main->setting.range.stop = j; + if (main->setting.buffer.string[j] == f_string_eol_s.string[0]) { + if (*line == main->setting.line) { + main->setting.range.stop = j; - if (main->callback.print_content) { - main->callback.print_content(&main->program.output, main->setting.range, main->setting.quotes_content.array[at].array[i], delimits_content); - } + if (main->callback.print_content) { + main->callback.print_content(&main->program.output, main->setting.range, main->setting.quotes_content.array[at].array[i], delimits_content); + } - main->setting.state.status = F_success; + main->setting.state.status = F_success; - return; - } + return; + } - main->setting.range.start = j + 1; + main->setting.range.start = j + 1; - if (j <= main->setting.range.stop) { - ++(*line); - } + if (j <= main->setting.range.stop) { + ++(*line); } - } // for + } } // for - } - else if (main->callback.print_content_empty_set) { - main->callback.print_content_empty_set(&main->program.output); - } + } // for } // @fixme The fll_fss_*_read functions do not have a store of the set closing ranges but should. @@ -549,7 +566,7 @@ extern "C" { range.stop = main->setting.contents.array[at].array[i].stop; // This content has no data, do not even check "include empty" because it cannot be counted as a line. - if (range.start > range.stop) continue; // @fixme review this check for when include empty is set (basic list might not count but extended list might). + if (range.start > range.stop) continue; for (j = range.start; j <= range.stop; ++j) {