- for (y = 0; y < table_nr (t); y++)
- {
- for (x = 0; x < table_nc (t); x++)
- {
- struct table_cell cell;
-
- table_get_cell (t, x, y, &cell);
-
- if (x > 0)
- fputs (csv->separator, csv->file);
-
- if (x != cell.d[TABLE_HORZ][0] || y != cell.d[TABLE_VERT][0])
- csv_output_field (csv, "");
- else if (cell.n_contents == 1 && cell.contents[0].text != NULL)
- csv_output_field (csv, cell.contents[0].text);
- else
- {
- struct string s;
- size_t i;
-
- ds_init_empty (&s);
- for (i = 0; i < cell.n_contents; i++)
- {
- if (i > 0)
- ds_put_cstr (&s, "\n\n");
-
- if (cell.contents[i].text != NULL)
- ds_put_cstr (&s, cell.contents[i].text);
- else
- csv_output_subtable (csv, &s, cell.contents[i].table);
- }
- csv_output_field (csv, ds_cstr (&s));
- ds_destroy (&s);
- }
-
- table_cell_free (&cell);
- }
- putc ('\n', csv->file);
- }
- }
- else if (is_text_item (output_item))
- {
- const struct text_item *text_item = to_text_item (output_item);
- enum text_item_type type = text_item_get_type (text_item);
- const char *text = text_item_get_text (text_item);
+ case OUTPUT_ITEM_MESSAGE:
+ csv_put_separator (csv);
+ char *s = msg_to_string (item->message);
+ csv_output_field (csv, s);
+ free (s);
+ putc ('\n', csv->file);
+ break;