From: Lars Magne Ingebrigtsen Date: Thu, 23 Jun 2011 00:17:41 +0000 (+0200) Subject: Clean up the ssl/tls support to be able to use the built-in support, too. X-Git-Tag: emacs-pretest-24.0.90~104^2~464 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=c4db078bfdea38627518a92872885e2948db48d3;p=emacs.git Clean up the ssl/tls support to be able to use the built-in support, too. --- diff --git a/lisp/erc/ChangeLog b/lisp/erc/ChangeLog index f1c0b2d1c65..3d9b0c8646f 100644 --- a/lisp/erc/ChangeLog +++ b/lisp/erc/ChangeLog @@ -1,3 +1,12 @@ +2011-06-23 Lars Magne Ingebrigtsen + + * erc.el (erc-ssl): Made into a synonym for erc-tls, which + provides a superset of the same functionality. + (erc-open-ssl-stream): Removed. + (erc-open-tls-stream): Use `open-network-stream' instead of + `open-tls-stream' directly to be able to use the built-in TLS + support. + 2011-05-28 Stefan Monnier * erc-pcomplete.el (erc-pcompletions-at-point): Mark the completion diff --git a/lisp/erc/erc.el b/lisp/erc/erc.el index a8c592696ad..bab8fd1e455 100644 --- a/lisp/erc/erc.el +++ b/lisp/erc/erc.el @@ -2164,34 +2164,7 @@ be invoked for the values of the other parameters." ;;;###autoload (defalias 'erc-select 'erc) - -(defun erc-ssl (&rest r) - "Interactively select SSL connection parameters and run ERC. -Arguments are the same as for `erc'." - (interactive (erc-select-read-args)) - (let ((erc-server-connect-function 'erc-open-ssl-stream)) - (apply 'erc r))) - -(defalias 'erc-select-ssl 'erc-ssl) - -(declare-function open-ssl-stream "ext:ssl" (name buffer host service)) - -(defun erc-open-ssl-stream (name buffer host port) - "Open an SSL stream to an IRC server. -The process will be given the name NAME, its target buffer will be -BUFFER. HOST and PORT specify the connection target." - (when (condition-case nil - (require 'ssl) - (error (message "You don't have ssl.el. %s" - "Try using `erc-tls' instead.") - nil)) - (let ((proc (open-ssl-stream name buffer host port))) - ;; Ugly hack, but it works for now. Problem is it is - ;; very hard to detect when ssl is established, because s_client - ;; doesn't give any CONNECTIONESTABLISHED kind of message, and - ;; most IRC servers send nothing and wait for you to identify. - (sit-for 5) - proc))) +(defalias 'erc-ssl 'erc-tls) (defun erc-tls (&rest r) "Interactively select TLS connection parameters and run ERC. @@ -2200,18 +2173,12 @@ Arguments are the same as for `erc'." (let ((erc-server-connect-function 'erc-open-tls-stream)) (apply 'erc r))) -(declare-function open-tls-stream "tls" (name buffer host port)) - (defun erc-open-tls-stream (name buffer host port) "Open an TLS stream to an IRC server. The process will be given the name NAME, its target buffer will be BUFFER. HOST and PORT specify the connection target." - (when (condition-case nil - (require 'tls) - (error (message "You don't have tls.el. %s" - "Try using `erc-ssl' instead.") - nil)) - (open-tls-stream name buffer host port))) + (open-network-stream name buffer host port + :type 'tls))) ;;; Displaying error messages