# HG changeset patch # User Glenn Morris # Date 1194139549 0 # Node ID 8f26c84d222f116e836894b3b7c5eb202290756c # Parent 97bb0fd6c11d900a7350cf14e6705ebf9371f4c2 Don't require rx when compiling. (tls-end-of-info): Rewrite without using rx. (open-tls-stream)): Use with-current-buffer. diff -r 97bb0fd6c11d -r 8f26c84d222f lisp/net/tls.el --- a/lisp/net/tls.el Sun Nov 04 01:22:45 2007 +0000 +++ b/lisp/net/tls.el Sun Nov 04 01:25:49 2007 +0000 @@ -51,37 +51,25 @@ (autoload 'format-spec "format-spec") (autoload 'format-spec-make "format-spec")) -(eval-when-compile - (require 'rx)) - (defgroup tls nil "Transport Layer Security (TLS) parameters." :group 'comm) (defcustom tls-end-of-info - (rx - (or - ;; `openssl s_client` regexp - (sequence - ;; see ssl/ssl_txt.c lines 219--220 - line-start - " Verify return code: " - (one-or-more not-newline) - "\n" - ;; according to apps/s_client.c line 1515 this is always the last - ;; line that is printed by s_client before the real data - "---\n") - ;; `gnutls` regexp - (sequence - ;; see src/cli.c lines 721-- - (sequence line-start "- Simple Client Mode:\n") - (zero-or-more - (or - "\n" ; ignore blank lines - ;; XXX: we have no way of knowing if the STARTTLS handshake - ;; sequence has completed successfully, because `gnutls` will - ;; only report failure. - (sequence line-start "\*\*\* Starting TLS handshake\n")))))) + (concat + "\\(" + ;; `openssl s_client' regexp. See ssl/ssl_txt.c lines 219-220. + ;; According to apps/s_client.c line 1515 `---' is always the last + ;; line that is printed by s_client before the real data. + "^ Verify return code: .+\n---\n\\|" + ;; `gnutls' regexp. See src/cli.c lines 721-. + "^- Simple Client Mode:\n" + "\\(\n\\|" ; ignore blank lines + ;; XXX: We have no way of knowing if the STARTTLS handshake sequence + ;; has completed successfully, because `gnutls' will only report + ;; failure. + "^\\*\\*\\* Starting TLS handshake\n\\)*" + "\\)") "Regexp matching end of TLS client informational messages. Client data stream begins after the last character matched by this. The default matches `openssl s_client' (version 0.9.8c) @@ -165,8 +153,7 @@ process cmd done) (if use-temp-buffer (setq buffer (generate-new-buffer " TLS"))) - (save-excursion - (set-buffer buffer) + (with-current-buffer buffer (message "Opening TLS connection to `%s'..." host) (while (and (not done) (setq cmd (pop cmds))) (message "Opening TLS connection with `%s'..." cmd)