X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=src%2Flist.q;h=56f45342be4005cf1c02d05e83c8fd7a480de558;hb=cf89e411db41c05c39753b05cf144c8b26a44d96;hp=578cfe5d0abaca0c0fc4e542b97a9051b0cc1381;hpb=d1fff00503280cb951cb8d3f592776ddf3c8595a;p=pspp diff --git a/src/list.q b/src/list.q index 578cfe5d0a..56f45342be 100644 --- a/src/list.q +++ b/src/list.q @@ -18,7 +18,7 @@ 02111-1307, USA. */ #include -#include +#include "error.h" #include #include #include "alloc.h" @@ -77,11 +77,11 @@ static int n_chars_width (struct outp_driver *d); static void write_line (struct outp_driver *d, char *s); /* Other functions. */ -static int list_cases (struct ccase *); +static int list_cases (struct ccase *, void *); static void determine_layout (void); static void clean_up (void); static void write_header (struct outp_driver *); -static void write_all_headers (void); +static void write_all_headers (void *); /* Returns the number of text lines that can fit on the remainder of the page. */ @@ -125,7 +125,6 @@ cmd_list (void) { struct variable casenum_var; - lex_match_id ("LIST"); if (!parse_list (&cmd)) return CMD_FAILURE; @@ -227,7 +226,7 @@ cmd_list (void) determine_layout (); case_num = 0; - procedure (write_all_headers, list_cases, NULL); + procedure_with_splits (write_all_headers, list_cases, NULL, NULL); free (line_buf); clean_up (); @@ -238,7 +237,7 @@ cmd_list (void) /* Writes headers to all devices. This is done at the beginning of each SPLIT FILE group. */ static void -write_all_headers (void) +write_all_headers (void *aux UNUSED) { struct outp_driver *d; @@ -253,7 +252,7 @@ write_all_headers (void) { struct html_driver_ext *x = d->ext; - assert (d->driver_open && d->page_open); + assert (d->driver_open); if (x->sequence_no == 0 && !d->class->open_page (d)) { msg (ME, _("Cannot open first page on HTML device %s."), @@ -618,7 +617,7 @@ determine_layout (void) } static int -list_cases (struct ccase *c) +list_cases (struct ccase *c, void *aux UNUSED) { struct outp_driver *d; @@ -669,19 +668,15 @@ list_cases (struct ccase *c) memset(&line_buf[x], ' ', width - v->print.w); x += width - v->print.w; } - - { - union value value; - - if (formats[v->print.type].cat & FCAT_STRING) - value.c = c->data[v->fv].s; - else if (v->fv == -1) - value.f = case_num; - else - value.f = c->data[v->fv].f; - - data_out (&line_buf[x], &v->print, &value); - } + + if ((formats[v->print.type].cat & FCAT_STRING) || v->fv != -1) + data_out (&line_buf[x], &v->print, &c->data[v->fv]); + else + { + union value case_num_value; + case_num_value.f = case_num; + data_out (&line_buf[x], &v->print, &case_num_value); + } x += v->print.w; line_buf[x++] = ' '; @@ -706,17 +701,16 @@ list_cases (struct ccase *c) for (column = 0; column < cmd.n_variables; column++) { struct variable *v = cmd.v_variables[column]; - union value value; char buf[41]; - if (formats[v->print.type].cat & FCAT_STRING) - value.c = c->data[v->fv].s; - else if (v->fv == -1) - value.f = case_num; - else - value.f = c->data[v->fv].f; - - data_out (buf, &v->print, &value); + if ((formats[v->print.type].cat & FCAT_STRING) || v->fv != -1) + data_out (buf, &v->print, &c->data[v->fv]); + else + { + union value case_num_value; + case_num_value.f = case_num; + data_out (buf, &v->print, &case_num_value); + } buf[v->print.w] = 0; fprintf (x->file.file, " %s\n",