-/* -*- c-basic-offset: 4; -*-
+/* -*- c-basic-offset: 4; -*-
* See LICENSE for license details
*
*
*/
-#define NOSPLIT ((void*)1)
-
enum {
/* statusbar symbols */
SYM_TITLE, SYM_URI, SYM_NAME,
SYM_LOADPRGS, SYM_LOADPRGSBAR,
SYM_KEYCMD, SYM_MODE, SYM_MSG,
SYM_SELECTED_URI,
- /* useragent symbols */
- SYM_WK_MAJ, SYM_WK_MIN, SYM_WK_MIC,
- SYM_SYSNAME, SYM_NODENAME,
- SYM_KERNREL, SYM_KERNVER,
- SYM_ARCHSYS, SYM_ARCHUZBL,
- SYM_DOMAINNAME, SYM_COMMIT
};
const struct {
gchar *symbol_name;
guint symbol_token;
} symbols[] = {
- {"NAME", SYM_NAME},
- {"URI", SYM_URI},
- {"TITLE", SYM_TITLE},
- {"SELECTED_URI", SYM_SELECTED_URI},
{"KEYCMD", SYM_KEYCMD},
- {"MODE", SYM_MODE},
- {"MSG", SYM_MSG},
- {"LOAD_PROGRESS", SYM_LOADPRGS},
- {"LOAD_PROGRESSBAR", SYM_LOADPRGSBAR},
-
- {"WEBKIT_MAJOR", SYM_WK_MAJ},
- {"WEBKIT_MINOR", SYM_WK_MIN},
- {"WEBKIT_MICRO", SYM_WK_MIC},
- {"SYSNAME", SYM_SYSNAME},
- {"NODENAME", SYM_NODENAME},
- {"KERNREL", SYM_KERNREL},
- {"KERNVER", SYM_KERNVER},
- {"ARCH_SYSTEM", SYM_ARCHSYS},
- {"ARCH_UZBL", SYM_ARCHUZBL},
- {"DOMAINNAME", SYM_DOMAINNAME},
- {"COMMIT", SYM_COMMIT},
+
{NULL, 0}
}, *symp = symbols;
gchar *msg;
gchar *progress_s, *progress_u;
int progress_w;
+ gchar *progress_bar;
+ gchar *mode_indicator;
} StatusBar;
/* gui elements */
typedef struct {
GtkWidget* main_window;
+ gchar* geometry;
+ GtkPlug* plug;
GtkWidget* scrolled_win;
GtkWidget* vbox;
GtkWidget* mainbar;
gchar *socket_path;
/* stores (key)"variable name" -> (value)"pointer to this var*/
GHashTable *proto_var;
+
gchar *sync_stdout;
} Communication;
typedef struct {
gchar *uri;
gchar *config_file;
- char *instance_name;
+ int socket_id;
+ char *instance_name;
gchar *selected_url;
gchar *executable_path;
- GString* keycmd;
+ gchar* keycmd;
gchar* searchtx;
- struct utsname unameinfo; /* system info */
gboolean verbose;
} State;
gchar* socket_dir;
gchar* download_handler;
gchar* cookie_handler;
+ gchar* new_window;
gboolean always_insert_mode;
gboolean show_status;
gboolean insert_mode;
gfloat zoom_level;
guint disable_plugins;
guint disable_scripts;
- guint autoload_img;
- guint autoshrink_img;
+ guint autoload_img;
+ guint autoshrink_img;
guint enable_spellcheck;
- guint enable_private;
- guint print_bg;
- gchar* style_uri;
- guint resizable_txt;
- gchar* default_encoding;
- guint enforce_96dpi;
+ guint enable_private;
+ guint print_bg;
+ gchar* style_uri;
+ guint resizable_txt;
+ gchar* default_encoding;
+ guint enforce_96dpi;
gchar *inject_html;
- guint caret_browsing;
- guint mode;
+ guint caret_browsing;
+ guint mode;
gchar* base_url;
gchar* html_endmarker;
gchar* insert_indicator;
gchar* cmd_indicator;
GString* html_buffer;
- guint html_timeout;
+ guint html_timeout;
+ gboolean print_version;
/* command list: name -> Command */
GHashTable* commands;
} Behaviour;
+/* javascript */
+typedef struct {
+ gboolean initialized;
+ JSClassDefinition classdef;
+ JSClassRef classref;
+} Javascript;
+
+/* static information */
+typedef struct {
+ int webkit_major;
+ int webkit_minor;
+ int webkit_micro;
+ gchar *arch;
+ gchar *commit;
+} Info;
/* main uzbl data structure */
typedef struct {
Network net;
Behaviour behave;
Communication comm;
+ Javascript js;
+ Info info;
Window xwin;
- GScanner *scan;
/* group bindings: key -> action */
GHashTable* bindings;
gchar* default_value;
} XDG_Var;
-XDG_Var XDG[] =
+XDG_Var XDG[] =
{
{ "XDG_CONFIG_HOME", "~/.config" },
{ "XDG_DATA_HOME", "~/.local/share" },
};
/* Functions */
-void
-setup_scanner();
-
char *
itos(int val);
set_var_value(gchar *name, gchar *val);
void
-print(WebKitWebView *page, GArray *argv);
+print(WebKitWebView *page, GArray *argv, GString *result);
gboolean
new_window_cb (WebKitWebView *web_view, WebKitWebFrame *frame, WebKitNetworkRequest *request, WebKitWebNavigationAction *navigation_action, WebKitWebPolicyDecision *policy_decision, gpointer user_data);
download_cb (WebKitWebView *web_view, GObject *download, gpointer user_data);
void
-toggle_status_cb (WebKitWebView* page, GArray *argv);
+toggle_zoom_type (WebKitWebView* page, GArray *argv, GString *result);
+
+void
+toggle_status_cb (WebKitWebView* page, GArray *argv, GString *result);
void
link_hover_cb (WebKitWebView* page, const gchar* title, const gchar* link, gpointer data);
void
-title_change_cb (WebKitWebView* web_view, WebKitWebFrame* web_frame, const gchar* title, gpointer data);
+title_change_cb (WebKitWebView* web_view, GParamSpec param_spec);
void
progress_change_cb (WebKitWebView* page, gint progress, gpointer data);
file_exists (const char * filename);
void
-toggle_insert_mode(WebKitWebView *page, GArray *argv);
+set_keycmd();
+
+void
+set_mode_indicator();
+
+void
+update_indicator();
void
-load_uri (WebKitWebView * web_view, GArray *argv);
+set_insert_mode(gboolean mode);
+
+void
+toggle_insert_mode(WebKitWebView *page, GArray *argv, GString *result);
+
+void
+load_uri (WebKitWebView * web_view, GArray *argv, GString *result);
void
new_window_load_uri (const gchar * uri);
void
-chain (WebKitWebView *page, GArray *argv);
+chain (WebKitWebView *page, GArray *argv, GString *result);
void
-keycmd (WebKitWebView *page, GArray *argv);
+keycmd (WebKitWebView *page, GArray *argv, GString *result);
void
-keycmd_nl (WebKitWebView *page, GArray *argv);
+keycmd_nl (WebKitWebView *page, GArray *argv, GString *result);
void
-keycmd_bs (WebKitWebView *page, GArray *argv);
+keycmd_bs (WebKitWebView *page, GArray *argv, GString *result);
void
-close_uzbl (WebKitWebView *page, GArray *argv);
+close_uzbl (WebKitWebView *page, GArray *argv, GString *result);
gboolean
run_command(const gchar *command, const guint npre,
const gchar **args, const gboolean sync, char **output_stdout);
+char*
+build_progressbar_ascii(int percent);
+
void
-spawn(WebKitWebView *web_view, GArray *argv);
+spawn(WebKitWebView *web_view, GArray *argv, GString *result);
void
-spawn_sh(WebKitWebView *web_view, GArray *argv);
+spawn_sh(WebKitWebView *web_view, GArray *argv, GString *result);
void
-spawn_sync(WebKitWebView *web_view, GArray *argv);
+spawn_sync(WebKitWebView *web_view, GArray *argv, GString *result);
void
-spawn_sh_sync(WebKitWebView *web_view, GArray *argv);
+spawn_sh_sync(WebKitWebView *web_view, GArray *argv, GString *result);
void
-parse_command(const char *cmd, const char *param);
+parse_command(const char *cmd, const char *param, GString *result);
void
-parse_cmd_line(const char *ctl_line);
+parse_cmd_line(const char *ctl_line, GString *result);
gchar*
build_stream_name(int type, const gchar *dir);
gboolean
control_socket(GIOChannel *chan);
+gboolean
+control_client_socket(GIOChannel *chan);
+
void
update_title (void);
void
exec_paramcmd(const Action* act, const guint i);
-GtkWidget*
+void
+initialize ();
+
+void
create_browser ();
GtkWidget*
GtkWidget*
create_window ();
+GtkPlug*
+create_plug ();
+
void
run_handler (const gchar *act, const gchar *args);
search_text (WebKitWebView *page, GArray *argv, const gboolean forward);
void
-search_forward_text (WebKitWebView *page, GArray *argv);
+search_forward_text (WebKitWebView *page, GArray *argv, GString *result);
+
+void
+search_reverse_text (WebKitWebView *page, GArray *argv, GString *result);
void
-search_reverse_text (WebKitWebView *page, GArray *argv);
+dehilight (WebKitWebView *page, GArray *argv, GString *result);
void
-dehilight (WebKitWebView *page, GArray *argv);
+run_js (WebKitWebView * web_view, GArray *argv, GString *result);
void
-run_js (WebKitWebView * web_view, GArray *argv);
+run_external_js (WebKitWebView * web_view, GArray *argv, GString *result);
void
-run_external_js (WebKitWebView * web_view, GArray *argv);
+eval_js(WebKitWebView * web_view, gchar *script, GString *result);
void handle_cookies (SoupSession *session,
SoupMessage *msg,
gpointer user_data);
void
-set_var(WebKitWebView *page, GArray *argv);
+set_var(WebKitWebView *page, GArray *argv, GString *result);
void
-act_bind(WebKitWebView *page, GArray *argv);
+act_bind(WebKitWebView *page, GArray *argv, GString *result);
void
act_dump_config();
void
dump_config();
+void
+retrieve_geometry();
+
+void
+update_gui(WebKitWebView *page, GArray *argv, GString *result);
+
+gboolean
+configure_event_cb(GtkWidget* window, GdkEventConfigure* event);
+
+typedef void (*Command)(WebKitWebView*, GArray *argv, GString *result);
+typedef struct {
+ Command function;
+ gboolean no_split;
+} CommandInfo;
/* Command callbacks */
void
cmd_cookie_handler();
void
+cmd_new_window();
+
+void
move_statusbar();
void
void
cmd_print_bg();
-void
+void
cmd_style_uri();
-void
+void
cmd_resizable_txt();
-void
+void
cmd_default_encoding();
-void
+void
cmd_enforce_96dpi();
void
cmd_inject_html();
-void
+void
cmd_caret_browsing();
+void
+cmd_set_geometry();
+
/* vi: set et ts=4: */