unofficial mirror of emacs-devel@gnu.org 
 help / color / mirror / code / Atom feed
* frameset-to-register
@ 2013-08-05  5:12 Juanma Barranquero
  2013-08-05 13:11 ` frameset-to-register Juanma Barranquero
  2013-08-05 20:35 ` frameset-to-register Drew Adams
  0 siblings, 2 replies; 8+ messages in thread
From: Juanma Barranquero @ 2013-08-05  5:12 UTC (permalink / raw)
  To: Emacs developers

This code adds a new frameset-to-register command.

Assuming that it is OK to install it, keybindings in the C-x r space
are scarce. I propose to bind it to C-x r F, which is already co-opted
by frame-configuration-to-register (via C-x r f) and seems mnemonic
enough.

   Juanma




=== modified file 'lisp/register.el'
--- lisp/register.el    2013-03-26 02:49:05 +0000
+++ lisp/register.el    2013-08-05 05:07:08 +0000
@@ -132,6 +132,20 @@
   ;; of point in the current buffer, so record that separately.
   (set-register register (list (current-frame-configuration) (point-marker))))

+(defun frameset-to-register (register &optional _arg)
+  "Store the current frameset in register REGISTER.
+Use \\[jump-to-register] to restore the frameset.
+Argument is a character, naming the register."
+  (interactive "cFrameset to register: \nP")
+  (set-register register
+               (list (frameset-save nil
+                                    :filters frameset-live-filter-alist
+                                    :properties '(:app register))
+                     ;; frameset-save does not include the value of point
+                     ;; in the current buffer, so record that separately.
+                     (frame-parameter nil 'frameset--id)
+                     (point-marker))))
+
 (defalias 'register-to-point 'jump-to-register)
 (defun jump-to-register (register &optional delete)
   "Move point to location stored in a register.
@@ -157,6 +171,18 @@
      ((and (consp val) (window-configuration-p (car val)))
       (set-window-configuration (car val))
       (goto-char (cadr val)))
+     ((and (consp val) (frameset-p (car val)))
+      (frameset-restore (car val)
+                       :filters frameset-live-filter-alist
+                       :reuse-frames t)
+      ;; At this point, cl-lib is loaded via frameset.el
+      (let ((frame (cl-find-if (lambda (f)
+                                (string= (frame-parameter f 'frameset--id)
+                                         (cadr val)))
+                              (frame-list))))
+       (when frame
+         (select-frame-set-input-focus frame)
+         (goto-char (nth 2 val)))))
      ((markerp val)
       (or (marker-buffer val)
          (error "That register's buffer no longer exists"))
@@ -269,6 +295,9 @@
      ((and (consp val) (frame-configuration-p (car val)))
       (princ "a frame configuration."))

+     ((and (consp val) (frameset-p (car val)))
+      (princ "a frameset."))
+
      ((and (consp val) (eq (car val) 'file))
       (princ "the file ")
       (prin1 (cdr val))



^ permalink raw reply	[flat|nested] 8+ messages in thread
* frameset-to-register
@ 2014-02-12 22:59 Juanma Barranquero
  2014-02-13  0:34 ` frameset-to-register Stefan Monnier
  0 siblings, 1 reply; 8+ messages in thread
From: Juanma Barranquero @ 2014-02-12 22:59 UTC (permalink / raw)
  To: Emacs developers

I'd like to commit this small patch, which basically makes the output
of list-registers/view-register a bit more informative for framesets.

It's not a bug fix, but OTOH, frameset-to-register is a new feature by
itself and this is just making the feature a bit better.

OK to install, or do I wait for the unfreezing?

   J



=== modified file 'lisp/frameset.el'
--- lisp/frameset.el 2014-02-11 20:48:23 +0000
+++ lisp/frameset.el 2014-02-12 22:42:11 +0000
@@ -1223,6 +1223,16 @@
     (set-frame-selected-window frame window)
     (with-current-buffer buffer (goto-char position))))))))

+(defun frameset--print-register (data)
+  "Print basic info about frameset stored in DATA.
+Called from `list-registers' and `view-register'.  Internal use only."
+  (let* ((fs (aref data 0))
+ (ns (length (frameset-states fs))))
+    (princ (format "a frameset (%d frame%s, saved on %s)."
+   ns
+   (if (= 1 ns) "" "s")
+   (format-time-string "%c" (frameset-timestamp fs))))))
+
 ;;;###autoload
 (defun frameset-to-register (register)
   "Store the current frameset in register REGISTER.
@@ -1240,7 +1250,7 @@
  ;; in the current buffer, so record that separately.
  (frameset-frame-id nil)
  (point-marker))
- :print-func (lambda (_data) (princ "a frameset."))
+ :print-func #'frameset--print-register
  :jump-func #'frameset--jump-to-register)))

 (provide 'frameset)



^ permalink raw reply	[flat|nested] 8+ messages in thread

end of thread, other threads:[~2014-02-13  0:34 UTC | newest]

Thread overview: 8+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2013-08-05  5:12 frameset-to-register Juanma Barranquero
2013-08-05 13:11 ` frameset-to-register Juanma Barranquero
2013-08-05 20:35 ` frameset-to-register Drew Adams
2013-08-05 20:49   ` frameset-to-register Juanma Barranquero
2013-08-06 21:11     ` frameset-to-register Stefan Monnier
2013-08-08  0:49       ` frameset-to-register Juanma Barranquero
  -- strict thread matches above, loose matches on Subject: below --
2014-02-12 22:59 frameset-to-register Juanma Barranquero
2014-02-13  0:34 ` frameset-to-register Stefan Monnier

Code repositories for project(s) associated with this public inbox

	https://git.savannah.gnu.org/cgit/emacs.git

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).