summaryrefslogtreecommitdiffstats
path: root/network/elinks/patches/0003-gopher_directory_links.patch
diff options
context:
space:
mode:
author David Woodfall2018-09-27 21:23:54 +0200
committer Willy Sudiarto Raharjo2018-09-29 02:47:38 +0200
commitdee957926712133d5a16bf78b4e275af7a6ec450 (patch)
tree478a6c2e872ac43c8e7d208493b496d0d7a03108 /network/elinks/patches/0003-gopher_directory_links.patch
parente464e4b03adae7f20853b3767fa917851388ef1b (diff)
downloadslackbuilds-dee957926712133d5a16bf78b4e275af7a6ec450.tar.gz
network/elinks: Add multiple build options and contributed code.
Diffstat (limited to 'network/elinks/patches/0003-gopher_directory_links.patch')
-rw-r--r--network/elinks/patches/0003-gopher_directory_links.patch61
1 files changed, 61 insertions, 0 deletions
diff --git a/network/elinks/patches/0003-gopher_directory_links.patch b/network/elinks/patches/0003-gopher_directory_links.patch
new file mode 100644
index 0000000000..dc80ef3728
--- /dev/null
+++ b/network/elinks/patches/0003-gopher_directory_links.patch
@@ -0,0 +1,61 @@
+#######################################################################
+# elinks does not follow links to directories on other servers
+# properly. This adds a '/' before the '1' at the start of a link and
+# removes any trailing 1.
+# dave@dawoodfall.net
+#######################################################################
+diff -Naur a/src/protocol/gopher/gopher.c b/src/protocol/gopher/gopher.c
+--- a/src/protocol/gopher/gopher.c 2017-12-17 01:54:27.941645180 +0000
++++ b/src/protocol/gopher/gopher.c 2017-12-17 21:52:05.072454433 +0000
+@@ -317,6 +317,9 @@
+ unsigned char *URL = "hURL%3";
+ unsigned char *CURI = "HURI%3";
+ unsigned char *CURL = "HURL%3";
++ unsigned char *DIR = "1";
++ unsigned char *SLASHDIR = "/1";
++ unsigned char *SLASHPOS;
+ int selectorlen = conn->uri->datalen;
+ struct gopher_entity_info *entity_info;
+ size_t size;
+@@ -354,6 +357,26 @@
+ selectorlen++;
+ }
+
++ if (entity_info->type == '1')
++ {
++ if (strstr(selector, DIR) == selector)
++ {
++ *selector++;
++ selectorlen--;
++ }
++ else
++ {
++ SLASHPOS = strstr(selector, SLASHDIR);
++ if (SLASHPOS != NULL)
++ {
++ if (strlen(SLASHPOS) == 2)
++ {
++ selectorlen--;
++ }
++ }
++ }
++ }
++
+ state = add_gopher_command(conn, &command, entity, selector, selectorlen);
+ if (!is_in_state(state, S_CONN))
+ return state;
+@@ -379,10 +402,10 @@
+ gopher->entity = entity_info;
+ gopher->commandlen = command.length;
+
+-debug_log("439 gopher->entity:", 1);
+-debug_log(gopher->entity, 1);
+-debug_log("437 command.source:", 1);
+-debug_log(command.source, 1);
++ debug_log("439 gopher->entity: ", 0);
++ debug_log(gopher->entity, 1);
++ debug_log("437 command.source: ", 0);
++ debug_log(command.source, 1);
+ memcpy(gopher->command, command.source, command.length);
+ done_string(&command);
+