diff options
| -rw-r--r-- | elisp/geiser-popup.el | 49 | 
1 files changed, 8 insertions, 41 deletions
| diff --git a/elisp/geiser-popup.el b/elisp/geiser-popup.el index 0fa14f1..2f78763 100644 --- a/elisp/geiser-popup.el +++ b/elisp/geiser-popup.el @@ -1,6 +1,6 @@  ;; geiser-popup.el -- popup windows -;; Copyright (C) 2009 Jose Antonio Ortega Ruiz +;; Copyright (C) 2009, 2010 Jose Antonio Ortega Ruiz  ;; This program is free software; you can redistribute it and/or  ;; modify it under the terms of the Modified BSD License. You should @@ -10,41 +10,6 @@  ;; Start date: Sat Feb 07, 2009 14:05 - -(make-variable-buffer-local - (defvar geiser-popup--created-window nil)) - -(make-variable-buffer-local - (defvar geiser-popup--selected-window nil)) - -(defun geiser-popup--display (&optional buffer) -  (when buffer (set-buffer buffer)) -  (let ((selected-window (selected-window)) -        (buffer (current-buffer))) -    (unless (eq selected-window (get-buffer-window buffer)) -      (let ((windows)) -        (walk-windows (lambda (w) (push w windows)) nil t) -        (prog1 (pop-to-buffer buffer) -          (set (make-local-variable 'geiser-popup--created-window) -               (unless (memq (selected-window) windows) (selected-window))) -          (set (make-local-variable 'geiser-popup--selected-window) -               selected-window)))))) - -(defun geiser-popup--quit () -  (interactive) -  (let ((selected geiser-popup--selected-window) -        (created geiser-popup--created-window)) -    (bury-buffer) -    (when (eq created (selected-window)) (delete-window created)) -    (when (window-live-p selected) (select-window selected)))) - -(define-minor-mode geiser-popup-mode -  "Mode for displaying read only stuff" -  nil nil -  '(("q" . geiser-popup--quit)) -  (setq buffer-read-only t)) - -  ;;; Support for defining popup buffers and accessors:  (defvar geiser-popup--registry nil) @@ -53,19 +18,21 @@    (let ((get-buff (intern (format "geiser-%s--buffer" base)))          (pop-buff (intern (format "geiser-%s--pop-to-buffer" base)))          (with-macro (intern (format "geiser-%s--with-buffer" base))) -        (method (make-symbol "method"))) +        (method (make-symbol "method")) +        (buffer (make-symbol "buffer")))    `(progn       (add-to-list 'geiser-popup--registry ,name)       (defun ,get-buff ()         (or (get-buffer ,name)             (with-current-buffer (get-buffer-create ,name)               (,mode) -             (geiser-popup-mode) +             (view-mode-enable)               (current-buffer))))       (defun ,pop-buff (&optional ,method) -       (cond ((eq ,method 'buffer) (switch-to-buffer (,get-buff))) -             ((eq ,method 'frame) (switch-to-buffer-other-frame (,get-buff))) -             (t (geiser-popup--display (,get-buff))))) +       (let ((,buffer (,get-buff))) +         (cond ((eq ,method 'buffer) (view-buffer ,buffer)) +               ((eq ,method 'frame) (view-buffer-other-frame ,buffer)) +               (t (view-buffer-other-window ,buffer)))))       (defmacro ,with-macro (&rest body)         (let ((buff ',get-buff))           `(with-current-buffer (funcall ',buff) | 
