diff options
author | Tatsuya Kinoshita <tats@debian.org> | 2020-10-24 06:16:10 +0000 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-10-24 06:16:10 +0000 |
commit | 35bc5aa8439829c44861a5c9b248572f5d5cac0b (patch) | |
tree | 540c98c6fabd9d92781fce7941fbe19173ca31ea /url.c | |
parent | Update ChangeLog (diff) | |
parent | Moved back filetype indicator to the beginning of file names (diff) | |
download | w3m-35bc5aa8439829c44861a5c9b248572f5d5cac0b.tar.gz w3m-35bc5aa8439829c44861a5c9b248572f5d5cac0b.zip |
Merge pull request #152 from bptato/master
Fix gopher support
Diffstat (limited to '')
-rw-r--r-- | url.c | 35 |
1 files changed, 35 insertions, 0 deletions
@@ -1570,6 +1570,11 @@ openURL(char *url, ParsedURL *pu, ParsedURL *current, Str tmp; int sock, scheme; char *p, *q, *u; +#ifdef USE_GOPHER + Str gophertmp; + char type; + int n; +#endif URLFile uf; HRequest hr0; #ifdef USE_SSL @@ -1833,6 +1838,33 @@ openURL(char *url, ParsedURL *pu, ParsedURL *current, break; #ifdef USE_GOPHER case SCM_GOPHER: + p = pu->file; + n = 0; + while(*p == '/') { + ++p; + ++n; + } + if(*p != '\0') { + type = pu->file[n]; + switch(type) { + case '0': + case '1': + case 'm': + case 's': + case 'g': + case 'h': + tmp = Strnew_charp(pu->file); + gophertmp = Strdup(tmp); + Strdelete(tmp, n, 1); + pu->file = tmp->ptr; + break; + default: + type = '\0'; + break; + } + } else { + type = '\0'; + } if (non_null(GOPHER_proxy) && !Do_not_use_proxy && pu->host != NULL && !check_no_proxy(pu->host)) { @@ -1855,6 +1887,9 @@ openURL(char *url, ParsedURL *pu, ParsedURL *current, Strcat_char(tmp, '\n'); } write(sock, tmp->ptr, tmp->length); + if(type != '\0') { + pu->file = gophertmp->ptr; + } break; #endif /* USE_GOPHER */ #ifdef USE_NNTP |