summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--doc/dwb.13
-rw-r--r--src/commands.c13
-rw-r--r--src/commands.h1
-rw-r--r--src/config.h6
-rw-r--r--src/dwb.c19
-rw-r--r--src/dwb.h2
6 files changed, 42 insertions, 2 deletions
diff --git a/doc/dwb.1 b/doc/dwb.1
index 8cbc94d4..bcbfc1b4 100644
--- a/doc/dwb.1
+++ b/doc/dwb.1
@@ -977,6 +977,8 @@ buffers |bu |Show all open tabs
cancel_download | |Cancel a download
clear_tab |clear |Clear tab
close_tab |close |Close tab
+dump | |Write html of current website to a
+ | |file or stdout if no argument is given
execute_javascript |exja |Execute a javascript snippet
execute_userscript | |Execute userscript
find_backward |bfind |Find backward
@@ -2013,6 +2015,7 @@ the variables
.IR DWB_PROFILE ,
.IR DWB_NUMMOD ,
.IR DWB_ARGUMENT ,
+.IR DWB_HTML_CONTENT ,
.IR DWB_REFERER ,
and
.I DWB_USER_AGENT
diff --git a/src/commands.c b/src/commands.c
index f882f45f..eae99baa 100644
--- a/src/commands.c
+++ b/src/commands.c
@@ -840,4 +840,17 @@ DwbStatus
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;
+}
/*}}}*/
diff --git a/src/commands.h b/src/commands.h
index df6d591e..1a52a247 100644
--- a/src/commands.h
+++ b/src/commands.h
@@ -92,5 +92,6 @@ DwbStatus commands_tab_move(KeyMap *, Arg *);
DwbStatus commands_clear_tab(KeyMap *, Arg *);
DwbStatus commands_cancel_download(KeyMap *, Arg *);
DwbStatus commands_normal_mode(KeyMap *, Arg *);
+DwbStatus commands_dump(KeyMap *, Arg *);
#endif
diff --git a/src/config.h b/src/config.h
index 8421c6ba..c514fd39 100644
--- a/src/config.h
+++ b/src/config.h
@@ -173,6 +173,7 @@ static KeyValue KEYS[] = {
{ "clear_tab", { "gc", 0 }, },
{ "cancel_download", { "ad", 0 }, },
{ "local_set", { NULL, 0 }, },
+ { "dump", { NULL, 0 }, },
};
/* FUNCTION_MAP{{{*/
@@ -190,7 +191,6 @@ static FunctionMap FMAP [] = {
{ .p = NULL }, EP_NONE, { "clear" }, },
{ { "execute_javascript", "Execute a javascript snippet", }, CP_COMMANDLINE,
-
(Func)commands_execute_javascript, NULL, ALWAYS_SM,
{ .p = NULL }, EP_NONE, { "exja", NULL }, },
@@ -205,6 +205,10 @@ static FunctionMap FMAP [] = {
(Func)commands_set, "Invalid value", POST_SM,
{ .p = NULL, .n = SET_LOCAL }, EP_NONE, { NULL }, },
+ { { "dump", "Write current website to a file or stdout", }, CP_COMMANDLINE,
+ (Func)commands_dump, NULL, POST_SM,
+ { .p = NULL }, EP_NONE, { NULL }, },
+
{ { "toggle_setting", "Toggle a setting", }, CP_COMMANDLINE,
(Func)commands_toggle_setting, "Invalid value", POST_SM,
{ .p = NULL , .n = SET_GLOBAL }, EP_NONE, { "toggle", "tog", NULL }, },
diff --git a/src/dwb.c b/src/dwb.c
index 8a4b97f5..53f75bb4 100644
--- a/src/dwb.c
+++ b/src/dwb.c
@@ -543,6 +543,19 @@ dwb_update_status_text(GList *gl, GtkAdjustment *a) {
/* FUNCTIONS {{{*/
+/* dwb_get_raw_data(GList *){{{*/
+char *
+dwb_get_raw_data(GList *gl) {
+ char *ret = NULL;
+ WebKitWebFrame *frame = webkit_web_view_get_main_frame(WEBVIEW(gl));
+ WebKitWebDataSource *data_source = webkit_web_frame_get_data_source(frame);
+ GString *data = webkit_web_data_source_get_data(data_source);
+ if (data != NULL) {
+ ret = data->str;
+ }
+ return ret;
+}/*}}}*/
+
DwbStatus/*{{{*/
dwb_scheme_handler(GList *gl, WebKitNetworkRequest *request) {
const char *handler = GET_CHAR("scheme-handler");
@@ -2455,12 +2468,18 @@ dwb_execute_user_script(KeyMap *km, Arg *a) {
list = g_slist_append(list, dwb_navigation_new("DWB_PROFILE", dwb.misc.profile));
list = g_slist_append(list, dwb_navigation_new("DWB_NUMMOD", nummod));
list = g_slist_append(list, dwb_navigation_new("DWB_ARGUMENT", a->p));
+
+ const char *raw_data = dwb_get_raw_data(dwb.state.fview);
+ list = g_slist_append(list, dwb_navigation_new("DWB_HTML_CONTENT", raw_data == NULL ? "" : raw_data));
+
const char *referer = soup_get_header(dwb.state.fview, "Referer");
if (referer != NULL)
list = g_slist_append(list, dwb_navigation_new("DWB_REFERER", referer));
+
const char *user_agent = soup_get_header(dwb.state.fview, "User-Agent");
if (user_agent != NULL)
list = g_slist_append(list, dwb_navigation_new("DWB_USER_AGENT", user_agent));
+
if (km->map->arg.b) {
dwb.misc.fifo = util_get_temp_filename("fifo_");
list = g_slist_append(list, dwb_navigation_new("DWB_FIFO", dwb.misc.fifo));
diff --git a/src/dwb.h b/src/dwb.h
index 4210ec93..73b562b5 100644
--- a/src/dwb.h
+++ b/src/dwb.h
@@ -887,6 +887,6 @@ DwbStatus dwb_scheme_handler(GList *gl, WebKitNetworkRequest *request);
GList *dwb_get_simple_list(GList *, const char *filename);
gboolean dwb_dom_remove_from_parent(WebKitDOMNode *node, GError **error);
-
+char * dwb_get_raw_data(GList *gl);
#endif