From 083c922ebcece6fc7a7545225d1096d0d49d95c3 Mon Sep 17 00:00:00 2001 From: Case Duckworth Date: Wed, 15 Sep 2021 17:33:12 -0500 Subject: Patch circe --- lisp/acdw-irc.el | 35 +++++++++++++++++++++++++++++++++++ 1 file changed, 35 insertions(+) (limited to 'lisp') diff --git a/lisp/acdw-irc.el b/lisp/acdw-irc.el index b4b75ec..305dc93 100644 --- a/lisp/acdw-irc.el +++ b/lisp/acdw-irc.el @@ -73,6 +73,41 @@ and right on t." (dolist (network (mapcar #'car circe-network-options)) (circe-maybe-connect network))) +(el-patch-feature circe) +(with-eval-after-load 'circe + (defvar circe-server-buffer-action 'pop-to-buffer-same-window + "What to do with `circe-server' buffers when created.") + + (el-patch-defun circe (network-or-server &rest server-options) + "Connect to IRC. + +Connect to the given network specified by NETWORK-OR-SERVER. + +When this function is called, it collects options from the +SERVER-OPTIONS argument, the user variable +`circe-network-options', and the defaults found in +`circe-network-defaults', in this order. + +If NETWORK-OR-SERVER is not found in any of these variables, the +argument is assumed to be the host name for the server, and all +relevant settings must be passed via SERVER-OPTIONS. + +All SERVER-OPTIONS are treated as variables by getting the string +\"circe-\" prepended to their name. This variable is then set +locally in the server buffer. + +See `circe-network-options' for a list of common options." + (interactive (circe--read-network-and-options)) + (let* ((options (circe--server-get-network-options network-or-server + server-options)) + (buffer (circe--server-generate-buffer options))) + (with-current-buffer buffer + (circe-server-mode) + (circe--server-set-variables options) + (circe-reconnect)) + (el-patch-swap (pop-to-buffer-same-window buffer) + (funcall circe-server-buffer-action buffer))))) + (defun circe-network-connected-p (network) "Return non-nil if there's any Circe server-buffer whose `circe-server-netwok' is NETWORK." -- cgit 1.4.1-21-gabe81 From cbe051fd637dc529d271331a49582c9f60b26ba8 Mon Sep 17 00:00:00 2001 From: Case Duckworth Date: Wed, 15 Sep 2021 17:33:49 -0500 Subject: Add acdw/org-export-copy Better'n `acdw/copy-region-plain' --- lisp/acdw.el | 24 ++++++++++++++++++++++++ 1 file changed, 24 insertions(+) (limited to 'lisp') diff --git a/lisp/acdw.el b/lisp/acdw.el index 0790f2e..40aff5d 100644 --- a/lisp/acdw.el +++ b/lisp/acdw.el @@ -395,6 +395,30 @@ first." (setq deactivate-mark t) nil) +(defun acdw/org-export-copy () + "copy a tree" + (interactive) + (require 'ox-ascii) + (let ((extracted-heading (acdw/org-extract-heading-text))) + ;; Export to ASCII - not async, subtree only, visible-only, body-only + (let ((org-export-show-temporary-export-buffer nil)) + (org-ascii-export-as-ascii nil t t t)) + (with-current-buffer "*Org ASCII Export*" + (goto-char (point-min)) + (insert extracted-heading) + (newline) + (newline) + + (unfill-region (point-min) (point-max)) + (flush-lines "^$" (point-min) (point-max)) + + (copy-region-as-kill (point-min) (point-max))) + + (when (called-interactively-p 'interactive) + (indicate-copied-region)) + (setq deactivate-mark t) + nil)) + (defun acdw/org-extract-heading-text () "Extract the heading text from an `org-mode' heading." (let ((heading (org-no-properties (org-get-heading t t t t)))) -- cgit 1.4.1-21-gabe81