1
0
mirror of https://github.com/rkd77/elinks.git synced 2025-01-03 14:57:44 -05:00
elinks/src/document/options.h

201 lines
5.2 KiB
C

#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;
/** @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
/** @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;
unsigned int was_xml_parsed: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.
*
* <dl>
* <dt>The position of the window (box.x and box.y)
*
* <dd>This is not compared at all since it doesn't make any
* difference what position the document will fit into a frameset
* or so.
*
* <dt>The width of the window (box.width)
*
* <dd>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.
*
* <dt>The height of the window (box.height)
*
* <dd>Only documents containing textarea or frames uses it and we
* only compare it if #needs_height is set.
* </dl> */
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;
#ifdef CONFIG_UTF8
unsigned int utf8:1;
#endif /* CONFIG_UTF8 */
unsigned int dump:1;
/** 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