The Lambda Lab
/
projects
/
elpher.git
/ commitdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
| commitdiff |
tree
raw
|
patch
|
inline
| side by side (parent:
798c375
)
Experimenting with asynchronous connections.
author
Tim Vaughan
<tgvaughan@gmail.com>
Thu, 24 Oct 2019 11:32:11 +0000
(13:32 +0200)
committer
Tim Vaughan
<tgvaughan@gmail.com>
Thu, 24 Oct 2019 11:32:11 +0000
(13:32 +0200)
elpher.el
patch
|
blob
|
history
diff --git
a/elpher.el
b/elpher.el
index
fc4416c
..
db5a820
100644
(file)
--- a/
elpher.el
+++ b/
elpher.el
@@
-60,6
+60,7
@@
(require 'shr)
(require 'url-util)
(require 'subr-x)
(require 'shr)
(require 'url-util)
(require 'subr-x)
+(require 'dns)
;;; Global constants
;;; Global constants
@@
-505,9
+506,10
@@
up to the calling function."
(condition-case the-error
(let* ((kill-buffer-query-functions nil)
(port (elpher-address-port address))
(condition-case the-error
(let* ((kill-buffer-query-functions nil)
(port (elpher-address-port address))
+ (host (elpher-address-host address))
(proc (open-network-stream "elpher-process"
nil
(proc (open-network-stream "elpher-process"
nil
- (elpher-address-host address)
+ host
(if (> port 0) port 70)
:type (if elpher-use-tls 'tls 'plain))))
(set-process-coding-system proc 'binary)
(if (> port 0) port 70)
:type (if elpher-use-tls 'tls 'plain))))
(set-process-coding-system proc 'binary)
@@
-782,11
+784,13
@@
The response is stored in the variable ‘elpher-gemini-response’."
(let* ((kill-buffer-query-functions nil)
(network-security-level 'medium)
(port (elpher-address-port address))
(let* ((kill-buffer-query-functions nil)
(network-security-level 'medium)
(port (elpher-address-port address))
+ (host (elpher-address-host address))
(proc (open-network-stream "elpher-process"
nil
(proc (open-network-stream "elpher-process"
nil
- (elpher-address-host address)
+ host
(if (> port 0) port 1965)
(if (> port 0) port 1965)
- :type 'tls)))
+ :type 'tls
+ :nowait t)))
(set-process-coding-system proc 'binary)
(set-process-filter proc
(lambda (_proc string)
(set-process-coding-system proc 'binary)
(set-process-filter proc
(lambda (_proc string)
@@
-832,7
+836,8
@@
The response is assumed to be in the variable `elpher-gemini-response'."
(query-address (elpher-address-from-url (concat url "?" query-string))))
(elpher-get-gemini-response query-address
(lambda (_proc event)
(query-address (elpher-address-from-url (concat url "?" query-string))))
(elpher-get-gemini-response query-address
(lambda (_proc event)
- (unless (string-prefix-p "deleted" event)
+ (unless (or (string-prefix-p "deleted" event)
+ (string-prefix-p "open" event))
(funcall #'elpher-process-gemini-response
renderer)
(elpher-restore-pos))))))
(funcall #'elpher-process-gemini-response
renderer)
(elpher-restore-pos))))))
@@
-853,7
+858,8
@@
The response is assumed to be in the variable `elpher-gemini-response'."
(add-to-list 'elpher-gemini-redirect-chain redirect-address)
(elpher-get-gemini-response redirect-address
(lambda (_proc event)
(add-to-list 'elpher-gemini-redirect-chain redirect-address)
(elpher-get-gemini-response redirect-address
(lambda (_proc event)
- (unless (string-prefix-p "deleted" event)
+ (unless (or (string-prefix-p "deleted" event)
+ (string-prefix-p "open" event))
(funcall #'elpher-process-gemini-response
renderer)
(elpher-restore-pos))))))
(funcall #'elpher-process-gemini-response
renderer)
(elpher-restore-pos))))))
@@
-885,7
+891,8
@@
The response is assumed to be in the variable `elpher-gemini-response'."
(setq elpher-gemini-redirect-chain nil)
(elpher-get-gemini-response address
(lambda (_proc event)
(setq elpher-gemini-redirect-chain nil)
(elpher-get-gemini-response address
(lambda (_proc event)
- (unless (string-prefix-p "deleted" event)
+ (unless (or (string-prefix-p "deleted" event)
+ (string-prefix-p "open" event))
(funcall #'elpher-process-gemini-response
renderer)
(elpher-restore-pos)))))
(funcall #'elpher-process-gemini-response
renderer)
(elpher-restore-pos)))))