1
0
mirror of https://github.com/rkd77/elinks.git synced 2024-12-04 14:46:47 -05:00

Compile with C++.

Weak points:
- alignof
- js problems

Todo:
- make js work with C++ and mozjs-17
- then mozjs-24
- then mozjs-52
- then mozjs-60
- decrease number of warnings
This commit is contained in:
Witold Filipczyk 2019-02-17 20:46:16 +01:00
parent 25dd2ecae9
commit 4f4df33638
141 changed files with 649 additions and 620 deletions

View File

@ -55,6 +55,7 @@ ASCIIDOC_FLAGS = --unsafe
AWK = @AWK@ AWK = @AWK@
CATALOGS = @CATALOGS@ CATALOGS = @CATALOGS@
CC = @CC@ CC = @CC@
CXX = @CXX@
LD = @LD@ LD = @LD@
GIT = @GIT@ GIT = @GIT@
CONFDIR = @CONFDIR@ CONFDIR = @CONFDIR@
@ -180,6 +181,7 @@ CONFIG_GSSAPI = @CONFIG_GSSAPI@
DEFS = @DEFS@ DEFS = @DEFS@
CFLAGS = @CFLAGS@ CFLAGS = @CFLAGS@
CXXFLAGS = @CXXFLAGS@
CPPFLAGS = @CPPFLAGS@ CPPFLAGS = @CPPFLAGS@
LDFLAGS = @LDFLAGS@ LDFLAGS = @LDFLAGS@
LIBS = @LIBS@ LIBS = @LIBS@
@ -187,7 +189,7 @@ LIBS = @LIBS@
INCLUDES = -I$(top_builddir) -I$(top_srcdir)/src INCLUDES = -I$(top_builddir) -I$(top_srcdir)/src
COMPILE = $(CC) $(DEFS) $(INCLUDES) $(CPPFLAGS) $(CFLAGS) COMPILE = $(CXX) $(DEFS) $(INCLUDES) $(CPPFLAGS) $(CFLAGS) $(CXXFLAGS)
MAKE_COLOR = @MAKE_COLOR@ MAKE_COLOR = @MAKE_COLOR@

View File

@ -62,7 +62,7 @@ quiet_cmd_ld_objs = " [$(LD_COLOR)LD$(END_COLOR)] $(RELPATH)$@"
`test -e $(subdir)/$(LIB_O_NAME) && echo $(subdir)/$(LIB_O_NAME)`) `test -e $(subdir)/$(LIB_O_NAME) && echo $(subdir)/$(LIB_O_NAME)`)
quiet_cmd_link = ' [$(LINK_COLOR)LINK$(END_COLOR)] $(RELPATH)$@' quiet_cmd_link = ' [$(LINK_COLOR)LINK$(END_COLOR)] $(RELPATH)$@'
cmd_link = $(CC) $(CFLAGS) $(LDFLAGS) -o $@ $^ $(LIBS) cmd_link = $(CXX) $(CFLAGS) $(LDFLAGS) -o $@ $^ $(LIBS)
quiet_cmd_sparse = ' [SPARSE] $(RELPATH)$(2)' quiet_cmd_sparse = ' [SPARSE] $(RELPATH)$(2)'
cmd_sparse = $(SPARSE) $(DEFS) $(INCLUDES) $(CPPFLAGS) $(CFLAGS) $(SPARSE_FLAGS) $(2) cmd_sparse = $(SPARSE) $(DEFS) $(INCLUDES) $(CPPFLAGS) $(CFLAGS) $(SPARSE_FLAGS) $(2)

View File

@ -59,7 +59,8 @@ echo "Feature summary:" > features.log
# Checks for programs. # Checks for programs.
# =================================================================== # ===================================================================
AC_PROG_CC AC_PROG_CXX
AC_LANG([C++])
AC_CHECK_TOOL([LD], [ld]) AC_CHECK_TOOL([LD], [ld])
AC_PROG_AWK AC_PROG_AWK
AC_PATH_PROGS(AWK, "$AWK") AC_PATH_PROGS(AWK, "$AWK")
@ -279,7 +280,6 @@ EL_CHECK_CODE([variadic macros], HAVE_VARIADIC_MACROS,
# Checks for library functions. # Checks for library functions.
# =================================================================== # ===================================================================
AC_PROG_GCC_TRADITIONAL
AC_FUNC_MEMCMP AC_FUNC_MEMCMP
AC_FUNC_MMAP AC_FUNC_MMAP
AC_FUNC_STRFTIME AC_FUNC_STRFTIME
@ -1748,6 +1748,7 @@ if test "x$ac_cv_c_compiler_gnu" = "xyes"; then
CFLAGS="$CFLAGS -Werror" CFLAGS="$CFLAGS -Werror"
fi fi
GETTEXT_CFLAGS="-Wno-uninitialized" GETTEXT_CFLAGS="-Wno-uninitialized"
CXXFLAGS="$CXXFLAGS -fpermissive"
case "`$CC -dumpversion`" in case "`$CC -dumpversion`" in
3.0|3.1|3.2) 3.0|3.1|3.2)
@ -1850,6 +1851,7 @@ fi
AC_SUBST(GETTEXT_CFLAGS) AC_SUBST(GETTEXT_CFLAGS)
EL_LOG_CONFIG(CFLAGS, [Compiler flags (CFLAGS)], []) EL_LOG_CONFIG(CFLAGS, [Compiler flags (CFLAGS)], [])
EL_LOG_CONFIG(CXXFLAGS, [Compiler flags (CXXFLAGS)], [])
EL_LOG_CONFIG(CPPFLAGS, [Preprocessor flags (CPPFLAGS)], []) EL_LOG_CONFIG(CPPFLAGS, [Preprocessor flags (CPPFLAGS)], [])
EL_LOG_CONFIG(LDFLAGS, [Linker flags (LDFLAGS)], []) EL_LOG_CONFIG(LDFLAGS, [Linker flags (LDFLAGS)], [])
EL_LOG_CONFIG(LIBS, [Library flags (LIBS)], []) EL_LOG_CONFIG(LIBS, [Library flags (LIBS)], [])

View File

@ -594,7 +594,7 @@ static void
print_delete_error(struct listbox_item *item, struct terminal *term, print_delete_error(struct listbox_item *item, struct terminal *term,
const struct listbox_ops *ops, enum delete_error err) const struct listbox_ops *ops, enum delete_error err)
{ {
struct string msg; struct string_ msg;
unsigned char *errmsg; unsigned char *errmsg;
unsigned char *text; unsigned char *text;

View File

@ -108,7 +108,7 @@ void
do_tab_compl_unambiguous(struct dialog_data *dlg_data, do_tab_compl_unambiguous(struct dialog_data *dlg_data,
LIST_OF(struct input_history_entry) *history) LIST_OF(struct input_history_entry) *history)
{ {
struct string completion; struct string_ completion;
struct widget_data *widget_data = selected_widget(dlg_data); struct widget_data *widget_data = selected_widget(dlg_data);
int base_len = widget_data->info.field.cpos; int base_len = widget_data->info.field.cpos;
/* Maximum number of characters in a match. Characters after this /* Maximum number of characters in a match. Characters after this

View File

@ -192,8 +192,8 @@ menu_labels(struct menu_item *items, unsigned char *base, unsigned char **lbls)
} }
void void
add_select_item(struct list_menu *menu, struct string *string, add_select_item(struct list_menu *menu, struct string_ *string,
struct string *orig_string, unsigned char **value, struct string_ *orig_string, unsigned char **value,
int order, int dont_add) int order, int dont_add)
{ {
int pos = order - 1; int pos = order - 1;

View File

@ -3,7 +3,7 @@
#define EL__BFU_LISTMENU_H #define EL__BFU_LISTMENU_H
struct session; struct session;
struct string; struct string_;
struct terminal; struct terminal;
struct list_menu { struct list_menu {
@ -13,7 +13,7 @@ struct list_menu {
void init_menu(struct list_menu *menu); void init_menu(struct list_menu *menu);
void destroy_menu(struct list_menu *menu); void destroy_menu(struct list_menu *menu);
void add_select_item(struct list_menu *menu, struct string *string, struct string *orig_string, unsigned char **value, int order, int dont_add); void add_select_item(struct list_menu *menu, struct string_ *string, struct string_ *orig_string, unsigned char **value, int order, int dont_add);
void new_menu_item(struct list_menu *menu, unsigned char *name, int data, int fullname); void new_menu_item(struct list_menu *menu, unsigned char *name, int data, int fullname);
struct menu_item *detach_menu(struct list_menu *menu); struct menu_item *detach_menu(struct list_menu *menu);
void menu_labels(struct menu_item *m, unsigned char *base, unsigned char **lbls); void menu_labels(struct menu_item *m, unsigned char *base, unsigned char **lbls);

View File

@ -220,7 +220,7 @@ get_menuitem_rtext_width(struct terminal *term, struct menu_item *mi)
rtext_width = L_RTEXT_SPACE + m_submenu_len + R_RTEXT_SPACE; rtext_width = L_RTEXT_SPACE + m_submenu_len + R_RTEXT_SPACE;
} else if (mi->action_id != ACT_MAIN_NONE) { } else if (mi->action_id != ACT_MAIN_NONE) {
struct string keystroke; struct string_ keystroke;
if (init_string(&keystroke)) { if (init_string(&keystroke)) {
add_keystroke_action_to_string(&keystroke, mi->action_id, KEYMAP_MAIN); add_keystroke_action_to_string(&keystroke, mi->action_id, KEYMAP_MAIN);
@ -634,7 +634,7 @@ display_menu(struct terminal *term, struct menu *menu)
draw_menu_right_text(term, m_submenu, m_submenu_len, draw_menu_right_text(term, m_submenu, m_submenu_len,
menu->box.x, box.y, box.width, color); menu->box.x, box.y, box.width, color);
} else if (mi->action_id != ACT_MAIN_NONE) { } else if (mi->action_id != ACT_MAIN_NONE) {
struct string keystroke; struct string_ keystroke;
#ifdef CONFIG_DEBUG #ifdef CONFIG_DEBUG
/* Help to detect action + right text. --Zas */ /* Help to detect action + right text. --Zas */

View File

@ -184,7 +184,7 @@ indentation(struct secure_save_info *ssi, int num)
static void static void
print_xml_entities(struct secure_save_info *ssi, const unsigned char *str) print_xml_entities(struct secure_save_info *ssi, const unsigned char *str)
{ {
struct string entitized = NULL_STRING; struct string_ entitized = NULL_STRING;
if (init_string(&entitized) if (init_string(&entitized)
&& add_html_to_string(&entitized, str, strlen(str))) { && add_html_to_string(&entitized, str, strlen(str))) {

View File

@ -690,7 +690,7 @@ bookmark_auto_save_tabs(struct terminal *term)
static void static void
bookmark_snapshot(void) bookmark_snapshot(void)
{ {
struct string folderstring; struct string_ folderstring;
struct bookmark *folder; struct bookmark *folder;
if (!init_string(&folderstring)) return; if (!init_string(&folderstring)) return;

View File

@ -75,7 +75,7 @@ get_bookmark_text(struct listbox_item *item, struct terminal *term)
static void static void
add_converted_bytes_to_string(void *data, unsigned char *buf, int buflen) add_converted_bytes_to_string(void *data, unsigned char *buf, int buflen)
{ {
struct string *string = data; struct string_ *string = data;
add_bytes_to_string(string, buf, buflen); /* ignore errors */ add_bytes_to_string(string, buf, buflen); /* ignore errors */
} }
@ -87,7 +87,7 @@ get_bookmark_info(struct listbox_item *item, struct terminal *term)
int utf8_cp = get_cp_index("UTF-8"); int utf8_cp = get_cp_index("UTF-8");
int term_cp = get_terminal_codepage(term); int term_cp = get_terminal_codepage(term);
struct conv_table *convert_table; struct conv_table *convert_table;
struct string info; struct string_ info;
if (item->type == BI_FOLDER) return NULL; if (item->type == BI_FOLDER) return NULL;
convert_table = get_translation_table(utf8_cp, term_cp); convert_table = get_translation_table(utf8_cp, term_cp);
@ -943,7 +943,7 @@ bookmark_terminal_tabs_ok(void *term_void, unsigned char *foldername)
void void
bookmark_terminal_tabs_dialog(struct terminal *term) bookmark_terminal_tabs_dialog(struct terminal *term)
{ {
struct string string; struct string_ string;
if (!init_string(&string)) return; if (!init_string(&string)) return;

2
src/cache/dialogs.c vendored
View File

@ -57,7 +57,7 @@ static unsigned char *
get_cache_entry_info(struct listbox_item *item, struct terminal *term) get_cache_entry_info(struct listbox_item *item, struct terminal *term)
{ {
struct cache_entry *cached = item->udata; struct cache_entry *cached = item->udata;
struct string msg; struct string_ msg;
if (item->type == BI_FOLDER) return NULL; if (item->type == BI_FOLDER) return NULL;
if (!init_string(&msg)) return NULL; if (!init_string(&msg)) return NULL;

View File

@ -431,12 +431,12 @@ version_cmd(struct option *o, unsigned char ***argv, int *argc)
static void print_option_desc(const unsigned char *desc) static void print_option_desc(const unsigned char *desc)
{ {
struct string wrapped; struct string_ wrapped;
static const struct string indent = INIT_STRING(" ", 12); static const struct string_ indent = INIT_STRING(" ", 12);
if (init_string(&wrapped) if (init_string(&wrapped)
&& wrap_option_desc(&wrapped, desc, &indent, 79 - indent.length)) { && wrap_option_desc(&wrapped, desc, &indent, 79 - indent.length)) {
/* struct string could in principle contain null /* struct string_ could in principle contain null
* characters, so don't use printf() or fputs(). */ * characters, so don't use printf() or fputs(). */
fwrite(wrapped.source, 1, wrapped.length, stdout); fwrite(wrapped.source, 1, wrapped.length, stdout);
} else { } else {
@ -595,8 +595,8 @@ print_short_help(void)
{ {
#define ALIGN_WIDTH 20 #define ALIGN_WIDTH 20
struct option *option; struct option *option;
struct string string = NULL_STRING; struct string_ string = NULL_STRING;
struct string *saved = NULL; struct string_ *saved = NULL;
unsigned char align[ALIGN_WIDTH]; unsigned char align[ALIGN_WIDTH];
/* Initialize @space used to align captions. */ /* Initialize @space used to align captions. */

View File

@ -200,7 +200,7 @@ skip_to_unquoted_newline_or_comment(struct conf_parsing_pos *pos)
static enum parse_error static enum parse_error
parse_set_common(struct option *opt_tree, struct conf_parsing_state *state, parse_set_common(struct option *opt_tree, struct conf_parsing_state *state,
struct string *mirror, int is_system_conf, int want_domain) struct string_ *mirror, int is_system_conf, int want_domain)
{ {
const unsigned char *domain_orig = NULL; const unsigned char *domain_orig = NULL;
size_t domain_len = 0; size_t domain_len = 0;
@ -386,14 +386,14 @@ parse_set_common(struct option *opt_tree, struct conf_parsing_state *state,
static enum parse_error static enum parse_error
parse_set_domain(struct option *opt_tree, struct conf_parsing_state *state, parse_set_domain(struct option *opt_tree, struct conf_parsing_state *state,
struct string *mirror, int is_system_conf) struct string_ *mirror, int is_system_conf)
{ {
return parse_set_common(opt_tree, state, mirror, is_system_conf, 1); return parse_set_common(opt_tree, state, mirror, is_system_conf, 1);
} }
static enum parse_error static enum parse_error
parse_set(struct option *opt_tree, struct conf_parsing_state *state, parse_set(struct option *opt_tree, struct conf_parsing_state *state,
struct string *mirror, int is_system_conf) struct string_ *mirror, int is_system_conf)
{ {
return parse_set_common(opt_tree, state, mirror, is_system_conf, 0); return parse_set_common(opt_tree, state, mirror, is_system_conf, 0);
} }
@ -401,7 +401,7 @@ parse_set(struct option *opt_tree, struct conf_parsing_state *state,
static enum parse_error static enum parse_error
parse_unset(struct option *opt_tree, struct conf_parsing_state *state, parse_unset(struct option *opt_tree, struct conf_parsing_state *state,
struct string *mirror, int is_system_conf) struct string_ *mirror, int is_system_conf)
{ {
const unsigned char *optname_orig; const unsigned char *optname_orig;
size_t optname_len; size_t optname_len;
@ -478,7 +478,7 @@ parse_unset(struct option *opt_tree, struct conf_parsing_state *state,
static enum parse_error static enum parse_error
parse_bind(struct option *opt_tree, struct conf_parsing_state *state, parse_bind(struct option *opt_tree, struct conf_parsing_state *state,
struct string *mirror, int is_system_conf) struct string_ *mirror, int is_system_conf)
{ {
unsigned char *keymap, *keystroke, *action; unsigned char *keymap, *keystroke, *action;
enum parse_error err = ERROR_NONE; enum parse_error err = ERROR_NONE;
@ -567,14 +567,14 @@ parse_bind(struct option *opt_tree, struct conf_parsing_state *state,
} }
static int load_config_file(unsigned char *, unsigned char *, struct option *, static int load_config_file(unsigned char *, unsigned char *, struct option *,
struct string *, int); struct string_ *, int);
static enum parse_error static enum parse_error
parse_include(struct option *opt_tree, struct conf_parsing_state *state, parse_include(struct option *opt_tree, struct conf_parsing_state *state,
struct string *mirror, int is_system_conf) struct string_ *mirror, int is_system_conf)
{ {
unsigned char *fname; unsigned char *fname;
struct string dumbstring; struct string_ dumbstring;
struct conf_parsing_pos before_error; struct conf_parsing_pos before_error;
if (!init_string(&dumbstring)) if (!init_string(&dumbstring))
@ -622,7 +622,7 @@ struct parse_handler {
const unsigned char *command; const unsigned char *command;
enum parse_error (*handler)(struct option *opt_tree, enum parse_error (*handler)(struct option *opt_tree,
struct conf_parsing_state *state, struct conf_parsing_state *state,
struct string *mirror, int is_system_conf); struct string_ *mirror, int is_system_conf);
}; };
static const struct parse_handler parse_handlers[] = { static const struct parse_handler parse_handlers[] = {
@ -637,7 +637,7 @@ static const struct parse_handler parse_handlers[] = {
static enum parse_error static enum parse_error
parse_config_command(struct option *options, struct conf_parsing_state *state, parse_config_command(struct option *options, struct conf_parsing_state *state,
struct string *mirror, int is_system_conf) struct string_ *mirror, int is_system_conf)
{ {
const struct parse_handler *handler; const struct parse_handler *handler;
@ -688,7 +688,7 @@ parse_config_exmode_command(unsigned char *cmd)
void void
parse_config_file(struct option *options, unsigned char *name, parse_config_file(struct option *options, unsigned char *name,
unsigned char *file, struct string *mirror, unsigned char *file, struct string_ *mirror,
int is_system_conf) int is_system_conf)
{ {
struct conf_parsing_state state = {{ 0 }}; struct conf_parsing_state state = {{ 0 }};
@ -766,7 +766,7 @@ read_config_file(unsigned char *name)
{ {
#define FILE_BUF 1024 #define FILE_BUF 1024
unsigned char cfg_buffer[FILE_BUF]; unsigned char cfg_buffer[FILE_BUF];
struct string string; struct string_ string;
int fd; int fd;
ssize_t r; ssize_t r;
@ -797,7 +797,7 @@ read_config_file(unsigned char *name)
/* Return 0 on success. */ /* Return 0 on success. */
static int static int
load_config_file(unsigned char *prefix, unsigned char *name, load_config_file(unsigned char *prefix, unsigned char *name,
struct option *options, struct string *mirror, struct option *options, struct string_ *mirror,
int is_system_conf) int is_system_conf)
{ {
unsigned char *config_str, *config_file; unsigned char *config_str, *config_file;
@ -856,16 +856,16 @@ conf_i18n(unsigned char *s, int i18n)
} }
static void static void
add_indent_to_string(struct string *string, int depth) add_indent_to_string(struct string_ *string, int depth)
{ {
if (!depth) return; if (!depth) return;
add_xchar_to_string(string, ' ', depth * indentation); add_xchar_to_string(string, ' ', depth * indentation);
} }
struct string * struct string_ *
wrap_option_desc(struct string *out, const unsigned char *src, wrap_option_desc(struct string_ *out, const unsigned char *src,
const struct string *indent, int maxwidth) const struct string_ *indent, int maxwidth)
{ {
const unsigned char *last_space = NULL; const unsigned char *last_space = NULL;
const unsigned char *uncopied = src; const unsigned char *uncopied = src;
@ -906,11 +906,11 @@ split:
} }
static void static void
output_option_desc_as_comment(struct string *out, const struct option *option, output_option_desc_as_comment(struct string_ *out, const struct option *option,
int i18n, int depth) int i18n, int depth)
{ {
unsigned char *desc_i18n = conf_i18n(option->desc, i18n); unsigned char *desc_i18n = conf_i18n(option->desc, i18n);
struct string indent; struct string_ indent;
if (!init_string(&indent)) return; if (!init_string(&indent)) return;
@ -926,7 +926,7 @@ out_of_memory:
static unsigned char *smart_config_output_fn_domain; static unsigned char *smart_config_output_fn_domain;
static void static void
smart_config_output_fn(struct string *string, struct option *option, smart_config_output_fn(struct string_ *string, struct option *option,
unsigned char *path, int depth, int do_print_comment, unsigned char *path, int depth, int do_print_comment,
int action, int i18n) int action, int i18n)
{ {
@ -999,7 +999,7 @@ smart_config_output_fn(struct string *string, struct option *option,
static void static void
add_cfg_header_to_string(struct string *string, unsigned char *text) add_cfg_header_to_string(struct string_ *string, unsigned char *text)
{ {
int n = strlen(text) + 2; int n = strlen(text) + 2;
@ -1016,9 +1016,9 @@ unsigned char *
create_config_string(unsigned char *prefix, unsigned char *name) create_config_string(unsigned char *prefix, unsigned char *name)
{ {
struct option *options = config_options; struct option *options = config_options;
struct string config; struct string_ config;
/* Don't write headers if nothing will be added anyway. */ /* Don't write headers if nothing will be added anyway. */
struct string tmpstring; struct string_ tmpstring;
int origlen; int origlen;
int savestyle = get_opt_int("config.saving_style", NULL); int savestyle = get_opt_int("config.saving_style", NULL);
int i18n = get_opt_bool("config.i18n", NULL); int i18n = get_opt_bool("config.i18n", NULL);

View File

@ -18,14 +18,14 @@ void load_config(void);
enum parse_error parse_config_exmode_command(unsigned char *cmd); enum parse_error parse_config_exmode_command(unsigned char *cmd);
#endif #endif
void parse_config_file(struct option *options, unsigned char *name, void parse_config_file(struct option *options, unsigned char *name,
unsigned char *file, struct string *mirror, unsigned char *file, struct string_ *mirror,
int is_system_conf); int is_system_conf);
int write_config(struct terminal *); int write_config(struct terminal *);
unsigned char * unsigned char *
create_config_string(unsigned char *prefix, unsigned char *name); create_config_string(unsigned char *prefix, unsigned char *name);
struct string *wrap_option_desc(struct string *out, const unsigned char *src, struct string_ *wrap_option_desc(struct string_ *out, const unsigned char *src,
const struct string *indent, int maxwidth); const struct string_ *indent, int maxwidth);
#endif #endif

View File

@ -102,7 +102,7 @@ is_option_used(struct listbox_item *item)
static unsigned char * static unsigned char *
get_range_string(struct option *option) get_range_string(struct option *option)
{ {
struct string info; struct string_ info;
if (!init_string(&info)) return NULL; if (!init_string(&info)) return NULL;
@ -133,7 +133,7 @@ get_option_info(struct listbox_item *item, struct terminal *term)
{ {
struct option *option = item->udata; struct option *option = item->udata;
unsigned char *desc, *type; unsigned char *desc, *type;
struct string info; struct string_ info;
if (!init_string(&info)) return NULL; if (!init_string(&info)) return NULL;
@ -154,7 +154,7 @@ get_option_info(struct listbox_item *item, struct terminal *term)
if (option_types[option->type].write) { if (option_types[option->type].write) {
unsigned char *range; unsigned char *range;
struct string value; struct string_ value;
if (!init_string(&value)) { if (!init_string(&value)) {
done_string(&info); done_string(&info);
@ -302,7 +302,7 @@ build_edit_dialog(struct terminal *term, struct session *ses,
#define EDIT_WIDGETS_COUNT 5 #define EDIT_WIDGETS_COUNT 5
struct dialog *dlg; struct dialog *dlg;
unsigned char *value, *name, *desc, *range; unsigned char *value, *name, *desc, *range;
struct string tvalue; struct string_ tvalue;
if (!init_string(&tvalue)) return; if (!init_string(&tvalue)) return;
@ -636,7 +636,7 @@ static unsigned char *
get_keybinding_text(struct listbox_item *item, struct terminal *term) get_keybinding_text(struct listbox_item *item, struct terminal *term)
{ {
struct keybinding *keybinding = item->udata; struct keybinding *keybinding = item->udata;
struct string info; struct string_ info;
if (item->depth == 0) { if (item->depth == 0) {
struct keymap *keymap = item->udata; struct keymap *keymap = item->udata;
@ -660,7 +660,7 @@ get_keybinding_info(struct listbox_item *item, struct terminal *term)
{ {
struct keybinding *keybinding = item->udata; struct keybinding *keybinding = item->udata;
unsigned char *action, *keymap; unsigned char *action, *keymap;
struct string info; struct string_ info;
if (item->depth < 2) return NULL; if (item->depth < 2) return NULL;
if (item->type == BI_FOLDER) return NULL; if (item->type == BI_FOLDER) return NULL;
@ -793,7 +793,7 @@ really_add_keybinding(void *data, unsigned char *keystroke)
if (keybinding_exists(hop->keymap_id, &hop->kbd, &action_id) if (keybinding_exists(hop->keymap_id, &hop->kbd, &action_id)
&& action_id != ACT_MAIN_NONE) { && action_id != ACT_MAIN_NONE) {
struct kbdbind_add_hop *new_hop; struct kbdbind_add_hop *new_hop;
struct string canonical; struct string_ canonical;
/* Same keystroke for same action, just return. */ /* Same keystroke for same action, just return. */
if (action_id == hop->action_id) return; if (action_id == hop->action_id) return;

View File

@ -467,7 +467,7 @@ parse_keystroke(const unsigned char *s, struct term_event_keyboard *kbd)
} }
void void
add_keystroke_to_string(struct string *str, struct term_event_keyboard *kbd, add_keystroke_to_string(struct string_ *str, struct term_event_keyboard *kbd,
int escape) int escape)
{ {
unsigned char key_buffer[3] = "\\x"; unsigned char key_buffer[3] = "\\x";
@ -503,7 +503,7 @@ add_keystroke_to_string(struct string *str, struct term_event_keyboard *kbd,
} }
void void
add_keystroke_action_to_string(struct string *string, action_id_T action_id, add_keystroke_action_to_string(struct string_ *string, action_id_T action_id,
enum keymap_id keymap_id) enum keymap_id keymap_id)
{ {
struct keybinding *keybinding = kbd_act_lookup(keymap_id, action_id); struct keybinding *keybinding = kbd_act_lookup(keymap_id, action_id);
@ -515,7 +515,7 @@ add_keystroke_action_to_string(struct string *string, action_id_T action_id,
unsigned char * unsigned char *
get_keystroke(action_id_T action_id, enum keymap_id keymap_id) get_keystroke(action_id_T action_id, enum keymap_id keymap_id)
{ {
struct string keystroke; struct string_ keystroke;
if (!init_string(&keystroke)) return NULL; if (!init_string(&keystroke)) return NULL;
@ -528,7 +528,7 @@ get_keystroke(action_id_T action_id, enum keymap_id keymap_id)
} }
void void
add_actions_to_string(struct string *string, action_id_T action_ids[], add_actions_to_string(struct string_ *string, action_id_T action_ids[],
enum keymap_id keymap_id, struct terminal *term) enum keymap_id keymap_id, struct terminal *term)
{ {
int i; int i;
@ -950,7 +950,7 @@ bind_act(unsigned char *keymap_str, const unsigned char *keystroke_str)
} }
static void static void
single_bind_config_string(struct string *file, enum keymap_id keymap_id, single_bind_config_string(struct string_ *file, enum keymap_id keymap_id,
struct keybinding *keybinding) struct keybinding *keybinding)
{ {
unsigned char *keymap_str = get_keymap_name(keymap_id); unsigned char *keymap_str = get_keymap_name(keymap_id);
@ -976,7 +976,7 @@ single_bind_config_string(struct string *file, enum keymap_id keymap_id,
} }
void void
bind_config_string(struct string *file) bind_config_string(struct string_ *file)
{ {
int keymap_id; int keymap_id;

View File

@ -162,9 +162,9 @@ term_event_key_T read_key(const unsigned char *);
unsigned char *get_keymap_name(enum keymap_id); unsigned char *get_keymap_name(enum keymap_id);
int parse_keystroke(const unsigned char *, struct term_event_keyboard *); int parse_keystroke(const unsigned char *, struct term_event_keyboard *);
void add_keystroke_to_string(struct string *str, struct term_event_keyboard *kbd, int escape); void add_keystroke_to_string(struct string_ *str, struct term_event_keyboard *kbd, int escape);
/* void add_accesskey_to_string(struct string *str, unicode_val_T accesskey); */ /* void add_accesskey_to_string(struct string_ *str, unicode_val_T accesskey); */
#define add_accesskey_to_string(str, accesskey) do { \ #define add_accesskey_to_string(str, accesskey) do { \
struct term_event_keyboard kbd; \ struct term_event_keyboard kbd; \
/* FIXME: #ifndef CONFIG_UTF8, kbd.key is encoded in \ /* FIXME: #ifndef CONFIG_UTF8, kbd.key is encoded in \
@ -184,17 +184,17 @@ struct keybinding *kbd_nm_lookup(enum keymap_id, unsigned char *);
int bind_do(unsigned char *, const unsigned char *, unsigned char *, int); int bind_do(unsigned char *, const unsigned char *, unsigned char *, int);
unsigned char *bind_act(unsigned char *, const unsigned char *); unsigned char *bind_act(unsigned char *, const unsigned char *);
void bind_config_string(struct string *); void bind_config_string(struct string_ *);
#ifdef CONFIG_SCRIPTING #ifdef CONFIG_SCRIPTING
int bind_key_to_event_name(unsigned char *, const unsigned char *, unsigned char *, int bind_key_to_event_name(unsigned char *, const unsigned char *, unsigned char *,
unsigned char **); unsigned char **);
#endif #endif
void add_keystroke_action_to_string(struct string *string, action_id_T action_id, enum keymap_id keymap_id); void add_keystroke_action_to_string(struct string_ *string, action_id_T action_id, enum keymap_id keymap_id);
unsigned char *get_keystroke(action_id_T action_id, enum keymap_id keymap_id); unsigned char *get_keystroke(action_id_T action_id, enum keymap_id keymap_id);
void add_actions_to_string(struct string *string, action_id_T actions[], void add_actions_to_string(struct string_ *string, action_id_T actions[],
enum keymap_id keymap_id, struct terminal *term); enum keymap_id keymap_id, struct terminal *term);
extern struct module kbdbind_module; extern struct module kbdbind_module;

View File

@ -1044,10 +1044,10 @@ check_nonempty_tree(LIST_OF(struct option) *options)
/*! @relates option */ /*! @relates option */
void void
smart_config_string(struct string *str, int print_comment, int i18n, smart_config_string(struct string_ *str, int print_comment, int i18n,
LIST_OF(struct option) *options, LIST_OF(struct option) *options,
unsigned char *path, int depth, unsigned char *path, int depth,
void (*fn)(struct string *, struct option *, void (*fn)(struct string_ *, struct option *,
unsigned char *, int, int, int, int)) unsigned char *, int, int, int, int))
{ {
struct option *option; struct option *option;
@ -1106,7 +1106,7 @@ smart_config_string(struct string *str, int print_comment, int i18n,
do_print_comment, 2, i18n); do_print_comment, 2, i18n);
} else if (option->type == OPT_TREE) { } else if (option->type == OPT_TREE) {
struct string newpath; struct string_ newpath;
int pc = print_comment; int pc = print_comment;
if (!init_string(&newpath)) continue; /* OK? */ if (!init_string(&newpath)) continue; /* OK? */

View File

@ -231,9 +231,9 @@ extern LIST_OF(struct option) *init_options_tree(void);
extern void prepare_mustsave_flags(LIST_OF(struct option) *, int set_all); extern void prepare_mustsave_flags(LIST_OF(struct option) *, int set_all);
extern void untouch_options(LIST_OF(struct option) *); extern void untouch_options(LIST_OF(struct option) *);
extern void smart_config_string(struct string *, int, int, extern void smart_config_string(struct string_ *, int, int,
LIST_OF(struct option) *, unsigned char *, int, LIST_OF(struct option) *, unsigned char *, int,
void (*)(struct string *, struct option *, void (*)(struct string_ *, struct option *,
unsigned char *, int, int, int, int)); unsigned char *, int, int, int, int));
enum copy_option_flags { enum copy_option_flags {

View File

@ -129,7 +129,7 @@ redir_rd(struct option *opt, unsigned char **file, int *line)
} }
static void static void
redir_wr(struct option *opt, struct string *string) redir_wr(struct option *opt, struct string_ *string)
{ {
struct option *real = get_opt_rec(config_options, opt->value.string); struct option *real = get_opt_rec(config_options, opt->value.string);
@ -189,7 +189,7 @@ redir_eq(struct option *opt, const unsigned char *str)
/* Support functions for config file parsing. */ /* Support functions for config file parsing. */
static void static void
add_optstring_to_string(struct string *s, const unsigned char *q, int qlen) add_optstring_to_string(struct string_ *s, const unsigned char *q, int qlen)
{ {
if (!commandline) add_char_to_string(s, '"'); if (!commandline) add_char_to_string(s, '"');
add_quoted_to_string(s, q, qlen); add_quoted_to_string(s, q, qlen);
@ -241,7 +241,7 @@ num_eq(struct option *opt, const unsigned char *str)
} }
static void static void
num_wr(struct option *option, struct string *string) num_wr(struct option *option, struct string_ *string)
{ {
add_knum_to_string(string, option->value.number); add_knum_to_string(string, option->value.number);
} }
@ -261,7 +261,7 @@ long_eq(struct option *opt, const unsigned char *str)
} }
static void static void
long_wr(struct option *option, struct string *string) long_wr(struct option *option, struct string_ *string)
{ {
add_knum_to_string(string, option->value.big_number); add_knum_to_string(string, option->value.big_number);
} }
@ -270,7 +270,7 @@ static unsigned char *
str_rd(struct option *opt, unsigned char **file, int *line) str_rd(struct option *opt, unsigned char **file, int *line)
{ {
unsigned char *str = *file; unsigned char *str = *file;
struct string str2; struct string_ str2;
if (!init_string(&str2)) return NULL; if (!init_string(&str2)) return NULL;
@ -336,7 +336,7 @@ str_eq(struct option *opt, const unsigned char *str)
} }
static void static void
str_wr(struct option *o, struct string *s) str_wr(struct option *o, struct string_ *s)
{ {
int len = strlen(o->value.string); int len = strlen(o->value.string);
@ -372,7 +372,7 @@ cp_eq(struct option *opt, const unsigned char *str)
} }
static void static void
cp_wr(struct option *o, struct string *s) cp_wr(struct option *o, struct string_ *s)
{ {
unsigned char *mime_name = get_cp_config_name(o->value.number); unsigned char *mime_name = get_cp_config_name(o->value.number);
@ -401,7 +401,7 @@ lang_eq(struct option *opt, const unsigned char *str)
} }
static void static void
lang_wr(struct option *o, struct string *s) lang_wr(struct option *o, struct string_ *s)
{ {
unsigned char *lang; unsigned char *lang;
@ -431,7 +431,7 @@ color_eq(struct option *opt, const unsigned char *str)
} }
static void static void
color_wr(struct option *opt, struct string *str) color_wr(struct option *opt, struct string_ *str)
{ {
color_T color = opt->value.color; color_T color = opt->value.color;
unsigned char hexcolor[8]; unsigned char hexcolor[8];

View File

@ -8,7 +8,7 @@ struct option_type_info {
unsigned char *name; unsigned char *name;
unsigned char *(*cmdline)(struct option *, unsigned char ***, int *); unsigned char *(*cmdline)(struct option *, unsigned char ***, int *);
unsigned char *(*read)(struct option *, unsigned char **, int *); unsigned char *(*read)(struct option *, unsigned char **, int *);
void (*write)(struct option *, struct string *); void (*write)(struct option *, struct string_ *);
void (*dup)(struct option *, struct option *, int); void (*dup)(struct option *, struct option *, int);
int (*set)(struct option *, unsigned char *); int (*set)(struct option *, unsigned char *);
int (*equals)(struct option *, const unsigned char *); int (*equals)(struct option *, const unsigned char *);

View File

@ -619,13 +619,13 @@ is_path_prefix(unsigned char *d, unsigned char *s)
} }
static struct string * static struct string_ *
send_cookies_common(struct uri *uri, unsigned int httponly) send_cookies_common(struct uri *uri, unsigned int httponly)
{ {
struct c_domain *cd; struct c_domain *cd;
struct cookie *c, *next; struct cookie *c, *next;
unsigned char *path = NULL; unsigned char *path = NULL;
static struct string header; static struct string_ header;
time_t now; time_t now;
if (!uri->host || !uri->data) if (!uri->host || !uri->data)
@ -686,13 +686,13 @@ send_cookies_common(struct uri *uri, unsigned int httponly)
return &header; return &header;
} }
struct string * struct string_ *
send_cookies(struct uri *uri) send_cookies(struct uri *uri)
{ {
return send_cookies_common(uri, 0); return send_cookies_common(uri, 0);
} }
struct string * struct string_ *
send_cookies_js(struct uri *uri) send_cookies_js(struct uri *uri)
{ {
return send_cookies_common(uri, 1); return send_cookies_common(uri, 1);

View File

@ -61,8 +61,8 @@ void set_cookies_dirty(void);
/* Note that the returned value points to a static structure and thus the /* Note that the returned value points to a static structure and thus the
* string will be overwritten at the next call time. The string source * string will be overwritten at the next call time. The string source
* itself is dynamically allocated, though. */ * itself is dynamically allocated, though. */
struct string *send_cookies(struct uri *uri); struct string_ *send_cookies(struct uri *uri);
struct string *send_cookies_js(struct uri *uri); struct string_ *send_cookies_js(struct uri *uri);
extern struct module cookies_module; extern struct module cookies_module;

View File

@ -32,7 +32,7 @@
INIT_LIST_OF(struct cookie, cookie_queries); INIT_LIST_OF(struct cookie, cookie_queries);
static void static void
add_cookie_info_to_string(struct string *string, struct cookie *cookie, add_cookie_info_to_string(struct string_ *string, struct cookie *cookie,
struct terminal *term) struct terminal *term)
{ {
add_format_to_string(string, "\n%s: %s", _("Name", term), cookie->name); add_format_to_string(string, "\n%s: %s", _("Name", term), cookie->name);
@ -74,7 +74,7 @@ accept_cookie_dialog(struct session *ses, void *data)
{ {
/* [gettext_accelerator_context(accept_cookie_dialog)] */ /* [gettext_accelerator_context(accept_cookie_dialog)] */
struct cookie *cookie = cookie_queries.next; struct cookie *cookie = cookie_queries.next;
struct string string; struct string_ string;
assert(ses); assert(ses);
@ -156,7 +156,7 @@ get_cookie_info(struct listbox_item *item, struct terminal *term)
{ {
struct cookie *cookie = item->udata; struct cookie *cookie = item->udata;
struct cookie_server *server; struct cookie_server *server;
struct string string; struct string_ string;
if (item->type == BI_FOLDER) return NULL; if (item->type == BI_FOLDER) return NULL;

View File

@ -46,7 +46,7 @@ nowhere_box(struct terminal *term, unsigned char *title)
} }
static void static void
add_link_info_to_string(struct string *msg, struct session *ses) add_link_info_to_string(struct string_ *msg, struct session *ses)
{ {
struct document_view *doc_view = current_frame(ses); struct document_view *doc_view = current_frame(ses);
struct terminal *term = ses->tab->term; struct terminal *term = ses->tab->term;
@ -73,7 +73,7 @@ add_link_info_to_string(struct string *msg, struct session *ses)
link = get_current_link_in_view(doc_view); link = get_current_link_in_view(doc_view);
if (link) { if (link) {
struct string img; struct string_ img;
#ifdef CONFIG_GLOBHIST #ifdef CONFIG_GLOBHIST
struct global_history_item *historyitem; struct global_history_item *historyitem;
#endif #endif
@ -119,7 +119,7 @@ link_info_dialog(struct session *ses)
{ {
struct terminal *term = ses->tab->term; struct terminal *term = ses->tab->term;
struct location *location = cur_loc(ses); struct location *location = cur_loc(ses);
struct string msg; struct string_ msg;
if (!location) { if (!location) {
nowhere_box(term, NULL); nowhere_box(term, NULL);
@ -142,7 +142,7 @@ document_info_dialog(struct session *ses)
struct terminal *term = ses->tab->term; struct terminal *term = ses->tab->term;
struct location *location = cur_loc(ses); struct location *location = cur_loc(ses);
struct document_view *doc_view; struct document_view *doc_view;
struct string msg; struct string_ msg;
if (!location) { if (!location) {
nowhere_box(term, NULL); nowhere_box(term, NULL);

View File

@ -87,7 +87,7 @@ menu_keys(struct terminal *term, void *d_, void *xxx)
ACT_MAIN_NONE, ACT_MAIN_NONE,
}; };
struct string keys; struct string_ keys;
struct keys_toggle_info *info; struct keys_toggle_info *info;
info = mem_calloc(1, sizeof(*info)); info = mem_calloc(1, sizeof(*info));
@ -157,7 +157,7 @@ menu_copying(struct terminal *term, void *xxx, void *xxxx)
static unsigned char * static unsigned char *
get_resource_info(struct terminal *term, void *data) get_resource_info(struct terminal *term, void *data)
{ {
struct string info; struct string_ info;
long val; long val;
unsigned longlong bigval; unsigned longlong bigval;

View File

@ -555,7 +555,7 @@ query_file(struct session *ses, struct uri *uri, void *data,
void (*std)(void *, unsigned char *), void (*std)(void *, unsigned char *),
void (*cancel)(void *), int interactive) void (*cancel)(void *), int interactive)
{ {
struct string def; struct string_ def;
assert(ses && uri); assert(ses && uri);
if_assert_failed return; if_assert_failed return;
@ -621,7 +621,7 @@ free_history_lists(void)
static void static void
add_cmdline_bool_option(struct string *string, unsigned char *name) add_cmdline_bool_option(struct string_ *string, unsigned char *name)
{ {
if (!get_cmd_opt_bool(name)) return; if (!get_cmd_opt_bool(name)) return;
add_to_string(string, " -"); add_to_string(string, " -");
@ -634,7 +634,7 @@ open_uri_in_new_window(struct session *ses, struct uri *uri, struct uri *referre
enum task_type task) enum task_type task)
{ {
int ring = get_cmd_opt_int("session-ring"); int ring = get_cmd_opt_int("session-ring");
struct string parameters; struct string_ parameters;
int id; int id;
assert(env && ses); assert(env && ses);
@ -774,7 +774,7 @@ do_pass_uri_to_command(struct terminal *term, void *command_, void *xxx)
static unsigned char * static unsigned char *
format_command(unsigned char *format, struct uri *uri) format_command(unsigned char *format, struct uri *uri)
{ {
struct string string; struct string_ string;
if (!init_string(&string)) return NULL; if (!init_string(&string)) return NULL;

View File

@ -19,7 +19,7 @@ static unsigned char *
get_progress_msg_2(struct progress *progress, struct terminal *term, get_progress_msg_2(struct progress *progress, struct terminal *term,
int wide, int full, unsigned char *separator, unsigned char *type) int wide, int full, unsigned char *separator, unsigned char *type)
{ {
struct string msg; struct string_ msg;
int newlines = separator[strlen(separator) - 1] == '\n'; int newlines = separator[strlen(separator) - 1] == '\n';
if (!init_string(&msg)) return NULL; if (!init_string(&msg)) return NULL;

View File

@ -397,7 +397,7 @@ display_title_bar(struct session *ses, struct terminal *term)
{ {
struct document_view *doc_view; struct document_view *doc_view;
struct document *document; struct document *document;
struct string title; struct string_ title;
unsigned char buf[40]; unsigned char buf[40];
int buflen = 0; int buflen = 0;
int height; int height;

View File

@ -155,7 +155,7 @@ static void
import_css_file(struct css_stylesheet *css, struct uri *base_uri, import_css_file(struct css_stylesheet *css, struct uri *base_uri,
const unsigned char *url, int urllen) const unsigned char *url, int urllen)
{ {
struct string string, filename; struct string_ string, filename;
if (!*url if (!*url
|| css->import_level >= MAX_REDIRECTS || css->import_level >= MAX_REDIRECTS

View File

@ -175,7 +175,7 @@ css_parse_atrule(struct css_stylesheet *css, struct scanner *scanner,
struct uri *base_uri) struct uri *base_uri)
{ {
struct scanner_token *token = get_scanner_token(scanner); struct scanner_token *token = get_scanner_token(scanner);
struct string import_uri; struct string_ import_uri;
/* Skip skip skip that code */ /* Skip skip skip that code */
switch (token->type) { switch (token->type) {

View File

@ -31,7 +31,7 @@
static inline void static inline void
init_dom_renderer(struct dom_renderer *renderer, struct document *document, init_dom_renderer(struct dom_renderer *renderer, struct document *document,
struct string *buffer, struct conv_table *convert_table) struct string_ *buffer, struct conv_table *convert_table)
{ {
memset(renderer, 0, sizeof(*renderer)); memset(renderer, 0, sizeof(*renderer));
@ -79,7 +79,7 @@ get_doctype(struct dom_renderer *renderer, struct cache_entry *cached)
/* Shared multiplexor between renderers */ /* Shared multiplexor between renderers */
void void
render_dom_document(struct cache_entry *cached, struct document *document, render_dom_document(struct cache_entry *cached, struct document *document,
struct string *buffer) struct string_ *buffer)
{ {
unsigned char *head = empty_string_or_(cached->head); unsigned char *head = empty_string_or_(cached->head);
struct dom_renderer renderer; struct dom_renderer renderer;

View File

@ -4,8 +4,8 @@
struct cache_entry; struct cache_entry;
struct document; struct document;
struct string; struct string_;
void render_dom_document(struct cache_entry *cached, struct document *document, struct string *buffer); void render_dom_document(struct cache_entry *cached, struct document *document, struct string_ *buffer);
#endif #endif

View File

@ -445,7 +445,7 @@ look_for_tag(unsigned char **pos, unsigned char *eof,
unsigned char *name, int namelen, unsigned char **label) unsigned char *name, int namelen, unsigned char **label)
{ {
unsigned char *pos2; unsigned char *pos2;
struct string str; struct string_ str;
if (!init_string(&str)) { if (!init_string(&str)) {
/* Is this the right way to bail out? --jonas */ /* Is this the right way to bail out? --jonas */
@ -643,7 +643,7 @@ get_image_map(unsigned char *head, unsigned char *pos, unsigned char *eof,
int to, int def, int hdef) int to, int def, int hdef)
{ {
struct conv_table *ct; struct conv_table *ct;
struct string hd; struct string_ hd;
int look_result; int look_result;
if (!init_string(&hd)) return -1; if (!init_string(&hd)) return -1;
@ -744,7 +744,7 @@ done_html_parser_state(struct html_context *html_context,
struct html_context * struct html_context *
init_html_parser(struct uri *uri, struct document_options *options, init_html_parser(struct uri *uri, struct document_options *options,
unsigned char *start, unsigned char *end, unsigned char *start, unsigned char *end,
struct string *head, struct string *title, struct string_ *head, struct string_ *title,
void (*put_chars)(struct html_context *, unsigned char *, int), void (*put_chars)(struct html_context *, unsigned char *, int),
void (*line_break)(struct html_context *), void (*line_break)(struct html_context *),
void *(*special)(struct html_context *, enum html_special_type, ...)) void *(*special)(struct html_context *, enum html_special_type, ...))

View File

@ -17,7 +17,7 @@ struct html_context;
struct memory_list; struct memory_list;
struct menu_item; struct menu_item;
struct part; struct part;
struct string; struct string_;
struct uri; struct uri;
/* XXX: This is just terible - this interface is from 75% only for other HTML /* XXX: This is just terible - this interface is from 75% only for other HTML
@ -165,7 +165,7 @@ struct html_element {
struct html_context * struct html_context *
init_html_parser(struct uri *uri, struct document_options *options, init_html_parser(struct uri *uri, struct document_options *options,
unsigned char *start, unsigned char *end, unsigned char *start, unsigned char *end,
struct string *head, struct string *title, struct string_ *head, struct string_ *title,
void (*put_chars)(struct html_context *, unsigned char *, int), void (*put_chars)(struct html_context *, unsigned char *, int),
void (*line_break)(struct html_context *), void (*line_break)(struct html_context *),
void *(*special)(struct html_context *, enum html_special_type, void *(*special)(struct html_context *, enum html_special_type,

View File

@ -341,7 +341,7 @@ do_html_select(unsigned char *attr, unsigned char *html,
{ {
struct conv_table *ct = html_context->special_f(html_context, SP_TABLE, NULL); struct conv_table *ct = html_context->special_f(html_context, SP_TABLE, NULL);
struct el_form_control *fc; struct el_form_control *fc;
struct string lbl = NULL_STRING, orig_lbl = NULL_STRING; struct string_ lbl = NULL_STRING, orig_lbl = NULL_STRING;
unsigned char **values = NULL; unsigned char **values = NULL;
unsigned char **labels; unsigned char **labels;
unsigned char *name, *t_attr, *en; unsigned char *name, *t_attr, *en;
@ -558,7 +558,7 @@ html_option(struct html_context *html_context, unsigned char *a,
val = get_attr_val(a, "value", html_context->doc_cp); val = get_attr_val(a, "value", html_context->doc_cp);
if (!val) { if (!val) {
struct string str; struct string_ str;
unsigned char *p, *r; unsigned char *p, *r;
unsigned char *name; unsigned char *name;
int namelen; int namelen;

View File

@ -450,7 +450,7 @@ void
html_handle_body_meta(struct html_context *html_context, unsigned char *meta, html_handle_body_meta(struct html_context *html_context, unsigned char *meta,
unsigned char *eof) unsigned char *eof)
{ {
struct string head; struct string_ head;
if (!init_string(&head)) return; if (!init_string(&head)) return;
@ -826,7 +826,7 @@ static struct {
}; };
static void static void
roman(struct string *p, unsigned n) roman(struct string_ *p, unsigned n)
{ {
int i = 0; int i = 0;
@ -884,7 +884,7 @@ html_li(struct html_context *html_context, unsigned char *a,
int nlen; int nlen;
int t = par_format.flags & P_LISTMASK; int t = par_format.flags & P_LISTMASK;
int s = get_num(a, "value", html_context->doc_cp); int s = get_num(a, "value", html_context->doc_cp);
struct string n; struct string_ n;
if (!init_string(&n)) return; if (!init_string(&n)) return;

View File

@ -865,7 +865,7 @@ html_link(struct html_context *html_context, unsigned char *a,
int link_display = html_context->options->meta_link_display; int link_display = html_context->options->meta_link_display;
unsigned char *name; unsigned char *name;
struct hlink link; struct hlink link;
struct string text; struct string_ text;
int name_neq_title = 0; int name_neq_title = 0;
int first = 1; int first = 1;

View File

@ -1165,8 +1165,8 @@ process_element(unsigned char *name, int namelen, int endingtag,
} }
void void
scan_http_equiv(unsigned char *s, unsigned char *eof, struct string *head, scan_http_equiv(unsigned char *s, unsigned char *eof, struct string_ *head,
struct string *title, int cp) struct string_ *title, int cp)
{ {
unsigned char *name, *attr, *he, *c; unsigned char *name, *attr, *he, *c;
int namelen; int namelen;

View File

@ -5,7 +5,7 @@
struct html_context; struct html_context;
struct document_options; struct document_options;
struct part; struct part;
struct string; struct string_;
/* Flags for get_attr_value(). */ /* Flags for get_attr_value(). */
enum html_attr_flags { enum html_attr_flags {
@ -66,7 +66,7 @@ int get_width(unsigned char *, unsigned char *, int, struct html_context *);
unsigned char *skip_comment(unsigned char *, unsigned char *); unsigned char *skip_comment(unsigned char *, unsigned char *);
void scan_http_equiv(unsigned char *s, unsigned char *eof, struct string *head, struct string *title, int cp); void scan_http_equiv(unsigned char *s, unsigned char *eof, struct string_ *head, struct string_ *title, int cp);
int supports_html_media_attr(const unsigned char *media); int supports_html_media_attr(const unsigned char *media);

View File

@ -2509,14 +2509,14 @@ ret:
void void
render_html_document(struct cache_entry *cached, struct document *document, render_html_document(struct cache_entry *cached, struct document *document,
struct string *buffer) struct string_ *buffer)
{ {
struct html_context *html_context; struct html_context *html_context;
struct part *part; struct part *part;
unsigned char *start; unsigned char *start;
unsigned char *end; unsigned char *end;
struct string title; struct string_ title;
struct string head; struct string_ head;
assert(cached && document); assert(cached && document);
if_assert_failed return; if_assert_failed return;

View File

@ -7,10 +7,10 @@
struct el_box; struct el_box;
struct cache_entry; struct cache_entry;
struct html_context; struct html_context;
struct string; struct string_;
void render_html_document(struct cache_entry *cached, struct document *document, struct string *buffer); void render_html_document(struct cache_entry *cached, struct document *document, struct string_ *buffer);
/* Interface with parser.c */ /* Interface with parser.c */

View File

@ -35,8 +35,8 @@
#include <dom/bindings/hubbub/parser.h> #include <dom/bindings/hubbub/parser.h>
struct source_renderer { struct source_renderer {
struct string tmp_buffer; struct string_ tmp_buffer;
struct string *source; struct string_ *source;
char *enc; char *enc;
}; };
@ -378,7 +378,7 @@ libdom_main(struct source_renderer *renderer)
void void
render_source_document(struct cache_entry *cached, struct document *document, render_source_document(struct cache_entry *cached, struct document *document,
struct string *buffer) struct string_ *buffer)
{ {
struct source_renderer renderer; struct source_renderer renderer;
unsigned char *head = empty_string_or_(cached->head); unsigned char *head = empty_string_or_(cached->head);

View File

@ -4,8 +4,8 @@
struct cache_entry; struct cache_entry;
struct document; struct document;
struct string; struct string_;
void render_source_document(struct cache_entry *cached, struct document *document, struct string *buffer); void render_source_document(struct cache_entry *cached, struct document *document, struct string_ *buffer);
#endif #endif

View File

@ -705,7 +705,7 @@ add_document_lines(struct plain_renderer *renderer)
void void
render_plain_document(struct cache_entry *cached, struct document *document, render_plain_document(struct cache_entry *cached, struct document *document,
struct string *buffer) struct string_ *buffer)
{ {
struct conv_table *convert_table; struct conv_table *convert_table;
unsigned char *head = empty_string_or_(cached->head); unsigned char *head = empty_string_or_(cached->head);

View File

@ -4,8 +4,8 @@
struct cache_entry; struct cache_entry;
struct document; struct document;
struct string; struct string_;
void render_plain_document(struct cache_entry *cached, struct document *document, struct string *buffer); void render_plain_document(struct cache_entry *cached, struct document *document, struct string_ *buffer);
#endif #endif

View File

@ -122,7 +122,7 @@ process_snippets(struct ecmascript_interpreter *interpreter,
*current = snippets->next; *current = snippets->next;
for (; *current != (struct string_list_item *) snippets; for (; *current != (struct string_list_item *) snippets;
(*current) = (*current)->next) { (*current) = (*current)->next) {
struct string *string = &(*current)->string; struct string_ *string = &(*current)->string;
unsigned char *uristring; unsigned char *uristring;
struct uri *uri; struct uri *uri;
struct cache_entry *cached; struct cache_entry *cached;
@ -196,7 +196,7 @@ process_snippets(struct ecmascript_interpreter *interpreter,
fragment = get_cache_fragment(cached); fragment = get_cache_fragment(cached);
if (fragment) { if (fragment) {
struct string code = INIT_STRING(fragment->data, fragment->length); struct string_ code = INIT_STRING(fragment->data, fragment->length);
ecmascript_eval(interpreter, &code, NULL); ecmascript_eval(interpreter, &code, NULL);
} }
@ -210,7 +210,7 @@ render_encoded_document(struct cache_entry *cached, struct document *document)
struct uri *uri = cached->uri; struct uri *uri = cached->uri;
enum stream_encoding encoding = ENCODING_NONE; enum stream_encoding encoding = ENCODING_NONE;
struct fragment *fragment = get_cache_fragment(cached); struct fragment *fragment = get_cache_fragment(cached);
struct string buffer = INIT_STRING("", 0); struct string_ buffer = INIT_STRING("", 0);
/* Even empty documents have to be rendered so that info in the protocol /* Even empty documents have to be rendered so that info in the protocol
* header, such as refresh info, get processed. (bug 625) */ * header, such as refresh info, get processed. (bug 625) */

View File

@ -451,7 +451,7 @@ walk_dom_nodes(struct dom_stack *stack, struct dom_node *root)
static inline unsigned char * static inline unsigned char *
compress_string(unsigned char *string, unsigned int length) compress_string(unsigned char *string, unsigned int length)
{ {
struct string buffer; struct string_ buffer;
unsigned char escape[2] = "\\"; unsigned char escape[2] = "\\";
if (!init_string(&buffer)) return NULL; if (!init_string(&buffer)) return NULL;

View File

@ -127,7 +127,7 @@ ecmascript_get_interpreter_count(void)
void void
ecmascript_eval(struct ecmascript_interpreter *interpreter, ecmascript_eval(struct ecmascript_interpreter *interpreter,
struct string *code, struct string *ret) struct string_ *code, struct string_ *ret)
{ {
if (!get_ecmascript_enable()) if (!get_ecmascript_enable())
return; return;
@ -139,7 +139,7 @@ ecmascript_eval(struct ecmascript_interpreter *interpreter,
unsigned char * unsigned char *
ecmascript_eval_stringback(struct ecmascript_interpreter *interpreter, ecmascript_eval_stringback(struct ecmascript_interpreter *interpreter,
struct string *code) struct string_ *code)
{ {
unsigned char *result; unsigned char *result;
@ -154,7 +154,7 @@ ecmascript_eval_stringback(struct ecmascript_interpreter *interpreter,
int int
ecmascript_eval_boolback(struct ecmascript_interpreter *interpreter, ecmascript_eval_boolback(struct ecmascript_interpreter *interpreter,
struct string *code) struct string_ *code)
{ {
int result; int result;
@ -211,7 +211,7 @@ void
ecmascript_protocol_handler(struct session *ses, struct uri *uri) ecmascript_protocol_handler(struct session *ses, struct uri *uri)
{ {
struct document_view *doc_view = current_frame(ses); struct document_view *doc_view = current_frame(ses);
struct string current_url = INIT_STRING(struri(uri), strlen(struri(uri))); struct string_ current_url = INIT_STRING(struri(uri), strlen(struri(uri)));
unsigned char *redirect_url, *redirect_abs_url; unsigned char *redirect_url, *redirect_abs_url;
struct uri *redirect_uri; struct uri *redirect_uri;

View File

@ -10,7 +10,7 @@
struct form_state; struct form_state;
struct form_view; struct form_view;
struct string; struct string_;
struct terminal; struct terminal;
struct uri; struct uri;
struct view_state; struct view_state;
@ -27,10 +27,10 @@ struct ecmascript_interpreter {
int backend_nesting; int backend_nesting;
/* Used by document.write() */ /* Used by document.write() */
struct string *ret; struct string_ *ret;
/* The code evaluated by setTimeout() */ /* The code evaluated by setTimeout() */
struct string code; struct string_ code;
#if defined(CONFIG_ECMASCRIPT_SMJS_HEARTBEAT) #if defined(CONFIG_ECMASCRIPT_SMJS_HEARTBEAT)
struct heartbeat *heartbeat; struct heartbeat *heartbeat;
@ -83,10 +83,10 @@ void ecmascript_moved_form_state(struct form_state *fs);
void ecmascript_reset_state(struct view_state *vs); void ecmascript_reset_state(struct view_state *vs);
void ecmascript_eval(struct ecmascript_interpreter *interpreter, struct string *code, struct string *ret); void ecmascript_eval(struct ecmascript_interpreter *interpreter, struct string_ *code, struct string_ *ret);
unsigned char *ecmascript_eval_stringback(struct ecmascript_interpreter *interpreter, struct string *code); unsigned char *ecmascript_eval_stringback(struct ecmascript_interpreter *interpreter, struct string_ *code);
/* Returns -1 if undefined. */ /* Returns -1 if undefined. */
int ecmascript_eval_boolback(struct ecmascript_interpreter *interpreter, struct string *code); int ecmascript_eval_boolback(struct ecmascript_interpreter *interpreter, struct string_ *code);
/* Takes line with the syntax javascript:<ecmascript code>. Activated when user /* Takes line with the syntax javascript:<ecmascript code>. Activated when user
* follows a link with this synstax. */ * follows a link with this synstax. */

View File

@ -87,7 +87,8 @@ jsid_to_string(JSContext *ctx, jsid *id)
return jsval_to_string(ctx, &v); return jsval_to_string(ctx, &v);
} }
#define ELINKS_CAST_PROP_PARAMS JSObject *obj = *(hobj._); \ #define ELINKS_CAST_PROP_PARAMS JSObject *obj = (hobj); \
jsval *vp = (hvp._); jsval vp2 = (hvp); \
jsval *vp = &vp2;
#endif #endif

View File

@ -66,7 +66,7 @@ error_reporter(JSContext *ctx, const char *message, JSErrorReport *report)
struct session *ses = interpreter->vs->doc_view->session; struct session *ses = interpreter->vs->doc_view->session;
struct terminal *term; struct terminal *term;
unsigned char *strict, *exception, *warning, *error; unsigned char *strict, *exception, *warning, *error;
struct string msg; struct string_ msg;
assert(interpreter && interpreter->vs && interpreter->vs->doc_view assert(interpreter && interpreter->vs && interpreter->vs->doc_view
&& ses && ses->tab); && ses && ses->tab);
@ -277,7 +277,7 @@ spidermonkey_put_interpreter(struct ecmascript_interpreter *interpreter)
void void
spidermonkey_eval(struct ecmascript_interpreter *interpreter, spidermonkey_eval(struct ecmascript_interpreter *interpreter,
struct string *code, struct string *ret) struct string_ *code, struct string_ *ret)
{ {
JSContext *ctx; JSContext *ctx;
jsval rval; jsval rval;
@ -305,7 +305,7 @@ spidermonkey_eval(struct ecmascript_interpreter *interpreter,
unsigned char * unsigned char *
spidermonkey_eval_stringback(struct ecmascript_interpreter *interpreter, spidermonkey_eval_stringback(struct ecmascript_interpreter *interpreter,
struct string *code) struct string_ *code)
{ {
JSBool ret; JSBool ret;
JSContext *ctx; JSContext *ctx;
@ -340,7 +340,7 @@ spidermonkey_eval_stringback(struct ecmascript_interpreter *interpreter,
int int
spidermonkey_eval_boolback(struct ecmascript_interpreter *interpreter, spidermonkey_eval_boolback(struct ecmascript_interpreter *interpreter,
struct string *code) struct string_ *code)
{ {
JSContext *ctx; JSContext *ctx;
JSFunction *fun; JSFunction *fun;

View File

@ -4,7 +4,7 @@
struct ecmascript_interpreter; struct ecmascript_interpreter;
struct form_view; struct form_view;
struct form_state; struct form_state;
struct string; struct string_;
void *spidermonkey_get_interpreter(struct ecmascript_interpreter *interpreter); void *spidermonkey_get_interpreter(struct ecmascript_interpreter *interpreter);
void spidermonkey_put_interpreter(struct ecmascript_interpreter *interpreter); void spidermonkey_put_interpreter(struct ecmascript_interpreter *interpreter);
@ -13,9 +13,9 @@ void spidermonkey_detach_form_view(struct form_view *fv);
void spidermonkey_detach_form_state(struct form_state *fs); void spidermonkey_detach_form_state(struct form_state *fs);
void spidermonkey_moved_form_state(struct form_state *fs); void spidermonkey_moved_form_state(struct form_state *fs);
void spidermonkey_eval(struct ecmascript_interpreter *interpreter, struct string *code, struct string *ret); void spidermonkey_eval(struct ecmascript_interpreter *interpreter, struct string_ *code, struct string_ *ret);
unsigned char *spidermonkey_eval_stringback(struct ecmascript_interpreter *interpreter, struct string *code); unsigned char *spidermonkey_eval_stringback(struct ecmascript_interpreter *interpreter, struct string_ *code);
int spidermonkey_eval_boolback(struct ecmascript_interpreter *interpreter, struct string *code); int spidermonkey_eval_boolback(struct ecmascript_interpreter *interpreter, struct string_ *code);
extern struct module spidermonkey_module; extern struct module spidermonkey_module;
#endif #endif

View File

@ -66,7 +66,7 @@ document_get_property_cookie(JSContext *ctx, JSHandleObject hobj, JSHandleId hid
JSObject *parent_win; /* instance of @window_class */ JSObject *parent_win; /* instance of @window_class */
struct view_state *vs; struct view_state *vs;
struct string *cookies; struct string_ *cookies;
JSClass* classPtr = JS_GetClass(obj); JSClass* classPtr = JS_GetClass(obj);
if (classPtr != &document_class) if (classPtr != &document_class)
@ -350,7 +350,7 @@ static JSBool
document_get_property(JSContext *ctx, JSHandleObject hobj, JSHandleId hid, JSMutableHandleValue hvp) document_get_property(JSContext *ctx, JSHandleObject hobj, JSHandleId hid, JSMutableHandleValue hvp)
{ {
ELINKS_CAST_PROP_PARAMS ELINKS_CAST_PROP_PARAMS
jsid id = *(hid._); jsid id = (hid);
JSObject *parent_win; /* instance of @window_class */ JSObject *parent_win; /* instance of @window_class */
struct view_state *vs; struct view_state *vs;
@ -399,7 +399,7 @@ document_write_do(JSContext *ctx, unsigned int argc, jsval *rval, int newline)
{ {
jsval val; jsval val;
struct ecmascript_interpreter *interpreter = JS_GetContextPrivate(ctx); struct ecmascript_interpreter *interpreter = JS_GetContextPrivate(ctx);
struct string *ret = interpreter->ret; struct string_ *ret = interpreter->ret;
jsval *argv = JS_ARGV(ctx, rval); jsval *argv = JS_ARGV(ctx, rval);
if (argc >= 1 && ret) { if (argc >= 1 && ret) {

View File

@ -46,10 +46,6 @@
#include "viewer/text/link.h" #include "viewer/text/link.h"
#include "viewer/text/vs.h" #include "viewer/text/vs.h"
static JSClass form_class; /* defined below */
/* Accordingly to the JS specs, each input type should own object. That'd be a /* Accordingly to the JS specs, each input type should own object. That'd be a
* huge PITA though, however DOM comes to the rescue and defines just a single * huge PITA though, however DOM comes to the rescue and defines just a single
* HTMLInputElement. The difference could be spotted only by some clever tricky * HTMLInputElement. The difference could be spotted only by some clever tricky
@ -1393,7 +1389,7 @@ static JSBool
input_get_property(JSContext *ctx, JSHandleObject hobj, JSHandleId hid, JSMutableHandleValue hvp) input_get_property(JSContext *ctx, JSHandleObject hobj, JSHandleId hid, JSMutableHandleValue hvp)
{ {
ELINKS_CAST_PROP_PARAMS ELINKS_CAST_PROP_PARAMS
jsid id = *(hid._); jsid id = (hid);
JSObject *parent_form; /* instance of @form_class */ JSObject *parent_form; /* instance of @form_class */
JSObject *parent_doc; /* instance of @document_class */ JSObject *parent_doc; /* instance of @document_class */
@ -1550,7 +1546,7 @@ static JSBool
input_set_property(JSContext *ctx, JSHandleObject hobj, JSHandleId hid, JSBool strict, JSMutableHandleValue hvp) input_set_property(JSContext *ctx, JSHandleObject hobj, JSHandleId hid, JSBool strict, JSMutableHandleValue hvp)
{ {
ELINKS_CAST_PROP_PARAMS ELINKS_CAST_PROP_PARAMS
jsid id = *(hid._); jsid id = (hid);
JSObject *parent_form; /* instance of @form_class */ JSObject *parent_form; /* instance of @form_class */
JSObject *parent_doc; /* instance of @document_class */ JSObject *parent_doc; /* instance of @document_class */
@ -1957,7 +1953,7 @@ static JSBool
form_elements_get_property(JSContext *ctx, JSHandleObject hobj, JSHandleId hid, JSMutableHandleValue hvp) form_elements_get_property(JSContext *ctx, JSHandleObject hobj, JSHandleId hid, JSMutableHandleValue hvp)
{ {
ELINKS_CAST_PROP_PARAMS ELINKS_CAST_PROP_PARAMS
jsid id = *(hid._); jsid id = (hid);
jsval idval; jsval idval;
JSObject *parent_form; /* instance of @form_class */ JSObject *parent_form; /* instance of @form_class */
@ -2285,7 +2281,7 @@ static JSBool
form_get_property(JSContext *ctx, JSHandleObject hobj, JSHandleId hid, JSMutableHandleValue hvp) form_get_property(JSContext *ctx, JSHandleObject hobj, JSHandleId hid, JSMutableHandleValue hvp)
{ {
ELINKS_CAST_PROP_PARAMS ELINKS_CAST_PROP_PARAMS
jsid id = *(hid._); jsid id = (hid);
/* DBG("doc %p %s\n", parent_doc, JS_GetStringBytes(JS_ValueToString(ctx, OBJECT_TO_JSVAL(parent_doc)))); */ /* DBG("doc %p %s\n", parent_doc, JS_GetStringBytes(JS_ValueToString(ctx, OBJECT_TO_JSVAL(parent_doc)))); */
JSObject *parent_doc; /* instance of @document_class */ JSObject *parent_doc; /* instance of @document_class */
JSObject *parent_win; /* instance of @window_class */ JSObject *parent_win; /* instance of @window_class */
@ -3124,7 +3120,7 @@ static JSBool
forms_get_property(JSContext *ctx, JSHandleObject hobj, JSHandleId hid, JSMutableHandleValue hvp) forms_get_property(JSContext *ctx, JSHandleObject hobj, JSHandleId hid, JSMutableHandleValue hvp)
{ {
ELINKS_CAST_PROP_PARAMS ELINKS_CAST_PROP_PARAMS
jsid id = *(hid._); jsid id = (hid);
jsval idval; jsval idval;
JSObject *parent_doc; /* instance of @document_class */ JSObject *parent_doc; /* instance of @document_class */

View File

@ -131,7 +131,7 @@ static JSBool
window_get_property(JSContext *ctx, JSHandleObject hobj, JSHandleId hid, JSMutableHandleValue hvp) window_get_property(JSContext *ctx, JSHandleObject hobj, JSHandleId hid, JSMutableHandleValue hvp)
{ {
ELINKS_CAST_PROP_PARAMS ELINKS_CAST_PROP_PARAMS
jsid id = *(hid._); jsid id = (hid);
struct view_state *vs; struct view_state *vs;

View File

@ -190,7 +190,7 @@ get_encoding_name(enum stream_encoding encoding)
/* Tries to open @prefixname with each of the supported encoding extensions /* Tries to open @prefixname with each of the supported encoding extensions
* appended. */ * appended. */
static inline enum stream_encoding static inline enum stream_encoding
try_encoding_extensions(struct string *filename, int *fd) try_encoding_extensions(struct string_ *filename, int *fd)
{ {
int length = filename->length; int length = filename->length;
int encoding; int encoding;
@ -226,7 +226,7 @@ try_encoding_extensions(struct string *filename, int *fd)
* *
* @return a connection state. S_OK if all is well. */ * @return a connection state. S_OK if all is well. */
struct connection_state struct connection_state
read_file(struct stream_encoded *stream, int readsize, struct string *page) read_file(struct stream_encoded *stream, int readsize, struct string_ *page)
{ {
if (!init_string(page)) return connection_state(S_OUT_OF_MEM); if (!init_string(page)) return connection_state(S_OUT_OF_MEM);
@ -282,7 +282,7 @@ read_file(struct stream_encoded *stream, int readsize, struct string *page)
} }
static inline int static inline int
is_stdin_pipe(struct stat *stt, struct string *filename) is_stdin_pipe(struct stat *stt, struct string_ *filename)
{ {
/* On Mac OS X, /dev/stdin has type S_IFSOCK. (bug 616) */ /* On Mac OS X, /dev/stdin has type S_IFSOCK. (bug 616) */
return !strlcmp(filename->source, filename->length, "/dev/stdin", 10) return !strlcmp(filename->source, filename->length, "/dev/stdin", 10)
@ -294,7 +294,7 @@ is_stdin_pipe(struct stat *stt, struct string *filename)
} }
struct connection_state struct connection_state
read_encoded_file(struct string *filename, struct string *page) read_encoded_file(struct string_ *filename, struct string_ *page)
{ {
struct stream_encoded *stream; struct stream_encoded *stream;
struct stat stt; struct stat stt;

View File

@ -41,9 +41,9 @@ const unsigned char *get_encoding_name(enum stream_encoding encoding);
/* Read from open @stream into the @page string */ /* Read from open @stream into the @page string */
struct connection_state struct connection_state
read_file(struct stream_encoded *stream, int readsize, struct string *page); read_file(struct stream_encoded *stream, int readsize, struct string_ *page);
/* Reads the file with the given @filename into the string @source. */ /* Reads the file with the given @filename into the string @source. */
struct connection_state read_encoded_file(struct string *filename, struct string *source); struct connection_state read_encoded_file(struct string_ *filename, struct string_ *source);
#endif #endif

View File

@ -54,7 +54,7 @@ static unsigned char *
get_formhist_data_info(struct listbox_item *item, struct terminal *term) get_formhist_data_info(struct listbox_item *item, struct terminal *term)
{ {
struct formhist_data *formhist_data = item->udata; struct formhist_data *formhist_data = item->udata;
struct string info; struct string_ info;
struct submitted_value *sv; struct submitted_value *sv;
if (item->type == BI_FOLDER) return NULL; if (item->type == BI_FOLDER) return NULL;

View File

@ -45,7 +45,7 @@ static unsigned char *
get_globhist_item_text(struct listbox_item *box_item, struct terminal *term) get_globhist_item_text(struct listbox_item *box_item, struct terminal *term)
{ {
struct global_history_item *item = box_item->udata; struct global_history_item *item = box_item->udata;
struct string info; struct string_ info;
if (get_opt_int("document.history.global.display_type", NULL) if (get_opt_int("document.history.global.display_type", NULL)
&& *item->title) && *item->title)
@ -60,7 +60,7 @@ static unsigned char *
get_globhist_item_info(struct listbox_item *box_item, struct terminal *term) get_globhist_item_info(struct listbox_item *box_item, struct terminal *term)
{ {
struct global_history_item *item = box_item->udata; struct global_history_item *item = box_item->udata;
struct string info; struct string_ info;
if (box_item->type == BI_FOLDER) return NULL; if (box_item->type == BI_FOLDER) return NULL;
if (!init_string(&info)) return NULL; if (!init_string(&info)) return NULL;

View File

@ -1085,7 +1085,7 @@ hits_cmp(const void *v1, const void *v2)
static int static int
compare_entities(const void *key_, const void *element_) compare_entities(const void *key_, const void *element_)
{ {
struct string *key = (struct string *) key_; struct string_ *key = (struct string_ *) key_;
struct entity *element = (struct entity *) element_; struct entity *element = (struct entity *) element_;
int length = key->length; int length = key->length;
unsigned char *first = key->source; unsigned char *first = key->source;
@ -1210,7 +1210,7 @@ skip:
fprintf(stderr, "%lu %016x %s\n", (unsigned long) n , n, result); fprintf(stderr, "%lu %016x %s\n", (unsigned long) n , n, result);
#endif #endif
} else { /* Text entity. */ } else { /* Text entity. */
struct string key = INIT_STRING((unsigned char *) str, strlen); struct string_ key = INIT_STRING((unsigned char *) str, strlen);
struct entity *element = bsearch((void *) &key, entities, struct entity *element = bsearch((void *) &key, entities,
N_ENTITIES, N_ENTITIES,
sizeof(*element), sizeof(*element),

View File

@ -213,8 +213,8 @@ _nl_free_domain_conv(struct loaded_domain *domain)
/* This is hacked for ELinks - we want to look up for the translations at the /* This is hacked for ELinks - we want to look up for the translations at the
* correct place even if we are being ran from the source/build tree. */ * correct place even if we are being ran from the source/build tree. */
static struct string * static struct string_ *
add_filename_to_string(struct string *str, struct loaded_l10nfile *domain_file) add_filename_to_string(struct string_ *str, struct loaded_l10nfile *domain_file)
{ {
unsigned char *slash = strrchr((const char *)program.path, '/'); unsigned char *slash = strrchr((const char *)program.path, '/');
size_t dirnamelen = (slash ? slash - program.path + 1 : 0); size_t dirnamelen = (slash ? slash - program.path + 1 : 0);
@ -257,7 +257,7 @@ _nl_load_domain(struct loaded_l10nfile *domain_file,
a call to bind_textdomain_codeset). */ a call to bind_textdomain_codeset). */
{ {
struct string filename; struct string_ filename;
if (init_string(&filename) if (init_string(&filename)
&& add_filename_to_string(&filename, domain_file)) { && add_filename_to_string(&filename, domain_file)) {

View File

@ -2454,7 +2454,7 @@ static const struct { unicode_val_T x; unsigned char *s; } unicode_7b [2453] = {
{0x0000ff62, "\""}, {0x0000ff62, "\""},
{0x0000ff63, "\""}, {0x0000ff63, "\""},
{0x0000ff64, ","}, {0x0000ff64, ","},
{-1, NULL} {0xffffffff, NULL}
}; };
#define N_UNICODE_7B 2452 #define N_UNICODE_7B 2452

View File

@ -111,7 +111,7 @@ enum addr_type {
* to free anything). * to free anything).
* It returns 1 on success. */ * It returns 1 on success. */
static int static int
get_sun_path(struct string *sun_path) get_sun_path(struct string_ *sun_path)
{ {
assert(sun_path); assert(sun_path);
if_assert_failed return 0; if_assert_failed return 0;
@ -134,7 +134,7 @@ get_address(struct socket_info *info, enum addr_type type)
{ {
struct sockaddr_un *addr = NULL; struct sockaddr_un *addr = NULL;
int sun_path_freespace; int sun_path_freespace;
struct string path; struct string_ path;
assert(info); assert(info);
if_assert_failed return -1; if_assert_failed return -1;

View File

@ -219,7 +219,7 @@ init(void)
program.retval = RET_REMOTE; program.retval = RET_REMOTE;
} else { } else {
struct string info; struct string_ info;
struct terminal *term = NULL; struct terminal *term = NULL;
if (!encode_session_info(&info, &url_list)) { if (!encode_session_info(&info, &url_list)) {

View File

@ -27,7 +27,7 @@ extern int event_enabled;
#endif #endif
static void static void
add_module_to_string(struct string *string, struct module *module, add_module_to_string(struct string_ *string, struct module *module,
struct terminal *term) struct terminal *term)
{ {
struct module *submodule; struct module *submodule;
@ -48,7 +48,7 @@ add_module_to_string(struct string *string, struct module *module,
} }
static void static void
add_modules_to_string(struct string *string, struct terminal *term) add_modules_to_string(struct string_ *string, struct terminal *term)
{ {
struct module *module; struct module *module;
int i; int i;
@ -62,7 +62,7 @@ add_modules_to_string(struct string *string, struct terminal *term)
/* Wrap string on spaces starting at position @start_at, trying /* Wrap string on spaces starting at position @start_at, trying
* to keep lines undex @maxlen length */ * to keep lines undex @maxlen length */
static void static void
wrap_string(struct string *string, int start_at, int maxlen) wrap_string(struct string_ *string, int start_at, int maxlen)
{ {
unsigned char *pos, *start_pos; unsigned char *pos, *start_pos;
unsigned char *last_pos = NULL; unsigned char *last_pos = NULL;
@ -92,7 +92,7 @@ unsigned char *
get_dyn_full_version(struct terminal *term, int more) get_dyn_full_version(struct terminal *term, int more)
{ {
static const unsigned char comma[] = ", "; static const unsigned char comma[] = ", ";
struct string string; struct string_ string;
if (!init_string(&string)) return NULL; if (!init_string(&string)) return NULL;

View File

@ -151,7 +151,7 @@ static struct option *
get_mime_type_option(unsigned char *type) get_mime_type_option(unsigned char *type)
{ {
struct option *opt; struct option *opt;
struct string name; struct string_ name;
opt = get_opt_rec_real(config_options, "mime.type"); opt = get_opt_rec_real(config_options, "mime.type");
if (!opt) return NULL; if (!opt) return NULL;

View File

@ -499,7 +499,7 @@ init_mailcap(struct module *module)
static unsigned char * static unsigned char *
format_command(unsigned char *command, unsigned char *type, int copiousoutput) format_command(unsigned char *command, unsigned char *type, int copiousoutput)
{ {
struct string cmd; struct string_ cmd;
if (!init_string(&cmd)) return NULL; if (!init_string(&cmd)) return NULL;

View File

@ -24,7 +24,7 @@ static struct option *
get_real_opt(unsigned char *base, unsigned char *id) get_real_opt(unsigned char *base, unsigned char *id)
{ {
struct option *opt = get_opt_rec_real(config_options, base); struct option *opt = get_opt_rec_real(config_options, base);
struct string translated; struct string_ translated;
assert(opt); assert(opt);
@ -82,7 +82,7 @@ static void
add_mime_extension(void *data) add_mime_extension(void *data)
{ {
struct extension *ext = data; struct extension *ext = data;
struct string name; struct string_ name;
if (!ext || !init_string(&name)) return; if (!ext || !init_string(&name)) return;
@ -152,7 +152,7 @@ menu_list_ext(struct terminal *term, void *fn_, void *xxx)
struct menu_item *mi = NULL; struct menu_item *mi = NULL;
foreachback (opt, *opt_tree) { foreachback (opt, *opt_tree) {
struct string translated; struct string_ translated;
unsigned char *translated2; unsigned char *translated2;
unsigned char *optptr2; unsigned char *optptr2;

View File

@ -328,8 +328,8 @@ get_mime_type_handler(unsigned char *content_type, int xwin)
return get_mime_handler_backends(content_type, xwin); return get_mime_handler_backends(content_type, xwin);
} }
struct string * struct string_ *
add_mime_filename_to_string(struct string *string, struct uri *uri) add_mime_filename_to_string(struct string_ *string, struct uri *uri)
{ {
unsigned char *filename = get_content_filename(uri, NULL); unsigned char *filename = get_content_filename(uri, NULL);

View File

@ -31,6 +31,6 @@ get_mime_type_handler(unsigned char *content_type, int xwin);
/* Extracts strictly the filename part (the crap between path and query) and /* Extracts strictly the filename part (the crap between path and query) and
* adds it to the @string. Note that there are cases where the string will be * adds it to the @string. Note that there are cases where the string will be
* empty ("") (ie. http://example.com/?crash=elinks). */ * empty ("") (ie. http://example.com/?crash=elinks). */
struct string *add_mime_filename_to_string(struct string *string, struct uri *uri); struct string_ *add_mime_filename_to_string(struct string_ *string, struct uri *uri);
#endif #endif

View File

@ -442,7 +442,7 @@ unsigned char *
get_ssl_connection_cipher(struct socket *socket) get_ssl_connection_cipher(struct socket *socket)
{ {
ssl_t *ssl = socket->ssl; ssl_t *ssl = socket->ssl;
struct string str; struct string_ str;
if (!init_string(&str)) return NULL; if (!init_string(&str)) return NULL;

View File

@ -48,8 +48,8 @@ main(void)
const struct match_hostname_pattern_test_case *test; const struct match_hostname_pattern_test_case *test;
int count_ok = 0; int count_ok = 0;
int count_fail = 0; int count_fail = 0;
struct string hostname_str = NULL_STRING; struct string_ hostname_str = NULL_STRING;
struct string pattern_str = NULL_STRING; struct string_ pattern_str = NULL_STRING;
if (!init_string(&hostname_str) || !init_string(&pattern_str)) { if (!init_string(&hostname_str) || !init_string(&pattern_str)) {
fputs("Out of memory.\n", stderr); fputs("Out of memory.\n", stderr);

View File

@ -93,8 +93,12 @@ safe_write(int fd, const void *buf, size_t count) {
#endif #endif
/* Alignment of types. */ /* Alignment of types. */
#define alignof(TYPE) \ #define alignof(TYPE) 1
#if 0
offsetof(struct { unsigned char dummy1; TYPE dummy2; }, dummy2) offsetof(struct { unsigned char dummy1; TYPE dummy2; }, dummy2)
#endif
/* Using this macro to copy structs is both faster and safer than /* Using this macro to copy structs is both faster and safer than
* memcpy(destination, source, sizeof(source)). Please, use this macro instead * memcpy(destination, source, sizeof(source)). Please, use this macro instead

View File

@ -368,7 +368,7 @@ get_clipboard_text(void)
#if 0 #if 0
/* GNU Screen's clipboard */ /* GNU Screen's clipboard */
if (is_gnuscreen()) { if (is_gnuscreen()) {
struct string str; struct string_ str;
if (!init_string(&str)) return NULL; if (!init_string(&str)) return NULL;
@ -386,7 +386,7 @@ set_clipboard_text(unsigned char *data)
{ {
/* GNU Screen's clipboard */ /* GNU Screen's clipboard */
if (is_gnuscreen()) { if (is_gnuscreen()) {
struct string str; struct string_ str;
if (!init_string(&str)) return; if (!init_string(&str)) return;
@ -406,7 +406,7 @@ set_clipboard_text(unsigned char *data)
void void
set_window_title(unsigned char *title, int codepage) set_window_title(unsigned char *title, int codepage)
{ {
struct string filtered; struct string_ filtered;
#ifndef HAVE_SYS_CYGWIN_H #ifndef HAVE_SYS_CYGWIN_H
/* Check if we're in a xterm-like terminal. */ /* Check if we're in a xterm-like terminal. */

View File

@ -199,7 +199,7 @@ static unsigned char *
get_auth_entry_info(struct listbox_item *item, struct terminal *term) get_auth_entry_info(struct listbox_item *item, struct terminal *term)
{ {
struct auth_entry *auth_entry = item->udata; struct auth_entry *auth_entry = item->udata;
struct string info; struct string_ info;
if (item->type == BI_FOLDER) return NULL; if (item->type == BI_FOLDER) return NULL;
if (!init_string(&info)) return NULL; if (!init_string(&info)) return NULL;

View File

@ -136,7 +136,7 @@ init_response_digest(md5_digest_hex_T response, struct auth_entry *entry,
unsigned char * unsigned char *
get_http_auth_digest_response(struct auth_entry *entry, struct uri *uri) get_http_auth_digest_response(struct auth_entry *entry, struct uri *uri)
{ {
struct string string; struct string_ string;
md5_digest_hex_T cnonce; md5_digest_hex_T cnonce;
md5_digest_hex_T response; md5_digest_hex_T response;

View File

@ -359,7 +359,7 @@ static unsigned char *
normalize_bencoding_path(const unsigned char *path, int pathlen, normalize_bencoding_path(const unsigned char *path, int pathlen,
int *malicious) int *malicious)
{ {
struct string string; struct string_ string;
/* Normalize and check for malicious paths in the the file list. */ /* Normalize and check for malicious paths in the the file list. */
@ -431,7 +431,7 @@ add_bittorrent_file(struct bittorrent_meta *meta, unsigned char *path,
/* Parses a list of path elements and adds them each to the path string /* Parses a list of path elements and adds them each to the path string
* separated by the platform specific directory separater. */ * separated by the platform specific directory separater. */
static enum bittorrent_state static enum bittorrent_state
parse_bencoding_file_path(struct scanner *scanner, struct string *path) parse_bencoding_file_path(struct scanner *scanner, struct string_ *path)
{ {
assert(get_scanner_token(scanner)->type == BENCODING_TOKEN_LIST); assert(get_scanner_token(scanner)->type == BENCODING_TOKEN_LIST);
@ -468,7 +468,7 @@ parse_bencoding_file_path(struct scanner *scanner, struct string *path)
/* Parse a dictionary of file information used for multi-file torrents. */ /* Parse a dictionary of file information used for multi-file torrents. */
static enum bittorrent_state static enum bittorrent_state
parse_bencoding_file_dictionary(struct bittorrent_meta *meta, parse_bencoding_file_dictionary(struct bittorrent_meta *meta,
struct scanner *scanner, struct string *path) struct scanner *scanner, struct string_ *path)
{ {
struct bittorrent_file file; struct bittorrent_file file;
@ -529,7 +529,7 @@ parse_bencoding_files_list(struct bittorrent_meta *meta, struct scanner *scanner
while (scanner_has_tokens(scanner)) { while (scanner_has_tokens(scanner)) {
struct scanner_token *token = get_scanner_token(scanner); struct scanner_token *token = get_scanner_token(scanner);
struct string path; struct string_ path;
enum bittorrent_state state; enum bittorrent_state state;
if (!token) break; if (!token) break;

View File

@ -231,6 +231,8 @@ struct bittorrent_file {
unsigned char name[1]; /**< Filename converted from path list. */ unsigned char name[1]; /**< Filename converted from path list. */
}; };
enum type_ { BITTORRENT_SINGLE_FILE, BITTORRENT_MULTI_FILE };
/** Static information from the .torrent metafile. */ /** Static information from the .torrent metafile. */
struct bittorrent_meta { struct bittorrent_meta {
/** The SHA1 info hash of the value of the info key from the metainfo /** The SHA1 info hash of the value of the info key from the metainfo
@ -260,7 +262,7 @@ struct bittorrent_meta {
unsigned char *piece_hash; unsigned char *piece_hash;
/** The type of the torrent. */ /** The type of the torrent. */
enum { BITTORRENT_SINGLE_FILE, BITTORRENT_MULTI_FILE } type; enum type_ type;
/** Potential bad file path detected. */ /** Potential bad file path detected. */
unsigned int malicious_paths:1; unsigned int malicious_paths:1;

View File

@ -60,7 +60,7 @@ init_bittorrent_download_info(struct bittorrent_meta *meta)
} }
foreach (file, meta->files) { foreach (file, meta->files) {
struct string string; struct string_ string;
int spaces; int spaces;
if (!init_string(&string)) if (!init_string(&string))
@ -114,7 +114,7 @@ init_bittorrent_download_info(struct bittorrent_meta *meta)
/* Add information from the meta file struct to a string. */ /* Add information from the meta file struct to a string. */
static void static void
add_bittorrent_meta_to_string(struct string *msg, struct bittorrent_meta *meta, add_bittorrent_meta_to_string(struct string_ *msg, struct bittorrent_meta *meta,
struct terminal *term, int add_files) struct terminal *term, int add_files)
{ {
if (meta->malicious_paths) { if (meta->malicious_paths) {
@ -236,7 +236,7 @@ dlg_show_bittorrent_info(struct dialog_data *dlg_data, struct widget_data *widge
{ {
struct file_download *file_download = dlg_data->dlg->udata; struct file_download *file_download = dlg_data->dlg->udata;
struct download *download = &file_download->download; struct download *download = &file_download->download;
struct string msg; struct string_ msg;
if (download->conn if (download->conn
&& download->conn->info && download->conn->info
@ -280,7 +280,7 @@ get_bittorrent_message(struct download *download, struct terminal *term,
}; };
struct bittorrent_connection *bittorrent; struct bittorrent_connection *bittorrent;
struct bittorrent_peer_connection *peer; struct bittorrent_peer_connection *peer;
struct string string; struct string_ string;
unsigned char *msg; unsigned char *msg;
uint32_t value; uint32_t value;
@ -565,7 +565,7 @@ void
bittorrent_message_dialog(struct session *ses, void *data) bittorrent_message_dialog(struct session *ses, void *data)
{ {
struct bittorrent_message *message = data; struct bittorrent_message *message = data;
struct string string; struct string_ string;
unsigned char *uristring; unsigned char *uristring;
/* Don't show error dialogs for missing CSS stylesheets */ /* Don't show error dialogs for missing CSS stylesheets */
@ -628,7 +628,7 @@ bittorrent_download(struct dialog_data *dlg_data, struct widget_data *widget_dat
struct bittorrent_download_info *info = dlg_data->dlg->udata; struct bittorrent_download_info *info = dlg_data->dlg->udata;
struct file_download *file_download; struct file_download *file_download;
struct session *ses = type_query->ses; struct session *ses = type_query->ses;
struct string redirect; struct string_ redirect;
struct uri *uri; struct uri *uri;
struct connection conn; struct connection conn;
@ -698,7 +698,7 @@ bittorrent_query_callback(void *data, struct connection_state state,
{ {
/* [gettext_accelerator_context(.bittorrent_query_callback)] */ /* [gettext_accelerator_context(.bittorrent_query_callback)] */
struct type_query *type_query = data; struct type_query *type_query = data;
struct string filename; struct string_ filename;
unsigned char *text; unsigned char *text;
struct dialog *dlg; struct dialog *dlg;
#define BITTORRENT_QUERY_WIDGETS_COUNT 6 #define BITTORRENT_QUERY_WIDGETS_COUNT 6
@ -709,7 +709,7 @@ bittorrent_query_callback(void *data, struct connection_state state,
struct dialog_data *dlg_data; struct dialog_data *dlg_data;
int selected_widget; int selected_widget;
struct memory_list *ml; struct memory_list *ml;
struct string msg; struct string_ msg;
int files; int files;
if (!is_in_state(state, S_OK)) if (!is_in_state(state, S_OK))

View File

@ -273,7 +273,7 @@ make_bittorrent_peer_connection(struct bittorrent_connection *bittorrent,
{ {
enum bittorrent_state result = BITTORRENT_STATE_OUT_OF_MEM; enum bittorrent_state result = BITTORRENT_STATE_OUT_OF_MEM;
struct uri *uri = NULL; struct uri *uri = NULL;
struct string uri_string = NULL_STRING; struct string_ uri_string = NULL_STRING;
struct bittorrent_peer_connection *peer; struct bittorrent_peer_connection *peer;
peer = init_bittorrent_peer_connection(-1); peer = init_bittorrent_peer_connection(-1);

View File

@ -228,7 +228,7 @@ sent_bittorrent_peer_message(struct socket *socket)
} }
static inline void static inline void
add_bittorrent_peer_integer(struct string *string, uint32_t integer) add_bittorrent_peer_integer(struct string_ *string, uint32_t integer)
{ {
uint32_t data = htonl(integer); uint32_t data = htonl(integer);
@ -242,7 +242,7 @@ do_send_bittorrent_peer_message(struct bittorrent_peer_connection *peer,
struct bittorrent_peer_request *message) struct bittorrent_peer_request *message)
{ {
struct bittorrent_connection *bittorrent = peer->bittorrent; struct bittorrent_connection *bittorrent = peer->bittorrent;
struct string string; struct string_ string;
unsigned char msgid_str[1] = { (unsigned char) message->id }; unsigned char msgid_str[1] = { (unsigned char) message->id };
uint32_t msglen = 0; uint32_t msglen = 0;

View File

@ -1175,7 +1175,7 @@ start_bittorrent_resume(struct bittorrent_connection *bittorrent,
struct bittorrent_const_string *meta) struct bittorrent_const_string *meta)
{ {
struct bittorrent_piece_cache *cache = bittorrent->cache; struct bittorrent_piece_cache *cache = bittorrent->cache;
struct string info; struct string_ info;
assert(cache && cache->resume_fd == -1); assert(cache && cache->resume_fd == -1);

View File

@ -145,7 +145,7 @@ do_send_bittorrent_tracker_request(struct connection *conn)
struct bittorrent_connection *bittorrent = conn->info; struct bittorrent_connection *bittorrent = conn->info;
int stopped = (bittorrent->tracker.event == BITTORRENT_EVENT_STOPPED); int stopped = (bittorrent->tracker.event == BITTORRENT_EVENT_STOPPED);
unsigned char *ip, *key; unsigned char *ip, *key;
struct string request; struct string_ request;
struct uri *uri = NULL; struct uri *uri = NULL;
int numwant, index, min_size; int numwant, index, min_size;

View File

@ -44,11 +44,11 @@ close_all_non_term_fd(void)
} }
struct connection_state struct connection_state
init_directory_listing(struct string *page, struct uri *uri) init_directory_listing(struct string_ *page, struct uri *uri)
{ {
struct string dirpath = NULL_STRING; struct string_ dirpath = NULL_STRING;
struct string decoded = NULL_STRING; struct string_ decoded = NULL_STRING;
struct string location = NULL_STRING; struct string_ location = NULL_STRING;
unsigned char *info; unsigned char *info;
int local = (uri->protocol == PROTOCOL_FILE); int local = (uri->protocol == PROTOCOL_FILE);

View File

@ -3,13 +3,13 @@
#include "network/state.h" #include "network/state.h"
struct string; struct string_;
struct uri; struct uri;
/* Close all non-terminal file descriptors. */ /* Close all non-terminal file descriptors. */
void close_all_non_term_fd(void); void close_all_non_term_fd(void);
struct connection_state struct connection_state
init_directory_listing(struct string *page, struct uri *uri); init_directory_listing(struct string_ *page, struct uri *uri);
#endif #endif

View File

@ -260,7 +260,7 @@ set_vars(struct connection *conn, unsigned char *script)
#ifdef CONFIG_COOKIES #ifdef CONFIG_COOKIES
{ {
struct string *cookies = send_cookies(conn->uri); struct string_ *cookies = send_cookies(conn->uri);
if (cookies) { if (cookies) {
env_set("HTTP_COOKIE", cookies->source, -1); env_set("HTTP_COOKIE", cookies->source, -1);

View File

@ -80,12 +80,12 @@ struct module file_protocol_module = struct_module(
/* Based on the @entry attributes and file-/dir-/linkname is added to the @data /* Based on the @entry attributes and file-/dir-/linkname is added to the @data
* fragment. All the strings are in the system charset. */ * fragment. All the strings are in the system charset. */
static inline void static inline void
add_dir_entry(struct directory_entry *entry, struct string *page, add_dir_entry(struct directory_entry *entry, struct string_ *page,
int pathlen, unsigned char *dircolor) int pathlen, unsigned char *dircolor)
{ {
unsigned char *lnk = NULL; unsigned char *lnk = NULL;
struct string html_encoded_name; struct string_ html_encoded_name;
struct string uri_encoded_name; struct string_ uri_encoded_name;
if (!init_string(&html_encoded_name)) return; if (!init_string(&html_encoded_name)) return;
if (!init_string(&uri_encoded_name)) { if (!init_string(&uri_encoded_name)) {
@ -150,7 +150,7 @@ add_dir_entry(struct directory_entry *entry, struct string *page,
* Finally the sorted entries are added to the @data->fragment one by one. */ * Finally the sorted entries are added to the @data->fragment one by one. */
static inline void static inline void
add_dir_entries(struct directory_entry *entries, unsigned char *dirpath, add_dir_entries(struct directory_entry *entries, unsigned char *dirpath,
struct string *page) struct string_ *page)
{ {
unsigned char dircolor[8]; unsigned char dircolor[8];
int dirpathlen = strlen(dirpath); int dirpathlen = strlen(dirpath);
@ -179,7 +179,7 @@ add_dir_entries(struct directory_entry *entries, unsigned char *dirpath,
/* Returns a connection state. S_OK if all is well. */ /* Returns a connection state. S_OK if all is well. */
static inline struct connection_state static inline struct connection_state
list_directory(struct connection *conn, unsigned char *dirpath, list_directory(struct connection *conn, unsigned char *dirpath,
struct string *page) struct string_ *page)
{ {
int show_hidden_files = get_opt_bool("protocol.file.show_hidden_files", int show_hidden_files = get_opt_bool("protocol.file.show_hidden_files",
NULL); NULL);
@ -245,7 +245,7 @@ void
file_protocol_handler(struct connection *connection) file_protocol_handler(struct connection *connection)
{ {
unsigned char *redirect_location = NULL; unsigned char *redirect_location = NULL;
struct string page, name; struct string_ page, name;
struct connection_state state; struct connection_state state;
int set_dir_content_type = 0; int set_dir_content_type = 0;

View File

@ -61,7 +61,7 @@ static void
finger_send_request(struct socket *socket) finger_send_request(struct socket *socket)
{ {
struct connection *conn = socket->conn; struct connection *conn = socket->conn;
struct string req; struct string_ req;
if (!init_string(&req)) return; if (!init_string(&req)) return;
/* add_to_string(&req, &rl, "/W"); */ /* add_to_string(&req, &rl, "/W"); */

View File

@ -121,7 +121,7 @@ compare(const void *av, const void *bv)
static void static void
display_entry(const FSP_RDENTRY *fentry, const unsigned char dircolor[]) display_entry(const FSP_RDENTRY *fentry, const unsigned char dircolor[])
{ {
struct string string; struct string_ string;
/* fentry->name is a fixed-size array and is followed by other /* fentry->name is a fixed-size array and is followed by other
* members; thus, if the name reported by the server does not * members; thus, if the name reported by the server does not
@ -199,7 +199,7 @@ sort_and_display_entries(FSP_DIR *dir, const unsigned char dircolor[])
static void static void
fsp_directory(FSP_SESSION *ses, struct uri *uri) fsp_directory(FSP_SESSION *ses, struct uri *uri)
{ {
struct string buf; struct string_ buf;
FSP_DIR *dir; FSP_DIR *dir;
unsigned char *data = get_uri_string(uri, URI_DATA); unsigned char *data = get_uri_string(uri, URI_DATA);
unsigned char dircolor[8] = ""; unsigned char dircolor[8] = "";

View File

@ -293,7 +293,7 @@ ftp_protocol_handler(struct connection *conn)
/* Send command, set connection state and free cmd string. */ /* Send command, set connection state and free cmd string. */
static void static void
send_cmd(struct connection *conn, struct string *cmd, void *callback, send_cmd(struct connection *conn, struct string_ *cmd, void *callback,
struct connection_state state) struct connection_state state)
{ {
request_from_socket(conn->socket, cmd->source, cmd->length, state, request_from_socket(conn->socket, cmd->source, cmd->length, state,
@ -341,7 +341,7 @@ static void
ftp_login(struct socket *socket) ftp_login(struct socket *socket)
{ {
struct connection *conn = socket->conn; struct connection *conn = socket->conn;
struct string cmd; struct string_ cmd;
struct auth_entry* auth; struct auth_entry* auth;
auth = find_auth(conn->uri); auth = find_auth(conn->uri);
@ -454,7 +454,7 @@ ftp_got_user_info(struct socket *socket, struct read_buffer *rb)
static void static void
ftp_pass(struct connection *conn) ftp_pass(struct connection *conn)
{ {
struct string cmd; struct string_ cmd;
struct auth_entry *auth; struct auth_entry *auth;
auth = find_auth(conn->uri); auth = find_auth(conn->uri);
@ -531,7 +531,7 @@ ftp_pass_info(struct socket *socket, struct read_buffer *rb)
/* Construct PORT command. */ /* Construct PORT command. */
static void static void
add_portcmd_to_string(struct string *string, unsigned char *pc) add_portcmd_to_string(struct string_ *string, unsigned char *pc)
{ {
/* From RFC 959: DATA PORT (PORT) /* From RFC 959: DATA PORT (PORT)
* *
@ -567,7 +567,7 @@ add_portcmd_to_string(struct string *string, unsigned char *pc)
#ifdef CONFIG_IPV6 #ifdef CONFIG_IPV6
/* Construct EPRT command. */ /* Construct EPRT command. */
static void static void
add_eprtcmd_to_string(struct string *string, struct sockaddr_in6 *addr) add_eprtcmd_to_string(struct string_ *string, struct sockaddr_in6 *addr)
{ {
unsigned char addr_str[INET6_ADDRSTRLEN]; unsigned char addr_str[INET6_ADDRSTRLEN];
@ -598,7 +598,7 @@ add_eprtcmd_to_string(struct string *string, struct sockaddr_in6 *addr)
* When PORT or EPRT are used, related sockets are created. * When PORT or EPRT are used, related sockets are created.
* It returns 0 on error (data socket creation failure). */ * It returns 0 on error (data socket creation failure). */
static int static int
get_ftp_data_socket(struct connection *conn, struct string *command) get_ftp_data_socket(struct connection *conn, struct string_ *command)
{ {
struct ftp_connection_info *ftp = conn->info; struct ftp_connection_info *ftp = conn->info;
@ -656,7 +656,7 @@ get_ftp_data_socket(struct connection *conn, struct string *command)
* FTP server. To prevent command injection attacks, this function * FTP server. To prevent command injection attacks, this function
* must reject CR LF sequences. */ * must reject CR LF sequences. */
static int static int
is_ftp_pathname_safe(const struct string *s) is_ftp_pathname_safe(const struct string_ *s)
{ {
int i; int i;
@ -681,9 +681,9 @@ add_file_cmd_to_str(struct connection *conn)
{ {
int ok = 0; int ok = 0;
struct ftp_connection_info *ftp = NULL; struct ftp_connection_info *ftp = NULL;
struct string command = NULL_STRING; struct string_ command = NULL_STRING;
struct string ftp_data_command = NULL_STRING; struct string_ ftp_data_command = NULL_STRING;
struct string pathname = NULL_STRING; struct string_ pathname = NULL_STRING;
if (!conn->uri->data) { if (!conn->uri->data) {
INTERNAL("conn->uri->data empty"); INTERNAL("conn->uri->data empty");
@ -828,7 +828,7 @@ ret:
} }
static void static void
send_it_line_by_line(struct connection *conn, struct string *cmd) send_it_line_by_line(struct connection *conn, struct string_ *cmd)
{ {
struct ftp_connection_info *ftp = conn->info; struct ftp_connection_info *ftp = conn->info;
unsigned char *nl = strchr((const char *)ftp->cmd_buffer, '\n'); unsigned char *nl = strchr((const char *)ftp->cmd_buffer, '\n');
@ -847,7 +847,7 @@ send_it_line_by_line(struct connection *conn, struct string *cmd)
static void static void
ftp_send_retr_req(struct connection *conn, struct connection_state state) ftp_send_retr_req(struct connection *conn, struct connection_state state)
{ {
struct string cmd; struct string_ cmd;
if (!init_string(&cmd)) { if (!init_string(&cmd)) {
abort_connection(conn, connection_state(S_OUT_OF_MEM)); abort_connection(conn, connection_state(S_OUT_OF_MEM));
@ -1184,7 +1184,7 @@ display_dir_entry(struct cache_entry *cached, off_t *pos, int *tries,
const struct ftp_dir_html_format *format, const struct ftp_dir_html_format *format,
struct ftp_file_info *ftp_info) struct ftp_file_info *ftp_info)
{ {
struct string string; struct string_ string;
unsigned char permissions[10] = "---------"; unsigned char permissions[10] = "---------";
if (!init_string(&string)) return -1; if (!init_string(&string)) return -1;
@ -1347,7 +1347,7 @@ ftp_add_unparsed_line(struct cache_entry *cached, off_t *pos, int *tries,
const unsigned char *line, int line_length) const unsigned char *line, int line_length)
{ {
int our_ret; int our_ret;
struct string string; struct string_ string;
int frag_ret; int frag_ret;
our_ret = -1; /* assume out of memory if returning early */ our_ret = -1; /* assume out of memory if returning early */
@ -1501,7 +1501,7 @@ out_of_mem:
} }
if (ftp->dir && !conn->from) { if (ftp->dir && !conn->from) {
struct string string; struct string_ string;
struct connection_state state; struct connection_state state;
if (!conn->uri->data) { if (!conn->uri->data) {

View File

@ -17,8 +17,8 @@ enum ftp_file_type {
/* Information about one file in a directory listing. */ /* Information about one file in a directory listing. */
struct ftp_file_info { struct ftp_file_info {
enum ftp_file_type type; /* File type */ enum ftp_file_type type; /* File type */
struct string name; /* File name */ struct string_ name; /* File name */
struct string symlink; /* Link to which file points */ struct string_ symlink; /* Link to which file points */
off_t size; /* File size. -1 if unknown. */ off_t size; /* File size. -1 if unknown. */
time_t mtime; /* Modification time */ time_t mtime; /* Modification time */
unsigned int local_time_zone:1; /* What format the mtime is in */ unsigned int local_time_zone:1; /* What format the mtime is in */

View File

@ -169,7 +169,7 @@ struct gopher_connection_info {
/* De-escape a selector into a command. */ /* De-escape a selector into a command. */
/* The % hex escapes are converted. Otherwise, the string is copied. */ /* The % hex escapes are converted. Otherwise, the string is copied. */
static void static void
add_uri_decoded(struct string *command, unsigned char *string, int length, add_uri_decoded(struct string_ *command, unsigned char *string, int length,
int replace_plus) int replace_plus)
{ {
int oldlen = command->length; int oldlen = command->length;
@ -200,7 +200,7 @@ add_uri_decoded(struct string *command, unsigned char *string, int length,
static struct connection_state init_gopher_index_cache_entry(struct connection *conn); static struct connection_state init_gopher_index_cache_entry(struct connection *conn);
static struct connection_state static struct connection_state
add_gopher_command(struct connection *conn, struct string *command, add_gopher_command(struct connection *conn, struct string_ *command,
enum gopher_entity entity, enum gopher_entity entity,
unsigned char *selector, int selectorlen) unsigned char *selector, int selectorlen)
{ {
@ -274,7 +274,7 @@ init_gopher_connection_info(struct connection *conn)
{ {
struct gopher_connection_info *gopher; struct gopher_connection_info *gopher;
struct connection_state state; struct connection_state state;
struct string command; struct string_ command;
enum gopher_entity entity = DEFAULT_GOPHER_ENTITY; enum gopher_entity entity = DEFAULT_GOPHER_ENTITY;
unsigned char *selector = conn->uri->data; unsigned char *selector = conn->uri->data;
int selectorlen = conn->uri->datalen; int selectorlen = conn->uri->datalen;
@ -344,7 +344,7 @@ init_gopher_connection_info(struct connection *conn)
*/ */
static void static void
add_gopher_link(struct string *buffer, const unsigned char *text, add_gopher_link(struct string_ *buffer, const unsigned char *text,
const unsigned char *addr) const unsigned char *addr)
{ {
add_format_to_string(buffer, "<a href=\"%s\">%s</a>", add_format_to_string(buffer, "<a href=\"%s\">%s</a>",
@ -352,7 +352,7 @@ add_gopher_link(struct string *buffer, const unsigned char *text,
} }
static void static void
add_gopher_search_field(struct string *buffer, const unsigned char *text, add_gopher_search_field(struct string_ *buffer, const unsigned char *text,
const unsigned char *addr) const unsigned char *addr)
{ {
add_format_to_string(buffer, add_format_to_string(buffer,
@ -368,7 +368,7 @@ add_gopher_search_field(struct string *buffer, const unsigned char *text,
} }
static void static void
add_gopher_description(struct string *buffer, enum gopher_entity entity) add_gopher_description(struct string_ *buffer, enum gopher_entity entity)
{ {
unsigned char *description = get_gopher_entity_description(entity); unsigned char *description = get_gopher_entity_description(entity);
@ -381,7 +381,7 @@ add_gopher_description(struct string *buffer, enum gopher_entity entity)
} }
static void static void
encode_selector_string(struct string *buffer, unsigned char *selector) encode_selector_string(struct string_ *buffer, unsigned char *selector)
{ {
unsigned char *slashes; unsigned char *slashes;
@ -399,7 +399,7 @@ encode_selector_string(struct string *buffer, unsigned char *selector)
} }
static void static void
add_gopher_menu_line(struct string *buffer, unsigned char *line) add_gopher_menu_line(struct string_ *buffer, unsigned char *line)
{ {
/* Gopher menu fields */ /* Gopher menu fields */
unsigned char *name = line; unsigned char *name = line;
@ -501,7 +501,7 @@ add_gopher_menu_line(struct string *buffer, unsigned char *line)
default: default:
{ {
struct string address; struct string_ address;
unsigned char *format = selector && *selector unsigned char *format = selector && *selector
? "%s://%s@%s/" : "%s://%s%s/"; ? "%s://%s@%s/" : "%s://%s%s/";
@ -584,7 +584,7 @@ static struct connection_state
read_gopher_directory_data(struct connection *conn, struct read_buffer *rb) read_gopher_directory_data(struct connection *conn, struct read_buffer *rb)
{ {
struct connection_state state = connection_state(S_TRANS); struct connection_state state = connection_state(S_TRANS);
struct string buffer; struct string_ buffer;
unsigned char *end; unsigned char *end;
if (conn->from == 0) { if (conn->from == 0) {
@ -654,7 +654,7 @@ static struct connection_state
init_gopher_index_cache_entry(struct connection *conn) init_gopher_index_cache_entry(struct connection *conn)
{ {
unsigned char *where; unsigned char *where;
struct string buffer; struct string_ buffer;
if (!init_gopher_cache_entry(conn) if (!init_gopher_cache_entry(conn)
|| !init_string(&buffer)) || !init_string(&buffer))

View File

@ -103,7 +103,7 @@ get_http_error_document(struct terminal *term, struct uri *uri, int code)
{ {
const unsigned char *codestr = http_code_to_string(code); const unsigned char *codestr = http_code_to_string(code);
unsigned char *title = asprintfa(_("HTTP error %03d", term), code); unsigned char *title = asprintfa(_("HTTP error %03d", term), code);
struct string string; struct string_ string;
if (!codestr) codestr = "Unknown error"; if (!codestr) codestr = "Unknown error";

View File

@ -258,7 +258,7 @@ done_http(void)
static void static void
init_accept_charset(void) init_accept_charset(void)
{ {
struct string ac; struct string_ ac;
unsigned char *cs; unsigned char *cs;
int i; int i;
@ -287,7 +287,7 @@ unsigned char *
subst_user_agent(unsigned char *fmt, unsigned char *version, subst_user_agent(unsigned char *fmt, unsigned char *version,
unsigned char *sysname, unsigned char *termsize) unsigned char *sysname, unsigned char *termsize)
{ {
struct string agent; struct string_ agent;
if (!init_string(&agent)) return NULL; if (!init_string(&agent)) return NULL;
@ -337,7 +337,7 @@ subst_user_agent(unsigned char *fmt, unsigned char *version,
} }
static void static void
add_url_to_http_string(struct string *header, struct uri *uri, int components) add_url_to_http_string(struct string_ *header, struct uri *uri, int components)
{ {
/* This block substitues spaces in URL by %20s. This is /* This block substitues spaces in URL by %20s. This is
* certainly not the right place where to do it, but now the * certainly not the right place where to do it, but now the
@ -586,7 +586,7 @@ init_http_connection_info(struct connection *conn, int major, int minor, int clo
} }
static void static void
accept_encoding_header(struct string *header) accept_encoding_header(struct string_ *header)
{ {
#if defined(CONFIG_GZIP) || defined(CONFIG_BZIP2) || defined(CONFIG_LZMA) || defined(CONFIG_BROTLI) #if defined(CONFIG_GZIP) || defined(CONFIG_BZIP2) || defined(CONFIG_LZMA) || defined(CONFIG_BROTLI)
int comma = 0; int comma = 0;
@ -658,7 +658,7 @@ http_send_header(struct socket *socket)
struct connection *conn = socket->conn; struct connection *conn = socket->conn;
struct http_connection_info *http; struct http_connection_info *http;
int trace = get_opt_bool("protocol.http.trace", NULL); int trace = get_opt_bool("protocol.http.trace", NULL);
struct string header; struct string_ header;
unsigned char *post_data = NULL; unsigned char *post_data = NULL;
struct auth_entry *entry = NULL; struct auth_entry *entry = NULL;
struct uri *uri = conn->proxied_uri; /* Set to the real uri */ struct uri *uri = conn->proxied_uri; /* Set to the real uri */
@ -1022,7 +1022,7 @@ http_send_header(struct socket *socket)
#ifdef CONFIG_COOKIES #ifdef CONFIG_COOKIES
/* CONNECT: Cookies are for the origin server only. */ /* CONNECT: Cookies are for the origin server only. */
if (!use_connect) { if (!use_connect) {
struct string *cookies = send_cookies(uri); struct string_ *cookies = send_cookies(uri);
if (cookies) { if (cookies) {
add_to_string(&header, "Cookie: "); add_to_string(&header, "Cookie: ");

View File

@ -253,7 +253,7 @@ http_negotiate_input(struct connection *conn, struct uri *uri,
* Fill output token to "Authorization: Negotiate <token>". * Fill output token to "Authorization: Negotiate <token>".
*/ */
int int
http_negotiate_output(struct uri *uri, struct string *header) http_negotiate_output(struct uri *uri, struct string_ *header)
{ {
struct negotiate *neg; struct negotiate *neg;
char *encoded = NULL; char *encoded = NULL;

View File

@ -14,7 +14,7 @@
int http_negotiate_input(struct connection *conn, struct uri *uri, int http_negotiate_input(struct connection *conn, struct uri *uri,
int type, unsigned char *data); int type, unsigned char *data);
int http_negotiate_output(struct uri *uri, struct string *header); int http_negotiate_output(struct uri *uri, struct string_ *header);
#endif /* EL_PROTOCOL_HTTP_HTTP_NEGOTIATE_H */ #endif /* EL_PROTOCOL_HTTP_HTTP_NEGOTIATE_H */

View File

@ -467,7 +467,7 @@ get_nntp_command(struct nntp_connection_info *nntp)
/* FIXME: For the beauty maybe %.*s could be used. --jonas */ /* FIXME: For the beauty maybe %.*s could be used. --jonas */
static void static void
add_nntp_command_to_string(struct string *req, struct nntp_connection_info *nntp) add_nntp_command_to_string(struct string_ *req, struct nntp_connection_info *nntp)
{ {
switch (nntp->command) { switch (nntp->command) {
case NNTP_COMMAND_GROUP: case NNTP_COMMAND_GROUP:
@ -520,7 +520,7 @@ static void
nntp_send_command(struct connection *conn) nntp_send_command(struct connection *conn)
{ {
struct nntp_connection_info *nntp = conn->info; struct nntp_connection_info *nntp = conn->info;
struct string req; struct string_ req;
nntp->command = get_nntp_command(nntp); nntp->command = get_nntp_command(nntp);
@ -580,7 +580,7 @@ news_protocol_handler(struct connection *conn)
{ {
unsigned char *protocol; unsigned char *protocol;
unsigned char *server = get_nntp_server(); unsigned char *server = get_nntp_server();
struct string location; struct string_ location;
if (!*server) server = getenv("NNTPSERVER"); if (!*server) server = getenv("NNTPSERVER");
if (!server || !*server) { if (!server || !*server) {

View File

@ -65,13 +65,13 @@ struct nntp_connection_info {
* for requesting the target. */ * for requesting the target. */
/* The <group> or undefined if target is NNTP_TARGET_GROUPS */ /* The <group> or undefined if target is NNTP_TARGET_GROUPS */
struct string group; struct string_ group;
/* Can contain either <message-id>, <article-number> or <article-range> /* Can contain either <message-id>, <article-number> or <article-range>
* or undefined if target is NTTP_TARGET_{GROUP,GROUPS}. */ * or undefined if target is NTTP_TARGET_{GROUP,GROUPS}. */
/* For <article-range> it contains start and end numbers as well as the /* For <article-range> it contains start and end numbers as well as the
* separating '-'. */ * separating '-'. */
struct string message; struct string_ message;
/* State for getting articles in a <group> or an <article-range> */ /* State for getting articles in a <group> or an <article-range> */
long current_article, end_article, articles; long current_article, end_article, articles;

Some files were not shown because too many files have changed in this diff Show More