diff options
| -rw-r--r-- | lisp/register.el | 28 | ||||
| -rw-r--r-- | lisp/window.el | 14 | 
2 files changed, 23 insertions, 19 deletions
| diff --git a/lisp/register.el b/lisp/register.el index 569e7e3b008..b12beb056e2 100644 --- a/lisp/register.el +++ b/lisp/register.el @@ -51,20 +51,38 @@ Argument is a character, naming the register."    (interactive "cPoint to register: \nP")    (set-register char (if arg (current-frame-configuration) (point-marker)))) +(defun window-configuration-to-register (char arg) +  "Store the window configuration of the selected frame in register REGISTER. +Use \\[jump-to-register] to restore the configuration. +Argument is a character, naming the register." +  (interactive "cPoint to register: \nP") +  (set-register char (current-window-configuration))) + +(defun frame-configuration-to-register (char arg) +  "Store the window configuration of all frames in register REGISTER. +Use \\[jump-to-register] to restore the configuration. +Argument is a character, naming the register." +  (interactive "cPoint to register: \nP") +  (set-register char (current-frame-configuration))) +  (fset 'register-to-point 'jump-to-register)  (defun jump-to-register (char)    "Move point to location stored in a register. +If the register contains a window configuration (one frame) or a frame +configuration (all frames), restore that frame or all frames accordingly.  Argument is a character, naming the register."    (interactive "cJump to register: ")    (let ((val (get-register char)))      (condition-case ()  	(set-frame-configuration val)        (error -       (if (markerp val) -	   (progn -	     (switch-to-buffer (marker-buffer val)) -	     (goto-char val)) -	 (error "Register doesn't contain a buffer position or frame configuration")))))) +       (if (window-configuration-p val) +	   (set-window-configuration val) +	 (if (markerp val) +	     (progn +	       (switch-to-buffer (marker-buffer val)) +	       (goto-char val)) +	   (error "Register doesn't contain a buffer position or configuration")))))))  ;(defun number-to-register (arg char)  ;  "Store a number in a register. diff --git a/lisp/window.el b/lisp/window.el index e2a403dff58..9cd82d8b0d1 100644 --- a/lisp/window.el +++ b/lisp/window.el @@ -110,22 +110,8 @@ ARG columns.  No arg means split equally."    (interactive "p")    (shrink-window arg t)) -(defun window-config-to-register (name) -  "Save the current window configuration in register REG (a letter). -It can be later retrieved using \\[M-x register-to-window-config]." -  (interactive "cSave window configuration in register: ") -  (set-register name (current-window-configuration))) - -(defun register-to-window-config (name) -  "Restore (make current) the window configuration in register REG (a letter). -Use with a register previously set with \\[window-config-to-register]." -  (interactive "cRestore window configuration from register: ") -  (set-window-configuration (get-register name))) -  (define-key ctl-x-map "2" 'split-window-vertically)  (define-key ctl-x-map "3" 'split-window-horizontally) -(define-key ctl-x-map "6" 'window-config-to-register) -(define-key ctl-x-map "7" 'register-to-window-config)  (define-key ctl-x-map "}" 'enlarge-window-horizontally)  (define-key ctl-x-map "{" 'shrink-window-horizontally) | 
