]> git.eshelyaron.com Git - emacs.git/commitdiff
(info-lookup): When Info buffer is visible on
authorMartin Rudalics <rudalics@gmx.at>
Sun, 23 Nov 2008 17:40:27 +0000 (17:40 +0000)
committerMartin Rudalics <rudalics@gmx.at>
Sun, 23 Nov 2008 17:40:27 +0000 (17:40 +0000)
another frame, raise that frame.

lisp/ChangeLog
lisp/info-look.el

index 090df75024f50a9ffaa40791d8319f6855615d2e..6b40ec39f2b0c87c60776950b78a1b8f81b1adff 100644 (file)
@@ -1,3 +1,8 @@
+2008-11-23  Martin Rudalics  <rudalics@gmx.at>
+
+       * info-look.el (info-lookup): When Info buffer is visible on
+       another frame, raise that frame.
+
 2008-11-23  Juanma Barranquero  <lekktu@gmail.com>
 
        * allout.el (allout-mode): Fix typo in docstring.
index fc8ff1e578b002ef87e527697ca0a644d6e99c4e..1373de9e24ad1a84ab3f284104b4214a961c1281 100644 (file)
@@ -335,22 +335,23 @@ If optional argument QUERY is non-nil, query for the help mode."
              (cons (list Info-current-file Info-current-node (point))
                    Info-history))))
          found doc-spec node prefix suffix doc-found)
-    (if (not (eq major-mode 'Info-mode))
-       (if (not info-lookup-other-window-flag)
-           (info)
-         (progn
-           (save-window-excursion (info))
-           ;; Determine whether or not the Info buffer is visible in
-           ;; another frame on the same display.  If it is, simply raise
-           ;; that frame.  Otherwise, display it in another window.
-           (let* ((window (get-buffer-window "*info*" t))
-                  (info-frame (and window (window-frame window))))
-             (if (and info-frame
-                      (display-multi-frame-p)
-                      (memq info-frame (frames-on-display-list))
-                      (not (eq info-frame (selected-frame))))
-                 (select-frame info-frame)
-               (switch-to-buffer-other-window "*info*"))))))
+    (unless (eq major-mode 'Info-mode)
+      (if (not info-lookup-other-window-flag)
+         (info)
+       (save-window-excursion (info))
+       (let* ((info-window (get-buffer-window "*info*" t))
+              (info-frame (and info-window (window-frame info-window))))
+         (if (and info-frame
+                  (not (eq info-frame (selected-frame)))
+                  (display-multi-frame-p)
+                  (memq info-frame (frames-on-display-list)))
+             ;; *info* is visible in another frame on same display.
+             ;; Raise that frame and select the window.
+             (progn
+               (select-window info-window)
+               (raise-frame info-frame))
+           ;; In any other case, switch to *info* in another window.
+           (switch-to-buffer-other-window "*info*")))))
     (while (and (not found) modes)
       (setq doc-spec (info-lookup->doc-spec topic (car modes)))
       (while (and (not found) doc-spec)