X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=src%2Foutput%2Ftable-item.c;h=9355a77a115f58f20462207c71e142d97ab313a9;hb=e91782a2d25dec932c93b7a57bd03d836614ba43;hp=6243f03109429b446e34e90d83960e7bd95dd968;hpb=0d95a6ff1dff86f7d1578a8bf20a964c7a00b6c3;p=pspp diff --git a/src/output/table-item.c b/src/output/table-item.c index 6243f03109..9355a77a11 100644 --- a/src/output/table-item.c +++ b/src/output/table-item.c @@ -52,7 +52,7 @@ table_item_text_clone (const struct table_item_text *old) .footnotes = xmemdup (old->footnotes, old->n_footnotes * sizeof *old->footnotes), .n_footnotes = old->n_footnotes, - .style = area_style_clone (NULL, old->style), + .style = table_area_style_clone (NULL, old->style), }; return new; } @@ -64,7 +64,7 @@ table_item_text_destroy (struct table_item_text *text) { free (text->content); free (text->footnotes); - area_style_free (text->style); + table_area_style_free (text->style); free (text); } } @@ -99,7 +99,7 @@ table_item_layers_clone (const struct table_item_layers *old) *new = (struct table_item_layers) { .layers = xnmalloc (old->n_layers, sizeof *new->layers), .n_layers = old->n_layers, - .style = area_style_clone (NULL, old->style), + .style = table_area_style_clone (NULL, old->style), }; for (size_t i = 0; i < new->n_layers; i++) table_item_layer_copy (&new->layers[i], &old->layers[i]); @@ -114,16 +114,17 @@ table_item_layers_destroy (struct table_item_layers *layers) for (size_t i = 0; i < layers->n_layers; i++) table_item_layer_uninit (&layers->layers[i]); free (layers->layers); - area_style_free (layers->style); + table_area_style_free (layers->style); free (layers); } } /* Initializes ITEM as a table item for rendering TABLE. The new table item - initially has the specified TITLE and CAPTION, which may each be NULL. The - caller retains ownership of TITLE and CAPTION. */ + initially has the specified TITLE, CAPTION, and NOTES, which may each be + NULL. The caller retains ownership of TITLE, CAPTION, and NOTES. */ struct table_item * -table_item_create (struct table *table, const char *title, const char *caption) +table_item_create (struct table *table, const char *title, const char *caption, + const char *notes) { struct table_item *item = xmalloc (sizeof *item); output_item_init (&item->output_item, &table_item_class); @@ -131,6 +132,8 @@ table_item_create (struct table *table, const char *title, const char *caption) item->title = table_item_text_create (title); item->layers = NULL; item->caption = table_item_text_create (caption); + item->notes = notes ? xstrdup (notes) : NULL; + item->pt = NULL; return item; } @@ -207,6 +210,26 @@ table_item_set_caption (struct table_item *item, item->caption = table_item_text_clone (caption); } +/* Returns ITEM's notes, which is a null pointer if ITEM has no notes. */ +const char * +table_item_get_notes (const struct table_item *item) +{ + return item->notes; +} + +/* Sets ITEM's notes to NOTES, replacing any previous notes. Specify NULL for + NOTES to clear any notes from ITEM. The caller retains ownership of + NOTES. + + This function may only be used on a table_item that is unshared.*/ +void +table_item_set_notes (struct table_item *item, const char *notes) +{ + assert (!table_item_is_shared (item)); + free (item->notes); + item->notes = notes ? xstrdup (notes) : NULL; +} + /* Submits TABLE_ITEM to the configured output drivers, and transfers ownership to the output subsystem. */ void @@ -222,6 +245,8 @@ table_item_destroy (struct output_item *output_item) table_item_text_destroy (item->title); table_item_text_destroy (item->caption); table_item_layers_destroy (item->layers); + free (item->notes); + pivot_table_unref (item->pt); table_unref (item->table); free (item); }