summaryrefslogtreecommitdiff
path: root/src/commands.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/commands.c')
-rw-r--r--src/commands.c1286
1 files changed, 710 insertions, 576 deletions
diff --git a/src/commands.c b/src/commands.c
index abc7d81c..6ab6b6aa 100644
--- a/src/commands.c
+++ b/src/commands.c
@@ -43,818 +43,945 @@ modulo(int x, int y) {
/* commands.h {{{*/
/* commands_simple_command(keyMap *km) {{{*/
DwbStatus
-commands_simple_command(KeyMap *km) {
- gboolean (*func)(void *, void *) = km->map->func;
- Arg *arg = &km->map->arg;
- arg->e = NULL;
- int ret;
-
- if (dwb.state.mode & AUTO_COMPLETE) {
- completion_clean_autocompletion();
- }
+commands_simple_command(KeyMap *km)
+{
+ int ret;
+ gboolean (*func)(void *, void *) = km->map->func;
+ Arg *arg = &km->map->arg;
+ arg->e = NULL;
+
+ if (dwb.state.mode & AUTO_COMPLETE)
+ {
+ completion_clean_autocompletion();
+ }
- ret = func(km, arg);
- switch (ret) {
- case STATUS_OK:
- if (km->map->hide == NEVER_SM)
- dwb_set_normal_message(dwb.state.fview, false, "%s:", km->map->n.second);
- else if (km->map->hide == ALWAYS_SM) {
- gtk_widget_hide(dwb.gui.entry);
- CLEAR_COMMAND_TEXT();
- }
- break;
- case STATUS_ERROR:
- dwb_set_error_message(dwb.state.fview, arg->e ? arg->e : km->map->error);
- break;
- case STATUS_END:
- return ret;
- default: break;
- }
- if (! km->map->arg.ro)
- km->map->arg.p = NULL;
- dwb_clean_key_buffer();
- return ret;
+ ret = func(km, arg);
+ switch (ret)
+ {
+ case STATUS_OK:
+ if (km->map->hide == NEVER_SM)
+ dwb_set_normal_message(dwb.state.fview, false, "%s:", km->map->n.second);
+ else if (km->map->hide == ALWAYS_SM)
+ {
+ gtk_widget_hide(dwb.gui.entry);
+ CLEAR_COMMAND_TEXT();
+ }
+ break;
+ case STATUS_ERROR:
+ dwb_set_error_message(dwb.state.fview, arg->e ? arg->e : km->map->error);
+ break;
+ case STATUS_END:
+ return ret;
+ default: break;
+ }
+ if (! km->map->arg.ro)
+ km->map->arg.p = NULL;
+ dwb_clean_key_buffer();
+ return ret;
}/*}}}*/
static WebKitWebView *
-commands_get_webview_with_nummod() {
- if (dwb.state.nummod > 0 && dwb.state.nummod <= (gint)g_list_length(dwb.state.views))
- return WEBVIEW(g_list_nth(dwb.state.views, NUMMOD - 1));
- else
- return CURRENT_WEBVIEW();
+commands_get_webview_with_nummod()
+{
+ if (dwb.state.nummod > 0 && dwb.state.nummod <= (gint)g_list_length(dwb.state.views))
+ return WEBVIEW(g_list_nth(dwb.state.views, NUMMOD - 1));
+ else
+ return CURRENT_WEBVIEW();
}
static GList *
-commands_get_view_from_nummod() {
- if (dwb.state.nummod > 0 && dwb.state.nummod <= (gint)g_list_length(dwb.state.views))
- return g_list_nth(dwb.state.views, NUMMOD - 1);
- return dwb.state.fview;
+commands_get_view_from_nummod()
+{
+ if (dwb.state.nummod > 0 && dwb.state.nummod <= (gint)g_list_length(dwb.state.views))
+ return g_list_nth(dwb.state.views, NUMMOD - 1);
+ return dwb.state.fview;
}
/* commands_add_view(KeyMap *, Arg *) {{{*/
DwbStatus
-commands_add_view(KeyMap *km, Arg *arg) {
- view_add(arg->p, false);
- if (arg->p == NULL)
- dwb_open_startpage(dwb.state.fview);
- return STATUS_OK;
+commands_add_view(KeyMap *km, Arg *arg)
+{
+ view_add(arg->p, false);
+ if (arg->p == NULL)
+ dwb_open_startpage(dwb.state.fview);
+ return STATUS_OK;
}/*}}}*/
/* commands_set_setting {{{*/
DwbStatus
-commands_set_setting(KeyMap *km, Arg *arg) {
- dwb.state.mode = arg->n;
- entry_focus();
- return STATUS_OK;
+commands_set_setting(KeyMap *km, Arg *arg)
+{
+ dwb.state.mode = arg->n;
+ entry_focus();
+ return STATUS_OK;
}/*}}}*/
/* commands_set_key {{{*/
DwbStatus
-commands_set_key(KeyMap *km, Arg *arg) {
- dwb.state.mode = KEY_MODE;
- entry_focus();
- return STATUS_OK;
+commands_set_key(KeyMap *km, Arg *arg)
+{
+ dwb.state.mode = KEY_MODE;
+ entry_focus();
+ return STATUS_OK;
}/*}}}*/
/* commands_focus_input {{{*/
DwbStatus
-commands_focus_input(KeyMap *km, Arg *a) {
- char *value;
- DwbStatus ret = STATUS_OK;
+commands_focus_input(KeyMap *km, Arg *a)
+{
+ char *value;
+ DwbStatus ret = STATUS_OK;
+
+ if ( (value = js_call_as_function(MAIN_FRAME(), CURRENT_VIEW()->js_base, "focusInput", NULL, kJSTypeUndefined, &value)) )
+ {
+ if (!g_strcmp0(value, "_dwb_no_input_"))
+ ret = STATUS_ERROR;
+ g_free(value);
+ }
- if ( (value = js_call_as_function(MAIN_FRAME(), CURRENT_VIEW()->js_base, "focusInput", NULL, kJSTypeUndefined, &value)) ) {
- if (!g_strcmp0(value, "_dwb_no_input_"))
- ret = STATUS_ERROR;
- g_free(value);
- }
-
- return ret;
+ return ret;
}/*}}}*/
/* commands_add_search_field(KeyMap *km, Arg *) {{{*/
DwbStatus
-commands_add_search_field(KeyMap *km, Arg *a) {
- char *value;
- if ( (value = js_call_as_function(MAIN_FRAME(), CURRENT_VIEW()->js_base, "addSearchEngine", NULL, kJSTypeUndefined, &value)) ) {
- if (!g_strcmp0(value, "_dwb_no_hints_")) {
- return STATUS_ERROR;
+commands_add_search_field(KeyMap *km, Arg *a)
+{
+ char *value;
+ if ( (value = js_call_as_function(MAIN_FRAME(), CURRENT_VIEW()->js_base, "addSearchEngine", NULL, kJSTypeUndefined, &value)) ) {
+ if (!g_strcmp0(value, "_dwb_no_hints_")) {
+ return STATUS_ERROR;
+ }
}
- }
- dwb.state.mode = SEARCH_FIELD_MODE;
- dwb_set_normal_message(dwb.state.fview, false, "Keyword:");
- entry_focus();
- g_free(value);
- return STATUS_OK;
+ dwb.state.mode = SEARCH_FIELD_MODE;
+ dwb_set_normal_message(dwb.state.fview, false, "Keyword:");
+ entry_focus();
+ g_free(value);
+ return STATUS_OK;
}/*}}}*/
DwbStatus
-commands_insert_mode(KeyMap *km, Arg *a) {
- return dwb_change_mode(INSERT_MODE);
+commands_insert_mode(KeyMap *km, Arg *a)
+{
+ return dwb_change_mode(INSERT_MODE);
}
DwbStatus
-commands_normal_mode(KeyMap *km, Arg *a) {
- dwb_change_mode(NORMAL_MODE, true);
- return STATUS_OK;
+commands_normal_mode(KeyMap *km, Arg *a)
+{
+ dwb_change_mode(NORMAL_MODE, true);
+ return STATUS_OK;
}
/* commands_toggle_proxy {{{*/
DwbStatus
-commands_toggle_proxy(KeyMap *km, Arg *a) {
- WebSettings *s = g_hash_table_lookup(dwb.settings, "proxy");
- s->arg_local.b = !s->arg_local.b;
+commands_toggle_proxy(KeyMap *km, Arg *a)
+{
+ WebSettings *s = g_hash_table_lookup(dwb.settings, "proxy");
+ s->arg_local.b = !s->arg_local.b;
- dwb_set_proxy(NULL, s);
+ dwb_set_proxy(NULL, s);
- return STATUS_OK;
+ return STATUS_OK;
}/*}}}*/
/*commands_find {{{*/
DwbStatus
-commands_find(KeyMap *km, Arg *arg) {
- View *v = CURRENT_VIEW();
- dwb.state.mode = FIND_MODE;
- dwb.state.search_flags = arg->n;
- if (v->status->search_string) {
- g_free(v->status->search_string);
- v->status->search_string = NULL;
- }
- entry_focus();
- return STATUS_OK;
+commands_find(KeyMap *km, Arg *arg)
+{
+ View *v = CURRENT_VIEW();
+ dwb.state.mode = FIND_MODE;
+ dwb.state.search_flags = arg->n;
+
+ if (v->status->search_string) {
+ g_free(v->status->search_string);
+ v->status->search_string = NULL;
+ }
+
+ entry_focus();
+ return STATUS_OK;
}/*}}}*/
DwbStatus
-commands_search(KeyMap *km, Arg *arg) {
- if (!dwb_search(arg))
- return STATUS_ERROR;
- return STATUS_OK;
+commands_search(KeyMap *km, Arg *arg)
+{
+ if (!dwb_search(arg))
+ return STATUS_ERROR;
+ return STATUS_OK;
}
/* commands_show_hints {{{*/
DwbStatus
-commands_show_hints(KeyMap *km, Arg *arg) {
+commands_show_hints(KeyMap *km, Arg *arg)
+{
return dwb_show_hints(arg);
}/*}}}*/
DwbStatus
-commands_show(KeyMap *km, Arg *arg) {
+commands_show(KeyMap *km, Arg *arg)
+{
html_load(dwb.state.fview, arg->p);
return STATUS_OK;
}
/* commands_allow_cookie {{{*/
DwbStatus
-commands_allow_cookie(KeyMap *km, Arg *arg) {
- switch (arg->n) {
- case COOKIE_ALLOW_PERSISTENT:
- return dwb_soup_allow_cookie(&dwb.fc.cookies_allow, dwb.files[FILES_COOKIES_ALLOW], arg->n);
- case COOKIE_ALLOW_SESSION:
- return dwb_soup_allow_cookie(&dwb.fc.cookies_session_allow, dwb.files[FILES_COOKIES_SESSION_ALLOW], arg->n);
- case COOKIE_ALLOW_SESSION_TMP:
- dwb_soup_allow_cookie_tmp();
- break;
- default:
- break;
+commands_allow_cookie(KeyMap *km, Arg *arg)
+{
+ switch (arg->n)
+ {
+ case COOKIE_ALLOW_PERSISTENT:
+ return dwb_soup_allow_cookie(&dwb.fc.cookies_allow, dwb.files[FILES_COOKIES_ALLOW], arg->n);
+ case COOKIE_ALLOW_SESSION:
+ return dwb_soup_allow_cookie(&dwb.fc.cookies_session_allow, dwb.files[FILES_COOKIES_SESSION_ALLOW], arg->n);
+ case COOKIE_ALLOW_SESSION_TMP:
+ dwb_soup_allow_cookie_tmp();
+ break;
+ default:
+ break;
- }
- return STATUS_OK;
+ }
+ return STATUS_OK;
}/*}}}*/
/* commands_bookmark {{{*/
DwbStatus
-commands_bookmark(KeyMap *km, Arg *arg) {
- gboolean noerror = STATUS_ERROR;
- if ( (noerror = dwb_prepend_navigation(dwb.state.fview, &dwb.fc.bookmarks)) == STATUS_OK) {
- util_file_add_navigation(dwb.files[FILES_BOOKMARKS], dwb.fc.bookmarks->data, true, -1);
- dwb.fc.bookmarks = g_list_sort(dwb.fc.bookmarks, (GCompareFunc)util_navigation_compare_first);
- dwb_set_normal_message(dwb.state.fview, true, "Saved bookmark: %s", webkit_web_view_get_uri(CURRENT_WEBVIEW()));
- }
- return noerror;
+commands_bookmark(KeyMap *km, Arg *arg)
+{
+ gboolean noerror = STATUS_ERROR;
+ if ( (noerror = dwb_prepend_navigation(dwb.state.fview, &dwb.fc.bookmarks)) == STATUS_OK)
+ {
+ util_file_add_navigation(dwb.files[FILES_BOOKMARKS], dwb.fc.bookmarks->data, true, -1);
+ dwb.fc.bookmarks = g_list_sort(dwb.fc.bookmarks, (GCompareFunc)util_navigation_compare_first);
+ dwb_set_normal_message(dwb.state.fview, true, "Saved bookmark: %s", webkit_web_view_get_uri(CURRENT_WEBVIEW()));
+ }
+ return noerror;
}/*}}}*/
/* commands_quickmark(KeyMap *km, Arg *arg) {{{*/
DwbStatus
-commands_quickmark(KeyMap *km, Arg *arg) {
- if (dwb.state.nv == OPEN_NORMAL)
- dwb_set_open_mode(arg->i);
- entry_focus();
- dwb.state.mode = arg->n;
- return STATUS_OK;
+commands_quickmark(KeyMap *km, Arg *arg)
+{
+ if (dwb.state.nv == OPEN_NORMAL)
+ dwb_set_open_mode(arg->i);
+ entry_focus();
+ dwb.state.mode = arg->n;
+ return STATUS_OK;
}/*}}}*/
/* commands_reload(KeyMap *km, Arg *){{{*/
DwbStatus
-commands_reload(KeyMap *km, Arg *arg) {
- GList *gl = dwb.state.nummod > 0 && dwb.state.nummod <= (gint)g_list_length(dwb.state.views)
- ? g_list_nth(dwb.state.views, dwb.state.nummod-1)
- : dwb.state.fview;
- dwb_reload(gl);
- return STATUS_OK;
+commands_reload(KeyMap *km, Arg *arg)
+{
+ GList *gl = dwb.state.nummod > 0 && dwb.state.nummod <= (gint)g_list_length(dwb.state.views)
+ ? g_list_nth(dwb.state.views, dwb.state.nummod-1)
+ : dwb.state.fview;
+ dwb_reload(gl);
+ return STATUS_OK;
}/*}}}*/
/* commands_reload_bypass_cache {{{*/
DwbStatus
-commands_reload_bypass_cache(KeyMap *km, Arg *arg) {
- webkit_web_view_reload_bypass_cache(commands_get_webview_with_nummod());
- return STATUS_OK;
+commands_reload_bypass_cache(KeyMap *km, Arg *arg)
+{
+ webkit_web_view_reload_bypass_cache(commands_get_webview_with_nummod());
+ return STATUS_OK;
}
/*}}}*/
/* commands_stop_loading {{{*/
DwbStatus
-commands_stop_loading(KeyMap *km, Arg *arg) {
- webkit_web_view_stop_loading(commands_get_webview_with_nummod());
- return STATUS_OK;
+commands_stop_loading(KeyMap *km, Arg *arg)
+{
+ webkit_web_view_stop_loading(commands_get_webview_with_nummod());
+ return STATUS_OK;
}
/*}}}*/
/* commands_view_source(Arg) {{{*/
DwbStatus
-commands_view_source(KeyMap *km, Arg *arg) {
- WebKitWebView *web = CURRENT_WEBVIEW();
- webkit_web_view_set_view_source_mode(web, !webkit_web_view_get_view_source_mode(web));
- webkit_web_view_reload(web);
- return STATUS_OK;
+commands_view_source(KeyMap *km, Arg *arg)
+{
+ WebKitWebView *web = CURRENT_WEBVIEW();
+ webkit_web_view_set_view_source_mode(web, !webkit_web_view_get_view_source_mode(web));
+ webkit_web_view_reload(web);
+ return STATUS_OK;
}/*}}}*/
/* commands_zoom_in(void *arg) {{{*/
DwbStatus
-commands_zoom(KeyMap *km, Arg *arg) {
- View *v = dwb.state.fview->data;
- WebKitWebView *web = WEBKIT_WEB_VIEW(v->web);
-
- gfloat zoomlevel = MAX(webkit_web_view_get_zoom_level(web) + arg->i * NUMMOD * GET_DOUBLE("zoom-step"), 0);
- webkit_web_view_set_zoom_level(web, zoomlevel);
- dwb_set_normal_message(dwb.state.fview, true, "Zoomlevel: %d%%", (int)(zoomlevel * 100));
- return STATUS_OK;
+commands_zoom(KeyMap *km, Arg *arg)
+{
+ View *v = dwb.state.fview->data;
+ WebKitWebView *web = WEBKIT_WEB_VIEW(v->web);
+
+ gfloat zoomlevel = MAX(webkit_web_view_get_zoom_level(web) + arg->i * NUMMOD * GET_DOUBLE("zoom-step"), 0);
+ webkit_web_view_set_zoom_level(web, zoomlevel);
+ dwb_set_normal_message(dwb.state.fview, true, "Zoomlevel: %d%%", (int)(zoomlevel * 100));
+ return STATUS_OK;
}/*}}}*/
/* commands_scroll {{{*/
DwbStatus
-commands_scroll(KeyMap *km, Arg *arg) {
- GList *gl = arg->p ? arg->p : dwb.state.fview;
- dwb_scroll(gl, dwb.misc.scroll_step, arg->n);
- return STATUS_OK;
+commands_scroll(KeyMap *km, Arg *arg)
+{
+ GList *gl = arg->p ? arg->p : dwb.state.fview;
+ dwb_scroll(gl, dwb.misc.scroll_step, arg->n);
+ return STATUS_OK;
}/*}}}*/
/* commands_set_zoom_level(KeyMap *km, Arg *arg) {{{*/
DwbStatus
-commands_set_zoom_level(KeyMap *km, Arg *arg) {
- GList *gl = arg->p ? arg->p : dwb.state.fview;
- double zoomlevel = dwb.state.nummod < 0 ? arg->d : (double)dwb.state.nummod / 100;
- webkit_web_view_set_zoom_level(WEBKIT_WEB_VIEW(((View*)gl->data)->web), zoomlevel);
- dwb_set_normal_message(dwb.state.fview, true, "Zoomlevel: %d%%", (int)(zoomlevel * 100));
- return STATUS_OK;
+commands_set_zoom_level(KeyMap *km, Arg *arg)
+{
+ GList *gl = arg->p ? arg->p : dwb.state.fview;
+ double zoomlevel = dwb.state.nummod < 0 ? arg->d : (double)dwb.state.nummod / 100;
+
+ webkit_web_view_set_zoom_level(WEBKIT_WEB_VIEW(((View*)gl->data)->web), zoomlevel);
+ dwb_set_normal_message(dwb.state.fview, true, "Zoomlevel: %d%%", (int)(zoomlevel * 100));
+ return STATUS_OK;
}/*}}}*/
/* History {{{*/
DwbStatus
-commands_history(KeyMap *km, Arg *arg) {
- return dwb_history(arg);
+commands_history(KeyMap *km, Arg *arg)
+{
+ return dwb_history(arg);
}/*}}}*/
/* commands_open(KeyMap *km, Arg *arg) {{{*/
DwbStatus
-commands_open(KeyMap *km, Arg *arg) {
- if (dwb.state.nv & OPEN_NORMAL)
- dwb_set_open_mode(arg->n & ~SET_URL);
+commands_open(KeyMap *km, Arg *arg)
+{
+ if (dwb.state.nv & OPEN_NORMAL)
+ dwb_set_open_mode(arg->n & ~SET_URL);
+
+ if (arg)
+ dwb.state.type = arg->i;
- if (arg)
- dwb.state.type = arg->i;
-
- if (arg && arg->p && ! (arg->n & SET_URL)) {
- dwb_load_uri(NULL, arg->p);
- CLEAR_COMMAND_TEXT();
+ if (arg && arg->p && ! (arg->n & SET_URL))
+ {
+ dwb_load_uri(NULL, arg->p);
+ CLEAR_COMMAND_TEXT();
+ return STATUS_OK;
+ }
+ else
+ {
+ entry_focus();
+ if (arg && (arg->n & SET_URL))
+ entry_set_text(arg->p ? arg->p : CURRENT_URL());
+ }
return STATUS_OK;
- }
- else {
- entry_focus();
- if (arg && (arg->n & SET_URL))
- entry_set_text(arg->p ? arg->p : CURRENT_URL());
- }
- return STATUS_OK;
} /*}}}*/
/* commands_open(KeyMap *km, Arg *arg) {{{*/
DwbStatus
-commands_open_startpage(KeyMap *km, Arg *arg) {
- return dwb_open_startpage(NULL);
+commands_open_startpage(KeyMap *km, Arg *arg)
+{
+ return dwb_open_startpage(NULL);
} /*}}}*/
/* commands_remove_view(KeyMap *km, Arg *arg) {{{*/
DwbStatus
-commands_remove_view(KeyMap *km, Arg *arg) {
- return view_remove(NULL);
+commands_remove_view(KeyMap *km, Arg *arg)
+{
+ return view_remove(NULL);
}/*}}}*/
/* commands_focus(KeyMap *km, Arg *arg) {{{*/
DwbStatus
-commands_focus(KeyMap *km, Arg *arg) {
- if (dwb.state.views->next) {
- int pos = modulo(g_list_position(dwb.state.views, dwb.state.fview) + NUMMOD * arg->n, g_list_length(dwb.state.views));
- GList *g = g_list_nth(dwb.state.views, pos);
- dwb_focus_view(g);
- return STATUS_OK;
- }
- return STATUS_ERROR;
+commands_focus(KeyMap *km, Arg *arg)
+{
+ if (dwb.state.views->next)
+ {
+ int pos = modulo(g_list_position(dwb.state.views, dwb.state.fview) + NUMMOD * arg->n, g_list_length(dwb.state.views));
+ GList *g = g_list_nth(dwb.state.views, pos);
+ dwb_focus_view(g);
+ return STATUS_OK;
+ }
+ return STATUS_ERROR;
}/*}}}*/
/* commands_focus_view{{{*/
DwbStatus
-commands_focus_nth_view(KeyMap *km, Arg *arg) {
- GList *l = NULL;
- if (!dwb.state.views->next)
- return STATUS_OK;
+commands_focus_nth_view(KeyMap *km, Arg *arg)
+{
+ GList *l = NULL;
+ if (!dwb.state.views->next)
+ return STATUS_OK;
+
+ switch (dwb.state.nummod)
+ {
+ case 0 : l = g_list_last(dwb.state.views); break;
+ case -1 : l = g_list_first(dwb.state.views); break;
+ default : l = g_list_nth(dwb.state.views, dwb.state.nummod - 1);
+ }
- switch (dwb.state.nummod) {
- case 0 : l = g_list_last(dwb.state.views); break;
- case -1 : l = g_list_first(dwb.state.views); break;
- default : l = g_list_nth(dwb.state.views, dwb.state.nummod - 1);
- }
- if (l == NULL)
- return STATUS_ERROR;
+ if (l == NULL)
+ return STATUS_ERROR;
- dwb_focus_view(l);
- return STATUS_OK;
+ dwb_focus_view(l);
+ return STATUS_OK;
}/*}}}*/
/* commands_yank {{{*/
DwbStatus
-commands_yank(KeyMap *km, Arg *arg) {
- GdkAtom atom = GDK_POINTER_TO_ATOM(arg->p);
- const char *text = NULL;
- WebKitWebView *wv = commands_get_webview_with_nummod();
- if (arg->n == CA_URI)
- text = webkit_web_view_get_uri(wv);
- else if (arg->n == CA_TITLE)
- text = webkit_web_view_get_title(wv);
+commands_yank(KeyMap *km, Arg *arg)
+{
+ const char *text = NULL;
+ GdkAtom atom = GDK_POINTER_TO_ATOM(arg->p);
+ WebKitWebView *wv = commands_get_webview_with_nummod();
+
+ if (arg->n == CA_URI)
+ text = webkit_web_view_get_uri(wv);
+ else if (arg->n == CA_TITLE)
+ text = webkit_web_view_get_title(wv);
- return dwb_set_clipboard(text, atom);
+ return dwb_set_clipboard(text, atom);
}/*}}}*/
/* commands_paste {{{*/
DwbStatus
-commands_paste(KeyMap *km, Arg *arg) {
- GdkAtom atom = GDK_POINTER_TO_ATOM(arg->p);
- char *text = NULL;
-
- if ( (text = dwb_clipboard_get_text(atom)) ) {
- if (dwb.state.nv == OPEN_NORMAL)
- dwb_set_open_mode(arg->n);
- dwb_load_uri(NULL, text);
- g_free(text);
- return STATUS_OK;
- }
- return STATUS_ERROR;
+commands_paste(KeyMap *km, Arg *arg)
+{
+ GdkAtom atom = GDK_POINTER_TO_ATOM(arg->p);
+ char *text = NULL;
+
+ if ( (text = dwb_clipboard_get_text(atom)) )
+ {
+ if (dwb.state.nv == OPEN_NORMAL)
+ dwb_set_open_mode(arg->n);
+ dwb_load_uri(NULL, text);
+ g_free(text);
+ return STATUS_OK;
+ }
+ return STATUS_ERROR;
}/*}}}*/
/* dwb_entry_movement() {{{*/
DwbStatus
-commands_entry_movement(KeyMap *m, Arg *a) {
- entry_move_cursor_step(a->n, a->i, a->b);
- return STATUS_OK;
+commands_entry_movement(KeyMap *m, Arg *a)
+{
+ entry_move_cursor_step(a->n, a->i, a->b);
+ return STATUS_OK;
}/*}}}*/
/* commands_entry_history_forward {{{*/
DwbStatus
-commands_entry_history_forward(KeyMap *km, Arg *a) {
- if (dwb.state.mode == COMMAND_MODE)
- return entry_history_forward(&dwb.state.last_com_history);
- else
- return entry_history_forward(&dwb.state.last_nav_history);
+commands_entry_history_forward(KeyMap *km, Arg *a)
+{
+ if (dwb.state.mode == COMMAND_MODE)
+ return entry_history_forward(&dwb.state.last_com_history);
+ else
+ return entry_history_forward(&dwb.state.last_nav_history);
}/*}}}*/
/* commands_entry_history_back {{{*/
DwbStatus
-commands_entry_history_back(KeyMap *km, Arg *a) {
- if (dwb.state.mode == COMMAND_MODE)
- return entry_history_back(&dwb.fc.commands, &dwb.state.last_com_history);
- else
- return entry_history_back(&dwb.fc.navigations, &dwb.state.last_nav_history);
+commands_entry_history_back(KeyMap *km, Arg *a)
+{
+ if (dwb.state.mode == COMMAND_MODE)
+ return entry_history_back(&dwb.fc.commands, &dwb.state.last_com_history);
+ else
+ return entry_history_back(&dwb.fc.navigations, &dwb.state.last_nav_history);
}/*}}}*/
/* commands_entry_confirm {{{*/
DwbStatus
-commands_entry_confirm(KeyMap *km, Arg *a) {
- GdkEventKey e = { .state = 0, .keyval = GDK_KEY_Return };
- gboolean ret;
- g_signal_emit_by_name(dwb.gui.entry, "key-press-event", &e, &ret);
- return STATUS_OK;
+commands_entry_confirm(KeyMap *km, Arg *a)
+{
+ gboolean ret;
+ GdkEventKey e = { .state = 0, .keyval = GDK_KEY_Return };
+ g_signal_emit_by_name(dwb.gui.entry, "key-press-event", &e, &ret);
+
+ return STATUS_OK;
}/*}}}*/
/* commands_entry_escape {{{*/
DwbStatus
-commands_entry_escape(KeyMap *km, Arg *a) {
- dwb_change_mode(NORMAL_MODE, true);
- return STATUS_OK;
+commands_entry_escape(KeyMap *km, Arg *a)
+{
+ dwb_change_mode(NORMAL_MODE, true);
+ return STATUS_OK;
}/*}}}*/
/* commands_save_session {{{*/
DwbStatus
-commands_save_session(KeyMap *km, Arg *arg) {
- if (arg->n == NORMAL_MODE) {
- dwb.state.mode = SAVE_SESSION;
- session_save(NULL, SESSION_FORCE);
- dwb_end();
- return STATUS_END;
- }
- else {
- dwb.state.mode = arg->n;
- entry_focus();
- dwb_set_normal_message(dwb.state.fview, false, "Session name:");
- }
- return STATUS_OK;
+commands_save_session(KeyMap *km, Arg *arg)
+{
+ if (arg->n == NORMAL_MODE)
+ {
+ dwb.state.mode = SAVE_SESSION;
+ session_save(NULL, SESSION_FORCE);
+ dwb_end();
+ return STATUS_END;
+ }
+ else
+ {
+ dwb.state.mode = arg->n;
+ entry_focus();
+ dwb_set_normal_message(dwb.state.fview, false, "Session name:");
+ }
+ return STATUS_OK;
}/*}}}*/
/* commands_bookmarks {{{*/
DwbStatus
-commands_bookmarks(KeyMap *km, Arg *arg) {
- if (!g_list_length(dwb.fc.bookmarks)) {
- return STATUS_ERROR;
- }
- if (dwb.state.nv == OPEN_NORMAL)
- dwb_set_open_mode(arg->n);
- completion_complete(COMP_BOOKMARK, 0);
- entry_focus();
- if (dwb.comps.active_comp != NULL) {
- completion_set_entry_text((Completion*)dwb.comps.active_comp->data);
- }
- return STATUS_OK;
+commands_bookmarks(KeyMap *km, Arg *arg)
+{
+ if (!g_list_length(dwb.fc.bookmarks))
+ return STATUS_ERROR;
+
+ if (dwb.state.nv == OPEN_NORMAL)
+ dwb_set_open_mode(arg->n);
+
+ completion_complete(COMP_BOOKMARK, 0);
+ entry_focus();
+
+ if (dwb.comps.active_comp != NULL)
+ completion_set_entry_text((Completion*)dwb.comps.active_comp->data);
+
+ return STATUS_OK;
}/*}}}*/
/* commands_history{{{*/
DwbStatus
-commands_complete_type(KeyMap *km, Arg *arg) {
- return completion_complete(arg->n, 0);
+commands_complete_type(KeyMap *km, Arg *arg)
+{
+ return completion_complete(arg->n, 0);
}/*}}}*/
void
-commands_toggle(Arg *arg, const char *filename, GList **tmp, GList **pers, const char *message) {
- char *host = NULL;
- const char *block = NULL;
- gboolean allowed;
- if (arg->n & ALLOW_HOST) {
- host = dwb_get_host(CURRENT_WEBVIEW());
- block = host;
- }
- else if (arg->n & ALLOW_URI) {
- block = webkit_web_view_get_uri(CURRENT_WEBVIEW());
- }
- else if (arg->p) {
- block = arg->p;
- }
- if (block != NULL) {
- if (arg->n & ALLOW_TMP) {
- GList *l;
- if ( (l = g_list_find_custom(*tmp, block, (GCompareFunc)g_strcmp0)) ) {
- g_free(l->data);
- *tmp = g_list_delete_link(*tmp, l);
- allowed = false;
- }
- else {
- *tmp = g_list_prepend(*tmp, g_strdup(block));
- allowed = true;
- }
- dwb_set_normal_message(dwb.state.fview, true, "%s temporarily %s for %s", message, allowed ? "allowed" : "blocked", block);
+commands_toggle(Arg *arg, const char *filename, GList **tmp, GList **pers, const char *message)
+{
+ char *host = NULL;
+ const char *block = NULL;
+ gboolean allowed;
+
+ if (arg->n & ALLOW_HOST)
+ {
+ host = dwb_get_host(CURRENT_WEBVIEW());
+ block = host;
}
- else {
- allowed = dwb_toggle_allowed(filename, block, pers);
- dwb_set_normal_message(dwb.state.fview, true, "%s %s for %s", message, allowed ? "allowed" : "blocked", block);
+ else if (arg->n & ALLOW_URI)
+ block = webkit_web_view_get_uri(CURRENT_WEBVIEW());
+ else if (arg->p)
+ block = arg->p;
+ if (block != NULL)
+ {
+ if (arg->n & ALLOW_TMP)
+ {
+ GList *l;
+ if ( (l = g_list_find_custom(*tmp, block, (GCompareFunc)g_strcmp0)) )
+ {
+ g_free(l->data);
+ *tmp = g_list_delete_link(*tmp, l);
+ allowed = false;
+ }
+ else
+ {
+ *tmp = g_list_prepend(*tmp, g_strdup(block));
+ allowed = true;
+ }
+ dwb_set_normal_message(dwb.state.fview, true, "%s temporarily %s for %s", message, allowed ? "allowed" : "blocked", block);
+ }
+ else
+ {
+ allowed = dwb_toggle_allowed(filename, block, pers);
+ dwb_set_normal_message(dwb.state.fview, true, "%s %s for %s", message, allowed ? "allowed" : "blocked", block);
+ }
}
- }
- else
- CLEAR_COMMAND_TEXT();
+ else
+ CLEAR_COMMAND_TEXT();
}
DwbStatus
-commands_toggle_plugin_blocker(KeyMap *km, Arg *arg) {
- commands_toggle(arg, dwb.files[FILES_PLUGINS_ALLOW], &dwb.fc.tmp_plugins, &dwb.fc.pers_plugins, "Plugins");
- return STATUS_OK;
+commands_toggle_plugin_blocker(KeyMap *km, Arg *arg)
+{
+ commands_toggle(arg, dwb.files[FILES_PLUGINS_ALLOW], &dwb.fc.tmp_plugins, &dwb.fc.pers_plugins, "Plugins");
+ return STATUS_OK;
}
/* commands_toggle_scripts {{{ */
DwbStatus
-commands_toggle_scripts(KeyMap *km, Arg *arg) {
- commands_toggle(arg, dwb.files[FILES_SCRIPTS_ALLOW], &dwb.fc.tmp_scripts, &dwb.fc.pers_scripts, "Scripts");
- return STATUS_OK;
+commands_toggle_scripts(KeyMap *km, Arg *arg)
+{
+ commands_toggle(arg, dwb.files[FILES_SCRIPTS_ALLOW], &dwb.fc.tmp_scripts, &dwb.fc.pers_scripts, "Scripts");
+ return STATUS_OK;
}/*}}}*/
/* commands_new_window_or_view{{{*/
DwbStatus
-commands_new_window_or_view(KeyMap *km, Arg *arg) {
- dwb_set_open_mode(arg->n | OPEN_EXPLICIT);
- return STATUS_OK;
+commands_new_window_or_view(KeyMap *km, Arg *arg)
+{
+ dwb_set_open_mode(arg->n | OPEN_EXPLICIT);
+ return STATUS_OK;
}/*}}}*/
/* commands_save_files(KeyMap *km, Arg *arg) {{{*/
DwbStatus
-commands_save_files(KeyMap *km, Arg *arg) {
- if (dwb_save_files(false)) {
- dwb_set_normal_message(dwb.state.fview, true, "Configuration files saved");
- return STATUS_OK;
+commands_save_files(KeyMap *km, Arg *arg)
+{
+ if (dwb_save_files(false))
+ {
+ dwb_set_normal_message(dwb.state.fview, true, "Configuration files saved");
+ return STATUS_OK;
}
return STATUS_ERROR;
}/*}}}*/
/* commands_undo() {{{*/
DwbStatus
-commands_undo(KeyMap *km, Arg *arg) {
- if (dwb.state.undo_list) {
- WebKitWebView *web = WEBVIEW(view_add(NULL, false));
- WebKitWebBackForwardList *bflist = webkit_web_back_forward_list_new_with_web_view(web);
- for (GList *l = dwb.state.undo_list->data; l; l=l->next) {
- Navigation *n = l->data;
- WebKitWebHistoryItem *item = webkit_web_history_item_new_with_data(n->first, n->second);
- webkit_web_back_forward_list_add_item(bflist, item);
- if (!l->next) {
- webkit_web_view_go_to_back_forward_item(web, item);
+commands_undo(KeyMap *km, Arg *arg)
+{
+ if (dwb.state.undo_list)
+ {
+ WebKitWebView *web = WEBVIEW(view_add(NULL, false));
+ WebKitWebBackForwardList *bflist = webkit_web_back_forward_list_new_with_web_view(web);
+
+ for (GList *l = dwb.state.undo_list->data; l; l=l->next)
+ {
+ Navigation *n = l->data;
+ WebKitWebHistoryItem *item = webkit_web_history_item_new_with_data(n->first, n->second);
+
+ webkit_web_back_forward_list_add_item(bflist, item);
+ if (!l->next)
+ webkit_web_view_go_to_back_forward_item(web, item);
+
+ dwb_navigation_free(n);
}
- dwb_navigation_free(n);
- }
- g_list_free(dwb.state.undo_list->data);
- dwb.state.undo_list = g_list_delete_link(dwb.state.undo_list, dwb.state.undo_list);
- return STATUS_OK;
+ g_list_free(dwb.state.undo_list->data);
+ dwb.state.undo_list = g_list_delete_link(dwb.state.undo_list, dwb.state.undo_list);
+ return STATUS_OK;
}
return STATUS_ERROR;
}/*}}}*/
/* commands_print (Arg *) {{{*/
DwbStatus
-commands_print(KeyMap *km, Arg *arg) {
- WebKitWebView *wv = commands_get_webview_with_nummod();
- WebKitWebFrame *frame = webkit_web_view_get_focused_frame(wv);
- if (frame) {
- webkit_web_frame_print(frame);
- return STATUS_OK;
- }
- return STATUS_ERROR;
+commands_print(KeyMap *km, Arg *arg)
+{
+ WebKitWebView *wv = commands_get_webview_with_nummod();
+ WebKitWebFrame *frame = webkit_web_view_get_focused_frame(wv);
+ if (frame)
+ {
+ webkit_web_frame_print(frame);
+ return STATUS_OK;
+ }
+ return STATUS_ERROR;
}/*}}}*/
/* commands_web_inspector {{{*/
DwbStatus
-commands_web_inspector(KeyMap *km, Arg *arg) {
- if (GET_BOOL("enable-developer-extras")) {
- WebKitWebView *wv = commands_get_webview_with_nummod();
- webkit_web_inspector_show(webkit_web_view_get_inspector(wv));
- return STATUS_OK;
- }
- return STATUS_ERROR;
+commands_web_inspector(KeyMap *km, Arg *arg)
+{
+ if (GET_BOOL("enable-developer-extras"))
+ {
+ WebKitWebView *wv = commands_get_webview_with_nummod();
+ webkit_web_inspector_show(webkit_web_view_get_inspector(wv));
+ return STATUS_OK;
+ }
+ return STATUS_ERROR;
}/*}}}*/
/* commands_execute_userscript (Arg *) {{{*/
DwbStatus
-commands_execute_userscript(KeyMap *km, Arg *arg) {
- if (!dwb.misc.userscripts)
- return STATUS_ERROR;
-
- if (arg->p) {
- char *path = g_build_filename(dwb.files[FILES_USERSCRIPTS], arg->p, NULL);
- Arg a = { .arg = path };
- dwb_execute_user_script(km, &a);
- g_free(path);
- }
- else {
- entry_focus();
- completion_complete(COMP_USERSCRIPT, 0);
- }
+commands_execute_userscript(KeyMap *km, Arg *arg)
+{
+ if (!dwb.misc.userscripts)
+ return STATUS_ERROR;
+
+ if (arg->p)
+ {
+ char *path = g_build_filename(dwb.files[FILES_USERSCRIPTS], arg->p, NULL);
+ Arg a = { .arg = path };
+ dwb_execute_user_script(km, &a);
+ g_free(path);
+ }
+ else
+ {
+ entry_focus();
+ completion_complete(COMP_USERSCRIPT, 0);
+ }
- return STATUS_OK;
+ return STATUS_OK;
}/*}}}*/
/* commands_toggle_hidden_files {{{*/
DwbStatus
-commands_toggle_hidden_files(KeyMap *km, Arg *arg) {
- dwb.state.hidden_files = !dwb.state.hidden_files;
- dwb_reload(dwb.state.fview);
- return STATUS_OK;
+commands_toggle_hidden_files(KeyMap *km, Arg *arg)
+{
+ dwb.state.hidden_files = !dwb.state.hidden_files;
+ dwb_reload(dwb.state.fview);
+ return STATUS_OK;
}/*}}}*/
/* commands_quit {{{*/
DwbStatus
-commands_quit(KeyMap *km, Arg *arg) {
- dwb_end();
- return STATUS_END;
+commands_quit(KeyMap *km, Arg *arg)
+{
+ dwb_end();
+ return STATUS_END;
}/*}}}*/
DwbStatus
-commands_reload_user_scripts(KeyMap *km, Arg *arg) {
- dwb_reload_userscripts();
- return STATUS_OK;
+commands_reload_user_scripts(KeyMap *km, Arg *arg)
+{
+ dwb_reload_userscripts();
+ return STATUS_OK;
}
/* commands_reload_scripts {{{*/
DwbStatus
-commands_fullscreen(KeyMap *km, Arg *arg) {
- if (dwb.state.bar_visible & BAR_PRESENTATION)
- return STATUS_ERROR;
- dwb.state.fullscreen = !dwb.state.fullscreen;
- if (dwb.state.fullscreen)
- gtk_window_fullscreen(GTK_WINDOW(dwb.gui.window));
- else
- gtk_window_unfullscreen(GTK_WINDOW(dwb.gui.window));
- return STATUS_OK;
+commands_fullscreen(KeyMap *km, Arg *arg)
+{
+ if (dwb.state.bar_visible & BAR_PRESENTATION)
+ return STATUS_ERROR;
+ dwb.state.fullscreen = !dwb.state.fullscreen;
+
+ if (dwb.state.fullscreen)
+ gtk_window_fullscreen(GTK_WINDOW(dwb.gui.window));
+ else
+ gtk_window_unfullscreen(GTK_WINDOW(dwb.gui.window));
+
+ return STATUS_OK;
}/*}}}*/
/* commands_reload_scripts {{{*/
DwbStatus
-commands_open_editor(KeyMap *km, Arg *arg) {
- return dwb_open_in_editor();
+commands_open_editor(KeyMap *km, Arg *arg)
+{
+ return dwb_open_in_editor();
}/*}}}*/
/* dwb_command_mode {{{*/
DwbStatus
-commands_command_mode(KeyMap *km, Arg *arg) {
- return dwb_change_mode(COMMAND_MODE);
+commands_command_mode(KeyMap *km, Arg *arg)
+{
+ return dwb_change_mode(COMMAND_MODE);
}/*}}}*/
/* dwb_command_mode {{{*/
DwbStatus
-commands_only(KeyMap *km, Arg *arg) {
- DwbStatus ret = STATUS_ERROR;
- GList *l = dwb.state.views, *next;
- while (l) {
- next = l->next;
- if (l != dwb.state.fview) {
- view_remove(l);
- ret = STATUS_OK;
+commands_only(KeyMap *km, Arg *arg)
+{
+ DwbStatus ret = STATUS_ERROR;
+ GList *l = dwb.state.views, *next;
+ while (l)
+ {
+ next = l->next;
+ if (l != dwb.state.fview)
+ {
+ view_remove(l);
+ ret = STATUS_OK;
+ }
+ l = next;
}
- l = next;
- }
- return ret;
+ return ret;
}/*}}}*/
static void
-commands_set_bars(int status) {
- gtk_widget_set_visible(dwb.gui.topbox, (status & BAR_VIS_TOP) && (GET_BOOL("show-single-tab") || dwb.state.views->next));
- gtk_widget_set_visible(dwb.gui.bottombox, status & BAR_VIS_STATUS);
- if ((status & BAR_VIS_STATUS) ) {
- dwb_dom_remove_from_parent(WEBKIT_DOM_NODE(CURRENT_VIEW()->hover.element), NULL);
- }
+commands_set_bars(int status)
+{
+ gtk_widget_set_visible(dwb.gui.topbox, (status & BAR_VIS_TOP) && (GET_BOOL("show-single-tab") || dwb.state.views->next));
+ gtk_widget_set_visible(dwb.gui.bottombox, status & BAR_VIS_STATUS);
+ if ((status & BAR_VIS_STATUS) )
+ dwb_dom_remove_from_parent(WEBKIT_DOM_NODE(CURRENT_VIEW()->hover.element), NULL);
}
/* commands_toggle_bars {{{*/
DwbStatus
-commands_toggle_bars(KeyMap *km, Arg *arg) {
- dwb.state.bar_visible ^= arg->n;
- commands_set_bars(dwb.state.bar_visible);
- return STATUS_OK;
+commands_toggle_bars(KeyMap *km, Arg *arg)
+{
+ dwb.state.bar_visible ^= arg->n;
+ commands_set_bars(dwb.state.bar_visible);
+ return STATUS_OK;
}/*}}}*/
/* commands_presentation_mode {{{*/
DwbStatus
-commands_presentation_mode(KeyMap *km, Arg *arg) {
- static int last;
- if (dwb.state.bar_visible & BAR_PRESENTATION) {
- if (! dwb.state.fullscreen)
- gtk_window_unfullscreen(GTK_WINDOW(dwb.gui.window));
- commands_set_bars(last);
- dwb.state.bar_visible = last & ~BAR_PRESENTATION;
- }
- else {
- dwb.state.bar_visible |= BAR_PRESENTATION;
- if (! dwb.state.fullscreen)
- gtk_window_fullscreen(GTK_WINDOW(dwb.gui.window));
- commands_set_bars(0);
- last = dwb.state.bar_visible;
- dwb.state.bar_visible = BAR_PRESENTATION;
- }
- return STATUS_OK;
+commands_presentation_mode(KeyMap *km, Arg *arg)
+{
+ static int last;
+ if (dwb.state.bar_visible & BAR_PRESENTATION)
+ {
+ if (! dwb.state.fullscreen)
+ gtk_window_unfullscreen(GTK_WINDOW(dwb.gui.window));
+
+ commands_set_bars(last);
+ dwb.state.bar_visible = last & ~BAR_PRESENTATION;
+ }
+ else
+ {
+ dwb.state.bar_visible |= BAR_PRESENTATION;
+ if (! dwb.state.fullscreen)
+ gtk_window_fullscreen(GTK_WINDOW(dwb.gui.window));
+ commands_set_bars(0);
+ last = dwb.state.bar_visible;
+ dwb.state.bar_visible = BAR_PRESENTATION;
+ }
+ return STATUS_OK;
}/*}}}*/
/* commands_toggle_lock_protect {{{*/
DwbStatus
-commands_toggle_lock_protect(KeyMap *km, Arg *arg) {
+commands_toggle_lock_protect(KeyMap *km, Arg *arg)
+{
GList *gl = dwb.state.nummod < 0 ? dwb.state.fview : g_list_nth(dwb.state.views, dwb.state.nummod-1);
if (gl == NULL)
return STATUS_ERROR;
+
View *v = VIEW(gl);
v->status->lockprotect ^= arg->n;
dwb_update_status(gl, NULL);
+
if (arg->n & LP_VISIBLE && gl != dwb.state.fview)
gtk_widget_set_visible(v->scroll, LP_VISIBLE(v));
+
return STATUS_OK;
}/*}}}*/
/* commands_execute_javascript {{{*/
DwbStatus
-commands_execute_javascript(KeyMap *km, Arg *arg) {
- static char *script;
- if (arg->p == NULL && script == NULL)
- return STATUS_ERROR;
- if (arg->p) {
- FREE0(script);
- script = g_strdup(arg->p);
- }
- WebKitWebView *wv = commands_get_webview_with_nummod();
- dwb_execute_script(webkit_web_view_get_focused_frame(wv), script, false);
- return STATUS_OK;
+commands_execute_javascript(KeyMap *km, Arg *arg)
+{
+ static char *script;
+ if (arg->p == NULL && script == NULL)
+ return STATUS_ERROR;
+ if (arg->p) {
+ FREE0(script);
+ script = g_strdup(arg->p);
+ }
+ WebKitWebView *wv = commands_get_webview_with_nummod();
+ dwb_execute_script(webkit_web_view_get_focused_frame(wv), script, false);
+ return STATUS_OK;
}/*}}}*/
/* commands_set {{{*/
DwbStatus
-commands_set(KeyMap *km, Arg *arg) {
- DwbStatus ret = STATUS_ERROR;
- const char *command = util_str_chug(arg->p);
- if (command && *command) {
- char **args = g_strsplit(command, " ", 2);
- if (g_strv_length(args) >= 2)
- ret = dwb_set_setting(args[0], args[1], arg->n);
- g_strfreev(args);
- }
- return ret;
+commands_set(KeyMap *km, Arg *arg)
+{
+ DwbStatus ret = STATUS_ERROR;
+ const char *command = util_str_chug(arg->p);
+ if (command && *command)
+ {
+ char **args = g_strsplit(command, " ", 2);
+ if (g_strv_length(args) >= 2)
+ ret = dwb_set_setting(args[0], args[1], arg->n);
+ g_strfreev(args);
+ }
+ return ret;
}/*}}}*/
/* commands_set {{{*/
DwbStatus
-commands_toggle_setting(KeyMap *km, Arg *arg) {
- const char *command = util_str_chug(arg->p);
- return dwb_toggle_setting(command, arg->n);
+commands_toggle_setting(KeyMap *km, Arg *arg)
+{
+ const char *command = util_str_chug(arg->p);
+ return dwb_toggle_setting(command, arg->n);
}/*}}}*/
DwbStatus
-commands_tab_move(KeyMap *km, Arg *arg) {
- int l = g_list_length(dwb.state.views);
- int newpos;
- if (dwb.state.views->next == NULL)
- return STATUS_ERROR;
- switch (arg->n) {
- case TAB_MOVE_LEFT : newpos = MAX(MIN(l-1, g_list_position(dwb.state.views, dwb.state.fview)-NUMMOD), 0); break;
- case TAB_MOVE_RIGHT : newpos = MAX(MIN(l-1, g_list_position(dwb.state.views, dwb.state.fview)+NUMMOD), 0); break;
- default : newpos = MAX(MIN(l, NUMMOD)-1, 0); break;
- }
- gtk_box_reorder_child(GTK_BOX(dwb.gui.topbox), CURRENT_VIEW()->tabevent, l-(newpos+1));
- gtk_box_reorder_child(GTK_BOX(dwb.gui.mainbox), CURRENT_VIEW()->scroll, newpos);
- dwb.state.views = g_list_remove_link(dwb.state.views, dwb.state.fview);
- GList *sibling = g_list_nth(dwb.state.views, newpos);
- g_list_position(dwb.state.fview, sibling);
- if (sibling == NULL) {
- GList *last = g_list_last(dwb.state.views);
- last->next = dwb.state.fview;
- dwb.state.fview->prev = last;
- }
- else if (sibling->prev == NULL) {
- dwb.state.views->prev = dwb.state.fview;
- dwb.state.fview->next = dwb.state.views;
- dwb.state.views = dwb.state.fview;
- }
- else {
- sibling->prev->next = dwb.state.fview;
- dwb.state.fview->prev = sibling->prev;
- sibling->prev = dwb.state.fview;
- dwb.state.fview->next = sibling;
- }
- dwb_focus(dwb.state.fview);
- dwb_update_layout();
- return STATUS_OK;
+commands_tab_move(KeyMap *km, Arg *arg)
+{
+ GList *sibling;
+ int newpos;
+ int l = g_list_length(dwb.state.views);
+ if (dwb.state.views->next == NULL)
+ return STATUS_ERROR;
+ switch (arg->n)
+ {
+ case TAB_MOVE_LEFT : newpos = MAX(MIN(l-1, g_list_position(dwb.state.views, dwb.state.fview)-NUMMOD), 0); break;
+ case TAB_MOVE_RIGHT : newpos = MAX(MIN(l-1, g_list_position(dwb.state.views, dwb.state.fview)+NUMMOD), 0); break;
+ default : newpos = MAX(MIN(l, NUMMOD)-1, 0); break;
+ }
+ gtk_box_reorder_child(GTK_BOX(dwb.gui.topbox), CURRENT_VIEW()->tabevent, l-(newpos+1));
+ gtk_box_reorder_child(GTK_BOX(dwb.gui.mainbox), CURRENT_VIEW()->scroll, newpos);
+
+ dwb.state.views = g_list_remove_link(dwb.state.views, dwb.state.fview);
+
+ sibling = g_list_nth(dwb.state.views, newpos);
+ g_list_position(dwb.state.fview, sibling);
+
+ if (sibling == NULL)
+ {
+ GList *last = g_list_last(dwb.state.views);
+ last->next = dwb.state.fview;
+ dwb.state.fview->prev = last;
+ }
+ else if (sibling->prev == NULL) {
+ dwb.state.views->prev = dwb.state.fview;
+ dwb.state.fview->next = dwb.state.views;
+ dwb.state.views = dwb.state.fview;
+ }
+ else
+ {
+ sibling->prev->next = dwb.state.fview;
+ dwb.state.fview->prev = sibling->prev;
+ sibling->prev = dwb.state.fview;
+ dwb.state.fview->next = sibling;
+ }
+ dwb_focus(dwb.state.fview);
+ dwb_update_layout();
+ return STATUS_OK;
}
DwbStatus
-commands_clear_tab(KeyMap *km, Arg *arg) {
- GList *gl = commands_get_view_from_nummod();
- view_clear_tab(gl);
- return STATUS_OK;
+commands_clear_tab(KeyMap *km, Arg *arg)
+{
+ GList *gl = commands_get_view_from_nummod();
+ view_clear_tab(gl);
+ return STATUS_OK;
}
DwbStatus
-commands_cancel_download(KeyMap *km, Arg *arg) {
- return download_cancel(dwb.state.nummod);
+commands_cancel_download(KeyMap *km, Arg *arg)
+{
+ return download_cancel(dwb.state.nummod);
}
DwbStatus
-commands_dump(KeyMap *km, Arg *arg) {
- char *data = dwb_get_raw_data(dwb.state.fview);
- if (data == NULL)
- return STATUS_ERROR;
- if (arg->p == NULL)
- puts(data);
- else {
- util_set_file_content(arg->p, data);
- arg->p = NULL;
- }
- return STATUS_OK;
+commands_dump(KeyMap *km, Arg *arg)
+{
+ char *data = dwb_get_raw_data(dwb.state.fview);
+ if (data == NULL)
+ return STATUS_ERROR;
+
+ if (arg->p == NULL)
+ puts(data);
+ else
+ {
+ util_set_file_content(arg->p, data);
+ arg->p = NULL;
+ }
+ return STATUS_OK;
}
/*{{{*/
DwbStatus
-commands_sanitize(KeyMap *km, Arg *arg) {
- Sanitize s = util_string_to_sanitize(arg->p);
- if (s == SANITIZE_ERROR) {
- return STATUS_ERROR;
- }
- if (s & SANITIZE_HISTORY) {
- dwb_free_list(dwb.fc.history, (void_func)dwb_navigation_free);
- dwb.fc.history = NULL;
- remove(dwb.files[FILES_HISTORY]);
- }
- if (s & (SANITIZE_HISTORY | SANITIZE_CACHE)) {
- for (GList *gl = dwb.state.views; gl; gl=gl->next) {
- WebKitWebBackForwardList *bf_list = webkit_web_view_get_back_forward_list(WEBVIEW(gl));
- webkit_web_back_forward_list_clear(bf_list);
+commands_sanitize(KeyMap *km, Arg *arg)
+{
+ Sanitize s = util_string_to_sanitize(arg->p);
+ if (s == SANITIZE_ERROR)
+ return STATUS_ERROR;
+
+ if (s & SANITIZE_HISTORY)
+ {
+ dwb_free_list(dwb.fc.history, (void_func)dwb_navigation_free);
+ dwb.fc.history = NULL;
+ remove(dwb.files[FILES_HISTORY]);
}
- }
- if (s & SANITIZE_COOKIES) {
- remove(dwb.files[FILES_COOKIES]);
- }
- if (s & (SANITIZE_CACHE | SANITIZE_COOKIES)) {
- dwb_soup_clear_cookies();
- }
- if (s & (SANITIZE_SESSION)) {
- session_clear_session();
- }
- if (s & (SANITIZE_ALLSESSIONS)) {
- remove(dwb.files[FILES_SESSION]);
- }
- dwb_set_normal_message(dwb.state.fview, true, "Sanitized %s", arg->p ? arg->p : "all");
- return STATUS_OK;
+ if (s & (SANITIZE_HISTORY | SANITIZE_CACHE))
+ {
+ for (GList *gl = dwb.state.views; gl; gl=gl->next)
+ {
+ WebKitWebBackForwardList *bf_list = webkit_web_view_get_back_forward_list(WEBVIEW(gl));
+ webkit_web_back_forward_list_clear(bf_list);
+ }
+ }
+ if (s & SANITIZE_COOKIES)
+ remove(dwb.files[FILES_COOKIES]);
+
+ if (s & (SANITIZE_CACHE | SANITIZE_COOKIES))
+ dwb_soup_clear_cookies();
+
+ if (s & (SANITIZE_SESSION))
+ session_clear_session();
+
+ if (s & (SANITIZE_ALLSESSIONS))
+ remove(dwb.files[FILES_SESSION]);
+
+ dwb_set_normal_message(dwb.state.fview, true, "Sanitized %s", arg->p ? arg->p : "all");
+ return STATUS_OK;
}/*}}}*/
DwbStatus
-commands_eval(KeyMap *km, Arg *arg) {
- if (arg->p != NULL) {
- if (scripts_execute_one(arg->p))
+commands_eval(KeyMap *km, Arg *arg)
+{
+ if (arg->p != NULL && scripts_execute_one(arg->p))
+ {
return STATUS_OK;
}
return STATUS_ERROR;
@@ -862,23 +989,27 @@ commands_eval(KeyMap *km, Arg *arg) {
/*}}}*/
DwbStatus
-commands_download(KeyMap *km, Arg *arg) {
- WebKitNetworkRequest *request = webkit_network_request_new(CURRENT_URL());
- if (request != NULL) {
- dwb.state.mimetype_request = NULL;
- WebKitDownload *download = webkit_download_new(request);
- download_get_path(dwb.state.fview, download);
- }
- return STATUS_OK;
+commands_download(KeyMap *km, Arg *arg)
+{
+ WebKitNetworkRequest *request = webkit_network_request_new(CURRENT_URL());
+ if (request != NULL)
+ {
+ dwb.state.mimetype_request = NULL;
+ WebKitDownload *download = webkit_download_new(request);
+ download_get_path(dwb.state.fview, download);
+ }
+ return STATUS_OK;
}
DwbStatus
-commands_toggle_tab(KeyMap *km, Arg *arg) {
- GList *last = g_list_nth(dwb.state.views, dwb.state.last_tab);
- if (last) {
- dwb_focus_view(last);
- return STATUS_OK;
- }
- return STATUS_ERROR;
+commands_toggle_tab(KeyMap *km, Arg *arg)
+{
+ GList *last = g_list_nth(dwb.state.views, dwb.state.last_tab);
+ if (last)
+ {
+ dwb_focus_view(last);
+ return STATUS_OK;
+ }
+ return STATUS_ERROR;
}
#if 0
@@ -895,37 +1026,40 @@ commands_group_show(KeyMap *km, Arg *arg) {
}
return STATUS_OK;
}
-#endif
DwbStatus
-commands_group_toggle(KeyMap *km, Arg *arg) {
- int n = MIN(NUMMOD, 9), i=0;
- dwb.state.current_groups ^= (1<<n);
- for (GList *gl = dwb.state.views; gl; gl=gl->next, i++) {
+commands_group_toggle(KeyMap *km, Arg *arg)
+{
+ int n = MIN(NUMMOD, 9), i=0;
+ dwb.state.current_groups ^= (1<<n);
+ for (GList *gl = dwb.state.views; gl; gl=gl->next, i++)
+ {
- }
- printf("%d\n", dwb.state.current_groups);
- return STATUS_OK;
+ }
+ printf("%d\n", dwb.state.current_groups);
+ return STATUS_OK;
}
DwbStatus
-commands_group_tag(KeyMap *km, Arg *arg) {
- int n = MIN(NUMMOD, 9);
- if (dwb.state.nummod > 9 || dwb.state.nummod < 0)
- return STATUS_ERROR;
- CURRENT_VIEW()->status->group &= (1<<n);
- tab_update(dwb.state.fview);
-
- //if (CURRENT_VIEW()->status->group & (1<<n)) {
- // CURRENT_VIEW()->status->group &= ~(1<<n);
- // if (!GROUP_VISIBLE(dwb.state.fview))
- // dwb_hide_tab(dwb.state.fview);
- // dwb_set_normal_message(dwb.state.fview, true, "Untagged group %d", n);
- //}
- //else {
- // CURRENT_VIEW()->status->group |= 1<<n;
- // if (GROUP_VISIBLE(dwb.state.fview))
- // dwb_show_tab(dwb.state.fview);
- // dwb_set_normal_message(dwb.state.fview, true, "Tagged group %d", n);
- //}
+commands_group_tag(KeyMap *km, Arg *arg)
+{
+ int n = MIN(NUMMOD, 9);
+ if (dwb.state.nummod > 9 || dwb.state.nummod < 0)
+ return STATUS_ERROR;
+ CURRENT_VIEW()->status->group &= (1<<n);
+ tab_update(dwb.state.fview);
+
+ //if (CURRENT_VIEW()->status->group & (1<<n)) {
+ // CURRENT_VIEW()->status->group &= ~(1<<n);
+ // if (!GROUP_VISIBLE(dwb.state.fview))
+ // dwb_hide_tab(dwb.state.fview);
+ // dwb_set_normal_message(dwb.state.fview, true, "Untagged group %d", n);
+ //}
+ //else {
+ // CURRENT_VIEW()->status->group |= 1<<n;
+ // if (GROUP_VISIBLE(dwb.state.fview))
+ // dwb_show_tab(dwb.state.fview);
+ // dwb_set_normal_message(dwb.state.fview, true, "Tagged group %d", n);
+ //}
- return STATUS_OK;
+ return STATUS_OK;
}
+#endif