X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=src%2Foutput%2Ftext-item.c;h=ba0f3873adb0071f2dc996f62b3846d2117ccf02;hb=56e6166660c0f1388cad4cb4d3189e026bc84dd5;hp=5b18e54c5d4618c693865fb5e9d624accc8ef852;hpb=e6bb779b866f297b736a7f93a0c8aa741131726f;p=pspp diff --git a/src/output/text-item.c b/src/output/text-item.c index 5b18e54c5d..ba0f3873ad 100644 --- a/src/output/text-item.c +++ b/src/output/text-item.c @@ -18,7 +18,6 @@ #include "output/text-item.h" -#include #include #include @@ -26,7 +25,7 @@ #include "libpspp/pool.h" #include "output/driver.h" #include "output/output-item-provider.h" -#include "output/tab.h" +#include "output/table.h" #include "output/table-item.h" #include "output/table-provider.h" @@ -36,6 +35,29 @@ #include "gettext.h" #define _(msgid) gettext (msgid) +const char * +text_item_type_to_string (enum text_item_type type) +{ + switch (type) + { + case TEXT_ITEM_PAGE_TITLE: + return _("Page Title"); + + case TEXT_ITEM_TITLE: + return _("Title"); + + case TEXT_ITEM_SYNTAX: + case TEXT_ITEM_LOG: + return _("Log"); + + case TEXT_ITEM_EJECT_PAGE: + return _("Page Break"); + + default: + return _("Text"); + } +} + /* Creates and returns a new text item containing TEXT and the specified TYPE. The new text item takes ownership of TEXT. */ struct text_item * @@ -97,25 +119,28 @@ text_item_submit (struct text_item *item) struct table_item * text_item_to_table_item (struct text_item *text_item) { - struct tab_table *tab = tab_create (1, 1); + struct table *tab = table_create (1, 1, 0, 0, 0, 0); - struct cell_style *style = pool_alloc (tab->container, sizeof *style); - *style = (struct cell_style) CELL_STYLE_INITIALIZER; + struct area_style *style = pool_alloc (tab->container, sizeof *style); + *style = (struct area_style) { AREA_STYLE_INITIALIZER__, + .cell_style.halign = TABLE_HALIGN_LEFT }; + struct font_style *font_style = &style->font_style; if (text_item->typeface) - style->typeface = pool_strdup (tab->container, text_item->typeface); - style->size = text_item->size; - style->bold = text_item->bold; - style->italic = text_item->italic; - style->underline = text_item->underline; + font_style->typeface = pool_strdup (tab->container, text_item->typeface); + font_style->size = text_item->size; + font_style->bold = text_item->bold; + font_style->italic = text_item->italic; + font_style->underline = text_item->underline; + font_style->markup = text_item->markup; tab->styles[0] = style; - int opts = TAB_LEFT; + int opts = 0; if (text_item->markup) opts |= TAB_MARKUP; if (text_item->type == TEXT_ITEM_SYNTAX || text_item->type == TEXT_ITEM_LOG) opts |= TAB_FIX; - tab_text (tab, 0, 0, opts, text_item_get_text (text_item)); - struct table_item *table_item = table_item_create (&tab->table, NULL, NULL); + table_text (tab, 0, 0, opts, text_item_get_text (text_item)); + struct table_item *table_item = table_item_create (tab, NULL, NULL); text_item_unref (text_item); return table_item; } @@ -131,5 +156,6 @@ text_item_destroy (struct output_item *output_item) const struct output_item_class text_item_class = { + "text", text_item_destroy, };