#ifndef EL__DOCUMENT_OPTIONS_H #define EL__DOCUMENT_OPTIONS_H #include "document/format.h" #include "terminal/color.h" #include "util/color.h" #include "util/box.h" #ifdef __cplusplus extern "C" { #endif struct session; /** Active link coloring options */ struct active_link_options_colors { color_T foreground; color_T background; }; struct active_link_options { unsigned int enable_color:1; unsigned int underline:1; unsigned int bold:1; unsigned int invert:1; struct active_link_options_colors color; struct active_link_options_colors insert_mode_color; }; /** This mostly acts as a option cache so rendering will be faster. However it * is also used to validate and invalidate documents in the format cache as to * whether they satisfy the current state of the document options. */ struct document_options_colors { color_T link; color_T vlink; #ifdef CONFIG_BOOKMARKS color_T bookmark_link; #endif color_T image_link; color_T link_number; }; struct document_options_image_link { char *prefix; char *suffix; int filename_maxlen; int label_maxlen; int display_style; int tagging; unsigned int show_any_as_links:1; }; struct document_options { color_mode_T color_mode; /** cp is the codepage for which the document is being formatted; * typically it is the codepage of a terminal. It is set in * render_document_frames(). */ int cp, assume_cp, hard_assume; int margin; int num_links_key; int use_document_colors; int meta_link_display; int default_form_input_size; int document_width; int cell_width; int cell_height; /** @name The default (fallback) colors. * @{ */ struct text_style default_style; struct document_options_colors default_color; /** @} */ unsigned int use_link_number_color:1; /** Color model/optimizations */ color_flags_T color_flags; /* XXX: Keep boolean options grouped to save padding */ #ifdef CONFIG_CSS #ifdef CONFIG_LIBCSS unsigned int libcss_enable:1; #endif /** @name CSS stuff * @{ */ unsigned int css_enable:1; unsigned int css_import:1; unsigned int css_ignore_display_none:1; /** @} */ #endif /** @name HTML stuff * @{ */ unsigned int tables:1; unsigned int table_order:1; unsigned int frames:1; unsigned int images:1; unsigned int iframes:1; unsigned int display_subs:1; unsigned int display_sups:1; unsigned int underline_links:1; unsigned int wrap_nbsp:1; /** @} */ /** @name Plain rendering stuff * @{ */ unsigned int plain_display_links:1; unsigned int plain_compress_empty_lines:1; unsigned int plain_fixup_tables:1; /** @} */ /** @name Link navigation * @{ */ unsigned int links_numbering:1; unsigned int use_tabindex:1; /** @} */ unsigned int plain:1; unsigned int wrap:1; unsigned int links_show_goto:1; /* XXX: Everything past this comment is specialy handled by compare_opt() */ char *framename; /** The location of the window in which the document is rendered. * *
*
The position of the window (box.x and box.y) * *
This is not compared at all since it doesn't make any * difference what position the document will fit into a frameset * or so. * *
The width of the window (box.width) * *
This controls how wide tables can be rendered and so on. It is * thus also to blame for the extra memory consumption when * resizing because all documents has to be rerendered. We only * need to compare it if not #plain. * *
The height of the window (box.height) * *
Only documents containing textarea or frames uses it and we * only compare it if #needs_height is set. *
*/ struct el_box box; unsigned int needs_height:1; unsigned int needs_width:1; /** Internal flag for rerendering */ unsigned int no_cache:1; unsigned int gradual_rerendering:1; unsigned int was_xml_parsed:1; #ifdef CONFIG_UTF8 unsigned int utf8:1; #endif /* CONFIG_UTF8 */ unsigned int dump:1; #ifdef CONFIG_LIBSIXEL unsigned int sixel:1; #endif /** Active link coloring. * This is mostly here to make use of this option cache so * link drawing is faster. --jonas */ struct active_link_options active_link; /** Options related with IMG tag */ struct document_options_image_link image_link; }; /** Fills the structure with values from the option system. * @relates document_options */ void init_document_options(struct session *ses, struct document_options *doo); /** Free allocated document options. * @relates document_options */ void done_document_options(struct document_options *options); /** Copies the values of one struct @a from to the other @a to. * Note that the document_options.framename is dynamically allocated. * @relates document_options */ void copy_opt(struct document_options *to, struct document_options *from); /* Compares comparable values from the two structures according to * the comparable members described in the struct definition. * @relates document_options */ int compare_opt(struct document_options *o1, struct document_options *o2); #define use_document_fg_colors(o) \ ((o)->color_mode != COLOR_MODE_MONO && (o)->use_document_colors >= 1) #define use_document_bg_colors(o) \ ((o)->color_mode != COLOR_MODE_MONO && (o)->use_document_colors == 2) /** Increments the numeric value of the option identified by @a option_name, * resetting it to the minimum value when it is already at the maximum value, * and redraws the document. */ void toggle_document_option(struct session *ses, const char *option_name); #ifdef __cplusplus } #endif #endif