-/*
+/* -*- c-basic-offset: 4; -*-
+
* See LICENSE for license details
*
* Changelog:
* (c) 2009 by Robert Manea
* - introduced struct concept
* - statusbar template
- *
+ *
*/
-#define STATUS_DEFAULT "<span background=\"darkblue\" foreground=\"white\"> MODE </span> <span background=\"red\" foreground=\"white\">KEYCMD</span> (LOAD_PROGRESS%) <b>TITLE</b> - Uzbl browser"
+#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
+};
-/* statusbar symbols */
-enum { SYM_TITLE, SYM_URI, SYM_NAME,
- SYM_LOADPRGS, SYM_LOADPRGSBAR,
- SYM_KEYCMD, SYM_MODE};
const struct {
gchar *symbol_name;
guint symbol_token;
{"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;
/* status bar elements */
typedef struct {
gint load_progress;
+ gchar *msg;
+ gchar *progress_s, *progress_u;
+ int progress_w;
} StatusBar;
/* gui elements */
typedef struct {
GtkWidget* main_window;
+ GtkWidget* scrolled_win;
+ GtkWidget* vbox;
GtkWidget* mainbar;
GtkWidget* mainbar_label;
- GtkScrollbar* scbar_v; // Horizontal and Vertical Scrollbar
- GtkScrollbar* scbar_h; // (These are still hidden)
- GtkAdjustment* bar_v; // Information about document length
- GtkAdjustment* bar_h; // and scrolling position
+ GtkScrollbar* scbar_v; /* Horizontal and Vertical Scrollbar */
+ GtkScrollbar* scbar_h; /* (These are still hidden) */
+ GtkAdjustment* bar_v; /* Information about document length */
+ GtkAdjustment* bar_h; /* and scrolling position */
WebKitWebView* web_view;
gchar* main_title;
+ /* WebInspector */
+ GtkWidget *inspector_window;
+ WebKitWebInspector *inspector;
+
StatusBar sbar;
} GUI;
/* external communication*/
enum { FIFO, SOCKET};
typedef struct {
- char fifo_path[64];
- char socket_path[108];
+ gchar *fifo_path;
+ gchar *socket_path;
+ /* stores (key)"variable name" -> (value)"pointer to this var*/
+ GHashTable *proto_var;
+ /* command parsing regexes */
+ GRegex *set_regex;
+ GRegex *act_regex;
+ GRegex *keycmd_regex;
+ GRegex *get_regex;
+ GRegex *bind_regex;
+ gchar *sync_stdout;
} Communication;
typedef struct {
gchar *uri;
gchar *config_file;
- gchar *instance_name;
- gchar config_file_path[500];
- gchar selected_url[500];
- char executable_path[500];
+ char *instance_name;
+ gchar *selected_url;
+ gchar *executable_path;
GString* keycmd;
- gchar searchtx[500];
+ gchar* searchtx;
struct utsname unameinfo; /* system info */
+ gboolean verbose;
} State;
/* behaviour */
typedef struct {
+ gchar* load_finish_handler;
+ gchar* load_start_handler;
+ gchar* load_commit_handler;
gchar* status_format;
+ gchar* title_format_short;
+ gchar* title_format_long;
gchar* status_background;
gchar* history_handler;
gchar* fifo_dir;
gboolean show_status;
gboolean insert_mode;
gboolean status_top;
+ gboolean reset_command_mode;
gchar* modkey;
guint modmask;
guint http_debug;
+ gchar* shell_cmd;
+ /* WebKitWebSettings exports */
+ guint font_size;
+ guint monospace_size;
+ guint minimum_font_size;
+ gfloat zoom_level;
+ guint disable_plugins;
+ guint disable_scripts;
+ 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;
+ gchar *inject_html;
+ guint caret_browsing;
+ guint mode;
+ gchar* base_url;
+ gchar* html_endmarker;
+ GString* html_buffer;
+ guint html_timeout;
/* command list: name -> Command */
GHashTable* commands;
typedef void sigfunc(int);
+/* XDG Stuff */
+
+typedef struct {
+ gchar* environmental;
+ gchar* default_value;
+} XDG_Var;
+
+XDG_Var XDG[] =
+{
+ { "XDG_CONFIG_HOME", "~/.config" },
+ { "XDG_DATA_HOME", "~/.local/share" },
+ { "XDG_CACHE_HOME", "~/.cache" },
+ { "XDG_CONFIG_DIRS", "/etc/xdg" },
+ { "XDG_DATA_DIRS", "/usr/local/share/:/usr/share/" },
+};
+
/* Functions */
static void
setup_scanner();
char *
itos(int val);
+static char *
+str_replace (const char* search, const char* replace, const char* string);
+
+static GArray*
+read_file_by_line (gchar *path);
+
+static
+gchar* parseenv (char* string);
+
static void
clean_up(void);
setup_signal(int signe, sigfunc *shandler);
static gboolean
+set_var_value(gchar *name, gchar *val);
+
+static gboolean
new_window_cb (WebKitWebView *web_view, WebKitWebFrame *frame, WebKitNetworkRequest *request, WebKitWebNavigationAction *navigation_action, WebKitWebPolicyDecision *policy_decision, gpointer user_data);
WebKitWebView*
download_cb (WebKitWebView *web_view, GObject *download, gpointer user_data);
static void
-toggle_status_cb (WebKitWebView* page, const char *param);
+toggle_status_cb (WebKitWebView* page, GArray *argv);
static void
link_hover_cb (WebKitWebView* page, const gchar* title, const gchar* link, gpointer data);
load_commit_cb (WebKitWebView* page, WebKitWebFrame* frame, gpointer data);
static void
+load_start_cb (WebKitWebView* page, WebKitWebFrame* frame, gpointer data);
+
+static void
+load_finish_cb (WebKitWebView* page, WebKitWebFrame* frame, gpointer data);
+
+static void
destroy_cb (GtkWidget* widget, gpointer data);
static void
static bool
file_exists (const char * filename);
-void
-set_insert_mode(WebKitWebView *page, const gchar *param);
+static void
+toggle_insert_mode(WebKitWebView *page, GArray *argv);
static void
-load_uri (WebKitWebView * web_view, const gchar *param);
+load_uri (WebKitWebView * web_view, GArray *argv);
static void
new_window_load_uri (const gchar * uri);
static void
-close_uzbl (WebKitWebView *page, const char *param);
-
-static gboolean
-run_command_async(const char *command, const char *args);
+close_uzbl (WebKitWebView *page, GArray *argv);
static gboolean
-run_command_sync(const char *command, const char *args, char **stdout);
+run_command(const gchar *command, const guint npre,
+ const gchar **args, const gboolean sync, char **stdout);
static void
-spawn(WebKitWebView *web_view, const char *param);
+spawn(WebKitWebView *web_view, GArray *argv);
static void
-parse_command(const char *cmd, const char *param);
+spawn_sh(WebKitWebView *web_view, GArray *argv);
static void
-parse_line(char *line);
+spawn_sync(WebKitWebView *web_view, GArray *argv);
-void
-build_stream_name(int type);
+static void
+spawn_sh_sync(WebKitWebView *web_view, GArray *argv);
static void
-control_fifo(GIOChannel *gio, GIOCondition condition);
+parse_command(const char *cmd, const char *param);
static void
-create_fifo();
+runcmd(WebKitWebView *page, GArray *argv);
static void
+parse_cmd_line(const char *ctl_line);
+
+static gchar*
+build_stream_name(int type, const gchar *dir);
+
+static gboolean
+control_fifo(GIOChannel *gio, GIOCondition condition);
+
+static gchar*
+init_fifo(gchar *dir);
+
+static gboolean
control_stdin(GIOChannel *gio, GIOCondition condition);
static void
create_stdin();
-static void
-create_socket();
+static gchar*
+init_socket(gchar *dir);
-static void
+static gboolean
control_socket(GIOChannel *chan);
-
static void
update_title (void);
-
+
static gboolean
-key_press_cb (WebKitWebView* page, GdkEventKey* event);
+key_press_cb (GtkWidget* window, GdkEventKey* event);
+
+static void
+run_keycmd(const gboolean key_ret);
+
+static void
+exec_paramcmd(const Action* act, const guint i);
static GtkWidget*
create_browser ();
GtkWidget* create_window ();
static void
+run_handler (const gchar *act, const gchar *args);
+
+static void
add_binding (const gchar *key, const gchar *act);
+static gchar*
+get_xdg_var (XDG_Var xdg);
+
+static gchar*
+find_xdg_file (int xdg_type, char* filename);
+
static void
settings_init ();
static void
-search_text (WebKitWebView *page, const char *param);
+search_text (WebKitWebView *page, GArray *argv, const gboolean forward);
static void
-run_js (WebKitWebView * web_view, const gchar *param);
+search_forward_text (WebKitWebView *page, GArray *argv);
-static char *
-str_replace (const char* search, const char* replace, const char* string);
+static void
+search_reverse_text (WebKitWebView *page, GArray *argv);
+
+static void
+dehilight (WebKitWebView *page, GArray *argv);
+
+static void
+run_js (WebKitWebView * web_view, GArray *argv);
+
+static void
+run_external_js (WebKitWebView * web_view, GArray *argv);
static void handle_cookies (SoupSession *session,
- SoupMessage *msg,
- gpointer user_data);
+ SoupMessage *msg,
+ gpointer user_data);
static void
save_cookies (SoupMessage *msg,
- gpointer user_data);
+ gpointer user_data);
+
+static void
+set_var(WebKitWebView *page, GArray *argv);
+
+static void
+render_html();
+
+static void
+set_timeout(int seconds);
+
+
+/* Command callbacks */
+static void
+cmd_load_uri();
+
+static void
+cmd_set_status();
+
+static void
+set_proxy_url();
+
+static void
+cmd_cookie_handler();
+
+static void
+move_statusbar();
+
+static void
+cmd_always_insert_mode();
+
+static void
+cmd_http_debug();
+
+static void
+cmd_max_conns();
+
+static void
+cmd_max_conns_host();
+
+/* exported WebKitWebSettings properties */
+
+static void
+cmd_font_size();
+
+static void
+cmd_zoom_level();
+
+static void
+cmd_disable_plugins();
+
+static void
+cmd_disable_scripts();
+
+static void
+cmd_minimum_font_size();
+
+static void
+cmd_fifo_dir();
+
+static void
+cmd_socket_dir();
+
+static void
+cmd_modkey();
+
+static void
+cmd_useragent() ;
+
+static void
+cmd_autoload_img();
+
+static void
+cmd_autoshrink_img();
+
+static void
+cmd_enable_spellcheck();
+
+static void
+cmd_enable_private();
+
+static void
+cmd_print_bg();
+
+static void
+cmd_style_uri();
+
+static void
+cmd_resizable_txt();
+
+static void
+cmd_default_encoding();
+
+static void
+cmd_enforce_96dpi();
+
+static void
+cmd_inject_html();
+
+static void
+cmd_caret_browsing();
+
/* vi: set et ts=4: */