annotate lisp/info.el @ 76022:e892213b9815

(w32_set_scroll_bar_thumb): Don't resize scroll-bar handle while dragging, except when we get close to eob. Fix position and size calculations so we don't scroll backwards just by clicking on the handle.
author Kim F. Storm <storm@cua.dk>
date Mon, 19 Feb 2007 14:45:39 +0000
parents 9d47b3ad340e
children a05e2047bdb8 52a7f3f50b89
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
38412
253f761ad37b Some fixes to follow coding conventions in files maintained by FSF.
Pavel Janík <Pavel@Janik.cz>
parents: 38407
diff changeset
1 ;;; info.el --- info package for Emacs
807
4f28bd14272c *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 754
diff changeset
2
62822
7f11f471aa34 (Info-goto-node): Revert autoload addition (2004-06-12).
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 62733
diff changeset
3 ;; Copyright (C) 1985, 1986, 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999,
75347
e3694f1cb928 Add 2007 to copyright years.
Glenn Morris <rgm@gnu.org>
parents: 75271
diff changeset
4 ;; 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007 Free Software Foundation, Inc.
846
20674ae6bf52 *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 811
diff changeset
5
807
4f28bd14272c *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 754
diff changeset
6 ;; Maintainer: FSF
811
e694e0879463 *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 807
diff changeset
7 ;; Keywords: help
807
4f28bd14272c *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 754
diff changeset
8
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
9 ;; This file is part of GNU Emacs.
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
10
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
11 ;; GNU Emacs is free software; you can redistribute it and/or modify
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
12 ;; it under the terms of the GNU General Public License as published by
807
4f28bd14272c *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 754
diff changeset
13 ;; the Free Software Foundation; either version 2, or (at your option)
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
14 ;; any later version.
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
15
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
16 ;; GNU Emacs is distributed in the hope that it will be useful,
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
17 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
18 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
19 ;; GNU General Public License for more details.
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
20
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
21 ;; You should have received a copy of the GNU General Public License
14169
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13990
diff changeset
22 ;; along with GNU Emacs; see the file COPYING. If not, write to the
64091
6fb026ad601f Update FSF's address.
Lute Kamstra <lute@gnu.org>
parents: 64071
diff changeset
23 ;; Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
6fb026ad601f Update FSF's address.
Lute Kamstra <lute@gnu.org>
parents: 64071
diff changeset
24 ;; Boston, MA 02110-1301, USA.
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
25
807
4f28bd14272c *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 754
diff changeset
26 ;;; Commentary:
4f28bd14272c *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 754
diff changeset
27
64812
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
28 ;; Note that nowadays we expect Info files to be made using makeinfo.
49424
59c37b87bb18 (Info-try-follow-nearest-node): Add case: Handle menu item
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 49390
diff changeset
29 ;; In particular we make these assumptions:
59c37b87bb18 (Info-try-follow-nearest-node): Add case: Handle menu item
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 49390
diff changeset
30 ;; - a menu item MAY contain colons but not colon-space ": "
59c37b87bb18 (Info-try-follow-nearest-node): Add case: Handle menu item
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 49390
diff changeset
31 ;; - a menu item ending with ": " (but not ":: ") is an index entry
59c37b87bb18 (Info-try-follow-nearest-node): Add case: Handle menu item
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 49390
diff changeset
32 ;; - a node name MAY NOT contain a colon
49426
7ac32aa920b9 (Info-extract-menu-node-name): When looking for end of
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 49424
diff changeset
33 ;; This distinction is to support indexing of computer programming
7ac32aa920b9 (Info-extract-menu-node-name): When looking for end of
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 49424
diff changeset
34 ;; language terms that may contain ":" but not ": ".
807
4f28bd14272c *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 754
diff changeset
35
4f28bd14272c *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 754
diff changeset
36 ;;; Code:
4f28bd14272c *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 754
diff changeset
37
25869
620e4683a89e Require jka-compr when compiling.
Dave Love <fx@gnu.org>
parents: 25811
diff changeset
38 (eval-when-compile (require 'jka-compr))
620e4683a89e Require jka-compr when compiling.
Dave Love <fx@gnu.org>
parents: 25811
diff changeset
39
17430
de68258fef5f Add defgroup; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 17154
diff changeset
40 (defgroup info nil
64013
9ee64186bcf1 (info): Finish `defgroup' description with period.
Juanma Barranquero <lekktu@gmail.com>
parents: 63935
diff changeset
41 "Info subsystem."
17430
de68258fef5f Add defgroup; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 17154
diff changeset
42 :group 'help
de68258fef5f Add defgroup; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 17154
diff changeset
43 :group 'docs)
de68258fef5f Add defgroup; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 17154
diff changeset
44
de68258fef5f Add defgroup; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 17154
diff changeset
45
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
46 (defvar Info-history nil
64812
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
47 "Stack of Info nodes user has visited.
64071
5a1b36dec43a (Info-history, Info-history-forward, Info-history-list,
Juanma Barranquero <lekktu@gmail.com>
parents: 64013
diff changeset
48 Each element of the stack is a list (FILENAME NODENAME BUFFERPOS).")
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
49
59472
1e81e65f3201 (Info-history-forward): New variable.
Juri Linkov <juri@jurta.org>
parents: 59423
diff changeset
50 (defvar Info-history-forward nil
64812
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
51 "Stack of Info nodes user has visited with `Info-history-back' command.
64071
5a1b36dec43a (Info-history, Info-history-forward, Info-history-list,
Juanma Barranquero <lekktu@gmail.com>
parents: 64013
diff changeset
52 Each element of the stack is a list (FILENAME NODENAME BUFFERPOS).")
59472
1e81e65f3201 (Info-history-forward): New variable.
Juri Linkov <juri@jurta.org>
parents: 59423
diff changeset
53
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
54 (defvar Info-history-list nil
64812
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
55 "List of all Info nodes user has visited.
64071
5a1b36dec43a (Info-history, Info-history-forward, Info-history-list,
Juanma Barranquero <lekktu@gmail.com>
parents: 64013
diff changeset
56 Each element of the list is a list (FILENAME NODENAME).")
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
57
17430
de68258fef5f Add defgroup; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 17154
diff changeset
58 (defcustom Info-enable-edit nil
3084
a4341d92948a (Info-edit, Info-last-search, Info-enable-edit):
Richard M. Stallman <rms@gnu.org>
parents: 3047
diff changeset
59 "*Non-nil means the \\<Info-mode-map>\\[Info-edit] command in Info can edit the current node.
64812
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
60 This is convenient if you want to write Info files by hand.
680
f99c8512cd41 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 660
diff changeset
61 However, we recommend that you not do this.
f99c8512cd41 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 660
diff changeset
62 It is better to write a Texinfo file and generate the Info file from that,
17430
de68258fef5f Add defgroup; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 17154
diff changeset
63 because that gives you a printed manual as well."
de68258fef5f Add defgroup; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 17154
diff changeset
64 :type 'boolean
de68258fef5f Add defgroup; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 17154
diff changeset
65 :group 'info)
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
66
15177
4935ada40f67 (Info-enable-active-nodes): Default to nil. Mark it risky.
Richard M. Stallman <rms@gnu.org>
parents: 15126
diff changeset
67 (defvar Info-enable-active-nodes nil
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
68 "Non-nil allows Info to execute Lisp code associated with nodes.
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
69 The Lisp code is executed when the node is selected.")
15177
4935ada40f67 (Info-enable-active-nodes): Default to nil. Mark it risky.
Richard M. Stallman <rms@gnu.org>
parents: 15126
diff changeset
70 (put 'Info-enable-active-nodes 'risky-local-variable t)
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
71
19043
a2853a75ce57 (info-node, info-xref, info-menu-5):
Richard M. Stallman <rms@gnu.org>
parents: 17968
diff changeset
72 (defface info-node
55061
966081800217 (info-node, info-menu-5, info-xref, info-header-node)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55057
diff changeset
73 '((((class color) (background light)) :foreground "brown" :weight bold :slant italic)
966081800217 (info-node, info-menu-5, info-xref, info-header-node)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55057
diff changeset
74 (((class color) (background dark)) :foreground "white" :weight bold :slant italic)
966081800217 (info-node, info-menu-5, info-xref, info-header-node)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55057
diff changeset
75 (t :weight bold :slant italic))
19043
a2853a75ce57 (info-node, info-xref, info-menu-5):
Richard M. Stallman <rms@gnu.org>
parents: 17968
diff changeset
76 "Face for Info node names."
a2853a75ce57 (info-node, info-xref, info-menu-5):
Richard M. Stallman <rms@gnu.org>
parents: 17968
diff changeset
77 :group 'info)
a2853a75ce57 (info-node, info-xref, info-menu-5):
Richard M. Stallman <rms@gnu.org>
parents: 17968
diff changeset
78
64812
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
79 (defface info-title-1
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
80 '((((type tty pc) (class color) (background light))
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
81 :foreground "green" :weight bold)
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
82 (((type tty pc) (class color) (background dark))
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
83 :foreground "yellow" :weight bold)
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
84 (t :height 1.2 :inherit info-title-2))
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
85 "Face for info titles at level 1."
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
86 :group 'info)
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
87 ;; backward-compatibility alias
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
88 (put 'Info-title-1-face 'face-alias 'info-title-1)
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
89
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
90 (defface info-title-2
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
91 '((((type tty pc) (class color)) :foreground "lightblue" :weight bold)
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
92 (t :height 1.2 :inherit info-title-3))
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
93 "Face for info titles at level 2."
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
94 :group 'info)
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
95 ;; backward-compatibility alias
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
96 (put 'Info-title-2-face 'face-alias 'info-title-2)
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
97
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
98 (defface info-title-3
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
99 '((((type tty pc) (class color)) :weight bold)
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
100 (t :height 1.2 :inherit info-title-4))
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
101 "Face for info titles at level 3."
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
102 :group 'info)
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
103 ;; backward-compatibility alias
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
104 (put 'Info-title-3-face 'face-alias 'info-title-3)
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
105
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
106 (defface info-title-4
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
107 '((((type tty pc) (class color)) :weight bold)
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
108 (t :weight bold :inherit variable-pitch))
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
109 "Face for info titles at level 4."
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
110 :group 'info)
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
111 ;; backward-compatibility alias
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
112 (put 'Info-title-4-face 'face-alias 'info-title-4)
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
113
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
114 (defface info-menu-header
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
115 '((((type tty pc))
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
116 :underline t
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
117 :weight bold)
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
118 (t
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
119 :inherit variable-pitch
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
120 :weight bold))
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
121 "Face for headers in Info menus."
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
122 :group 'info)
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
123
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
124 (defface info-menu-star
55061
966081800217 (info-node, info-menu-5, info-xref, info-header-node)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55057
diff changeset
125 '((((class color)) :foreground "red1")
966081800217 (info-node, info-menu-5, info-xref, info-header-node)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55057
diff changeset
126 (t :underline t))
46029
65fc39bc254a (info-menu-5): Fix documentation.
Juanma Barranquero <lekktu@gmail.com>
parents: 45784
diff changeset
127 "Face for every third `*' in an Info menu."
19043
a2853a75ce57 (info-node, info-xref, info-menu-5):
Richard M. Stallman <rms@gnu.org>
parents: 17968
diff changeset
128 :group 'info)
64812
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
129 (put 'info-menu-5 'face-alias 'info-menu-star)
19043
a2853a75ce57 (info-node, info-xref, info-menu-5):
Richard M. Stallman <rms@gnu.org>
parents: 17968
diff changeset
130
a2853a75ce57 (info-node, info-xref, info-menu-5):
Richard M. Stallman <rms@gnu.org>
parents: 17968
diff changeset
131 (defface info-xref
68342
e3989d3241d5 (info-xref): Inherit from `link'.
Juri Linkov <juri@jurta.org>
parents: 68227
diff changeset
132 '((t :inherit link))
e3989d3241d5 (info-xref): Inherit from `link'.
Juri Linkov <juri@jurta.org>
parents: 68227
diff changeset
133 "Face for unvisited Info cross-references."
19043
a2853a75ce57 (info-node, info-xref, info-menu-5):
Richard M. Stallman <rms@gnu.org>
parents: 17968
diff changeset
134 :group 'info)
a2853a75ce57 (info-node, info-xref, info-menu-5):
Richard M. Stallman <rms@gnu.org>
parents: 17968
diff changeset
135
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
136 (defface info-xref-visited
68853
4e74c8b341d8 (info-xref-visited): Inherit from info-xref too.
Juri Linkov <juri@jurta.org>
parents: 68826
diff changeset
137 '((t :inherit (link-visited info-xref)))
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
138 "Face for visited Info cross-references."
68342
e3989d3241d5 (info-xref): Inherit from `link'.
Juri Linkov <juri@jurta.org>
parents: 68227
diff changeset
139 :version "22.1"
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
140 :group 'info)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
141
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
142 (defcustom Info-fontify-visited-nodes t
64812
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
143 "*Non-nil to fontify references to visited nodes in `info-xref-visited' face."
59996
aac0a33f5772 Change release version from 21.4 to 22.1 throughout.
Kim F. Storm <storm@cua.dk>
parents: 59472
diff changeset
144 :version "22.1"
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
145 :type 'boolean
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
146 :group 'info)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
147
74809
2ae1c7a27a0a (Info-fontify-maximum-menu-size): Bump to 1000000.
Chong Yidong <cyd@stupidchicken.com>
parents: 74719
diff changeset
148 (defcustom Info-fontify-maximum-menu-size 1000000
75750
9d47b3ad340e (Info-fontify-maximum-menu-size): Document the effect of a nil value.
Eli Zaretskii <eliz@gnu.org>
parents: 75347
diff changeset
149 "*Maximum size of menu to fontify if `font-lock-mode' is non-nil.
9d47b3ad340e (Info-fontify-maximum-menu-size): Document the effect of a nil value.
Eli Zaretskii <eliz@gnu.org>
parents: 75347
diff changeset
150 Set to nil to disable node fontification."
17430
de68258fef5f Add defgroup; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 17154
diff changeset
151 :type 'integer
de68258fef5f Add defgroup; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 17154
diff changeset
152 :group 'info)
8480
7f28030d9529 (Info-additional-directory-list): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8461
diff changeset
153
31660
84c9abde389f (Info-fontify-node):
Miles Bader <miles@gnu.org>
parents: 31324
diff changeset
154 (defcustom Info-use-header-line t
46326
6953d46b05f5 (info-emacs-manual): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46252
diff changeset
155 "*Non-nil means to put the beginning-of-node links in an Emacs header-line.
31660
84c9abde389f (Info-fontify-node):
Miles Bader <miles@gnu.org>
parents: 31324
diff changeset
156 A header-line does not scroll with the rest of the buffer."
84c9abde389f (Info-fontify-node):
Miles Bader <miles@gnu.org>
parents: 31324
diff changeset
157 :type 'boolean
84c9abde389f (Info-fontify-node):
Miles Bader <miles@gnu.org>
parents: 31324
diff changeset
158 :group 'info)
84c9abde389f (Info-fontify-node):
Miles Bader <miles@gnu.org>
parents: 31324
diff changeset
159
84c9abde389f (Info-fontify-node):
Miles Bader <miles@gnu.org>
parents: 31324
diff changeset
160 (defface info-header-xref
55061
966081800217 (info-node, info-menu-5, info-xref, info-header-node)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55057
diff changeset
161 '((t :inherit info-xref))
31660
84c9abde389f (Info-fontify-node):
Miles Bader <miles@gnu.org>
parents: 31324
diff changeset
162 "Face for Info cross-references in a node header."
84c9abde389f (Info-fontify-node):
Miles Bader <miles@gnu.org>
parents: 31324
diff changeset
163 :group 'info)
84c9abde389f (Info-fontify-node):
Miles Bader <miles@gnu.org>
parents: 31324
diff changeset
164
84c9abde389f (Info-fontify-node):
Miles Bader <miles@gnu.org>
parents: 31324
diff changeset
165 (defface info-header-node
55061
966081800217 (info-node, info-menu-5, info-xref, info-header-node)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55057
diff changeset
166 '((t :inherit info-node))
31660
84c9abde389f (Info-fontify-node):
Miles Bader <miles@gnu.org>
parents: 31324
diff changeset
167 "Face for Info nodes in a node header."
84c9abde389f (Info-fontify-node):
Miles Bader <miles@gnu.org>
parents: 31324
diff changeset
168 :group 'info)
84c9abde389f (Info-fontify-node):
Miles Bader <miles@gnu.org>
parents: 31324
diff changeset
169
25145
784d7bc2a991 (info-initialize): New function.
Richard M. Stallman <rms@gnu.org>
parents: 24963
diff changeset
170 (defvar Info-directory-list nil
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
171 "List of directories to search for Info documentation files.
46252
0b84df44f862 (Info-directory-list): Fix docstring.
Juanma Barranquero <lekktu@gmail.com>
parents: 46139
diff changeset
172 If nil, meaning not yet initialized, Info uses the environment
1979
0582c70595f1 * info.el (Info-directory-list): Doc fix; it is set according to
Jim Blandy <jimb@redhat.com>
parents: 1971
diff changeset
173 variable INFOPATH to initialize it, or `Info-default-directory-list'
51434
4c85e6a5a9d2 (Info-mode-hook): Obey obsolete `Info-fontify'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51310
diff changeset
174 if there is no INFOPATH variable in the environment, or the
4c85e6a5a9d2 (Info-mode-hook): Obey obsolete `Info-fontify'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51310
diff changeset
175 concatenation of the two if INFOPATH ends with a colon.
31324
928516355e95 (Info-directory-list): Doc fix.
Eli Zaretskii <eliz@gnu.org>
parents: 30763
diff changeset
176
928516355e95 (Info-directory-list): Doc fix.
Eli Zaretskii <eliz@gnu.org>
parents: 30763
diff changeset
177 When `Info-directory-list' is initialized from the value of
34574
9283cc675c49 (Info-directory-list): Change doc string to reflect the
Eli Zaretskii <eliz@gnu.org>
parents: 34503
diff changeset
178 `Info-default-directory-list', and Emacs is installed in one of the
9283cc675c49 (Info-directory-list): Change doc string to reflect the
Eli Zaretskii <eliz@gnu.org>
parents: 34503
diff changeset
179 standard directories, the directory of Info files that come with Emacs
9283cc675c49 (Info-directory-list): Change doc string to reflect the
Eli Zaretskii <eliz@gnu.org>
parents: 34503
diff changeset
180 is put last (so that local Info files override standard ones).
9283cc675c49 (Info-directory-list): Change doc string to reflect the
Eli Zaretskii <eliz@gnu.org>
parents: 34503
diff changeset
181
9283cc675c49 (Info-directory-list): Change doc string to reflect the
Eli Zaretskii <eliz@gnu.org>
parents: 34503
diff changeset
182 When `Info-directory-list' is initialized from the value of
9283cc675c49 (Info-directory-list): Change doc string to reflect the
Eli Zaretskii <eliz@gnu.org>
parents: 34503
diff changeset
183 `Info-default-directory-list', and Emacs is not installed in one
9283cc675c49 (Info-directory-list): Change doc string to reflect the
Eli Zaretskii <eliz@gnu.org>
parents: 34503
diff changeset
184 of the standard directories, the first element of the resulting
31324
928516355e95 (Info-directory-list): Doc fix.
Eli Zaretskii <eliz@gnu.org>
parents: 30763
diff changeset
185 list is the directory where Emacs installs the Info files that
928516355e95 (Info-directory-list): Doc fix.
Eli Zaretskii <eliz@gnu.org>
parents: 30763
diff changeset
186 come with it. This is so that Emacs's own manual, which suits the
34574
9283cc675c49 (Info-directory-list): Change doc string to reflect the
Eli Zaretskii <eliz@gnu.org>
parents: 34503
diff changeset
187 version of Emacs you are using, will always be found first. This
9283cc675c49 (Info-directory-list): Change doc string to reflect the
Eli Zaretskii <eliz@gnu.org>
parents: 34503
diff changeset
188 is useful when you install an experimental version of Emacs without
9283cc675c49 (Info-directory-list): Change doc string to reflect the
Eli Zaretskii <eliz@gnu.org>
parents: 34503
diff changeset
189 removing the standard installation.
9283cc675c49 (Info-directory-list): Change doc string to reflect the
Eli Zaretskii <eliz@gnu.org>
parents: 34503
diff changeset
190
9283cc675c49 (Info-directory-list): Change doc string to reflect the
Eli Zaretskii <eliz@gnu.org>
parents: 34503
diff changeset
191 If you want to override the order of directories in
9283cc675c49 (Info-directory-list): Change doc string to reflect the
Eli Zaretskii <eliz@gnu.org>
parents: 34503
diff changeset
192 `Info-default-directory-list', set INFOPATH in the environment.
8461
c88361c3b940 (Info-directory-list): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 8369
diff changeset
193
c88361c3b940 (Info-directory-list): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 8369
diff changeset
194 If you run the Emacs executable from the `src' directory in the Emacs
31324
928516355e95 (Info-directory-list): Doc fix.
Eli Zaretskii <eliz@gnu.org>
parents: 30763
diff changeset
195 source tree, and INFOPATH is not defined, the `info' directory in the
928516355e95 (Info-directory-list): Doc fix.
Eli Zaretskii <eliz@gnu.org>
parents: 30763
diff changeset
196 source tree is used as the first element of `Info-directory-list', in
928516355e95 (Info-directory-list): Doc fix.
Eli Zaretskii <eliz@gnu.org>
parents: 30763
diff changeset
197 place of the installation Info directory. This is useful when you run
928516355e95 (Info-directory-list): Doc fix.
Eli Zaretskii <eliz@gnu.org>
parents: 30763
diff changeset
198 a version of Emacs without installing it.")
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
199
17430
de68258fef5f Add defgroup; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 17154
diff changeset
200 (defcustom Info-additional-directory-list nil
8480
7f28030d9529 (Info-additional-directory-list): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8461
diff changeset
201 "List of additional directories to search for Info documentation files.
48582
cb623072f5da (Info-additional-directory-list): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 48287
diff changeset
202 These directories are searched after those in `Info-directory-list'."
17430
de68258fef5f Add defgroup; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 17154
diff changeset
203 :type '(repeat directory)
de68258fef5f Add defgroup; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 17154
diff changeset
204 :group 'info)
8480
7f28030d9529 (Info-additional-directory-list): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8461
diff changeset
205
51709
02d430615dd4 (Info-fontify-menu-headers): Only fontify `* Menu:' at the beginning
Luc Teirlinck <teirllm@auburn.edu>
parents: 51623
diff changeset
206 (defcustom Info-scroll-prefer-subnodes nil
34182
3f2ee9f3d8bf (Info-scroll-prefer-subnodes): New defcustom.
Eli Zaretskii <eliz@gnu.org>
parents: 33621
diff changeset
207 "*If non-nil, \\<Info-mode-map>\\[Info-scroll-up] in a menu visits subnodes.
64812
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
208
34182
3f2ee9f3d8bf (Info-scroll-prefer-subnodes): New defcustom.
Eli Zaretskii <eliz@gnu.org>
parents: 33621
diff changeset
209 If this is non-nil, and you scroll far enough in a node that its menu
3f2ee9f3d8bf (Info-scroll-prefer-subnodes): New defcustom.
Eli Zaretskii <eliz@gnu.org>
parents: 33621
diff changeset
210 appears on the screen, the next \\<Info-mode-map>\\[Info-scroll-up]
3f2ee9f3d8bf (Info-scroll-prefer-subnodes): New defcustom.
Eli Zaretskii <eliz@gnu.org>
parents: 33621
diff changeset
211 moves to a subnode indicated by the following menu item. This means
3f2ee9f3d8bf (Info-scroll-prefer-subnodes): New defcustom.
Eli Zaretskii <eliz@gnu.org>
parents: 33621
diff changeset
212 that you visit a subnode before getting to the end of the menu.
3f2ee9f3d8bf (Info-scroll-prefer-subnodes): New defcustom.
Eli Zaretskii <eliz@gnu.org>
parents: 33621
diff changeset
213
3f2ee9f3d8bf (Info-scroll-prefer-subnodes): New defcustom.
Eli Zaretskii <eliz@gnu.org>
parents: 33621
diff changeset
214 Setting this option to nil results in behavior similar to the stand-alone
3f2ee9f3d8bf (Info-scroll-prefer-subnodes): New defcustom.
Eli Zaretskii <eliz@gnu.org>
parents: 33621
diff changeset
215 Info reader program, which visits the first subnode from the menu only
3f2ee9f3d8bf (Info-scroll-prefer-subnodes): New defcustom.
Eli Zaretskii <eliz@gnu.org>
parents: 33621
diff changeset
216 when you hit the end of the current node."
59996
aac0a33f5772 Change release version from 21.4 to 22.1 throughout.
Kim F. Storm <storm@cua.dk>
parents: 59472
diff changeset
217 :version "22.1"
34182
3f2ee9f3d8bf (Info-scroll-prefer-subnodes): New defcustom.
Eli Zaretskii <eliz@gnu.org>
parents: 33621
diff changeset
218 :type 'boolean
3f2ee9f3d8bf (Info-scroll-prefer-subnodes): New defcustom.
Eli Zaretskii <eliz@gnu.org>
parents: 33621
diff changeset
219 :group 'info)
3f2ee9f3d8bf (Info-scroll-prefer-subnodes): New defcustom.
Eli Zaretskii <eliz@gnu.org>
parents: 33621
diff changeset
220
48107
c0a7fff00ce5 (Info-hide-note-references): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48103
diff changeset
221 (defcustom Info-hide-note-references t
48118
40e2242be50f (Info-hide-note-references): nil value now does no
Kim F. Storm <storm@cua.dk>
parents: 48107
diff changeset
222 "*If non-nil, hide the tag and section reference in *note and * menu items.
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
223 If value is non-nil but not `hide', also replaces the \"*note\" with \"see\".
64812
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
224 If value is non-nil but not t or `hide', the reference section is still shown.
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
225 `nil' completely disables this feature."
59996
aac0a33f5772 Change release version from 21.4 to 22.1 throughout.
Kim F. Storm <storm@cua.dk>
parents: 59472
diff changeset
226 :version "22.1"
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
227 :type '(choice (const :tag "No hiding" nil)
50004
14d6d1ad4a06 (Info-fontify-node): Don't hide indentation before the
Andreas Schwab <schwab@suse.de>
parents: 49879
diff changeset
228 (const :tag "Replace tag and hide reference" t)
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
229 (const :tag "Hide tag and reference" hide)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
230 (other :tag "Only replace tag" tag))
48107
c0a7fff00ce5 (Info-hide-note-references): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48103
diff changeset
231 :group 'info)
c0a7fff00ce5 (Info-hide-note-references): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48103
diff changeset
232
51731
6b3b6b76e307 Disable paragraph refilling.
Kim F. Storm <storm@cua.dk>
parents: 51709
diff changeset
233 (defcustom Info-refill-paragraphs nil
6b3b6b76e307 Disable paragraph refilling.
Kim F. Storm <storm@cua.dk>
parents: 51709
diff changeset
234 "*If non-nil, attempt to refill paragraphs with hidden references.
64812
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
235 This refilling may accidentally remove explicit line breaks in the Info
51731
6b3b6b76e307 Disable paragraph refilling.
Kim F. Storm <storm@cua.dk>
parents: 51709
diff changeset
236 file, so be prepared for a few surprises if you enable this feature."
59996
aac0a33f5772 Change release version from 21.4 to 22.1 throughout.
Kim F. Storm <storm@cua.dk>
parents: 59472
diff changeset
237 :version "22.1"
51731
6b3b6b76e307 Disable paragraph refilling.
Kim F. Storm <storm@cua.dk>
parents: 51709
diff changeset
238 :type 'boolean
6b3b6b76e307 Disable paragraph refilling.
Kim F. Storm <storm@cua.dk>
parents: 51709
diff changeset
239 :group 'info)
6b3b6b76e307 Disable paragraph refilling.
Kim F. Storm <storm@cua.dk>
parents: 51709
diff changeset
240
58604
a227196e4498 (Info-search-whitespace-regexp): Remove shy group.
Juri Linkov <juri@jurta.org>
parents: 58350
diff changeset
241 (defcustom Info-search-whitespace-regexp "\\s-+"
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
242 "*If non-nil, regular expression to match a sequence of whitespace chars.
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
243 This applies to Info search for regular expressions.
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
244 You might want to use something like \"[ \\t\\r\\n]+\" instead.
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
245 In the Customization buffer, that is `[' followed by a space,
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
246 a tab, a carriage return (control-M), a newline, and `]+'."
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
247 :type 'regexp
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
248 :group 'info)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
249
60222
56061feffaa0 (Info-isearch-search): New defcustom.
Juri Linkov <juri@jurta.org>
parents: 59996
diff changeset
250 (defcustom Info-isearch-search t
60626
20a8e6e5ae57 Update error messages for `debug-ignored-errors'.
Juri Linkov <juri@jurta.org>
parents: 60615
diff changeset
251 "*If non-nil, isearch in Info searches through multiple nodes.
20a8e6e5ae57 Update error messages for `debug-ignored-errors'.
Juri Linkov <juri@jurta.org>
parents: 60615
diff changeset
252 Before leaving the initial Info node, where isearch was started,
20a8e6e5ae57 Update error messages for `debug-ignored-errors'.
Juri Linkov <juri@jurta.org>
parents: 60615
diff changeset
253 it fails once with the error message [initial node], and with
20a8e6e5ae57 Update error messages for `debug-ignored-errors'.
Juri Linkov <juri@jurta.org>
parents: 60615
diff changeset
254 subsequent C-s/C-r continues through other nodes without failing
20a8e6e5ae57 Update error messages for `debug-ignored-errors'.
Juri Linkov <juri@jurta.org>
parents: 60615
diff changeset
255 with this error message in other nodes. When isearch fails for
20a8e6e5ae57 Update error messages for `debug-ignored-errors'.
Juri Linkov <juri@jurta.org>
parents: 60615
diff changeset
256 the rest of the manual, it wraps aroung the whole manual and
20a8e6e5ae57 Update error messages for `debug-ignored-errors'.
Juri Linkov <juri@jurta.org>
parents: 60615
diff changeset
257 restarts the search from the top/final node depending on
20a8e6e5ae57 Update error messages for `debug-ignored-errors'.
Juri Linkov <juri@jurta.org>
parents: 60615
diff changeset
258 search direction.
20a8e6e5ae57 Update error messages for `debug-ignored-errors'.
Juri Linkov <juri@jurta.org>
parents: 60615
diff changeset
259
20a8e6e5ae57 Update error messages for `debug-ignored-errors'.
Juri Linkov <juri@jurta.org>
parents: 60615
diff changeset
260 Setting this option to nil restores the default isearch behavior
20a8e6e5ae57 Update error messages for `debug-ignored-errors'.
Juri Linkov <juri@jurta.org>
parents: 60615
diff changeset
261 with wrapping around the current Info node."
60222
56061feffaa0 (Info-isearch-search): New defcustom.
Juri Linkov <juri@jurta.org>
parents: 59996
diff changeset
262 :version "22.1"
56061feffaa0 (Info-isearch-search): New defcustom.
Juri Linkov <juri@jurta.org>
parents: 59996
diff changeset
263 :type 'boolean
56061feffaa0 (Info-isearch-search): New defcustom.
Juri Linkov <juri@jurta.org>
parents: 59996
diff changeset
264 :group 'info)
56061feffaa0 (Info-isearch-search): New defcustom.
Juri Linkov <juri@jurta.org>
parents: 59996
diff changeset
265
60615
643e6516a779 (Info-isearch-initial-node): New internal variable.
Juri Linkov <juri@jurta.org>
parents: 60577
diff changeset
266 (defvar Info-isearch-initial-node nil)
643e6516a779 (Info-isearch-initial-node): New internal variable.
Juri Linkov <juri@jurta.org>
parents: 60577
diff changeset
267
51434
4c85e6a5a9d2 (Info-mode-hook): Obey obsolete `Info-fontify'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51310
diff changeset
268 (defcustom Info-mode-hook
4c85e6a5a9d2 (Info-mode-hook): Obey obsolete `Info-fontify'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51310
diff changeset
269 ;; Try to obey obsolete Info-fontify settings.
4c85e6a5a9d2 (Info-mode-hook): Obey obsolete `Info-fontify'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51310
diff changeset
270 (unless (and (boundp 'Info-fontify) (null Info-fontify))
4c85e6a5a9d2 (Info-mode-hook): Obey obsolete `Info-fontify'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51310
diff changeset
271 '(turn-on-font-lock))
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
272 "Hooks run when `Info-mode' is called."
45458
7d835214e61e (Info-fontify): Deleted.
Colin Walters <walters@gnu.org>
parents: 45182
diff changeset
273 :type 'hook
7d835214e61e (Info-fontify): Deleted.
Colin Walters <walters@gnu.org>
parents: 45182
diff changeset
274 :group 'info)
7d835214e61e (Info-fontify): Deleted.
Colin Walters <walters@gnu.org>
parents: 45182
diff changeset
275
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
276 (defcustom Info-selection-hook nil
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
277 "Hooks run when `Info-select-node' is called."
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
278 :type 'hook
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
279 :group 'info)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
280
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
281 (defvar Info-edit-mode-hook nil
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
282 "Hooks run when `Info-edit-mode' is called.")
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
283
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
284 (defvar Info-current-file nil
12646
cd83cf47be08 (Info-current-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 12433
diff changeset
285 "Info file that Info is now looking at, or nil.
cd83cf47be08 (Info-current-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 12433
diff changeset
286 This is the name that was specified in Info, not the actual file name.
67121
f354001864bf * info.el (Info-on-current-buffer): Record actual filename in
Chong Yidong <cyd@stupidchicken.com>
parents: 67109
diff changeset
287 It doesn't contain directory names or file name extensions added by Info.")
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
288
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
289 (defvar Info-current-subfile nil
29621
f03c3a69a809 Doc fixes.
Dave Love <fx@gnu.org>
parents: 29583
diff changeset
290 "Info subfile that is actually in the *info* buffer now.
64812
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
291 nil if current Info file is not split into subfiles.")
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
292
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
293 (defvar Info-current-node nil
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
294 "Name of node that Info is now looking at, or nil.")
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
295
16981
643e0f90e153 Handle multiple Info buffers.
Richard M. Stallman <rms@gnu.org>
parents: 16790
diff changeset
296 (defvar Info-tag-table-marker nil
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
297 "Marker pointing at beginning of current Info file's tag table.
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
298 Marker points nowhere if file has no tag table.")
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
299
16981
643e0f90e153 Handle multiple Info buffers.
Richard M. Stallman <rms@gnu.org>
parents: 16790
diff changeset
300 (defvar Info-tag-table-buffer nil
643e0f90e153 Handle multiple Info buffers.
Richard M. Stallman <rms@gnu.org>
parents: 16790
diff changeset
301 "Buffer used for indirect tag tables.")
643e0f90e153 Handle multiple Info buffers.
Richard M. Stallman <rms@gnu.org>
parents: 16790
diff changeset
302
4410
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
303 (defvar Info-current-file-completions nil
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
304 "Cached completion list for current Info file.")
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
305
66602
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
306 (defvar Info-file-supports-index-cookies nil
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
307 "Non-nil if current Info file supports index cookies.")
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
308
2561
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
309 (defvar Info-index-alternatives nil
29621
f03c3a69a809 Doc fixes.
Dave Love <fx@gnu.org>
parents: 29583
diff changeset
310 "List of possible matches for last `Info-index' command.")
2561
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
311
55174
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
312 (defvar Info-point-loc nil
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
313 "Point location within a selected node.
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
314 If string, the point is moved to the proper occurrence of the
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
315 name of the followed cross reference within a selected node.
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
316 If number, the point is moved to the corresponding line.")
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
317
4410
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
318 (defvar Info-standalone nil
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
319 "Non-nil if Emacs was started solely as an Info browser.")
25145
784d7bc2a991 (info-initialize): New function.
Richard M. Stallman <rms@gnu.org>
parents: 24963
diff changeset
320
12927
d3cda9e7c55f (Info-suffix-list): For MS-DOS, use gunzip as the only uncompressor,
Richard M. Stallman <rms@gnu.org>
parents: 12892
diff changeset
321 (defvar Info-suffix-list
19937
f497e74a29aa (Info-suffix-list): Add suffixes for MS-DOS version
Richard M. Stallman <rms@gnu.org>
parents: 19821
diff changeset
322 ;; The MS-DOS list should work both when long file names are
f497e74a29aa (Info-suffix-list): Add suffixes for MS-DOS version
Richard M. Stallman <rms@gnu.org>
parents: 19821
diff changeset
323 ;; supported (Windows 9X), and when only 8+3 file names are available.
12927
d3cda9e7c55f (Info-suffix-list): For MS-DOS, use gunzip as the only uncompressor,
Richard M. Stallman <rms@gnu.org>
parents: 12892
diff changeset
324 (if (eq system-type 'ms-dos)
d3cda9e7c55f (Info-suffix-list): For MS-DOS, use gunzip as the only uncompressor,
Richard M. Stallman <rms@gnu.org>
parents: 12892
diff changeset
325 '( (".gz" . "gunzip")
d3cda9e7c55f (Info-suffix-list): For MS-DOS, use gunzip as the only uncompressor,
Richard M. Stallman <rms@gnu.org>
parents: 12892
diff changeset
326 (".z" . "gunzip")
34503
00d3d092888c (Info-suffix-list): Change format for a command that
Kenichi Handa <handa@m17n.org>
parents: 34468
diff changeset
327 (".bz2" . ("bzip2" "-dc"))
19937
f497e74a29aa (Info-suffix-list): Add suffixes for MS-DOS version
Richard M. Stallman <rms@gnu.org>
parents: 19821
diff changeset
328 (".inz" . "gunzip")
f497e74a29aa (Info-suffix-list): Add suffixes for MS-DOS version
Richard M. Stallman <rms@gnu.org>
parents: 19821
diff changeset
329 (".igz" . "gunzip")
f497e74a29aa (Info-suffix-list): Add suffixes for MS-DOS version
Richard M. Stallman <rms@gnu.org>
parents: 19821
diff changeset
330 (".info.Z" . "gunzip")
f497e74a29aa (Info-suffix-list): Add suffixes for MS-DOS version
Richard M. Stallman <rms@gnu.org>
parents: 19821
diff changeset
331 (".info.gz" . "gunzip")
f497e74a29aa (Info-suffix-list): Add suffixes for MS-DOS version
Richard M. Stallman <rms@gnu.org>
parents: 19821
diff changeset
332 ("-info.Z" . "gunzip")
f497e74a29aa (Info-suffix-list): Add suffixes for MS-DOS version
Richard M. Stallman <rms@gnu.org>
parents: 19821
diff changeset
333 ("-info.gz" . "gunzip")
f497e74a29aa (Info-suffix-list): Add suffixes for MS-DOS version
Richard M. Stallman <rms@gnu.org>
parents: 19821
diff changeset
334 ("/index.gz". "gunzip")
f497e74a29aa (Info-suffix-list): Add suffixes for MS-DOS version
Richard M. Stallman <rms@gnu.org>
parents: 19821
diff changeset
335 ("/index.z" . "gunzip")
13004
0ed37da6f0f3 (Info-suffix-list): Add .inf to MSDOS list.
Richard M. Stallman <rms@gnu.org>
parents: 12947
diff changeset
336 (".inf" . nil)
19937
f497e74a29aa (Info-suffix-list): Add suffixes for MS-DOS version
Richard M. Stallman <rms@gnu.org>
parents: 19821
diff changeset
337 (".info" . nil)
f497e74a29aa (Info-suffix-list): Add suffixes for MS-DOS version
Richard M. Stallman <rms@gnu.org>
parents: 19821
diff changeset
338 ("-info" . nil)
f497e74a29aa (Info-suffix-list): Add suffixes for MS-DOS version
Richard M. Stallman <rms@gnu.org>
parents: 19821
diff changeset
339 ("/index" . nil)
12927
d3cda9e7c55f (Info-suffix-list): For MS-DOS, use gunzip as the only uncompressor,
Richard M. Stallman <rms@gnu.org>
parents: 12892
diff changeset
340 ("" . nil))
17941
2465a6a42a60 (Info-suffix-list): Accept -info as suffix;
Richard M. Stallman <rms@gnu.org>
parents: 17859
diff changeset
341 '( (".info.Z". "uncompress")
2465a6a42a60 (Info-suffix-list): Accept -info as suffix;
Richard M. Stallman <rms@gnu.org>
parents: 17859
diff changeset
342 (".info.Y". "unyabba")
2465a6a42a60 (Info-suffix-list): Accept -info as suffix;
Richard M. Stallman <rms@gnu.org>
parents: 17859
diff changeset
343 (".info.gz". "gunzip")
2465a6a42a60 (Info-suffix-list): Accept -info as suffix;
Richard M. Stallman <rms@gnu.org>
parents: 17859
diff changeset
344 (".info.z". "gunzip")
34503
00d3d092888c (Info-suffix-list): Change format for a command that
Kenichi Handa <handa@m17n.org>
parents: 34468
diff changeset
345 (".info.bz2" . ("bzip2" "-dc"))
17941
2465a6a42a60 (Info-suffix-list): Accept -info as suffix;
Richard M. Stallman <rms@gnu.org>
parents: 17859
diff changeset
346 (".info". nil)
2465a6a42a60 (Info-suffix-list): Accept -info as suffix;
Richard M. Stallman <rms@gnu.org>
parents: 17859
diff changeset
347 ("-info.Z". "uncompress")
2465a6a42a60 (Info-suffix-list): Accept -info as suffix;
Richard M. Stallman <rms@gnu.org>
parents: 17859
diff changeset
348 ("-info.Y". "unyabba")
2465a6a42a60 (Info-suffix-list): Accept -info as suffix;
Richard M. Stallman <rms@gnu.org>
parents: 17859
diff changeset
349 ("-info.gz". "gunzip")
34503
00d3d092888c (Info-suffix-list): Change format for a command that
Kenichi Handa <handa@m17n.org>
parents: 34468
diff changeset
350 ("-info.bz2" . ("bzip2" "-dc"))
17941
2465a6a42a60 (Info-suffix-list): Accept -info as suffix;
Richard M. Stallman <rms@gnu.org>
parents: 17859
diff changeset
351 ("-info.z". "gunzip")
2465a6a42a60 (Info-suffix-list): Accept -info as suffix;
Richard M. Stallman <rms@gnu.org>
parents: 17859
diff changeset
352 ("-info". nil)
2465a6a42a60 (Info-suffix-list): Accept -info as suffix;
Richard M. Stallman <rms@gnu.org>
parents: 17859
diff changeset
353 ("/index.Z". "uncompress")
2465a6a42a60 (Info-suffix-list): Accept -info as suffix;
Richard M. Stallman <rms@gnu.org>
parents: 17859
diff changeset
354 ("/index.Y". "unyabba")
2465a6a42a60 (Info-suffix-list): Accept -info as suffix;
Richard M. Stallman <rms@gnu.org>
parents: 17859
diff changeset
355 ("/index.gz". "gunzip")
2465a6a42a60 (Info-suffix-list): Accept -info as suffix;
Richard M. Stallman <rms@gnu.org>
parents: 17859
diff changeset
356 ("/index.z". "gunzip")
34503
00d3d092888c (Info-suffix-list): Change format for a command that
Kenichi Handa <handa@m17n.org>
parents: 34468
diff changeset
357 ("/index.bz2". ("bzip2" "-dc"))
17941
2465a6a42a60 (Info-suffix-list): Accept -info as suffix;
Richard M. Stallman <rms@gnu.org>
parents: 17859
diff changeset
358 ("/index". nil)
2465a6a42a60 (Info-suffix-list): Accept -info as suffix;
Richard M. Stallman <rms@gnu.org>
parents: 17859
diff changeset
359 (".Z". "uncompress")
2465a6a42a60 (Info-suffix-list): Accept -info as suffix;
Richard M. Stallman <rms@gnu.org>
parents: 17859
diff changeset
360 (".Y". "unyabba")
2465a6a42a60 (Info-suffix-list): Accept -info as suffix;
Richard M. Stallman <rms@gnu.org>
parents: 17859
diff changeset
361 (".gz". "gunzip")
2465a6a42a60 (Info-suffix-list): Accept -info as suffix;
Richard M. Stallman <rms@gnu.org>
parents: 17859
diff changeset
362 (".z". "gunzip")
34503
00d3d092888c (Info-suffix-list): Change format for a command that
Kenichi Handa <handa@m17n.org>
parents: 34468
diff changeset
363 (".bz2" . ("bzip2" "-dc"))
17941
2465a6a42a60 (Info-suffix-list): Accept -info as suffix;
Richard M. Stallman <rms@gnu.org>
parents: 17859
diff changeset
364 ("". nil)))
2561
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
365 "List of file name suffixes and associated decoding commands.
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
366 Each entry should be (SUFFIX . STRING); the file is given to
34503
00d3d092888c (Info-suffix-list): Change format for a command that
Kenichi Handa <handa@m17n.org>
parents: 34468
diff changeset
367 the command as standard input.
00d3d092888c (Info-suffix-list): Change format for a command that
Kenichi Handa <handa@m17n.org>
parents: 34468
diff changeset
368
00d3d092888c (Info-suffix-list): Change format for a command that
Kenichi Handa <handa@m17n.org>
parents: 34468
diff changeset
369 STRING may be a list of strings. In that case, the first element is
00d3d092888c (Info-suffix-list): Change format for a command that
Kenichi Handa <handa@m17n.org>
parents: 34468
diff changeset
370 the command name, and the rest are arguments to that command.
00d3d092888c (Info-suffix-list): Change format for a command that
Kenichi Handa <handa@m17n.org>
parents: 34468
diff changeset
371
00d3d092888c (Info-suffix-list): Change format for a command that
Kenichi Handa <handa@m17n.org>
parents: 34468
diff changeset
372 If STRING is nil, no decoding is done.
6566
248eede22658 (Info-suffix-list): Put empty string last.
Karl Heuer <kwzh@gnu.org>
parents: 6537
diff changeset
373 Because the SUFFIXes are tried in order, the empty string should
248eede22658 (Info-suffix-list): Put empty string last.
Karl Heuer <kwzh@gnu.org>
parents: 6537
diff changeset
374 be last in the list.")
2561
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
375
13562
80870ef96f18 (info-insert-file-contents-1): Various rewrites.
Richard M. Stallman <rms@gnu.org>
parents: 13287
diff changeset
376 ;; Concatenate SUFFIX onto FILENAME. SUFFIX should start with a dot.
36452
b42d9cfd5c8f (info-insert-file-contents-1): Accept an additional
Eli Zaretskii <eliz@gnu.org>
parents: 36092
diff changeset
377 ;; First, on MS-DOS with no long file names support, delete some of
b42d9cfd5c8f (info-insert-file-contents-1): Accept an additional
Eli Zaretskii <eliz@gnu.org>
parents: 36092
diff changeset
378 ;; the extension in FILENAME to make room.
b42d9cfd5c8f (info-insert-file-contents-1): Accept an additional
Eli Zaretskii <eliz@gnu.org>
parents: 36092
diff changeset
379 (defun info-insert-file-contents-1 (filename suffix lfn)
b42d9cfd5c8f (info-insert-file-contents-1): Accept an additional
Eli Zaretskii <eliz@gnu.org>
parents: 36092
diff changeset
380 (if lfn ; long file names are supported
12927
d3cda9e7c55f (Info-suffix-list): For MS-DOS, use gunzip as the only uncompressor,
Richard M. Stallman <rms@gnu.org>
parents: 12892
diff changeset
381 (concat filename suffix)
d3cda9e7c55f (Info-suffix-list): For MS-DOS, use gunzip as the only uncompressor,
Richard M. Stallman <rms@gnu.org>
parents: 12892
diff changeset
382 (let* ((sans-exts (file-name-sans-extension filename))
13562
80870ef96f18 (info-insert-file-contents-1): Various rewrites.
Richard M. Stallman <rms@gnu.org>
parents: 13287
diff changeset
383 ;; How long is the extension in FILENAME (not counting the dot).
80870ef96f18 (info-insert-file-contents-1): Various rewrites.
Richard M. Stallman <rms@gnu.org>
parents: 13287
diff changeset
384 (ext-len (max 0 (- (length filename) (length sans-exts) 1)))
80870ef96f18 (info-insert-file-contents-1): Various rewrites.
Richard M. Stallman <rms@gnu.org>
parents: 13287
diff changeset
385 ext-left)
13004
0ed37da6f0f3 (Info-suffix-list): Add .inf to MSDOS list.
Richard M. Stallman <rms@gnu.org>
parents: 12947
diff changeset
386 ;; SUFFIX starts with a dot. If FILENAME already has one,
14577
39a431eafb34 (info-insert-file-contents-1) [MSDOS]: Remove leading
Karl Heuer <kwzh@gnu.org>
parents: 14560
diff changeset
387 ;; get rid of the one in SUFFIX (unless suffix is empty).
13562
80870ef96f18 (info-insert-file-contents-1): Various rewrites.
Richard M. Stallman <rms@gnu.org>
parents: 13287
diff changeset
388 (or (and (<= ext-len 0)
13004
0ed37da6f0f3 (Info-suffix-list): Add .inf to MSDOS list.
Richard M. Stallman <rms@gnu.org>
parents: 12947
diff changeset
389 (not (eq (aref filename (1- (length filename))) ?.)))
14577
39a431eafb34 (info-insert-file-contents-1) [MSDOS]: Remove leading
Karl Heuer <kwzh@gnu.org>
parents: 14560
diff changeset
390 (= (length suffix) 0)
13004
0ed37da6f0f3 (Info-suffix-list): Add .inf to MSDOS list.
Richard M. Stallman <rms@gnu.org>
parents: 12947
diff changeset
391 (setq suffix (substring suffix 1)))
13562
80870ef96f18 (info-insert-file-contents-1): Various rewrites.
Richard M. Stallman <rms@gnu.org>
parents: 13287
diff changeset
392 ;; How many chars of that extension should we keep?
80870ef96f18 (info-insert-file-contents-1): Various rewrites.
Richard M. Stallman <rms@gnu.org>
parents: 13287
diff changeset
393 (setq ext-left (min ext-len (max 0 (- 3 (length suffix)))))
12927
d3cda9e7c55f (Info-suffix-list): For MS-DOS, use gunzip as the only uncompressor,
Richard M. Stallman <rms@gnu.org>
parents: 12892
diff changeset
394 ;; Get rid of the rest of the extension, and add SUFFIX.
d3cda9e7c55f (Info-suffix-list): For MS-DOS, use gunzip as the only uncompressor,
Richard M. Stallman <rms@gnu.org>
parents: 12892
diff changeset
395 (concat (substring filename 0 (- (length filename)
d3cda9e7c55f (Info-suffix-list): For MS-DOS, use gunzip as the only uncompressor,
Richard M. Stallman <rms@gnu.org>
parents: 12892
diff changeset
396 (- ext-len ext-left)))
d3cda9e7c55f (Info-suffix-list): For MS-DOS, use gunzip as the only uncompressor,
Richard M. Stallman <rms@gnu.org>
parents: 12892
diff changeset
397 suffix))))
d3cda9e7c55f (Info-suffix-list): For MS-DOS, use gunzip as the only uncompressor,
Richard M. Stallman <rms@gnu.org>
parents: 12892
diff changeset
398
22067
5665490a6f9e (Info-find-node): Use info-file-exists-p
Richard M. Stallman <rms@gnu.org>
parents: 21910
diff changeset
399 (defun info-file-exists-p (filename)
5665490a6f9e (Info-find-node): Use info-file-exists-p
Richard M. Stallman <rms@gnu.org>
parents: 21910
diff changeset
400 (and (file-exists-p filename)
5665490a6f9e (Info-find-node): Use info-file-exists-p
Richard M. Stallman <rms@gnu.org>
parents: 21910
diff changeset
401 (not (file-directory-p filename))))
5665490a6f9e (Info-find-node): Use info-file-exists-p
Richard M. Stallman <rms@gnu.org>
parents: 21910
diff changeset
402
2561
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
403 (defun info-insert-file-contents (filename &optional visit)
64812
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
404 "Insert the contents of an Info file in the current buffer.
2561
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
405 Do the right thing if the file has been compressed or zipped."
36452
b42d9cfd5c8f (info-insert-file-contents-1): Accept an additional
Eli Zaretskii <eliz@gnu.org>
parents: 36092
diff changeset
406 (let* ((tail Info-suffix-list)
49467
c057b532bd92 (info-insert-file-contents) [!MSDOS]: Avoid byte-compiler warning.
Kim F. Storm <storm@cua.dk>
parents: 49465
diff changeset
407 (lfn (if (fboundp 'msdos-long-file-names)
c057b532bd92 (info-insert-file-contents) [!MSDOS]: Avoid byte-compiler warning.
Kim F. Storm <storm@cua.dk>
parents: 49465
diff changeset
408 (msdos-long-file-names)
c057b532bd92 (info-insert-file-contents) [!MSDOS]: Avoid byte-compiler warning.
Kim F. Storm <storm@cua.dk>
parents: 49465
diff changeset
409 t))
36452
b42d9cfd5c8f (info-insert-file-contents-1): Accept an additional
Eli Zaretskii <eliz@gnu.org>
parents: 36092
diff changeset
410 (check-short (and (fboundp 'msdos-long-file-names)
b42d9cfd5c8f (info-insert-file-contents-1): Accept an additional
Eli Zaretskii <eliz@gnu.org>
parents: 36092
diff changeset
411 lfn))
b42d9cfd5c8f (info-insert-file-contents-1): Accept an additional
Eli Zaretskii <eliz@gnu.org>
parents: 36092
diff changeset
412 fullname decoder done)
38679
341786a2d705 (info-insert-file-contents): Use info-file-exists-p
Gerd Moellmann <gerd@gnu.org>
parents: 38412
diff changeset
413 (if (info-file-exists-p filename)
12927
d3cda9e7c55f (Info-suffix-list): For MS-DOS, use gunzip as the only uncompressor,
Richard M. Stallman <rms@gnu.org>
parents: 12892
diff changeset
414 ;; FILENAME exists--see if that name contains a suffix.
d3cda9e7c55f (Info-suffix-list): For MS-DOS, use gunzip as the only uncompressor,
Richard M. Stallman <rms@gnu.org>
parents: 12892
diff changeset
415 ;; If so, set DECODE accordingly.
6566
248eede22658 (Info-suffix-list): Put empty string last.
Karl Heuer <kwzh@gnu.org>
parents: 6537
diff changeset
416 (progn
248eede22658 (Info-suffix-list): Put empty string last.
Karl Heuer <kwzh@gnu.org>
parents: 6537
diff changeset
417 (while (and tail
248eede22658 (Info-suffix-list): Put empty string last.
Karl Heuer <kwzh@gnu.org>
parents: 6537
diff changeset
418 (not (string-match
248eede22658 (Info-suffix-list): Put empty string last.
Karl Heuer <kwzh@gnu.org>
parents: 6537
diff changeset
419 (concat (regexp-quote (car (car tail))) "$")
248eede22658 (Info-suffix-list): Put empty string last.
Karl Heuer <kwzh@gnu.org>
parents: 6537
diff changeset
420 filename)))
248eede22658 (Info-suffix-list): Put empty string last.
Karl Heuer <kwzh@gnu.org>
parents: 6537
diff changeset
421 (setq tail (cdr tail)))
248eede22658 (Info-suffix-list): Put empty string last.
Karl Heuer <kwzh@gnu.org>
parents: 6537
diff changeset
422 (setq fullname filename
248eede22658 (Info-suffix-list): Put empty string last.
Karl Heuer <kwzh@gnu.org>
parents: 6537
diff changeset
423 decoder (cdr (car tail))))
12927
d3cda9e7c55f (Info-suffix-list): For MS-DOS, use gunzip as the only uncompressor,
Richard M. Stallman <rms@gnu.org>
parents: 12892
diff changeset
424 ;; Try adding suffixes to FILENAME and see if we can find something.
36452
b42d9cfd5c8f (info-insert-file-contents-1): Accept an additional
Eli Zaretskii <eliz@gnu.org>
parents: 36092
diff changeset
425 (while (and tail (not done))
b42d9cfd5c8f (info-insert-file-contents-1): Accept an additional
Eli Zaretskii <eliz@gnu.org>
parents: 36092
diff changeset
426 (setq fullname (info-insert-file-contents-1 filename
b42d9cfd5c8f (info-insert-file-contents-1): Accept an additional
Eli Zaretskii <eliz@gnu.org>
parents: 36092
diff changeset
427 (car (car tail)) lfn))
b42d9cfd5c8f (info-insert-file-contents-1): Accept an additional
Eli Zaretskii <eliz@gnu.org>
parents: 36092
diff changeset
428 (if (info-file-exists-p fullname)
b42d9cfd5c8f (info-insert-file-contents-1): Accept an additional
Eli Zaretskii <eliz@gnu.org>
parents: 36092
diff changeset
429 (setq done t
b42d9cfd5c8f (info-insert-file-contents-1): Accept an additional
Eli Zaretskii <eliz@gnu.org>
parents: 36092
diff changeset
430 ;; If we found a file with a suffix, set DECODER
b42d9cfd5c8f (info-insert-file-contents-1): Accept an additional
Eli Zaretskii <eliz@gnu.org>
parents: 36092
diff changeset
431 ;; according to the suffix.
b42d9cfd5c8f (info-insert-file-contents-1): Accept an additional
Eli Zaretskii <eliz@gnu.org>
parents: 36092
diff changeset
432 decoder (cdr (car tail)))
b42d9cfd5c8f (info-insert-file-contents-1): Accept an additional
Eli Zaretskii <eliz@gnu.org>
parents: 36092
diff changeset
433 ;; When the MS-DOS port runs on Windows, we need to check
b42d9cfd5c8f (info-insert-file-contents-1): Accept an additional
Eli Zaretskii <eliz@gnu.org>
parents: 36092
diff changeset
434 ;; the short variant of a long file name as well.
b42d9cfd5c8f (info-insert-file-contents-1): Accept an additional
Eli Zaretskii <eliz@gnu.org>
parents: 36092
diff changeset
435 (when check-short
b42d9cfd5c8f (info-insert-file-contents-1): Accept an additional
Eli Zaretskii <eliz@gnu.org>
parents: 36092
diff changeset
436 (setq fullname (info-insert-file-contents-1 filename
b42d9cfd5c8f (info-insert-file-contents-1): Accept an additional
Eli Zaretskii <eliz@gnu.org>
parents: 36092
diff changeset
437 (car (car tail)) nil))
b42d9cfd5c8f (info-insert-file-contents-1): Accept an additional
Eli Zaretskii <eliz@gnu.org>
parents: 36092
diff changeset
438 (if (info-file-exists-p fullname)
b42d9cfd5c8f (info-insert-file-contents-1): Accept an additional
Eli Zaretskii <eliz@gnu.org>
parents: 36092
diff changeset
439 (setq done t
b42d9cfd5c8f (info-insert-file-contents-1): Accept an additional
Eli Zaretskii <eliz@gnu.org>
parents: 36092
diff changeset
440 decoder (cdr (car tail))))))
6566
248eede22658 (Info-suffix-list): Put empty string last.
Karl Heuer <kwzh@gnu.org>
parents: 6537
diff changeset
441 (setq tail (cdr tail)))
248eede22658 (Info-suffix-list): Put empty string last.
Karl Heuer <kwzh@gnu.org>
parents: 6537
diff changeset
442 (or tail
12927
d3cda9e7c55f (Info-suffix-list): For MS-DOS, use gunzip as the only uncompressor,
Richard M. Stallman <rms@gnu.org>
parents: 12892
diff changeset
443 (error "Can't find %s or any compressed version of it" filename)))
9588
7d465ccfd45b (info-insert-file-contents): Always check for conflict with jka-compr.
Richard M. Stallman <rms@gnu.org>
parents: 9572
diff changeset
444 ;; check for conflict with jka-compr
67520
d08070c157fd (Info-on-current-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 67374
diff changeset
445 (if (and (jka-compr-installed-p)
9588
7d465ccfd45b (info-insert-file-contents): Always check for conflict with jka-compr.
Richard M. Stallman <rms@gnu.org>
parents: 9572
diff changeset
446 (jka-compr-get-compression-info fullname))
7d465ccfd45b (info-insert-file-contents): Always check for conflict with jka-compr.
Richard M. Stallman <rms@gnu.org>
parents: 9572
diff changeset
447 (setq decoder nil))
6566
248eede22658 (Info-suffix-list): Put empty string last.
Karl Heuer <kwzh@gnu.org>
parents: 6537
diff changeset
448 (if decoder
19937
f497e74a29aa (Info-suffix-list): Add suffixes for MS-DOS version
Richard M. Stallman <rms@gnu.org>
parents: 19821
diff changeset
449 (progn
f497e74a29aa (Info-suffix-list): Add suffixes for MS-DOS version
Richard M. Stallman <rms@gnu.org>
parents: 19821
diff changeset
450 (insert-file-contents-literally fullname visit)
f497e74a29aa (Info-suffix-list): Add suffixes for MS-DOS version
Richard M. Stallman <rms@gnu.org>
parents: 19821
diff changeset
451 (let ((buffer-read-only nil)
f497e74a29aa (Info-suffix-list): Add suffixes for MS-DOS version
Richard M. Stallman <rms@gnu.org>
parents: 19821
diff changeset
452 (coding-system-for-write 'no-conversion)
f497e74a29aa (Info-suffix-list): Add suffixes for MS-DOS version
Richard M. Stallman <rms@gnu.org>
parents: 19821
diff changeset
453 (default-directory (or (file-name-directory fullname)
f497e74a29aa (Info-suffix-list): Add suffixes for MS-DOS version
Richard M. Stallman <rms@gnu.org>
parents: 19821
diff changeset
454 default-directory)))
34503
00d3d092888c (Info-suffix-list): Change format for a command that
Kenichi Handa <handa@m17n.org>
parents: 34468
diff changeset
455 (or (consp decoder)
00d3d092888c (Info-suffix-list): Change format for a command that
Kenichi Handa <handa@m17n.org>
parents: 34468
diff changeset
456 (setq decoder (list decoder)))
00d3d092888c (Info-suffix-list): Change format for a command that
Kenichi Handa <handa@m17n.org>
parents: 34468
diff changeset
457 (apply 'call-process-region (point-min) (point-max)
00d3d092888c (Info-suffix-list): Change format for a command that
Kenichi Handa <handa@m17n.org>
parents: 34468
diff changeset
458 (car decoder) t t nil (cdr decoder))))
19937
f497e74a29aa (Info-suffix-list): Add suffixes for MS-DOS version
Richard M. Stallman <rms@gnu.org>
parents: 19821
diff changeset
459 (insert-file-contents fullname visit))))
25145
784d7bc2a991 (info-initialize): New function.
Richard M. Stallman <rms@gnu.org>
parents: 24963
diff changeset
460
50660
4d6ac18fff69 (Info-default-dirs): New fun extracted from Info-initialize.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50454
diff changeset
461 (defun Info-default-dirs ()
4d6ac18fff69 (Info-default-dirs): New fun extracted from Info-initialize.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50454
diff changeset
462 (let ((source (expand-file-name "info/" source-directory))
4d6ac18fff69 (Info-default-dirs): New fun extracted from Info-initialize.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50454
diff changeset
463 (sibling (if installation-directory
4d6ac18fff69 (Info-default-dirs): New fun extracted from Info-initialize.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50454
diff changeset
464 (expand-file-name "info/" installation-directory)
4d6ac18fff69 (Info-default-dirs): New fun extracted from Info-initialize.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50454
diff changeset
465 (if invocation-directory
4d6ac18fff69 (Info-default-dirs): New fun extracted from Info-initialize.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50454
diff changeset
466 (let ((infodir (expand-file-name
75271
1841eb88b38a (Info-default-dirs): Change default info dir to
Chong Yidong <cyd@stupidchicken.com>
parents: 75165
diff changeset
467 "../share/info/"
50660
4d6ac18fff69 (Info-default-dirs): New fun extracted from Info-initialize.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50454
diff changeset
468 invocation-directory)))
4d6ac18fff69 (Info-default-dirs): New fun extracted from Info-initialize.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50454
diff changeset
469 (if (file-exists-p infodir)
4d6ac18fff69 (Info-default-dirs): New fun extracted from Info-initialize.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50454
diff changeset
470 infodir
4d6ac18fff69 (Info-default-dirs): New fun extracted from Info-initialize.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50454
diff changeset
471 (setq infodir (expand-file-name
75271
1841eb88b38a (Info-default-dirs): Change default info dir to
Chong Yidong <cyd@stupidchicken.com>
parents: 75165
diff changeset
472 "../../../share/info/"
50660
4d6ac18fff69 (Info-default-dirs): New fun extracted from Info-initialize.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50454
diff changeset
473 invocation-directory))
4d6ac18fff69 (Info-default-dirs): New fun extracted from Info-initialize.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50454
diff changeset
474 (and (file-exists-p infodir)
4d6ac18fff69 (Info-default-dirs): New fun extracted from Info-initialize.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50454
diff changeset
475 infodir))))))
4d6ac18fff69 (Info-default-dirs): New fun extracted from Info-initialize.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50454
diff changeset
476 alternative)
4d6ac18fff69 (Info-default-dirs): New fun extracted from Info-initialize.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50454
diff changeset
477 (setq alternative
4d6ac18fff69 (Info-default-dirs): New fun extracted from Info-initialize.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50454
diff changeset
478 (if (and sibling (file-exists-p sibling))
4d6ac18fff69 (Info-default-dirs): New fun extracted from Info-initialize.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50454
diff changeset
479 ;; Uninstalled, Emacs builddir != srcdir.
4d6ac18fff69 (Info-default-dirs): New fun extracted from Info-initialize.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50454
diff changeset
480 sibling
4d6ac18fff69 (Info-default-dirs): New fun extracted from Info-initialize.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50454
diff changeset
481 ;; Uninstalled, builddir == srcdir
4d6ac18fff69 (Info-default-dirs): New fun extracted from Info-initialize.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50454
diff changeset
482 source))
4d6ac18fff69 (Info-default-dirs): New fun extracted from Info-initialize.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50454
diff changeset
483 (if (or (member alternative Info-default-directory-list)
4d6ac18fff69 (Info-default-dirs): New fun extracted from Info-initialize.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50454
diff changeset
484 ;; On DOS/NT, we use movable executables always,
4d6ac18fff69 (Info-default-dirs): New fun extracted from Info-initialize.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50454
diff changeset
485 ;; and we must always find the Info dir at run time.
4d6ac18fff69 (Info-default-dirs): New fun extracted from Info-initialize.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50454
diff changeset
486 (if (memq system-type '(ms-dos windows-nt))
4d6ac18fff69 (Info-default-dirs): New fun extracted from Info-initialize.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50454
diff changeset
487 nil
4d6ac18fff69 (Info-default-dirs): New fun extracted from Info-initialize.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50454
diff changeset
488 ;; Use invocation-directory for Info
4d6ac18fff69 (Info-default-dirs): New fun extracted from Info-initialize.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50454
diff changeset
489 ;; only if we used it for exec-directory also.
4d6ac18fff69 (Info-default-dirs): New fun extracted from Info-initialize.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50454
diff changeset
490 (not (string= exec-directory
4d6ac18fff69 (Info-default-dirs): New fun extracted from Info-initialize.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50454
diff changeset
491 (expand-file-name "lib-src/"
4d6ac18fff69 (Info-default-dirs): New fun extracted from Info-initialize.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50454
diff changeset
492 installation-directory))))
4d6ac18fff69 (Info-default-dirs): New fun extracted from Info-initialize.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50454
diff changeset
493 (not (file-exists-p alternative)))
4d6ac18fff69 (Info-default-dirs): New fun extracted from Info-initialize.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50454
diff changeset
494 Info-default-directory-list
4d6ac18fff69 (Info-default-dirs): New fun extracted from Info-initialize.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50454
diff changeset
495 ;; `alternative' contains the Info files that came with this
4d6ac18fff69 (Info-default-dirs): New fun extracted from Info-initialize.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50454
diff changeset
496 ;; version, so we should look there first. `Info-insert-dir'
4d6ac18fff69 (Info-default-dirs): New fun extracted from Info-initialize.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50454
diff changeset
497 ;; currently expects to find `alternative' first on the list.
4d6ac18fff69 (Info-default-dirs): New fun extracted from Info-initialize.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50454
diff changeset
498 (cons alternative
54435
bcc27a58f6ac (Info-default-dirs): Don't ignore last part of I-d-d-l.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 53409
diff changeset
499 ;; Don't drop the last part, it might contain non-Emacs stuff.
bcc27a58f6ac (Info-default-dirs): Don't ignore last part of I-d-d-l.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 53409
diff changeset
500 ;; (reverse (cdr (reverse
bcc27a58f6ac (Info-default-dirs): Don't ignore last part of I-d-d-l.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 53409
diff changeset
501 Info-default-directory-list)))) ;; )))
50660
4d6ac18fff69 (Info-default-dirs): New fun extracted from Info-initialize.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50454
diff changeset
502
25145
784d7bc2a991 (info-initialize): New function.
Richard M. Stallman <rms@gnu.org>
parents: 24963
diff changeset
503 (defun info-initialize ()
29621
f03c3a69a809 Doc fixes.
Dave Love <fx@gnu.org>
parents: 29583
diff changeset
504 "Initialize `Info-directory-list', if that hasn't been done yet."
25145
784d7bc2a991 (info-initialize): New function.
Richard M. Stallman <rms@gnu.org>
parents: 24963
diff changeset
505 (unless Info-directory-list
50660
4d6ac18fff69 (Info-default-dirs): New fun extracted from Info-initialize.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50454
diff changeset
506 (let ((path (getenv "INFOPATH")))
25145
784d7bc2a991 (info-initialize): New function.
Richard M. Stallman <rms@gnu.org>
parents: 24963
diff changeset
507 (setq Info-directory-list
30020
fd781aee7a03 (info-initialize): Use prune-directory-list to remove non-existant
Miles Bader <miles@gnu.org>
parents: 29684
diff changeset
508 (prune-directory-list
fd781aee7a03 (info-initialize): Use prune-directory-list to remove non-existant
Miles Bader <miles@gnu.org>
parents: 29684
diff changeset
509 (if path
50660
4d6ac18fff69 (Info-default-dirs): New fun extracted from Info-initialize.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50454
diff changeset
510 (if (string-match ":\\'" path)
4d6ac18fff69 (Info-default-dirs): New fun extracted from Info-initialize.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50454
diff changeset
511 (append (split-string (substring path 0 -1)
4d6ac18fff69 (Info-default-dirs): New fun extracted from Info-initialize.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50454
diff changeset
512 (regexp-quote path-separator))
4d6ac18fff69 (Info-default-dirs): New fun extracted from Info-initialize.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50454
diff changeset
513 (Info-default-dirs))
4d6ac18fff69 (Info-default-dirs): New fun extracted from Info-initialize.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50454
diff changeset
514 (split-string path (regexp-quote path-separator)))
4d6ac18fff69 (Info-default-dirs): New fun extracted from Info-initialize.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50454
diff changeset
515 (Info-default-dirs)))))))
2561
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
516
22471
39efe6bebb46 (info-other-window): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22331
diff changeset
517 ;;;###autoload
67778
0c0bb618627a (info-other-window, info): Rename function argument
Juri Linkov <juri@jurta.org>
parents: 67623
diff changeset
518 (defun info-other-window (&optional file-or-node)
22471
39efe6bebb46 (info-other-window): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22331
diff changeset
519 "Like `info' but show the Info buffer in another window."
39efe6bebb46 (info-other-window): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22331
diff changeset
520 (interactive (if current-prefix-arg
39efe6bebb46 (info-other-window): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22331
diff changeset
521 (list (read-file-name "Info file name: " nil nil t))))
55174
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
522 (let (same-window-buffer-names same-window-regexps)
67778
0c0bb618627a (info-other-window, info): Rename function argument
Juri Linkov <juri@jurta.org>
parents: 67623
diff changeset
523 (info file-or-node)))
28943
36fd90774cf7 (debug-ignored-errors): more errors to ignore.
Sam Steingold <sds@gnu.org>
parents: 28559
diff changeset
524
55174
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
525 ;;;###autoload (add-hook 'same-window-regexps "\\*info\\*\\(\\|<[0-9]+>\\)")
10957
6d3568e33019 (Info-menu): Bind beg with let.
Richard M. Stallman <rms@gnu.org>
parents: 10918
diff changeset
526
57468
478f1e91eac3 (info-xref): Add underlining.
Richard M. Stallman <rms@gnu.org>
parents: 57329
diff changeset
527 ;;;###autoload (put 'info 'info-file "emacs")
10957
6d3568e33019 (Info-menu): Bind beg with let.
Richard M. Stallman <rms@gnu.org>
parents: 10918
diff changeset
528 ;;;###autoload
67778
0c0bb618627a (info-other-window, info): Rename function argument
Juri Linkov <juri@jurta.org>
parents: 67623
diff changeset
529 (defun info (&optional file-or-node buffer)
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
530 "Enter Info, the documentation browser.
67778
0c0bb618627a (info-other-window, info): Rename function argument
Juri Linkov <juri@jurta.org>
parents: 67623
diff changeset
531 Optional argument FILE-OR-NODE specifies the file to examine;
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
532 the default is the top-level directory of Info.
67778
0c0bb618627a (info-other-window, info): Rename function argument
Juri Linkov <juri@jurta.org>
parents: 67623
diff changeset
533 Called from a program, FILE-OR-NODE may specify an Info node of the form
25311
745ff7cc2786 (info): Doc fix.
Dave Love <fx@gnu.org>
parents: 25172
diff changeset
534 `(FILENAME)NODENAME'.
55174
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
535 Optional argument BUFFER specifies the Info buffer name;
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
536 the default buffer name is *info*. If BUFFER exists,
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
537 just switch to BUFFER. Otherwise, create a new buffer
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
538 with the top-level Info directory.
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
539
55174
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
540 In interactive use, a non-numeric prefix argument directs
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
541 this command to read a file name from the minibuffer.
56044
7aad97855e39 (Info-goto-node): Add autoload.
Juri Linkov <juri@jurta.org>
parents: 55797
diff changeset
542 A numeric prefix argument selects an Info buffer with the prefix number
7aad97855e39 (Info-goto-node): Add autoload.
Juri Linkov <juri@jurta.org>
parents: 55797
diff changeset
543 appended to the Info buffer name.
14529
6c886dde14b8 (info): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 14424
diff changeset
544
6c886dde14b8 (info): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 14424
diff changeset
545 The search path for Info files is in the variable `Info-directory-list'.
28943
36fd90774cf7 (debug-ignored-errors): more errors to ignore.
Sam Steingold <sds@gnu.org>
parents: 28559
diff changeset
546 The top-level Info directory is made by combining all the files named `dir'
14529
6c886dde14b8 (info): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 14424
diff changeset
547 in all the directories in that path."
55174
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
548 (interactive (list
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
549 (if (and current-prefix-arg (not (numberp current-prefix-arg)))
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
550 (read-file-name "Info file name: " nil nil t))
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
551 (if (numberp current-prefix-arg)
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
552 (format "*info*<%s>" current-prefix-arg))))
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
553 (pop-to-buffer (or buffer "*info*"))
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
554 (if (and buffer (not (eq major-mode 'Info-mode)))
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
555 (Info-mode))
67778
0c0bb618627a (info-other-window, info): Rename function argument
Juri Linkov <juri@jurta.org>
parents: 67623
diff changeset
556 (if file-or-node
54878
327d069f80bb (info): Always jump to *info*.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54865
diff changeset
557 ;; If argument already contains parentheses, don't add another set
327d069f80bb (info): Always jump to *info*.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54865
diff changeset
558 ;; since the argument will then be parsed improperly. This also
327d069f80bb (info): Always jump to *info*.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54865
diff changeset
559 ;; has the added benefit of allowing node names to be included
327d069f80bb (info): Always jump to *info*.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54865
diff changeset
560 ;; following the parenthesized filename.
62822
7f11f471aa34 (Info-goto-node): Revert autoload addition (2004-06-12).
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 62733
diff changeset
561 (Info-goto-node
67778
0c0bb618627a (info-other-window, info): Rename function argument
Juri Linkov <juri@jurta.org>
parents: 67623
diff changeset
562 (if (and (stringp file-or-node) (string-match "(.*)" file-or-node))
0c0bb618627a (info-other-window, info): Rename function argument
Juri Linkov <juri@jurta.org>
parents: 67623
diff changeset
563 file-or-node
0c0bb618627a (info-other-window, info): Rename function argument
Juri Linkov <juri@jurta.org>
parents: 67623
diff changeset
564 (concat "(" file-or-node ")")))
68045
84897e4dbe0c (Info-find-node): Don't record previous node if have none.
Richard M. Stallman <rms@gnu.org>
parents: 67778
diff changeset
565 (if (and (zerop (buffer-size))
84897e4dbe0c (Info-find-node): Don't record previous node if have none.
Richard M. Stallman <rms@gnu.org>
parents: 67778
diff changeset
566 (null Info-history))
84897e4dbe0c (Info-find-node): Don't record previous node if have none.
Richard M. Stallman <rms@gnu.org>
parents: 67778
diff changeset
567 ;; If we just created the Info buffer, go to the directory.
84897e4dbe0c (Info-find-node): Don't record previous node if have none.
Richard M. Stallman <rms@gnu.org>
parents: 67778
diff changeset
568 (Info-directory))))
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
569
4410
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
570 ;;;###autoload
46326
6953d46b05f5 (info-emacs-manual): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46252
diff changeset
571 (defun info-emacs-manual ()
47794
c460856d1bfd (Info-next-menu-item, Info-last-menu-item)
John Paul Wallington <jpw@pobox.com>
parents: 47376
diff changeset
572 "Display the Emacs manual in Info mode."
46326
6953d46b05f5 (info-emacs-manual): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46252
diff changeset
573 (interactive)
6953d46b05f5 (info-emacs-manual): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46252
diff changeset
574 (info "emacs"))
6953d46b05f5 (info-emacs-manual): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46252
diff changeset
575
6953d46b05f5 (info-emacs-manual): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46252
diff changeset
576 ;;;###autoload
4410
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
577 (defun info-standalone ()
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
578 "Run Emacs as a standalone Info reader.
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
579 Usage: emacs -f info-standalone [filename]
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
580 In standalone mode, \\<Info-mode-map>\\[Info-exit] exits Emacs itself."
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
581 (setq Info-standalone t)
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
582 (if (and command-line-args-left
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
583 (not (string-match "^-" (car command-line-args-left))))
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
584 (condition-case err
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
585 (progn
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
586 (info (car command-line-args-left))
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
587 (setq command-line-args-left (cdr command-line-args-left)))
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
588 (error (send-string-to-terminal
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
589 (format "%s\n" (if (eq (car-safe err) 'error)
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
590 (nth 1 err) err)))
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
591 (save-buffers-kill-emacs)))
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
592 (info)))
25145
784d7bc2a991 (info-initialize): New function.
Richard M. Stallman <rms@gnu.org>
parents: 24963
diff changeset
593
31942
55dd93c0d728 (Info-extract-pointer):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31798
diff changeset
594 ;; See if the accessible portion of the buffer begins with a node
23923
950f2c278c9a (Info-node-at-bob-matching): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 23904
diff changeset
595 ;; delimiter, and the node header line which follows matches REGEXP.
950f2c278c9a (Info-node-at-bob-matching): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 23904
diff changeset
596 ;; Typically, this test will be followed by a loop that examines the
950f2c278c9a (Info-node-at-bob-matching): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 23904
diff changeset
597 ;; rest of the buffer with (search-forward "\n\^_"), and it's a pity
950f2c278c9a (Info-node-at-bob-matching): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 23904
diff changeset
598 ;; to have the overhead of this special test inside the loop.
950f2c278c9a (Info-node-at-bob-matching): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 23904
diff changeset
599
950f2c278c9a (Info-node-at-bob-matching): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 23904
diff changeset
600 ;; This function changes match-data, but supposedly the caller might
950f2c278c9a (Info-node-at-bob-matching): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 23904
diff changeset
601 ;; want to use the results of re-search-backward.
950f2c278c9a (Info-node-at-bob-matching): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 23904
diff changeset
602
950f2c278c9a (Info-node-at-bob-matching): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 23904
diff changeset
603 ;; The return value is the value of point at the beginning of matching
31942
55dd93c0d728 (Info-extract-pointer):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31798
diff changeset
604 ;; REGEXP, if the function succeeds, nil otherwise.
23923
950f2c278c9a (Info-node-at-bob-matching): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 23904
diff changeset
605 (defun Info-node-at-bob-matching (regexp)
29446
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
606 (and (bobp) ; are we at beginning of buffer?
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
607 (looking-at "\^_") ; does it begin with node delimiter?
23923
950f2c278c9a (Info-node-at-bob-matching): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 23904
diff changeset
608 (let (beg)
950f2c278c9a (Info-node-at-bob-matching): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 23904
diff changeset
609 (forward-line 1)
950f2c278c9a (Info-node-at-bob-matching): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 23904
diff changeset
610 (setq beg (point))
29446
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
611 (forward-line 1) ; does the line after delimiter match REGEXP?
23923
950f2c278c9a (Info-node-at-bob-matching): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 23904
diff changeset
612 (re-search-backward regexp beg t))))
950f2c278c9a (Info-node-at-bob-matching): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 23904
diff changeset
613
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
614 (defun Info-find-file (filename &optional noerror)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
615 "Return expanded FILENAME, or t, if FILENAME is \"dir\".
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
616 Optional second argument NOERROR, if t, means if file is not found
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
617 just return nil (no error)."
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
618 ;; Convert filename to lower case if not found as specified.
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
619 ;; Expand it.
26004
11f91800bec3 (Info-on-current-buffer): new entry point.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 25878
diff changeset
620 (if (stringp filename)
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
621 (let (temp temp-downcase found)
22692
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
622 (setq filename (substitute-in-file-name filename))
55074
dd4c270b21af Restore 2004-04-18 changes.
Juri Linkov <juri@jurta.org>
parents: 55061
diff changeset
623 (cond
54718
fd0577e11e88 (info-apropos): New function.
Jesper Harder <harder@ifa.au.dk>
parents: 54506
diff changeset
624 ((string= (downcase filename) "dir")
fd0577e11e88 (info-apropos): New function.
Jesper Harder <harder@ifa.au.dk>
parents: 54506
diff changeset
625 (setq found t))
fd0577e11e88 (info-apropos): New function.
Jesper Harder <harder@ifa.au.dk>
parents: 54506
diff changeset
626 (t
fd0577e11e88 (info-apropos): New function.
Jesper Harder <harder@ifa.au.dk>
parents: 54506
diff changeset
627 (let ((dirs (if (string-match "^\\./" filename)
22692
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
628 ;; If specified name starts with `./'
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
629 ;; then just try current directory.
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
630 '("./")
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
631 (if (file-name-absolute-p filename)
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
632 ;; No point in searching for an
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
633 ;; absolute file name
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
634 '(nil)
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
635 (if Info-additional-directory-list
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
636 (append Info-directory-list
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
637 Info-additional-directory-list)
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
638 Info-directory-list)))))
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
639 ;; Search the directory list for file FILENAME.
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
640 (while (and dirs (not found))
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
641 (setq temp (expand-file-name filename (car dirs)))
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
642 (setq temp-downcase
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
643 (expand-file-name (downcase filename) (car dirs)))
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
644 ;; Try several variants of specified name.
36452
b42d9cfd5c8f (info-insert-file-contents-1): Accept an additional
Eli Zaretskii <eliz@gnu.org>
parents: 36092
diff changeset
645 (let ((suffix-list Info-suffix-list)
49467
c057b532bd92 (info-insert-file-contents) [!MSDOS]: Avoid byte-compiler warning.
Kim F. Storm <storm@cua.dk>
parents: 49465
diff changeset
646 (lfn (if (fboundp 'msdos-long-file-names)
c057b532bd92 (info-insert-file-contents) [!MSDOS]: Avoid byte-compiler warning.
Kim F. Storm <storm@cua.dk>
parents: 49465
diff changeset
647 (msdos-long-file-names)
c057b532bd92 (info-insert-file-contents) [!MSDOS]: Avoid byte-compiler warning.
Kim F. Storm <storm@cua.dk>
parents: 49465
diff changeset
648 t)))
22692
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
649 (while (and suffix-list (not found))
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
650 (cond ((info-file-exists-p
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
651 (info-insert-file-contents-1
36452
b42d9cfd5c8f (info-insert-file-contents-1): Accept an additional
Eli Zaretskii <eliz@gnu.org>
parents: 36092
diff changeset
652 temp (car (car suffix-list)) lfn))
22692
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
653 (setq found temp))
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
654 ((info-file-exists-p
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
655 (info-insert-file-contents-1
36452
b42d9cfd5c8f (info-insert-file-contents-1): Accept an additional
Eli Zaretskii <eliz@gnu.org>
parents: 36092
diff changeset
656 temp-downcase (car (car suffix-list)) lfn))
b42d9cfd5c8f (info-insert-file-contents-1): Accept an additional
Eli Zaretskii <eliz@gnu.org>
parents: 36092
diff changeset
657 (setq found temp-downcase))
b42d9cfd5c8f (info-insert-file-contents-1): Accept an additional
Eli Zaretskii <eliz@gnu.org>
parents: 36092
diff changeset
658 ((and (fboundp 'msdos-long-file-names)
b42d9cfd5c8f (info-insert-file-contents-1): Accept an additional
Eli Zaretskii <eliz@gnu.org>
parents: 36092
diff changeset
659 lfn
b42d9cfd5c8f (info-insert-file-contents-1): Accept an additional
Eli Zaretskii <eliz@gnu.org>
parents: 36092
diff changeset
660 (info-file-exists-p
b42d9cfd5c8f (info-insert-file-contents-1): Accept an additional
Eli Zaretskii <eliz@gnu.org>
parents: 36092
diff changeset
661 (info-insert-file-contents-1
b42d9cfd5c8f (info-insert-file-contents-1): Accept an additional
Eli Zaretskii <eliz@gnu.org>
parents: 36092
diff changeset
662 temp (car (car suffix-list)) nil)))
b42d9cfd5c8f (info-insert-file-contents-1): Accept an additional
Eli Zaretskii <eliz@gnu.org>
parents: 36092
diff changeset
663 (setq found temp)))
22692
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
664 (setq suffix-list (cdr suffix-list))))
54718
fd0577e11e88 (info-apropos): New function.
Jesper Harder <harder@ifa.au.dk>
parents: 54506
diff changeset
665 (setq dirs (cdr dirs))))))
22692
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
666 (if found
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
667 (setq filename found)
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
668 (if noerror
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
669 (setq filename nil)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
670 (error "Info file %s does not exist" filename)))
68980
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
671 filename)
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
672 (and (member filename '(apropos history toc)) filename)))
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
673
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
674 (defun Info-find-node (filename nodename &optional no-going-back)
64812
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
675 "Go to an Info node specified as separate FILENAME and NODENAME.
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
676 NO-GOING-BACK is non-nil if recovering from an error in this function;
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
677 it says do not attempt further (recursive) error recovery."
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
678 (info-initialize)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
679 (setq filename (Info-find-file filename))
64812
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
680 ;; Go into Info buffer.
60626
20a8e6e5ae57 Update error messages for `debug-ignored-errors'.
Juri Linkov <juri@jurta.org>
parents: 60615
diff changeset
681 (or (eq major-mode 'Info-mode) (pop-to-buffer "*info*"))
68045
84897e4dbe0c (Info-find-node): Don't record previous node if have none.
Richard M. Stallman <rms@gnu.org>
parents: 67778
diff changeset
682 ;; Record the node we are leaving, if we were in one.
84897e4dbe0c (Info-find-node): Don't record previous node if have none.
Richard M. Stallman <rms@gnu.org>
parents: 67778
diff changeset
683 (and (not no-going-back)
84897e4dbe0c (Info-find-node): Don't record previous node if have none.
Richard M. Stallman <rms@gnu.org>
parents: 67778
diff changeset
684 Info-current-file
84897e4dbe0c (Info-find-node): Don't record previous node if have none.
Richard M. Stallman <rms@gnu.org>
parents: 67778
diff changeset
685 (setq Info-history
84897e4dbe0c (Info-find-node): Don't record previous node if have none.
Richard M. Stallman <rms@gnu.org>
parents: 67778
diff changeset
686 (cons (list Info-current-file Info-current-node (point))
84897e4dbe0c (Info-find-node): Don't record previous node if have none.
Richard M. Stallman <rms@gnu.org>
parents: 67778
diff changeset
687 Info-history)))
26004
11f91800bec3 (Info-on-current-buffer): new entry point.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 25878
diff changeset
688 (Info-find-node-2 filename nodename no-going-back))
11f91800bec3 (Info-on-current-buffer): new entry point.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 25878
diff changeset
689
67121
f354001864bf * info.el (Info-on-current-buffer): Record actual filename in
Chong Yidong <cyd@stupidchicken.com>
parents: 67109
diff changeset
690 ;;;###autoload
26004
11f91800bec3 (Info-on-current-buffer): new entry point.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 25878
diff changeset
691 (defun Info-on-current-buffer (&optional nodename)
67520
d08070c157fd (Info-on-current-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 67374
diff changeset
692 "Use Info mode to browse the current Info buffer.
d08070c157fd (Info-on-current-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 67374
diff changeset
693 With a prefix arg, this queries for the node name to visit first;
d08070c157fd (Info-on-current-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 67374
diff changeset
694 otherwise, that defaults to `Top'."
26004
11f91800bec3 (Info-on-current-buffer): new entry point.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 25878
diff changeset
695 (interactive
11f91800bec3 (Info-on-current-buffer): new entry point.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 25878
diff changeset
696 (list (if current-prefix-arg
11f91800bec3 (Info-on-current-buffer): new entry point.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 25878
diff changeset
697 (completing-read "Node name: " (Info-build-node-completions)
39459
a7adbd38c82a (Info-on-current-buffer): Default arg to "Top".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39382
diff changeset
698 nil t "Top"))))
a7adbd38c82a (Info-on-current-buffer): Default arg to "Top".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39382
diff changeset
699 (unless nodename (setq nodename "Top"))
29410
935f96194020 (Info-on-current-buffer): Initialize info.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 29164
diff changeset
700 (info-initialize)
26004
11f91800bec3 (Info-on-current-buffer): new entry point.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 25878
diff changeset
701 (Info-mode)
67121
f354001864bf * info.el (Info-on-current-buffer): Record actual filename in
Chong Yidong <cyd@stupidchicken.com>
parents: 67109
diff changeset
702 (set (make-local-variable 'Info-current-file)
f354001864bf * info.el (Info-on-current-buffer): Record actual filename in
Chong Yidong <cyd@stupidchicken.com>
parents: 67109
diff changeset
703 (or buffer-file-name
f354001864bf * info.el (Info-on-current-buffer): Record actual filename in
Chong Yidong <cyd@stupidchicken.com>
parents: 67109
diff changeset
704 ;; If called on a non-file buffer, make a fake file name.
f354001864bf * info.el (Info-on-current-buffer): Record actual filename in
Chong Yidong <cyd@stupidchicken.com>
parents: 67109
diff changeset
705 (concat default-directory (buffer-name))))
26004
11f91800bec3 (Info-on-current-buffer): new entry point.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 25878
diff changeset
706 (Info-find-node-2 nil nodename))
11f91800bec3 (Info-on-current-buffer): new entry point.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 25878
diff changeset
707
48933
06dd01f3b917 (Info-revert-find-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 48887
diff changeset
708 ;; It's perhaps a bit nasty to kill the *info* buffer to force a re-read,
06dd01f3b917 (Info-revert-find-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 48887
diff changeset
709 ;; but at least it keeps this routine (which is only for the benefit of
06dd01f3b917 (Info-revert-find-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 48887
diff changeset
710 ;; makeinfo-buffer) out of the way of normal operations.
06dd01f3b917 (Info-revert-find-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 48887
diff changeset
711 ;;
06dd01f3b917 (Info-revert-find-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 48887
diff changeset
712 (defun Info-revert-find-node (filename nodename)
64812
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
713 "Go to an Info node FILENAME and NODENAME, re-reading disk contents.
48933
06dd01f3b917 (Info-revert-find-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 48887
diff changeset
714 When *info* is already displaying FILENAME and NODENAME, the window position
06dd01f3b917 (Info-revert-find-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 48887
diff changeset
715 is preserved, if possible."
06dd01f3b917 (Info-revert-find-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 48887
diff changeset
716 (pop-to-buffer "*info*")
06dd01f3b917 (Info-revert-find-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 48887
diff changeset
717 (let ((old-filename Info-current-file)
06dd01f3b917 (Info-revert-find-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 48887
diff changeset
718 (old-nodename Info-current-node)
06dd01f3b917 (Info-revert-find-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 48887
diff changeset
719 (pcolumn (current-column))
06dd01f3b917 (Info-revert-find-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 48887
diff changeset
720 (pline (count-lines (point-min) (line-beginning-position)))
06dd01f3b917 (Info-revert-find-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 48887
diff changeset
721 (wline (count-lines (point-min) (window-start)))
06dd01f3b917 (Info-revert-find-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 48887
diff changeset
722 (old-history Info-history)
68227
51ca63f92c59 (Info-revert-find-node): Check for Info-current-file
Juri Linkov <juri@jurta.org>
parents: 68216
diff changeset
723 (new-history (and Info-current-file
51ca63f92c59 (Info-revert-find-node): Check for Info-current-file
Juri Linkov <juri@jurta.org>
parents: 68216
diff changeset
724 (list Info-current-file Info-current-node (point)))))
48933
06dd01f3b917 (Info-revert-find-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 48887
diff changeset
725 (kill-buffer (current-buffer))
06dd01f3b917 (Info-revert-find-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 48887
diff changeset
726 (Info-find-node filename nodename)
06dd01f3b917 (Info-revert-find-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 48887
diff changeset
727 (setq Info-history old-history)
06dd01f3b917 (Info-revert-find-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 48887
diff changeset
728 (if (and (equal old-filename Info-current-file)
06dd01f3b917 (Info-revert-find-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 48887
diff changeset
729 (equal old-nodename Info-current-node))
06dd01f3b917 (Info-revert-find-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 48887
diff changeset
730 (progn
06dd01f3b917 (Info-revert-find-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 48887
diff changeset
731 ;; note goto-line is no good, we want to measure from point-min
58040
af694410e72f (Info-revert-find-node): Don't use beginning-of-buffer.
Richard M. Stallman <rms@gnu.org>
parents: 57958
diff changeset
732 (goto-char (point-min))
48933
06dd01f3b917 (Info-revert-find-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 48887
diff changeset
733 (forward-line wline)
06dd01f3b917 (Info-revert-find-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 48887
diff changeset
734 (set-window-start (selected-window) (point))
58040
af694410e72f (Info-revert-find-node): Don't use beginning-of-buffer.
Richard M. Stallman <rms@gnu.org>
parents: 57958
diff changeset
735 (goto-char (point-min))
48933
06dd01f3b917 (Info-revert-find-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 48887
diff changeset
736 (forward-line pline)
06dd01f3b917 (Info-revert-find-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 48887
diff changeset
737 (move-to-column pcolumn))
06dd01f3b917 (Info-revert-find-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 48887
diff changeset
738 ;; only add to the history when coming from a different file+node
06dd01f3b917 (Info-revert-find-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 48887
diff changeset
739 (if new-history
06dd01f3b917 (Info-revert-find-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 48887
diff changeset
740 (setq Info-history (cons new-history Info-history))))))
06dd01f3b917 (Info-revert-find-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 48887
diff changeset
741
29684
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
742 (defun Info-find-in-tag-table-1 (marker regexp case-fold)
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
743 "Find a node in a tag table.
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
744 MARKER specifies the buffer and position to start searching at.
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
745 REGEXP is a regular expression matching nodes or references. Its first
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
746 group should match `Node:' or `Ref:'.
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
747 CASE-FOLD t means search for a case-insensitive match.
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
748 If a match was found, value is a list (FOUND-ANCHOR POS MODE), where
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
749 FOUND-ANCHOR is non-nil if a `Ref:' was matched, POS is the position
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
750 where the match was found, and MODE is `major-mode' of the buffer in
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
751 which the match was found."
51434
4c85e6a5a9d2 (Info-mode-hook): Obey obsolete `Info-fontify'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51310
diff changeset
752 (let ((case-fold-search case-fold))
29684
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
753 (save-excursion
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
754 (set-buffer (marker-buffer marker))
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
755 (goto-char marker)
49424
59c37b87bb18 (Info-try-follow-nearest-node): Add case: Handle menu item
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 49390
diff changeset
756
29684
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
757 ;; Search tag table
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
758 (beginning-of-line)
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
759 (when (re-search-forward regexp nil t)
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
760 (list (string-equal "Ref:" (match-string 1))
45014
a590e8ab89d0 (Info-find-in-tag-table-1, Info-read-subfile): Use point-min.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44902
diff changeset
761 (+ (point-min) (read (current-buffer)))
29684
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
762 major-mode)))))
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
763
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
764 (defun Info-find-in-tag-table (marker regexp)
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
765 "Find a node in a tag table.
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
766 MARKER specifies the buffer and position to start searching at.
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
767 REGEXP is a regular expression matching nodes or references. Its first
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
768 group should match `Node:' or `Ref:'.
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
769 If a match was found, value is a list (FOUND-ANCHOR POS MODE), where
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
770 FOUND-ANCHOR is non-nil if a `Ref:' was matched, POS is the position
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
771 where the match was found, and MODE is `major-mode' of the buffer in
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
772 which the match was found.
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
773 This function tries to find a case-sensitive match first, then a
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
774 case-insensitive match is tried."
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
775 (let ((result (Info-find-in-tag-table-1 marker regexp nil)))
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
776 (when (null (car result))
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
777 (setq result (Info-find-in-tag-table-1 marker regexp t)))
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
778 result))
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
779
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
780 (defun Info-find-node-in-buffer-1 (regexp case-fold)
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
781 "Find a node or anchor in the current buffer.
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
782 REGEXP is a regular expression matching nodes or references. Its first
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
783 group should match `Node:' or `Ref:'.
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
784 CASE-FOLD t means search for a case-insensitive match.
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
785 Value is the position at which a match was found, or nil if not found."
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
786 (let ((case-fold-search case-fold)
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
787 found)
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
788 (save-excursion
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
789 (when (Info-node-at-bob-matching regexp)
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
790 (setq found (point)))
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
791 (while (and (not found)
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
792 (search-forward "\n\^_" nil t))
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
793 (forward-line 1)
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
794 (let ((beg (point)))
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
795 (forward-line 1)
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
796 (when (re-search-backward regexp beg t)
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
797 (beginning-of-line)
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
798 (setq found (point)))))
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
799 found)))
49424
59c37b87bb18 (Info-try-follow-nearest-node): Add case: Handle menu item
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 49390
diff changeset
800
29684
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
801 (defun Info-find-node-in-buffer (regexp)
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
802 "Find a node or anchor in the current buffer.
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
803 REGEXP is a regular expression matching nodes or references. Its first
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
804 group should match `Node:' or `Ref:'.
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
805 Value is the position at which a match was found, or nil if not found.
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
806 This function looks for a case-sensitive match first. If none is found,
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
807 a case-insensitive match is tried."
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
808 (or (Info-find-node-in-buffer-1 regexp nil)
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
809 (Info-find-node-in-buffer-1 regexp t)))
49424
59c37b87bb18 (Info-try-follow-nearest-node): Add case: Handle menu item
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 49390
diff changeset
810
26004
11f91800bec3 (Info-on-current-buffer): new entry point.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 25878
diff changeset
811 (defun Info-find-node-2 (filename nodename &optional no-going-back)
21704
e2283c4df334 (Info-fontify-node): For menu items, use info-xref font.
Richard M. Stallman <rms@gnu.org>
parents: 21641
diff changeset
812 (buffer-disable-undo (current-buffer))
e2283c4df334 (Info-fontify-node): For menu items, use info-xref font.
Richard M. Stallman <rms@gnu.org>
parents: 21641
diff changeset
813 (or (eq major-mode 'Info-mode)
e2283c4df334 (Info-fontify-node): For menu items, use info-xref font.
Richard M. Stallman <rms@gnu.org>
parents: 21641
diff changeset
814 (Info-mode))
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
815 (widen)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
816 (setq Info-current-node nil)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
817 (unwind-protect
24632
a6ad37f4f6cb (Info-find-node): Position properly after finding anchor.
Karl Heuer <kwzh@gnu.org>
parents: 24580
diff changeset
818 (let ((case-fold-search t)
a6ad37f4f6cb (Info-find-node): Position properly after finding anchor.
Karl Heuer <kwzh@gnu.org>
parents: 24580
diff changeset
819 anchorpos)
22692
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
820 ;; Switch files if necessary
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
821 (or (null filename)
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
822 (equal Info-current-file filename)
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
823 (let ((buffer-read-only nil))
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
824 (setq Info-current-file nil
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
825 Info-current-subfile nil
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
826 Info-current-file-completions nil
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
827 buffer-file-name nil)
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
828 (erase-buffer)
54718
fd0577e11e88 (info-apropos): New function.
Jesper Harder <harder@ifa.au.dk>
parents: 54506
diff changeset
829 (cond
fd0577e11e88 (info-apropos): New function.
Jesper Harder <harder@ifa.au.dk>
parents: 54506
diff changeset
830 ((eq filename t)
fd0577e11e88 (info-apropos): New function.
Jesper Harder <harder@ifa.au.dk>
parents: 54506
diff changeset
831 (Info-insert-dir))
fd0577e11e88 (info-apropos): New function.
Jesper Harder <harder@ifa.au.dk>
parents: 54506
diff changeset
832 ((eq filename 'apropos)
fd0577e11e88 (info-apropos): New function.
Jesper Harder <harder@ifa.au.dk>
parents: 54506
diff changeset
833 (insert-buffer-substring " *info-apropos*"))
55074
dd4c270b21af Restore 2004-04-18 changes.
Juri Linkov <juri@jurta.org>
parents: 55061
diff changeset
834 ((eq filename 'history)
dd4c270b21af Restore 2004-04-18 changes.
Juri Linkov <juri@jurta.org>
parents: 55061
diff changeset
835 (insert-buffer-substring " *info-history*"))
dd4c270b21af Restore 2004-04-18 changes.
Juri Linkov <juri@jurta.org>
parents: 55061
diff changeset
836 ((eq filename 'toc)
dd4c270b21af Restore 2004-04-18 changes.
Juri Linkov <juri@jurta.org>
parents: 55061
diff changeset
837 (insert-buffer-substring " *info-toc*"))
54718
fd0577e11e88 (info-apropos): New function.
Jesper Harder <harder@ifa.au.dk>
parents: 54506
diff changeset
838 (t
41713
d53ece895385 (Info-find-node-2): Don't call info-insert-file-contents
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 41691
diff changeset
839 (info-insert-file-contents filename nil)
54718
fd0577e11e88 (info-apropos): New function.
Jesper Harder <harder@ifa.au.dk>
parents: 54506
diff changeset
840 (setq default-directory (file-name-directory filename))))
22692
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
841 (set-buffer-modified-p nil)
66602
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
842
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
843 ;; Check makeinfo version for index cookie support
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
844 (let ((found nil))
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
845 (goto-char (point-min))
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
846 (condition-case ()
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
847 (if (and (re-search-forward
71533
f6293eaa5979 (Info-find-node-2): Search for makeinfo version more carefully.
Nick Roberts <nickrob@snap.net.nz>
parents: 70973
diff changeset
848 "makeinfo[ \n]version[ \n]\\([0-9]+.[0-9]+\\)"
66602
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
849 (line-beginning-position 3) t)
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
850 (not (version< (match-string 1) "4.7")))
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
851 (setq found t))
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
852 (error nil))
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
853 (set (make-local-variable 'Info-file-supports-index-cookies) found))
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
854
22692
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
855 ;; See whether file has a tag table. Record the location if yes.
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
856 (goto-char (point-max))
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
857 (forward-line -8)
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
858 ;; Use string-equal, not equal, to ignore text props.
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
859 (if (not (or (string-equal nodename "*")
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
860 (not
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
861 (search-forward "\^_\nEnd tag table\n" nil t))))
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
862 (let (pos)
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
863 ;; We have a tag table. Find its beginning.
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
864 ;; Is this an indirect file?
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
865 (search-backward "\nTag table:\n")
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
866 (setq pos (point))
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
867 (if (save-excursion
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
868 (forward-line 2)
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
869 (looking-at "(Indirect)\n"))
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
870 ;; It is indirect. Copy it to another buffer
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
871 ;; and record that the tag table is in that buffer.
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
872 (let ((buf (current-buffer))
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
873 (tagbuf
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
874 (or Info-tag-table-buffer
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
875 (generate-new-buffer " *info tag table*"))))
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
876 (setq Info-tag-table-buffer tagbuf)
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
877 (save-excursion
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
878 (set-buffer tagbuf)
1484
6c2a714566d3 Rename buffer-flush-undo to buffer-disable-undo.
Richard M. Stallman <rms@gnu.org>
parents: 1477
diff changeset
879 (buffer-disable-undo (current-buffer))
22692
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
880 (setq case-fold-search t)
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
881 (erase-buffer)
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
882 (insert-buffer-substring buf))
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
883 (set-marker Info-tag-table-marker
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
884 (match-end 0) tagbuf))
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
885 (set-marker Info-tag-table-marker pos)))
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
886 (set-marker Info-tag-table-marker nil))
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
887 (setq Info-current-file
54718
fd0577e11e88 (info-apropos): New function.
Jesper Harder <harder@ifa.au.dk>
parents: 54506
diff changeset
888 (cond
fd0577e11e88 (info-apropos): New function.
Jesper Harder <harder@ifa.au.dk>
parents: 54506
diff changeset
889 ((eq filename t) "dir")
fd0577e11e88 (info-apropos): New function.
Jesper Harder <harder@ifa.au.dk>
parents: 54506
diff changeset
890 (t filename)))
fd0577e11e88 (info-apropos): New function.
Jesper Harder <harder@ifa.au.dk>
parents: 54506
diff changeset
891 ))
22692
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
892 ;; Use string-equal, not equal, to ignore text props.
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
893 (if (string-equal nodename "*")
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
894 (progn (setq Info-current-node nodename)
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
895 (Info-set-mode-line))
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
896 ;; Possibilities:
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
897 ;;
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
898 ;; 1. Anchor found in tag table
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
899 ;; 2. Anchor *not* in tag table
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
900 ;;
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
901 ;; 3. Node found in tag table
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
902 ;; 4. Node *not* found in tag table, but found in file
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
903 ;; 5. Node *not* in tag table, and *not* in file
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
904 ;;
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
905 ;; *Or* the same, but in an indirect subfile.
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
906
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
907 ;; Search file for a suitable node.
24632
a6ad37f4f6cb (Info-find-node): Position properly after finding anchor.
Karl Heuer <kwzh@gnu.org>
parents: 24580
diff changeset
908 (let ((guesspos (point-min))
29684
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
909 (regexp (concat "\\(Node:\\|Ref:\\) *\\("
38262
03f0515fe575 (Info-clone-buffer-hook): Really unconditionally copy marker.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 38225
diff changeset
910 (if (stringp nodename)
30686
23c301a64c8f (Info-insert-dir): Use Info-additional-directory-list if
Gerd Moellmann <gerd@gnu.org>
parents: 30423
diff changeset
911 (regexp-quote nodename)
23c301a64c8f (Info-insert-dir): Use Info-additional-directory-list if
Gerd Moellmann <gerd@gnu.org>
parents: 30423
diff changeset
912 "")
51434
4c85e6a5a9d2 (Info-mode-hook): Obey obsolete `Info-fontify'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51310
diff changeset
913 "\\) *[,\t\n\177]")))
22692
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
914
29164
71275ee34b42 (Info-find-node-2): Restructure [following "Vadim S. Solomin"
Dave Love <fx@gnu.org>
parents: 29085
diff changeset
915 (catch 'foo
49424
59c37b87bb18 (Info-try-follow-nearest-node): Add case: Handle menu item
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 49390
diff changeset
916
29164
71275ee34b42 (Info-find-node-2): Restructure [following "Vadim S. Solomin"
Dave Love <fx@gnu.org>
parents: 29085
diff changeset
917 ;; First, search a tag table, if any
29684
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
918 (when (marker-position Info-tag-table-marker)
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
919 (let* ((m Info-tag-table-marker)
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
920 (found (Info-find-in-tag-table m regexp)))
49424
59c37b87bb18 (Info-try-follow-nearest-node): Add case: Handle menu item
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 49390
diff changeset
921
29684
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
922 (when found
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
923 ;; FOUND is (ANCHOR POS MODE).
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
924 (setq guesspos (nth 1 found))
49424
59c37b87bb18 (Info-try-follow-nearest-node): Add case: Handle menu item
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 49390
diff changeset
925
29684
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
926 ;; If this is an indirect file, determine which
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
927 ;; file really holds this node and read it in.
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
928 (unless (eq (nth 2 found) 'Info-mode)
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
929 ;; Note that the current buffer must be the
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
930 ;; *info* buffer on entry to
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
931 ;; Info-read-subfile. Thus the hackery above.
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
932 (setq guesspos (Info-read-subfile guesspos)))
29164
71275ee34b42 (Info-find-node-2): Restructure [following "Vadim S. Solomin"
Dave Love <fx@gnu.org>
parents: 29085
diff changeset
933
71275ee34b42 (Info-find-node-2): Restructure [following "Vadim S. Solomin"
Dave Love <fx@gnu.org>
parents: 29085
diff changeset
934 ;; Handle anchor
29684
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
935 (when (nth 0 found)
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
936 (goto-char (setq anchorpos guesspos))
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
937 (throw 'foo t)))))
29164
71275ee34b42 (Info-find-node-2): Restructure [following "Vadim S. Solomin"
Dave Love <fx@gnu.org>
parents: 29085
diff changeset
938
71275ee34b42 (Info-find-node-2): Restructure [following "Vadim S. Solomin"
Dave Love <fx@gnu.org>
parents: 29085
diff changeset
939 ;; Else we may have a node, which we search for:
71275ee34b42 (Info-find-node-2): Restructure [following "Vadim S. Solomin"
Dave Love <fx@gnu.org>
parents: 29085
diff changeset
940 (goto-char (max (point-min)
71275ee34b42 (Info-find-node-2): Restructure [following "Vadim S. Solomin"
Dave Love <fx@gnu.org>
parents: 29085
diff changeset
941 (- (byte-to-position guesspos) 1000)))
49424
59c37b87bb18 (Info-try-follow-nearest-node): Add case: Handle menu item
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 49390
diff changeset
942
29684
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
943 ;; Now search from our advised position (or from beg of
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
944 ;; buffer) to find the actual node. First, check
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
945 ;; whether the node is right where we are, in case the
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
946 ;; buffer begins with a node.
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
947 (let ((pos (Info-find-node-in-buffer regexp)))
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
948 (when pos
4380fdbfe977 (Info-find-in-tag-table-1, Info-find-in-tag-table)
Gerd Moellmann <gerd@gnu.org>
parents: 29675
diff changeset
949 (goto-char pos)
55751
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
950 (throw 'foo t)))
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
951
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
952 (when (string-match "\\([^.]+\\)\\." nodename)
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
953 (let (Info-point-loc)
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
954 (Info-find-node-2
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
955 filename (match-string 1 nodename) no-going-back))
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
956 (widen)
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
957 (throw 'foo t))
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
958
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
959 ;; No such anchor in tag table or node in tag table or file
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
960 (error "No such node or anchor: %s" nodename))
29164
71275ee34b42 (Info-find-node-2): Restructure [following "Vadim S. Solomin"
Dave Love <fx@gnu.org>
parents: 29085
diff changeset
961
71275ee34b42 (Info-find-node-2): Restructure [following "Vadim S. Solomin"
Dave Love <fx@gnu.org>
parents: 29085
diff changeset
962 (Info-select-node)
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
963 (goto-char (point-min))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
964 (cond (anchorpos
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
965 (let ((new-history (list Info-current-file
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
966 (substring-no-properties nodename))))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
967 ;; Add anchors to the history too
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
968 (setq Info-history-list
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
969 (cons new-history
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
970 (delete new-history Info-history-list))))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
971 (goto-char anchorpos))
55174
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
972 ((numberp Info-point-loc)
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
973 (forward-line (1- Info-point-loc))
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
974 (setq Info-point-loc nil))
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
975 ((stringp Info-point-loc)
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
976 (Info-find-index-name Info-point-loc)
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
977 (setq Info-point-loc nil))))))
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
978 ;; If we did not finish finding the specified node,
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
979 ;; go back to the previous one.
6716
9ce2d1a2c155 (Info-find-node): Don't try to backstep if no history.
Karl Heuer <kwzh@gnu.org>
parents: 6624
diff changeset
980 (or Info-current-node no-going-back (null Info-history)
22692
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
981 (let ((hist (car Info-history)))
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
982 (setq Info-history (cdr Info-history))
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
983 (Info-find-node (nth 0 hist) (nth 1 hist) t)
578a6d997580 (Info-find-node): Handle cross references to an @anchor.
Richard M. Stallman <rms@gnu.org>
parents: 22643
diff changeset
984 (goto-char (nth 2 hist))))))
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
985
1979
0582c70595f1 * info.el (Info-directory-list): Doc fix; it is set according to
Jim Blandy <jimb@redhat.com>
parents: 1971
diff changeset
986 ;; Cache the contents of the (virtual) dir file, once we have merged
0582c70595f1 * info.el (Info-directory-list): Doc fix; it is set according to
Jim Blandy <jimb@redhat.com>
parents: 1971
diff changeset
987 ;; it for the first time, so we can save time subsequently.
1971
b540866e8a79 (Info-insert-dir): Make menu items in Top node
Richard M. Stallman <rms@gnu.org>
parents: 1821
diff changeset
988 (defvar Info-dir-contents nil)
b540866e8a79 (Info-insert-dir): Make menu items in Top node
Richard M. Stallman <rms@gnu.org>
parents: 1821
diff changeset
989
1979
0582c70595f1 * info.el (Info-directory-list): Doc fix; it is set according to
Jim Blandy <jimb@redhat.com>
parents: 1971
diff changeset
990 ;; Cache for the directory we decided to use for the default-directory
0582c70595f1 * info.el (Info-directory-list): Doc fix; it is set according to
Jim Blandy <jimb@redhat.com>
parents: 1971
diff changeset
991 ;; of the merged dir text.
0582c70595f1 * info.el (Info-directory-list): Doc fix; it is set according to
Jim Blandy <jimb@redhat.com>
parents: 1971
diff changeset
992 (defvar Info-dir-contents-directory nil)
0582c70595f1 * info.el (Info-directory-list): Doc fix; it is set according to
Jim Blandy <jimb@redhat.com>
parents: 1971
diff changeset
993
3836
04f1cff889f4 (Info-insert-dir): Record file attributes of files used.
Richard M. Stallman <rms@gnu.org>
parents: 3565
diff changeset
994 ;; Record the file attributes of all the files from which we
04f1cff889f4 (Info-insert-dir): Record file attributes of files used.
Richard M. Stallman <rms@gnu.org>
parents: 3565
diff changeset
995 ;; constructed Info-dir-contents.
04f1cff889f4 (Info-insert-dir): Record file attributes of files used.
Richard M. Stallman <rms@gnu.org>
parents: 3565
diff changeset
996 (defvar Info-dir-file-attributes nil)
04f1cff889f4 (Info-insert-dir): Record file attributes of files used.
Richard M. Stallman <rms@gnu.org>
parents: 3565
diff changeset
997
23416
83f51f5fb749 (Info-insert-dir): Detect and report problems
Richard M. Stallman <rms@gnu.org>
parents: 23175
diff changeset
998 (defvar Info-dir-file-name nil)
83f51f5fb749 (Info-insert-dir): Detect and report problems
Richard M. Stallman <rms@gnu.org>
parents: 23175
diff changeset
999
1971
b540866e8a79 (Info-insert-dir): Make menu items in Top node
Richard M. Stallman <rms@gnu.org>
parents: 1821
diff changeset
1000 ;; Construct the Info directory node by merging the files named `dir'
1979
0582c70595f1 * info.el (Info-directory-list): Doc fix; it is set according to
Jim Blandy <jimb@redhat.com>
parents: 1971
diff changeset
1001 ;; from various directories. Set the *info* buffer's
0582c70595f1 * info.el (Info-directory-list): Doc fix; it is set according to
Jim Blandy <jimb@redhat.com>
parents: 1971
diff changeset
1002 ;; default-directory to the first directory we actually get any text
0582c70595f1 * info.el (Info-directory-list): Doc fix; it is set according to
Jim Blandy <jimb@redhat.com>
parents: 1971
diff changeset
1003 ;; from.
1971
b540866e8a79 (Info-insert-dir): Make menu items in Top node
Richard M. Stallman <rms@gnu.org>
parents: 1821
diff changeset
1004 (defun Info-insert-dir ()
3836
04f1cff889f4 (Info-insert-dir): Record file attributes of files used.
Richard M. Stallman <rms@gnu.org>
parents: 3565
diff changeset
1005 (if (and Info-dir-contents Info-dir-file-attributes
04f1cff889f4 (Info-insert-dir): Record file attributes of files used.
Richard M. Stallman <rms@gnu.org>
parents: 3565
diff changeset
1006 ;; Verify that none of the files we used has changed
04f1cff889f4 (Info-insert-dir): Record file attributes of files used.
Richard M. Stallman <rms@gnu.org>
parents: 3565
diff changeset
1007 ;; since we used it.
04f1cff889f4 (Info-insert-dir): Record file attributes of files used.
Richard M. Stallman <rms@gnu.org>
parents: 3565
diff changeset
1008 (eval (cons 'and
29583
f1b4be7fce6d (Info-insert-dir): Don't quote lambda.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 29446
diff changeset
1009 (mapcar (lambda (elt)
f1b4be7fce6d (Info-insert-dir): Don't quote lambda.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 29446
diff changeset
1010 (let ((curr (file-attributes
f1b4be7fce6d (Info-insert-dir): Don't quote lambda.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 29446
diff changeset
1011 ;; Handle symlinks
f1b4be7fce6d (Info-insert-dir): Don't quote lambda.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 29446
diff changeset
1012 (file-truename (car elt)))))
28943
36fd90774cf7 (debug-ignored-errors): more errors to ignore.
Sam Steingold <sds@gnu.org>
parents: 28559
diff changeset
1013
29583
f1b4be7fce6d (Info-insert-dir): Don't quote lambda.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 29446
diff changeset
1014 ;; Don't compare the access time.
f1b4be7fce6d (Info-insert-dir): Don't quote lambda.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 29446
diff changeset
1015 (if curr (setcar (nthcdr 4 curr) 0))
f1b4be7fce6d (Info-insert-dir): Don't quote lambda.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 29446
diff changeset
1016 (setcar (nthcdr 4 (cdr elt)) 0)
f1b4be7fce6d (Info-insert-dir): Don't quote lambda.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 29446
diff changeset
1017 (equal (cdr elt) curr)))
3836
04f1cff889f4 (Info-insert-dir): Record file attributes of files used.
Richard M. Stallman <rms@gnu.org>
parents: 3565
diff changeset
1018 Info-dir-file-attributes))))
23416
83f51f5fb749 (Info-insert-dir): Detect and report problems
Richard M. Stallman <rms@gnu.org>
parents: 23175
diff changeset
1019 (progn
83f51f5fb749 (Info-insert-dir): Detect and report problems
Richard M. Stallman <rms@gnu.org>
parents: 23175
diff changeset
1020 (insert Info-dir-contents)
83f51f5fb749 (Info-insert-dir): Detect and report problems
Richard M. Stallman <rms@gnu.org>
parents: 23175
diff changeset
1021 (goto-char (point-min)))
30686
23c301a64c8f (Info-insert-dir): Use Info-additional-directory-list if
Gerd Moellmann <gerd@gnu.org>
parents: 30423
diff changeset
1022 (let ((dirs (if Info-additional-directory-list
46139
0632bf21a2c9 Indentation change.
Richard M. Stallman <rms@gnu.org>
parents: 46104
diff changeset
1023 (append Info-directory-list
0632bf21a2c9 Indentation change.
Richard M. Stallman <rms@gnu.org>
parents: 46104
diff changeset
1024 Info-additional-directory-list)
0632bf21a2c9 Indentation change.
Richard M. Stallman <rms@gnu.org>
parents: 46104
diff changeset
1025 Info-directory-list))
48690
036a8f0597c4 (Info-insert-dir): Make dir-node-cache variables buffer-local, so that
Miles Bader <miles@gnu.org>
parents: 48582
diff changeset
1026 (dir-file-attrs nil)
22951
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
1027 ;; Bind this in case the user sets it to nil.
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
1028 (case-fold-search t)
23416
83f51f5fb749 (Info-insert-dir): Detect and report problems
Richard M. Stallman <rms@gnu.org>
parents: 23175
diff changeset
1029 ;; This is set non-nil if we find a problem in some input files.
83f51f5fb749 (Info-insert-dir): Detect and report problems
Richard M. Stallman <rms@gnu.org>
parents: 23175
diff changeset
1030 problems
3212
cd8f8468a190 (Info-insert-dir): Ignore duplicate directories.
Richard M. Stallman <rms@gnu.org>
parents: 3127
diff changeset
1031 buffers buffer others nodes dirs-done)
1979
0582c70595f1 * info.el (Info-directory-list): Doc fix; it is set according to
Jim Blandy <jimb@redhat.com>
parents: 1971
diff changeset
1032
0582c70595f1 * info.el (Info-directory-list): Doc fix; it is set according to
Jim Blandy <jimb@redhat.com>
parents: 1971
diff changeset
1033 ;; Search the directory list for the directory file.
1971
b540866e8a79 (Info-insert-dir): Make menu items in Top node
Richard M. Stallman <rms@gnu.org>
parents: 1821
diff changeset
1034 (while dirs
5271
c415cc48a084 (Info-insert-dir): Compute truename just once for each dir.
Richard M. Stallman <rms@gnu.org>
parents: 5146
diff changeset
1035 (let ((truename (file-truename (expand-file-name (car dirs)))))
c415cc48a084 (Info-insert-dir): Compute truename just once for each dir.
Richard M. Stallman <rms@gnu.org>
parents: 5146
diff changeset
1036 (or (member truename dirs-done)
c415cc48a084 (Info-insert-dir): Compute truename just once for each dir.
Richard M. Stallman <rms@gnu.org>
parents: 5146
diff changeset
1037 (member (directory-file-name truename) dirs-done)
c415cc48a084 (Info-insert-dir): Compute truename just once for each dir.
Richard M. Stallman <rms@gnu.org>
parents: 5146
diff changeset
1038 ;; Try several variants of specified name.
c415cc48a084 (Info-insert-dir): Compute truename just once for each dir.
Richard M. Stallman <rms@gnu.org>
parents: 5146
diff changeset
1039 ;; Try upcasing, appending `.info', or both.
7911
185c1f12db67 (Info-insert-dir): Ignore access times when comparing
Richard M. Stallman <rms@gnu.org>
parents: 7859
diff changeset
1040 (let* (file
185c1f12db67 (Info-insert-dir): Ignore access times when comparing
Richard M. Stallman <rms@gnu.org>
parents: 7859
diff changeset
1041 (attrs
185c1f12db67 (Info-insert-dir): Ignore access times when comparing
Richard M. Stallman <rms@gnu.org>
parents: 7859
diff changeset
1042 (or
185c1f12db67 (Info-insert-dir): Ignore access times when comparing
Richard M. Stallman <rms@gnu.org>
parents: 7859
diff changeset
1043 (progn (setq file (expand-file-name "dir" truename))
185c1f12db67 (Info-insert-dir): Ignore access times when comparing
Richard M. Stallman <rms@gnu.org>
parents: 7859
diff changeset
1044 (file-attributes file))
185c1f12db67 (Info-insert-dir): Ignore access times when comparing
Richard M. Stallman <rms@gnu.org>
parents: 7859
diff changeset
1045 (progn (setq file (expand-file-name "DIR" truename))
185c1f12db67 (Info-insert-dir): Ignore access times when comparing
Richard M. Stallman <rms@gnu.org>
parents: 7859
diff changeset
1046 (file-attributes file))
185c1f12db67 (Info-insert-dir): Ignore access times when comparing
Richard M. Stallman <rms@gnu.org>
parents: 7859
diff changeset
1047 (progn (setq file (expand-file-name "dir.info" truename))
185c1f12db67 (Info-insert-dir): Ignore access times when comparing
Richard M. Stallman <rms@gnu.org>
parents: 7859
diff changeset
1048 (file-attributes file))
185c1f12db67 (Info-insert-dir): Ignore access times when comparing
Richard M. Stallman <rms@gnu.org>
parents: 7859
diff changeset
1049 (progn (setq file (expand-file-name "DIR.INFO" truename))
185c1f12db67 (Info-insert-dir): Ignore access times when comparing
Richard M. Stallman <rms@gnu.org>
parents: 7859
diff changeset
1050 (file-attributes file)))))
5271
c415cc48a084 (Info-insert-dir): Compute truename just once for each dir.
Richard M. Stallman <rms@gnu.org>
parents: 5146
diff changeset
1051 (setq dirs-done
c415cc48a084 (Info-insert-dir): Compute truename just once for each dir.
Richard M. Stallman <rms@gnu.org>
parents: 5146
diff changeset
1052 (cons truename
c415cc48a084 (Info-insert-dir): Compute truename just once for each dir.
Richard M. Stallman <rms@gnu.org>
parents: 5146
diff changeset
1053 (cons (directory-file-name truename)
c415cc48a084 (Info-insert-dir): Compute truename just once for each dir.
Richard M. Stallman <rms@gnu.org>
parents: 5146
diff changeset
1054 dirs-done)))
7911
185c1f12db67 (Info-insert-dir): Ignore access times when comparing
Richard M. Stallman <rms@gnu.org>
parents: 7859
diff changeset
1055 (if attrs
185c1f12db67 (Info-insert-dir): Ignore access times when comparing
Richard M. Stallman <rms@gnu.org>
parents: 7859
diff changeset
1056 (save-excursion
185c1f12db67 (Info-insert-dir): Ignore access times when comparing
Richard M. Stallman <rms@gnu.org>
parents: 7859
diff changeset
1057 (or buffers
185c1f12db67 (Info-insert-dir): Ignore access times when comparing
Richard M. Stallman <rms@gnu.org>
parents: 7859
diff changeset
1058 (message "Composing main Info directory..."))
20421
6d1f6745878f (Info-insert-dir): Use leading space in buffer name.
Karl Heuer <kwzh@gnu.org>
parents: 19937
diff changeset
1059 (set-buffer (generate-new-buffer " info dir"))
22863
58584d6a8237 (Info-find-node): Position at the beginning of the node
Richard M. Stallman <rms@gnu.org>
parents: 22761
diff changeset
1060 (condition-case nil
58584d6a8237 (Info-find-node): Position at the beginning of the node
Richard M. Stallman <rms@gnu.org>
parents: 22761
diff changeset
1061 (progn
58584d6a8237 (Info-find-node): Position at the beginning of the node
Richard M. Stallman <rms@gnu.org>
parents: 22761
diff changeset
1062 (insert-file-contents file)
48690
036a8f0597c4 (Info-insert-dir): Make dir-node-cache variables buffer-local, so that
Miles Bader <miles@gnu.org>
parents: 48582
diff changeset
1063 (set (make-local-variable 'Info-dir-file-name)
036a8f0597c4 (Info-insert-dir): Make dir-node-cache variables buffer-local, so that
Miles Bader <miles@gnu.org>
parents: 48582
diff changeset
1064 file)
48135
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1065 (push (current-buffer) buffers)
48690
036a8f0597c4 (Info-insert-dir): Make dir-node-cache variables buffer-local, so that
Miles Bader <miles@gnu.org>
parents: 48582
diff changeset
1066 (push (cons file attrs) dir-file-attrs))
22863
58584d6a8237 (Info-find-node): Position at the beginning of the node
Richard M. Stallman <rms@gnu.org>
parents: 22761
diff changeset
1067 (error (kill-buffer (current-buffer))))))))
48690
036a8f0597c4 (Info-insert-dir): Make dir-node-cache variables buffer-local, so that
Miles Bader <miles@gnu.org>
parents: 48582
diff changeset
1068 (unless (cdr dirs)
036a8f0597c4 (Info-insert-dir): Make dir-node-cache variables buffer-local, so that
Miles Bader <miles@gnu.org>
parents: 48582
diff changeset
1069 (set (make-local-variable 'Info-dir-contents-directory)
036a8f0597c4 (Info-insert-dir): Make dir-node-cache variables buffer-local, so that
Miles Bader <miles@gnu.org>
parents: 48582
diff changeset
1070 (file-name-as-directory (car dirs))))
7911
185c1f12db67 (Info-insert-dir): Ignore access times when comparing
Richard M. Stallman <rms@gnu.org>
parents: 7859
diff changeset
1071 (setq dirs (cdr dirs))))
28943
36fd90774cf7 (debug-ignored-errors): more errors to ignore.
Sam Steingold <sds@gnu.org>
parents: 28559
diff changeset
1072
6716
9ce2d1a2c155 (Info-find-node): Don't try to backstep if no history.
Karl Heuer <kwzh@gnu.org>
parents: 6624
diff changeset
1073 (or buffers
14664
f77b58df548c (Info-index): If fail, go back to original node.
Richard M. Stallman <rms@gnu.org>
parents: 14577
diff changeset
1074 (error "Can't find the Info directory node"))
48690
036a8f0597c4 (Info-insert-dir): Make dir-node-cache variables buffer-local, so that
Miles Bader <miles@gnu.org>
parents: 48582
diff changeset
1075
1979
0582c70595f1 * info.el (Info-directory-list): Doc fix; it is set according to
Jim Blandy <jimb@redhat.com>
parents: 1971
diff changeset
1076 ;; Distinguish the dir file that comes with Emacs from all the
3212
cd8f8468a190 (Info-insert-dir): Ignore duplicate directories.
Richard M. Stallman <rms@gnu.org>
parents: 3127
diff changeset
1077 ;; others. Yes, that is really what this is supposed to do.
24513
2db3b19a94bb (Info-directory-list): Revert change to re-writing
Dave Love <fx@gnu.org>
parents: 24196
diff changeset
1078 ;; The definition of `Info-directory-list' puts it first on that
2db3b19a94bb (Info-directory-list): Revert change to re-writing
Dave Love <fx@gnu.org>
parents: 24196
diff changeset
1079 ;; list and so last in `buffers' at this point.
2db3b19a94bb (Info-directory-list): Revert change to re-writing
Dave Love <fx@gnu.org>
parents: 24196
diff changeset
1080 (setq buffer (car (last buffers))
2db3b19a94bb (Info-directory-list): Revert change to re-writing
Dave Love <fx@gnu.org>
parents: 24196
diff changeset
1081 others (delq buffer buffers))
1979
0582c70595f1 * info.el (Info-directory-list): Doc fix; it is set according to
Jim Blandy <jimb@redhat.com>
parents: 1971
diff changeset
1082
15304
d78c3fd6a0ab (Info-insert-dir): Fix default directory.
Karl Heuer <kwzh@gnu.org>
parents: 15177
diff changeset
1083 ;; Insert the entire original dir file as a start; note that we've
d78c3fd6a0ab (Info-insert-dir): Fix default directory.
Karl Heuer <kwzh@gnu.org>
parents: 15177
diff changeset
1084 ;; already saved its default directory to use as the default
d78c3fd6a0ab (Info-insert-dir): Fix default directory.
Karl Heuer <kwzh@gnu.org>
parents: 15177
diff changeset
1085 ;; directory for the whole concatenation.
65069
fc42a1decf2d (Info-insert-dir): Use save-excursion around insert-buffer-substring.
Juri Linkov <juri@jurta.org>
parents: 64961
diff changeset
1086 (save-excursion (insert-buffer-substring buffer))
1979
0582c70595f1 * info.el (Info-directory-list): Doc fix; it is set according to
Jim Blandy <jimb@redhat.com>
parents: 1971
diff changeset
1087
1971
b540866e8a79 (Info-insert-dir): Make menu items in Top node
Richard M. Stallman <rms@gnu.org>
parents: 1821
diff changeset
1088 ;; Look at each of the other buffers one by one.
48135
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1089 (dolist (other others)
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1090 (let (this-buffer-nodes)
1971
b540866e8a79 (Info-insert-dir): Make menu items in Top node
Richard M. Stallman <rms@gnu.org>
parents: 1821
diff changeset
1091 ;; In each, find all the menus.
48135
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1092 (with-current-buffer other
1971
b540866e8a79 (Info-insert-dir): Make menu items in Top node
Richard M. Stallman <rms@gnu.org>
parents: 1821
diff changeset
1093 (goto-char (point-min))
b540866e8a79 (Info-insert-dir): Make menu items in Top node
Richard M. Stallman <rms@gnu.org>
parents: 1821
diff changeset
1094 ;; Find each menu, and add an elt to NODES for it.
b540866e8a79 (Info-insert-dir): Make menu items in Top node
Richard M. Stallman <rms@gnu.org>
parents: 1821
diff changeset
1095 (while (re-search-forward "^\\* Menu:" nil t)
48135
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1096 (while (and (zerop (forward-line 1)) (eolp)))
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1097 (let ((beg (point))
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1098 nodename end)
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1099 (re-search-backward "^\^_")
1971
b540866e8a79 (Info-insert-dir): Make menu items in Top node
Richard M. Stallman <rms@gnu.org>
parents: 1821
diff changeset
1100 (search-forward "Node: ")
55074
dd4c270b21af Restore 2004-04-18 changes.
Juri Linkov <juri@jurta.org>
parents: 55061
diff changeset
1101 (setq nodename (Info-following-node-name))
6339
f0f62abb621b (Info-insert-dir): Use printable escapes instead of embedding literal control
Karl Heuer <kwzh@gnu.org>
parents: 6121
diff changeset
1102 (search-forward "\n\^_" nil 'move)
1971
b540866e8a79 (Info-insert-dir): Make menu items in Top node
Richard M. Stallman <rms@gnu.org>
parents: 1821
diff changeset
1103 (beginning-of-line)
b540866e8a79 (Info-insert-dir): Make menu items in Top node
Richard M. Stallman <rms@gnu.org>
parents: 1821
diff changeset
1104 (setq end (point))
48135
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1105 (push (list nodename other beg end) this-buffer-nodes)))
53409
6f40406c2b3e (Info-insert-dir): Use assoc-string.
Richard M. Stallman <rms@gnu.org>
parents: 53246
diff changeset
1106 (if (assoc-string "top" this-buffer-nodes t)
23416
83f51f5fb749 (Info-insert-dir): Detect and report problems
Richard M. Stallman <rms@gnu.org>
parents: 23175
diff changeset
1107 (setq nodes (nconc this-buffer-nodes nodes))
83f51f5fb749 (Info-insert-dir): Detect and report problems
Richard M. Stallman <rms@gnu.org>
parents: 23175
diff changeset
1108 (setq problems t)
48135
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1109 (message "No `top' node in %s" Info-dir-file-name)))))
29621
f03c3a69a809 Doc fixes.
Dave Love <fx@gnu.org>
parents: 29583
diff changeset
1110 ;; Add to the main menu a menu item for each other node.
48135
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1111 (re-search-forward "^\\* Menu:")
1971
b540866e8a79 (Info-insert-dir): Make menu items in Top node
Richard M. Stallman <rms@gnu.org>
parents: 1821
diff changeset
1112 (forward-line 1)
b540866e8a79 (Info-insert-dir): Make menu items in Top node
Richard M. Stallman <rms@gnu.org>
parents: 1821
diff changeset
1113 (let ((menu-items '("top"))
6339
f0f62abb621b (Info-insert-dir): Use printable escapes instead of embedding literal control
Karl Heuer <kwzh@gnu.org>
parents: 6121
diff changeset
1114 (end (save-excursion (search-forward "\^_" nil t) (point))))
48135
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1115 (dolist (node nodes)
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1116 (let ((nodename (car node)))
6537
f5ab0b6b9640 (Info-insert-dir): Add a save-excursion.
Richard M. Stallman <rms@gnu.org>
parents: 6339
diff changeset
1117 (save-excursion
f5ab0b6b9640 (Info-insert-dir): Add a save-excursion.
Richard M. Stallman <rms@gnu.org>
parents: 6339
diff changeset
1118 (or (member (downcase nodename) menu-items)
21641
1174b1d6cbf6 (Info-menu): Allow extra spaces at start of menu item.
Richard M. Stallman <rms@gnu.org>
parents: 21197
diff changeset
1119 (re-search-forward (concat "^\\* +"
6537
f5ab0b6b9640 (Info-insert-dir): Add a save-excursion.
Richard M. Stallman <rms@gnu.org>
parents: 6339
diff changeset
1120 (regexp-quote nodename)
f5ab0b6b9640 (Info-insert-dir): Add a save-excursion.
Richard M. Stallman <rms@gnu.org>
parents: 6339
diff changeset
1121 "::")
f5ab0b6b9640 (Info-insert-dir): Add a save-excursion.
Richard M. Stallman <rms@gnu.org>
parents: 6339
diff changeset
1122 end t)
f5ab0b6b9640 (Info-insert-dir): Add a save-excursion.
Richard M. Stallman <rms@gnu.org>
parents: 6339
diff changeset
1123 (progn
f5ab0b6b9640 (Info-insert-dir): Add a save-excursion.
Richard M. Stallman <rms@gnu.org>
parents: 6339
diff changeset
1124 (insert "* " nodename "::" "\n")
48135
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1125 (push nodename menu-items)))))))
1971
b540866e8a79 (Info-insert-dir): Make menu items in Top node
Richard M. Stallman <rms@gnu.org>
parents: 1821
diff changeset
1126 ;; Now take each node of each of the other buffers
b540866e8a79 (Info-insert-dir): Make menu items in Top node
Richard M. Stallman <rms@gnu.org>
parents: 1821
diff changeset
1127 ;; and merge it into the main buffer.
48135
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1128 (dolist (node nodes)
29446
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
1129 (let ((case-fold-search t)
48135
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1130 (nodename (car node)))
1971
b540866e8a79 (Info-insert-dir): Make menu items in Top node
Richard M. Stallman <rms@gnu.org>
parents: 1821
diff changeset
1131 (goto-char (point-min))
b540866e8a79 (Info-insert-dir): Make menu items in Top node
Richard M. Stallman <rms@gnu.org>
parents: 1821
diff changeset
1132 ;; Find the like-named node in the main buffer.
23904
74c3c643e90c (Info-find-node): Add 1 to the position read from the
Eli Zaretskii <eliz@gnu.org>
parents: 23819
diff changeset
1133 (if (re-search-forward (concat "^\^_.*\n.*Node: "
1971
b540866e8a79 (Info-insert-dir): Make menu items in Top node
Richard M. Stallman <rms@gnu.org>
parents: 1821
diff changeset
1134 (regexp-quote nodename)
b540866e8a79 (Info-insert-dir): Make menu items in Top node
Richard M. Stallman <rms@gnu.org>
parents: 1821
diff changeset
1135 "[,\n\t]")
b540866e8a79 (Info-insert-dir): Make menu items in Top node
Richard M. Stallman <rms@gnu.org>
parents: 1821
diff changeset
1136 nil t)
b540866e8a79 (Info-insert-dir): Make menu items in Top node
Richard M. Stallman <rms@gnu.org>
parents: 1821
diff changeset
1137 (progn
6339
f0f62abb621b (Info-insert-dir): Use printable escapes instead of embedding literal control
Karl Heuer <kwzh@gnu.org>
parents: 6121
diff changeset
1138 (search-forward "\n\^_" nil 'move)
8913
65a8b9c507dc (Info-insert-dir): Insert newlines before rather than
Richard M. Stallman <rms@gnu.org>
parents: 8805
diff changeset
1139 (beginning-of-line)
65a8b9c507dc (Info-insert-dir): Insert newlines before rather than
Richard M. Stallman <rms@gnu.org>
parents: 8805
diff changeset
1140 (insert "\n"))
1971
b540866e8a79 (Info-insert-dir): Make menu items in Top node
Richard M. Stallman <rms@gnu.org>
parents: 1821
diff changeset
1141 ;; If none exists, add one.
b540866e8a79 (Info-insert-dir): Make menu items in Top node
Richard M. Stallman <rms@gnu.org>
parents: 1821
diff changeset
1142 (goto-char (point-max))
8069
dfef58fcda75 (Info-insert-dir): Capitalize `node' when inserting it.
Richard M. Stallman <rms@gnu.org>
parents: 8018
diff changeset
1143 (insert "\^_\nFile: dir\tNode: " nodename "\n\n* Menu:\n\n"))
1971
b540866e8a79 (Info-insert-dir): Make menu items in Top node
Richard M. Stallman <rms@gnu.org>
parents: 1821
diff changeset
1144 ;; Merge the text from the other buffer's menu
b540866e8a79 (Info-insert-dir): Make menu items in Top node
Richard M. Stallman <rms@gnu.org>
parents: 1821
diff changeset
1145 ;; into the menu in the like-named node in the main buffer.
48135
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1146 (apply 'insert-buffer-substring (cdr node))))
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1147 (Info-dir-remove-duplicates)
56991
53c840d7ea68 (Info-insert-dir): Fix temp buffer leak bug.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 56882
diff changeset
1148 ;; Kill all the buffers we just made, including the special one excised.
53c840d7ea68 (Info-insert-dir): Fix temp buffer leak bug.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 56882
diff changeset
1149 (mapc 'kill-buffer (cons buffer buffers))
23416
83f51f5fb749 (Info-insert-dir): Detect and report problems
Richard M. Stallman <rms@gnu.org>
parents: 23175
diff changeset
1150 (goto-char (point-min))
83f51f5fb749 (Info-insert-dir): Detect and report problems
Richard M. Stallman <rms@gnu.org>
parents: 23175
diff changeset
1151 (if problems
83f51f5fb749 (Info-insert-dir): Detect and report problems
Richard M. Stallman <rms@gnu.org>
parents: 23175
diff changeset
1152 (message "Composing main Info directory...problems encountered, see `*Messages*'")
48690
036a8f0597c4 (Info-insert-dir): Make dir-node-cache variables buffer-local, so that
Miles Bader <miles@gnu.org>
parents: 48582
diff changeset
1153 (message "Composing main Info directory...done"))
036a8f0597c4 (Info-insert-dir): Make dir-node-cache variables buffer-local, so that
Miles Bader <miles@gnu.org>
parents: 48582
diff changeset
1154 (set (make-local-variable 'Info-dir-contents) (buffer-string))
036a8f0597c4 (Info-insert-dir): Make dir-node-cache variables buffer-local, so that
Miles Bader <miles@gnu.org>
parents: 48582
diff changeset
1155 (set (make-local-variable 'Info-dir-file-attributes) dir-file-attrs)))
1979
0582c70595f1 * info.el (Info-directory-list): Doc fix; it is set according to
Jim Blandy <jimb@redhat.com>
parents: 1971
diff changeset
1156 (setq default-directory Info-dir-contents-directory))
1971
b540866e8a79 (Info-insert-dir): Make menu items in Top node
Richard M. Stallman <rms@gnu.org>
parents: 1821
diff changeset
1157
48135
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1158 (defvar Info-streamline-headings
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1159 '(("Emacs" . "Emacs")
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1160 ("Programming" . "Programming")
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1161 ("Libraries" . "Libraries")
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1162 ("World Wide Web\\|Net Utilities" . "Net Utilities"))
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1163 "List of elements (RE . NAME) to merge headings matching RE to NAME.")
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1164
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1165 (defun Info-dir-remove-duplicates ()
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1166 (let (limit)
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1167 (goto-char (point-min))
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1168 ;; Remove duplicate headings in the same menu.
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1169 (while (search-forward "\n* Menu:" nil t)
55751
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
1170 (setq limit (save-excursion (search-forward "\n\^_" nil t)))
48135
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1171 ;; Look for the next heading to unify.
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1172 (while (re-search-forward "^\\(\\w.*\\)\n\\*" limit t)
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1173 (let ((name (match-string 1))
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1174 (start (match-beginning 0))
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1175 (entries nil) re)
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1176 ;; Check whether this heading should be streamlined.
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1177 (save-match-data
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1178 (dolist (x Info-streamline-headings)
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1179 (when (string-match (car x) name)
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1180 (setq name (cdr x))
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1181 (setq re (car x)))))
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1182 (if re (replace-match name t t nil 1))
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1183 (goto-char (if (re-search-forward "^[^* \n\t]" limit t)
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1184 (match-beginning 0)
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1185 (or limit (point-max))))
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1186 ;; Look for other headings of the same category and merge them.
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1187 (save-excursion
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1188 (while (re-search-forward "^\\(\\w.*\\)\n\\*" limit t)
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1189 (when (if re (save-match-data (string-match re (match-string 1)))
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1190 (equal name (match-string 1)))
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1191 (forward-line 0)
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1192 ;; Delete redundant heading.
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1193 (delete-region (match-beginning 0) (point))
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1194 ;; Push the entries onto `text'.
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1195 (push
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1196 (delete-and-extract-region
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1197 (point)
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1198 (if (re-search-forward "^[^* \n\t]" nil t)
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1199 (match-beginning 0)
69415
bbbd0ad05f29 (Info-dir-remove-duplicates): Move point to the
Juri Linkov <juri@jurta.org>
parents: 69128
diff changeset
1200 (or limit (point-max))))
bbbd0ad05f29 (Info-dir-remove-duplicates): Move point to the
Juri Linkov <juri@jurta.org>
parents: 69128
diff changeset
1201 entries)
bbbd0ad05f29 (Info-dir-remove-duplicates): Move point to the
Juri Linkov <juri@jurta.org>
parents: 69128
diff changeset
1202 (forward-line 0))))
48135
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1203 ;; Insert the entries just found.
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1204 (while (= (line-beginning-position 0) (1- (point)))
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1205 (backward-char))
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1206 (dolist (entry (nreverse entries))
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1207 (insert entry)
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1208 (while (= (line-beginning-position 0) (1- (point)))
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1209 (delete-region (1- (point)) (point))))
49424
59c37b87bb18 (Info-try-follow-nearest-node): Add case: Handle menu item
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 49390
diff changeset
1210
48135
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1211 ;; Now remove duplicate entries under the same heading.
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1212 (let ((seen nil)
69415
bbbd0ad05f29 (Info-dir-remove-duplicates): Move point to the
Juri Linkov <juri@jurta.org>
parents: 69128
diff changeset
1213 (limit (point-marker)))
48135
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1214 (goto-char start)
69415
bbbd0ad05f29 (Info-dir-remove-duplicates): Move point to the
Juri Linkov <juri@jurta.org>
parents: 69128
diff changeset
1215 (while (and (> limit (point))
bbbd0ad05f29 (Info-dir-remove-duplicates): Move point to the
Juri Linkov <juri@jurta.org>
parents: 69128
diff changeset
1216 (re-search-forward "^* \\([^:\n]+:\\(:\\|[^.\n]+\\).\\)"
bbbd0ad05f29 (Info-dir-remove-duplicates): Move point to the
Juri Linkov <juri@jurta.org>
parents: 69128
diff changeset
1217 limit 'move))
64781
72ec215d0ecf (Info-dir-remove-duplicates): Avoid case folding in loop;
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 64762
diff changeset
1218 ;; Fold case straight away; `member-ignore-case' here wasteful.
72ec215d0ecf (Info-dir-remove-duplicates): Avoid case folding in loop;
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 64762
diff changeset
1219 (let ((x (downcase (match-string 1))))
72ec215d0ecf (Info-dir-remove-duplicates): Avoid case folding in loop;
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 64762
diff changeset
1220 (if (member x seen)
48135
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1221 (delete-region (match-beginning 0)
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1222 (progn (re-search-forward "^[^ \t]" nil t)
48887
e846f8d1619c (Info-dir-remove-duplicates): Avoid infloop when
John Paul Wallington <jpw@pobox.com>
parents: 48690
diff changeset
1223 (match-beginning 0)))
48135
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1224 (push x seen))))))))))
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
1225
16981
643e0f90e153 Handle multiple Info buffers.
Richard M. Stallman <rms@gnu.org>
parents: 16790
diff changeset
1226 ;; Note that on entry to this function the current-buffer must be the
643e0f90e153 Handle multiple Info buffers.
Richard M. Stallman <rms@gnu.org>
parents: 16790
diff changeset
1227 ;; *info* buffer; not the info tags buffer.
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1228 (defun Info-read-subfile (nodepos)
16399
f73d53a1b448 (Info-read-subfile): Allow a file name as arg.
Richard M. Stallman <rms@gnu.org>
parents: 16202
diff changeset
1229 ;; NODEPOS is either a position (in the Info file as a whole,
f73d53a1b448 (Info-read-subfile): Allow a file name as arg.
Richard M. Stallman <rms@gnu.org>
parents: 16202
diff changeset
1230 ;; not relative to a subfile) or the name of a subfile.
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1231 (let (lastfilepos
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1232 lastfilename)
16399
f73d53a1b448 (Info-read-subfile): Allow a file name as arg.
Richard M. Stallman <rms@gnu.org>
parents: 16202
diff changeset
1233 (if (numberp nodepos)
f73d53a1b448 (Info-read-subfile): Allow a file name as arg.
Richard M. Stallman <rms@gnu.org>
parents: 16202
diff changeset
1234 (save-excursion
f73d53a1b448 (Info-read-subfile): Allow a file name as arg.
Richard M. Stallman <rms@gnu.org>
parents: 16202
diff changeset
1235 (set-buffer (marker-buffer Info-tag-table-marker))
f73d53a1b448 (Info-read-subfile): Allow a file name as arg.
Richard M. Stallman <rms@gnu.org>
parents: 16202
diff changeset
1236 (goto-char (point-min))
23904
74c3c643e90c (Info-find-node): Add 1 to the position read from the
Eli Zaretskii <eliz@gnu.org>
parents: 23819
diff changeset
1237 (or (looking-at "\^_")
74c3c643e90c (Info-find-node): Add 1 to the position read from the
Eli Zaretskii <eliz@gnu.org>
parents: 23819
diff changeset
1238 (search-forward "\n\^_"))
16399
f73d53a1b448 (Info-read-subfile): Allow a file name as arg.
Richard M. Stallman <rms@gnu.org>
parents: 16202
diff changeset
1239 (forward-line 2)
f73d53a1b448 (Info-read-subfile): Allow a file name as arg.
Richard M. Stallman <rms@gnu.org>
parents: 16202
diff changeset
1240 (catch 'foo
f73d53a1b448 (Info-read-subfile): Allow a file name as arg.
Richard M. Stallman <rms@gnu.org>
parents: 16202
diff changeset
1241 (while (not (looking-at "\^_"))
f73d53a1b448 (Info-read-subfile): Allow a file name as arg.
Richard M. Stallman <rms@gnu.org>
parents: 16202
diff changeset
1242 (if (not (eolp))
f73d53a1b448 (Info-read-subfile): Allow a file name as arg.
Richard M. Stallman <rms@gnu.org>
parents: 16202
diff changeset
1243 (let ((beg (point))
f73d53a1b448 (Info-read-subfile): Allow a file name as arg.
Richard M. Stallman <rms@gnu.org>
parents: 16202
diff changeset
1244 thisfilepos thisfilename)
f73d53a1b448 (Info-read-subfile): Allow a file name as arg.
Richard M. Stallman <rms@gnu.org>
parents: 16202
diff changeset
1245 (search-forward ": ")
f73d53a1b448 (Info-read-subfile): Allow a file name as arg.
Richard M. Stallman <rms@gnu.org>
parents: 16202
diff changeset
1246 (setq thisfilename (buffer-substring beg (- (point) 2)))
45014
a590e8ab89d0 (Info-find-in-tag-table-1, Info-read-subfile): Use point-min.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44902
diff changeset
1247 (setq thisfilepos (+ (point-min) (read (current-buffer))))
16399
f73d53a1b448 (Info-read-subfile): Allow a file name as arg.
Richard M. Stallman <rms@gnu.org>
parents: 16202
diff changeset
1248 ;; read in version 19 stops at the end of number.
f73d53a1b448 (Info-read-subfile): Allow a file name as arg.
Richard M. Stallman <rms@gnu.org>
parents: 16202
diff changeset
1249 ;; Advance to the next line.
f73d53a1b448 (Info-read-subfile): Allow a file name as arg.
Richard M. Stallman <rms@gnu.org>
parents: 16202
diff changeset
1250 (forward-line 1)
f73d53a1b448 (Info-read-subfile): Allow a file name as arg.
Richard M. Stallman <rms@gnu.org>
parents: 16202
diff changeset
1251 (if (> thisfilepos nodepos)
f73d53a1b448 (Info-read-subfile): Allow a file name as arg.
Richard M. Stallman <rms@gnu.org>
parents: 16202
diff changeset
1252 (throw 'foo t))
f73d53a1b448 (Info-read-subfile): Allow a file name as arg.
Richard M. Stallman <rms@gnu.org>
parents: 16202
diff changeset
1253 (setq lastfilename thisfilename)
f73d53a1b448 (Info-read-subfile): Allow a file name as arg.
Richard M. Stallman <rms@gnu.org>
parents: 16202
diff changeset
1254 (setq lastfilepos thisfilepos))
f73d53a1b448 (Info-read-subfile): Allow a file name as arg.
Richard M. Stallman <rms@gnu.org>
parents: 16202
diff changeset
1255 (forward-line 1)))))
f73d53a1b448 (Info-read-subfile): Allow a file name as arg.
Richard M. Stallman <rms@gnu.org>
parents: 16202
diff changeset
1256 (setq lastfilename nodepos)
f73d53a1b448 (Info-read-subfile): Allow a file name as arg.
Richard M. Stallman <rms@gnu.org>
parents: 16202
diff changeset
1257 (setq lastfilepos 0))
16981
643e0f90e153 Handle multiple Info buffers.
Richard M. Stallman <rms@gnu.org>
parents: 16790
diff changeset
1258 ;; Assume previous buffer is in Info-mode.
643e0f90e153 Handle multiple Info buffers.
Richard M. Stallman <rms@gnu.org>
parents: 16790
diff changeset
1259 ;; (set-buffer (get-buffer "*info*"))
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1260 (or (equal Info-current-subfile lastfilename)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1261 (let ((buffer-read-only nil))
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1262 (setq buffer-file-name nil)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1263 (widen)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1264 (erase-buffer)
2561
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
1265 (info-insert-file-contents lastfilename)
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1266 (set-buffer-modified-p nil)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1267 (setq Info-current-subfile lastfilename)))
37837
39e5892b1843 (Info-read-subfile): Widen before finding the
Richard M. Stallman <rms@gnu.org>
parents: 37473
diff changeset
1268 ;; Widen in case we are in the same subfile as before.
39e5892b1843 (Info-read-subfile): Widen before finding the
Richard M. Stallman <rms@gnu.org>
parents: 37473
diff changeset
1269 (widen)
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1270 (goto-char (point-min))
23904
74c3c643e90c (Info-find-node): Add 1 to the position read from the
Eli Zaretskii <eliz@gnu.org>
parents: 23819
diff changeset
1271 (if (looking-at "\^_")
74c3c643e90c (Info-find-node): Add 1 to the position read from the
Eli Zaretskii <eliz@gnu.org>
parents: 23819
diff changeset
1272 (forward-char 1)
74c3c643e90c (Info-find-node): Add 1 to the position read from the
Eli Zaretskii <eliz@gnu.org>
parents: 23819
diff changeset
1273 (search-forward "\n\^_"))
16399
f73d53a1b448 (Info-read-subfile): Allow a file name as arg.
Richard M. Stallman <rms@gnu.org>
parents: 16202
diff changeset
1274 (if (numberp nodepos)
f73d53a1b448 (Info-read-subfile): Allow a file name as arg.
Richard M. Stallman <rms@gnu.org>
parents: 16202
diff changeset
1275 (+ (- nodepos lastfilepos) (point)))))
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1276
50707
692de9e94f6c new image display support, from janneke
Karl Berry <karl@gnu.org>
parents: 50660
diff changeset
1277 (defun Info-unescape-quotes (value)
53246
c07db7df7073 (Info-unescape-quotes, Info-split-parameter-string)
John Paul Wallington <jpw@pobox.com>
parents: 52767
diff changeset
1278 "Unescape double quotes and backslashes in VALUE."
50707
692de9e94f6c new image display support, from janneke
Karl Berry <karl@gnu.org>
parents: 50660
diff changeset
1279 (let ((start 0)
692de9e94f6c new image display support, from janneke
Karl Berry <karl@gnu.org>
parents: 50660
diff changeset
1280 (unquote value))
692de9e94f6c new image display support, from janneke
Karl Berry <karl@gnu.org>
parents: 50660
diff changeset
1281 (while (string-match "[^\\\"]*\\(\\\\\\)[\\\\\"]" unquote start)
692de9e94f6c new image display support, from janneke
Karl Berry <karl@gnu.org>
parents: 50660
diff changeset
1282 (setq unquote (replace-match "" t t unquote 1))
692de9e94f6c new image display support, from janneke
Karl Berry <karl@gnu.org>
parents: 50660
diff changeset
1283 (setq start (- (match-end 0) 1)))
692de9e94f6c new image display support, from janneke
Karl Berry <karl@gnu.org>
parents: 50660
diff changeset
1284 unquote))
692de9e94f6c new image display support, from janneke
Karl Berry <karl@gnu.org>
parents: 50660
diff changeset
1285
692de9e94f6c new image display support, from janneke
Karl Berry <karl@gnu.org>
parents: 50660
diff changeset
1286 ;; As of Texinfo 4.6, makeinfo writes constructs like
692de9e94f6c new image display support, from janneke
Karl Berry <karl@gnu.org>
parents: 50660
diff changeset
1287 ;; \0\h[image param=value ...\h\0]
692de9e94f6c new image display support, from janneke
Karl Berry <karl@gnu.org>
parents: 50660
diff changeset
1288 ;; into the Info file for handling images.
692de9e94f6c new image display support, from janneke
Karl Berry <karl@gnu.org>
parents: 50660
diff changeset
1289 (defun Info-split-parameter-string (parameter-string)
692de9e94f6c new image display support, from janneke
Karl Berry <karl@gnu.org>
parents: 50660
diff changeset
1290 "Return alist of (\"KEY\" . \"VALUE\") from PARAMETER-STRING; a
53246
c07db7df7073 (Info-unescape-quotes, Info-split-parameter-string)
John Paul Wallington <jpw@pobox.com>
parents: 52767
diff changeset
1291 whitespace separated list of KEY=VALUE pairs. If VALUE contains
c07db7df7073 (Info-unescape-quotes, Info-split-parameter-string)
John Paul Wallington <jpw@pobox.com>
parents: 52767
diff changeset
1292 whitespace or double quotes, it must be quoted in double quotes and
c07db7df7073 (Info-unescape-quotes, Info-split-parameter-string)
John Paul Wallington <jpw@pobox.com>
parents: 52767
diff changeset
1293 any double quotes or backslashes must be escaped (\\\",\\\\)."
50707
692de9e94f6c new image display support, from janneke
Karl Berry <karl@gnu.org>
parents: 50660
diff changeset
1294 (let ((start 0)
692de9e94f6c new image display support, from janneke
Karl Berry <karl@gnu.org>
parents: 50660
diff changeset
1295 (parameter-alist))
692de9e94f6c new image display support, from janneke
Karl Berry <karl@gnu.org>
parents: 50660
diff changeset
1296 (while (string-match
692de9e94f6c new image display support, from janneke
Karl Berry <karl@gnu.org>
parents: 50660
diff changeset
1297 "\\s *\\([^=]+\\)=\\(?:\\([^\\s \"]+\\)\\|\\(?:\"\\(\\(?:[^\\\"]\\|\\\\[\\\\\"]\\)*\\)\"\\)\\)"
692de9e94f6c new image display support, from janneke
Karl Berry <karl@gnu.org>
parents: 50660
diff changeset
1298 parameter-string start)
692de9e94f6c new image display support, from janneke
Karl Berry <karl@gnu.org>
parents: 50660
diff changeset
1299 (setq start (match-end 0))
692de9e94f6c new image display support, from janneke
Karl Berry <karl@gnu.org>
parents: 50660
diff changeset
1300 (push (cons (match-string 1 parameter-string)
692de9e94f6c new image display support, from janneke
Karl Berry <karl@gnu.org>
parents: 50660
diff changeset
1301 (or (match-string 2 parameter-string)
692de9e94f6c new image display support, from janneke
Karl Berry <karl@gnu.org>
parents: 50660
diff changeset
1302 (Info-unescape-quotes
692de9e94f6c new image display support, from janneke
Karl Berry <karl@gnu.org>
parents: 50660
diff changeset
1303 (match-string 3 parameter-string))))
692de9e94f6c new image display support, from janneke
Karl Berry <karl@gnu.org>
parents: 50660
diff changeset
1304 parameter-alist))
692de9e94f6c new image display support, from janneke
Karl Berry <karl@gnu.org>
parents: 50660
diff changeset
1305 parameter-alist))
692de9e94f6c new image display support, from janneke
Karl Berry <karl@gnu.org>
parents: 50660
diff changeset
1306
692de9e94f6c new image display support, from janneke
Karl Berry <karl@gnu.org>
parents: 50660
diff changeset
1307 (defun Info-display-images-node ()
692de9e94f6c new image display support, from janneke
Karl Berry <karl@gnu.org>
parents: 50660
diff changeset
1308 "Display images in current node."
692de9e94f6c new image display support, from janneke
Karl Berry <karl@gnu.org>
parents: 50660
diff changeset
1309 (save-excursion
692de9e94f6c new image display support, from janneke
Karl Berry <karl@gnu.org>
parents: 50660
diff changeset
1310 (let ((inhibit-read-only t)
51434
4c85e6a5a9d2 (Info-mode-hook): Obey obsolete `Info-fontify'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51310
diff changeset
1311 (case-fold-search t))
50707
692de9e94f6c new image display support, from janneke
Karl Berry <karl@gnu.org>
parents: 50660
diff changeset
1312 (goto-char (point-min))
692de9e94f6c new image display support, from janneke
Karl Berry <karl@gnu.org>
parents: 50660
diff changeset
1313 (while (re-search-forward
692de9e94f6c new image display support, from janneke
Karl Berry <karl@gnu.org>
parents: 50660
diff changeset
1314 "\\(\0\b[[]image\\(\\(?:[^\b]\\|[^\0]+\b\\)*\\)\0\b[]]\\)"
692de9e94f6c new image display support, from janneke
Karl Berry <karl@gnu.org>
parents: 50660
diff changeset
1315 nil t)
692de9e94f6c new image display support, from janneke
Karl Berry <karl@gnu.org>
parents: 50660
diff changeset
1316 (let* ((start (match-beginning 1))
692de9e94f6c new image display support, from janneke
Karl Berry <karl@gnu.org>
parents: 50660
diff changeset
1317 (parameter-alist (Info-split-parameter-string (match-string 2)))
692de9e94f6c new image display support, from janneke
Karl Berry <karl@gnu.org>
parents: 50660
diff changeset
1318 (src (cdr (assoc-string "src" parameter-alist)))
692de9e94f6c new image display support, from janneke
Karl Berry <karl@gnu.org>
parents: 50660
diff changeset
1319 (image-file (if src (if (file-name-absolute-p src) src
692de9e94f6c new image display support, from janneke
Karl Berry <karl@gnu.org>
parents: 50660
diff changeset
1320 (concat default-directory src))
692de9e94f6c new image display support, from janneke
Karl Berry <karl@gnu.org>
parents: 50660
diff changeset
1321 ""))
692de9e94f6c new image display support, from janneke
Karl Berry <karl@gnu.org>
parents: 50660
diff changeset
1322 (image (if (file-exists-p image-file)
692de9e94f6c new image display support, from janneke
Karl Berry <karl@gnu.org>
parents: 50660
diff changeset
1323 (create-image image-file)
692de9e94f6c new image display support, from janneke
Karl Berry <karl@gnu.org>
parents: 50660
diff changeset
1324 "[broken image]")))
692de9e94f6c new image display support, from janneke
Karl Berry <karl@gnu.org>
parents: 50660
diff changeset
1325 (if (not (get-text-property start 'display))
692de9e94f6c new image display support, from janneke
Karl Berry <karl@gnu.org>
parents: 50660
diff changeset
1326 (add-text-properties
692de9e94f6c new image display support, from janneke
Karl Berry <karl@gnu.org>
parents: 50660
diff changeset
1327 start (point) `(display ,image rear-nonsticky (display)))))))
692de9e94f6c new image display support, from janneke
Karl Berry <karl@gnu.org>
parents: 50660
diff changeset
1328 (set-buffer-modified-p nil)))
692de9e94f6c new image display support, from janneke
Karl Berry <karl@gnu.org>
parents: 50660
diff changeset
1329
54752
4aa6485ff6e3 (Info-hide-cookies-node): New function.
Juri Linkov <juri@jurta.org>
parents: 54718
diff changeset
1330 ;; Texinfo 4.7 adds cookies of the form ^@^H[NAME CONTENTS ^@^H].
4aa6485ff6e3 (Info-hide-cookies-node): New function.
Juri Linkov <juri@jurta.org>
parents: 54718
diff changeset
1331 ;; Hide any construct of the general form ^@[^@-^_][ ... ^@[^@-^_]],
4aa6485ff6e3 (Info-hide-cookies-node): New function.
Juri Linkov <juri@jurta.org>
parents: 54718
diff changeset
1332 ;; including one optional trailing newline.
4aa6485ff6e3 (Info-hide-cookies-node): New function.
Juri Linkov <juri@jurta.org>
parents: 54718
diff changeset
1333 (defun Info-hide-cookies-node ()
63503
512a76e42d3f (Info-hide-cookies-node): Fix spelling in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents: 63208
diff changeset
1334 "Hide unrecognized cookies in current node."
54752
4aa6485ff6e3 (Info-hide-cookies-node): New function.
Juri Linkov <juri@jurta.org>
parents: 54718
diff changeset
1335 (save-excursion
4aa6485ff6e3 (Info-hide-cookies-node): New function.
Juri Linkov <juri@jurta.org>
parents: 54718
diff changeset
1336 (let ((inhibit-read-only t)
4aa6485ff6e3 (Info-hide-cookies-node): New function.
Juri Linkov <juri@jurta.org>
parents: 54718
diff changeset
1337 (case-fold-search t))
4aa6485ff6e3 (Info-hide-cookies-node): New function.
Juri Linkov <juri@jurta.org>
parents: 54718
diff changeset
1338 (goto-char (point-min))
4aa6485ff6e3 (Info-hide-cookies-node): New function.
Juri Linkov <juri@jurta.org>
parents: 54718
diff changeset
1339 (while (re-search-forward
4aa6485ff6e3 (Info-hide-cookies-node): New function.
Juri Linkov <juri@jurta.org>
parents: 54718
diff changeset
1340 "\\(\0[\0-\37][[][^\0]*\0[\0-\37][]]\n?\\)"
4aa6485ff6e3 (Info-hide-cookies-node): New function.
Juri Linkov <juri@jurta.org>
parents: 54718
diff changeset
1341 nil t)
4aa6485ff6e3 (Info-hide-cookies-node): New function.
Juri Linkov <juri@jurta.org>
parents: 54718
diff changeset
1342 (let* ((start (match-beginning 1)))
4aa6485ff6e3 (Info-hide-cookies-node): New function.
Juri Linkov <juri@jurta.org>
parents: 54718
diff changeset
1343 (if (not (get-text-property start 'invisible))
4aa6485ff6e3 (Info-hide-cookies-node): New function.
Juri Linkov <juri@jurta.org>
parents: 54718
diff changeset
1344 (put-text-property start (point) 'invisible t)))))
4aa6485ff6e3 (Info-hide-cookies-node): New function.
Juri Linkov <juri@jurta.org>
parents: 54718
diff changeset
1345 (set-buffer-modified-p nil)))
4aa6485ff6e3 (Info-hide-cookies-node): New function.
Juri Linkov <juri@jurta.org>
parents: 54718
diff changeset
1346
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1347 (defun Info-select-node ()
64812
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
1348 "Select the Info node that point is in."
51513
a1170353615d (Info-select-node): Doc fix.
Andreas Schwab <schwab@suse.de>
parents: 51504
diff changeset
1349 ;; Bind this in case the user sets it to nil.
22951
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
1350 (let ((case-fold-search t))
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
1351 (save-excursion
29446
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
1352 ;; Find beginning of node.
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
1353 (if (search-backward "\n\^_" nil 'move)
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
1354 (forward-line 2)
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
1355 (if (looking-at "\^_")
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
1356 (forward-line 1)
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
1357 (signal 'search-failed (list "\n\^_"))))
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
1358 ;; Get nodename spelled as it is in the node.
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
1359 (re-search-forward "Node:[ \t]*")
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
1360 (setq Info-current-node
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
1361 (buffer-substring-no-properties (point)
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
1362 (progn
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
1363 (skip-chars-forward "^,\t\n")
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
1364 (point))))
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
1365 (Info-set-mode-line)
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
1366 ;; Find the end of it, and narrow.
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
1367 (beginning-of-line)
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
1368 (let (active-expression)
31660
84c9abde389f (Info-fontify-node):
Miles Bader <miles@gnu.org>
parents: 31324
diff changeset
1369 ;; Narrow to the node contents
29446
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
1370 (narrow-to-region (point)
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
1371 (if (re-search-forward "\n[\^_\f]" nil t)
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
1372 (prog1
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
1373 (1- (point))
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
1374 (if (looking-at "[\n\^_\f]*execute: ")
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
1375 (progn
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
1376 (goto-char (match-end 0))
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
1377 (setq active-expression
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
1378 (read (current-buffer))))))
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
1379 (point-max)))
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
1380 (if Info-enable-active-nodes (eval active-expression))
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
1381 ;; Add a new unique history item to full history list
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
1382 (let ((new-history (list Info-current-file Info-current-node)))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
1383 (setq Info-history-list
59472
1e81e65f3201 (Info-history-forward): New variable.
Juri Linkov <juri@jurta.org>
parents: 59423
diff changeset
1384 (cons new-history (delete new-history Info-history-list)))
1e81e65f3201 (Info-history-forward): New variable.
Juri Linkov <juri@jurta.org>
parents: 59423
diff changeset
1385 (setq Info-history-forward nil))
55751
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
1386 (if (not (eq Info-fontify-maximum-menu-size nil))
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
1387 (Info-fontify-node))
50707
692de9e94f6c new image display support, from janneke
Karl Berry <karl@gnu.org>
parents: 50660
diff changeset
1388 (Info-display-images-node)
54752
4aa6485ff6e3 (Info-hide-cookies-node): New function.
Juri Linkov <juri@jurta.org>
parents: 54718
diff changeset
1389 (Info-hide-cookies-node)
29446
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
1390 (run-hooks 'Info-selection-hook)))))
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1391
68216
9f1c66838760 (Info-mode-line-node-keymap): New defvar.
Juri Linkov <juri@jurta.org>
parents: 68045
diff changeset
1392 (defvar Info-mode-line-node-keymap
9f1c66838760 (Info-mode-line-node-keymap): New defvar.
Juri Linkov <juri@jurta.org>
parents: 68045
diff changeset
1393 (let ((map (make-sparse-keymap)))
9f1c66838760 (Info-mode-line-node-keymap): New defvar.
Juri Linkov <juri@jurta.org>
parents: 68045
diff changeset
1394 (define-key map [mode-line mouse-1] 'Info-scroll-up)
9f1c66838760 (Info-mode-line-node-keymap): New defvar.
Juri Linkov <juri@jurta.org>
parents: 68045
diff changeset
1395 (define-key map [mode-line mouse-3] 'Info-scroll-down)
9f1c66838760 (Info-mode-line-node-keymap): New defvar.
Juri Linkov <juri@jurta.org>
parents: 68045
diff changeset
1396 map)
9f1c66838760 (Info-mode-line-node-keymap): New defvar.
Juri Linkov <juri@jurta.org>
parents: 68045
diff changeset
1397 "Keymap to put on the Info node name in the mode line.")
9f1c66838760 (Info-mode-line-node-keymap): New defvar.
Juri Linkov <juri@jurta.org>
parents: 68045
diff changeset
1398
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1399 (defun Info-set-mode-line ()
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1400 (setq mode-line-buffer-identification
32538
69087927a683 (Info-set-mode-line): Tweak string.
Miles Bader <miles@gnu.org>
parents: 32533
diff changeset
1401 (nconc (propertized-buffer-identification "%b")
32533
ec12d23c8eea (Info-set-mode-line): Use `%b' instead of hardwired string "*Info*".
Miles Bader <miles@gnu.org>
parents: 32500
diff changeset
1402 (list
68216
9f1c66838760 (Info-mode-line-node-keymap): New defvar.
Juri Linkov <juri@jurta.org>
parents: 68045
diff changeset
1403 (concat
9f1c66838760 (Info-mode-line-node-keymap): New defvar.
Juri Linkov <juri@jurta.org>
parents: 68045
diff changeset
1404 " ("
9f1c66838760 (Info-mode-line-node-keymap): New defvar.
Juri Linkov <juri@jurta.org>
parents: 68045
diff changeset
1405 (if (stringp Info-current-file)
68853
4e74c8b341d8 (info-xref-visited): Inherit from info-xref too.
Juri Linkov <juri@jurta.org>
parents: 68826
diff changeset
1406 (replace-regexp-in-string
4e74c8b341d8 (info-xref-visited): Inherit from info-xref too.
Juri Linkov <juri@jurta.org>
parents: 68826
diff changeset
1407 "%" "%%" (file-name-nondirectory Info-current-file))
68980
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
1408 (format "*%S*" Info-current-file))
68216
9f1c66838760 (Info-mode-line-node-keymap): New defvar.
Juri Linkov <juri@jurta.org>
parents: 68045
diff changeset
1409 ") "
9f1c66838760 (Info-mode-line-node-keymap): New defvar.
Juri Linkov <juri@jurta.org>
parents: 68045
diff changeset
1410 (if Info-current-node
68853
4e74c8b341d8 (info-xref-visited): Inherit from info-xref too.
Juri Linkov <juri@jurta.org>
parents: 68826
diff changeset
1411 (propertize (replace-regexp-in-string
4e74c8b341d8 (info-xref-visited): Inherit from info-xref too.
Juri Linkov <juri@jurta.org>
parents: 68826
diff changeset
1412 "%" "%%" Info-current-node)
68216
9f1c66838760 (Info-mode-line-node-keymap): New defvar.
Juri Linkov <juri@jurta.org>
parents: 68045
diff changeset
1413 'face 'mode-line-buffer-id
9f1c66838760 (Info-mode-line-node-keymap): New defvar.
Juri Linkov <juri@jurta.org>
parents: 68045
diff changeset
1414 'help-echo
9f1c66838760 (Info-mode-line-node-keymap): New defvar.
Juri Linkov <juri@jurta.org>
parents: 68045
diff changeset
1415 "mouse-1: scroll forward, mouse-3: scroll back"
9f1c66838760 (Info-mode-line-node-keymap): New defvar.
Juri Linkov <juri@jurta.org>
parents: 68045
diff changeset
1416 'mouse-face 'mode-line-highlight
9f1c66838760 (Info-mode-line-node-keymap): New defvar.
Juri Linkov <juri@jurta.org>
parents: 68045
diff changeset
1417 'local-map Info-mode-line-node-keymap)
9f1c66838760 (Info-mode-line-node-keymap): New defvar.
Juri Linkov <juri@jurta.org>
parents: 68045
diff changeset
1418 ""))))))
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1419
64812
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
1420 ;; Go to an Info node specified with a filename-and-nodename string
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1421 ;; of the sort that is found in pointers in nodes.
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1422
62822
7f11f471aa34 (Info-goto-node): Revert autoload addition (2004-06-12).
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 62733
diff changeset
1423 ;; Don't autoload this function: the correct entry point for other packages
7f11f471aa34 (Info-goto-node): Revert autoload addition (2004-06-12).
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 62733
diff changeset
1424 ;; to use is `info'. --Stef
7f11f471aa34 (Info-goto-node): Revert autoload addition (2004-06-12).
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 62733
diff changeset
1425 ;; ;;;###autoload
26004
11f91800bec3 (Info-on-current-buffer): new entry point.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 25878
diff changeset
1426 (defun Info-goto-node (nodename &optional fork)
64812
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
1427 "Go to Info node named NODENAME. Give just NODENAME or (FILENAME)NODENAME.
39382
18515f20ccce (Info-goto-node, Info-menu): Doc fix. Suggested by
Eli Zaretskii <eliz@gnu.org>
parents: 39364
diff changeset
1428 If NODENAME is of the form (FILENAME)NODENAME, the node is in the Info file
18515f20ccce (Info-goto-node, Info-menu): Doc fix. Suggested by
Eli Zaretskii <eliz@gnu.org>
parents: 39364
diff changeset
1429 FILENAME; otherwise, NODENAME should be in the current Info file (or one of
18515f20ccce (Info-goto-node, Info-menu): Doc fix. Suggested by
Eli Zaretskii <eliz@gnu.org>
parents: 39364
diff changeset
1430 its sub-files).
18515f20ccce (Info-goto-node, Info-menu): Doc fix. Suggested by
Eli Zaretskii <eliz@gnu.org>
parents: 39364
diff changeset
1431 Completion is available, but only for node names in the current Info file.
32286
c0b19a2770ca (Info-goto-node, Info-menu): Doc fix.
Dave Love <fx@gnu.org>
parents: 32007
diff changeset
1432 If FORK is non-nil (interactively with a prefix arg), show the node in
64812
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
1433 a new Info buffer.
26004
11f91800bec3 (Info-on-current-buffer): new entry point.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 25878
diff changeset
1434 If FORK is a string, it is the name to use for the new buffer."
32500
5f2aedbe47b5 (Info-mouse-follow-nearest-node): Use mouse-set-point.
Dave Love <fx@gnu.org>
parents: 32391
diff changeset
1435 (interactive (list (Info-read-node-name "Go to node: ") current-prefix-arg))
25172
5a57e11d78c9 (Info-find-node): Call info-initialize here.
Dave Love <fx@gnu.org>
parents: 25145
diff changeset
1436 (info-initialize)
26004
11f91800bec3 (Info-on-current-buffer): new entry point.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 25878
diff changeset
1437 (if fork
29446
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
1438 (set-buffer
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
1439 (clone-buffer (concat "*info-" (if (stringp fork) fork nodename) "*") t)))
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1440 (let (filename)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1441 (string-match "\\s *\\((\\s *\\([^\t)]*\\)\\s *)\\s *\\|\\)\\(.*\\)"
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1442 nodename)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1443 (setq filename (if (= (match-beginning 1) (match-end 1))
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1444 ""
51735
204ae43066d1 (Info-following-node-name-re): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51731
diff changeset
1445 (match-string 2 nodename))
204ae43066d1 (Info-following-node-name-re): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51731
diff changeset
1446 nodename (match-string 3 nodename))
55174
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
1447 (let ((trim (string-match "\\s +\\'" filename)))
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1448 (if trim (setq filename (substring filename 0 trim))))
55174
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
1449 (let ((trim (string-match "\\s +\\'" nodename)))
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1450 (if trim (setq nodename (substring nodename 0 trim))))
12433
17387b7fe5b8 (Info-goto-node, Info-search):
Richard M. Stallman <rms@gnu.org>
parents: 12294
diff changeset
1451 (if transient-mark-mode (deactivate-mark))
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1452 (Info-find-node (if (equal filename "") nil filename)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1453 (if (equal nodename "") "Top" nodename))))
4410
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
1454
22760
e080fa4636c7 (Info-read-node-name-1, Info-read-node-name):
Richard M. Stallman <rms@gnu.org>
parents: 22733
diff changeset
1455 (defvar Info-read-node-completion-table)
e080fa4636c7 (Info-read-node-name-1, Info-read-node-name):
Richard M. Stallman <rms@gnu.org>
parents: 22733
diff changeset
1456
63065
58dcb71db77b (Info-read-node-name-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 63055
diff changeset
1457 (defun Info-read-node-name-2 (string path-and-suffixes action)
58dcb71db77b (Info-read-node-name-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 63055
diff changeset
1458 "Virtual completion table for file names input in Info node names.
58dcb71db77b (Info-read-node-name-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 63055
diff changeset
1459 PATH-AND-SUFFIXES is a pair of lists, (DIRECTORIES . SUFFIXES)."
58dcb71db77b (Info-read-node-name-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 63055
diff changeset
1460 (let* ((names nil)
58dcb71db77b (Info-read-node-name-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 63055
diff changeset
1461 (suffixes (remove "" (cdr path-and-suffixes)))
58dcb71db77b (Info-read-node-name-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 63055
diff changeset
1462 (suffix (concat (regexp-opt suffixes t) "\\'"))
58dcb71db77b (Info-read-node-name-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 63055
diff changeset
1463 (string-dir (file-name-directory string))
58dcb71db77b (Info-read-node-name-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 63055
diff changeset
1464 (dirs
58dcb71db77b (Info-read-node-name-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 63055
diff changeset
1465 (if (file-name-absolute-p string)
58dcb71db77b (Info-read-node-name-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 63055
diff changeset
1466 (list (file-name-directory string))
58dcb71db77b (Info-read-node-name-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 63055
diff changeset
1467 (car path-and-suffixes))))
58dcb71db77b (Info-read-node-name-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 63055
diff changeset
1468 (dolist (dir dirs)
58dcb71db77b (Info-read-node-name-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 63055
diff changeset
1469 (unless dir
58dcb71db77b (Info-read-node-name-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 63055
diff changeset
1470 (setq dir default-directory))
58dcb71db77b (Info-read-node-name-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 63055
diff changeset
1471 (if string-dir (setq dir (expand-file-name string-dir dir)))
58dcb71db77b (Info-read-node-name-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 63055
diff changeset
1472 (when (file-directory-p dir)
58dcb71db77b (Info-read-node-name-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 63055
diff changeset
1473 (dolist (file (file-name-all-completions
58dcb71db77b (Info-read-node-name-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 63055
diff changeset
1474 (file-name-nondirectory string) dir))
58dcb71db77b (Info-read-node-name-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 63055
diff changeset
1475 ;; If the file name has no suffix or a standard suffix,
58dcb71db77b (Info-read-node-name-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 63055
diff changeset
1476 ;; include it.
58dcb71db77b (Info-read-node-name-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 63055
diff changeset
1477 (and (or (null (file-name-extension file))
58dcb71db77b (Info-read-node-name-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 63055
diff changeset
1478 (string-match suffix file))
64812
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
1479 ;; But exclude subfiles of split Info files.
63065
58dcb71db77b (Info-read-node-name-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 63055
diff changeset
1480 (not (string-match "-[0-9]+\\'" file))
58dcb71db77b (Info-read-node-name-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 63055
diff changeset
1481 ;; And exclude backup files.
58dcb71db77b (Info-read-node-name-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 63055
diff changeset
1482 (not (string-match "~\\'" file))
58dcb71db77b (Info-read-node-name-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 63055
diff changeset
1483 (push (if string-dir (concat string-dir file) file) names))
58dcb71db77b (Info-read-node-name-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 63055
diff changeset
1484 ;; If the file name ends in a standard suffix,
58dcb71db77b (Info-read-node-name-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 63055
diff changeset
1485 ;; add the unsuffixed name as a completion option.
58dcb71db77b (Info-read-node-name-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 63055
diff changeset
1486 (when (string-match suffix file)
58dcb71db77b (Info-read-node-name-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 63055
diff changeset
1487 (setq file (substring file 0 (match-beginning 0)))
58dcb71db77b (Info-read-node-name-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 63055
diff changeset
1488 (push (if string-dir (concat string-dir file) file) names)))))
58dcb71db77b (Info-read-node-name-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 63055
diff changeset
1489 (cond
58dcb71db77b (Info-read-node-name-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 63055
diff changeset
1490 ((eq action t) (all-completions string names))
58dcb71db77b (Info-read-node-name-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 63055
diff changeset
1491 ((null action) (try-completion string names))
58dcb71db77b (Info-read-node-name-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 63055
diff changeset
1492 (t (test-completion string names)))))
58dcb71db77b (Info-read-node-name-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 63055
diff changeset
1493
12779
5b3d83e51b91 (Info-read-node-name-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 12646
diff changeset
1494 ;; This function is used as the "completion table" while reading a node name.
22760
e080fa4636c7 (Info-read-node-name-1, Info-read-node-name):
Richard M. Stallman <rms@gnu.org>
parents: 22733
diff changeset
1495 ;; It does completion using the alist in Info-read-node-completion-table
12779
5b3d83e51b91 (Info-read-node-name-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 12646
diff changeset
1496 ;; unless STRING starts with an open-paren.
5b3d83e51b91 (Info-read-node-name-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 12646
diff changeset
1497 (defun Info-read-node-name-1 (string predicate code)
45014
a590e8ab89d0 (Info-find-in-tag-table-1, Info-read-subfile): Use point-min.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44902
diff changeset
1498 (cond
a590e8ab89d0 (Info-find-in-tag-table-1, Info-read-subfile): Use point-min.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44902
diff changeset
1499 ;; First complete embedded file names.
a590e8ab89d0 (Info-find-in-tag-table-1, Info-read-subfile): Use point-min.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44902
diff changeset
1500 ((string-match "\\`([^)]*\\'" string)
a590e8ab89d0 (Info-find-in-tag-table-1, Info-read-subfile): Use point-min.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44902
diff changeset
1501 (let ((file (substring string 1)))
a590e8ab89d0 (Info-find-in-tag-table-1, Info-read-subfile): Use point-min.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44902
diff changeset
1502 (cond
a590e8ab89d0 (Info-find-in-tag-table-1, Info-read-subfile): Use point-min.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44902
diff changeset
1503 ((eq code nil)
63065
58dcb71db77b (Info-read-node-name-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 63055
diff changeset
1504 (let ((comp (try-completion file 'Info-read-node-name-2
45014
a590e8ab89d0 (Info-find-in-tag-table-1, Info-read-subfile): Use point-min.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44902
diff changeset
1505 (cons Info-directory-list
a590e8ab89d0 (Info-find-in-tag-table-1, Info-read-subfile): Use point-min.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44902
diff changeset
1506 (mapcar 'car Info-suffix-list)))))
a590e8ab89d0 (Info-find-in-tag-table-1, Info-read-subfile): Use point-min.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44902
diff changeset
1507 (cond
a590e8ab89d0 (Info-find-in-tag-table-1, Info-read-subfile): Use point-min.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44902
diff changeset
1508 ((eq comp t) (concat string ")"))
a590e8ab89d0 (Info-find-in-tag-table-1, Info-read-subfile): Use point-min.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44902
diff changeset
1509 (comp (concat "(" comp)))))
63065
58dcb71db77b (Info-read-node-name-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 63055
diff changeset
1510 ((eq code t)
58dcb71db77b (Info-read-node-name-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 63055
diff changeset
1511 (all-completions file 'Info-read-node-name-2
58dcb71db77b (Info-read-node-name-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 63055
diff changeset
1512 (cons Info-directory-list
58dcb71db77b (Info-read-node-name-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 63055
diff changeset
1513 (mapcar 'car Info-suffix-list))))
45014
a590e8ab89d0 (Info-find-in-tag-table-1, Info-read-subfile): Use point-min.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44902
diff changeset
1514 (t nil))))
a590e8ab89d0 (Info-find-in-tag-table-1, Info-read-subfile): Use point-min.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44902
diff changeset
1515 ;; If a file name was given, then any node is fair game.
a590e8ab89d0 (Info-find-in-tag-table-1, Info-read-subfile): Use point-min.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44902
diff changeset
1516 ((string-match "\\`(" string)
a590e8ab89d0 (Info-find-in-tag-table-1, Info-read-subfile): Use point-min.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44902
diff changeset
1517 (cond
a590e8ab89d0 (Info-find-in-tag-table-1, Info-read-subfile): Use point-min.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44902
diff changeset
1518 ((eq code nil) string)
a590e8ab89d0 (Info-find-in-tag-table-1, Info-read-subfile): Use point-min.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44902
diff changeset
1519 ((eq code t) nil)
a590e8ab89d0 (Info-find-in-tag-table-1, Info-read-subfile): Use point-min.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44902
diff changeset
1520 (t t)))
a590e8ab89d0 (Info-find-in-tag-table-1, Info-read-subfile): Use point-min.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44902
diff changeset
1521 ;; Otherwise use Info-read-node-completion-table.
a590e8ab89d0 (Info-find-in-tag-table-1, Info-read-subfile): Use point-min.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44902
diff changeset
1522 ((eq code nil)
a590e8ab89d0 (Info-find-in-tag-table-1, Info-read-subfile): Use point-min.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44902
diff changeset
1523 (try-completion string Info-read-node-completion-table predicate))
a590e8ab89d0 (Info-find-in-tag-table-1, Info-read-subfile): Use point-min.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44902
diff changeset
1524 ((eq code t)
a590e8ab89d0 (Info-find-in-tag-table-1, Info-read-subfile): Use point-min.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44902
diff changeset
1525 (all-completions string Info-read-node-completion-table predicate))
a590e8ab89d0 (Info-find-in-tag-table-1, Info-read-subfile): Use point-min.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44902
diff changeset
1526 (t
a590e8ab89d0 (Info-find-in-tag-table-1, Info-read-subfile): Use point-min.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44902
diff changeset
1527 (test-completion string Info-read-node-completion-table predicate))))
12779
5b3d83e51b91 (Info-read-node-name-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 12646
diff changeset
1528
63065
58dcb71db77b (Info-read-node-name-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 63055
diff changeset
1529 ;; Arrange to highlight the proper letters in the completion list buffer.
58dcb71db77b (Info-read-node-name-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 63055
diff changeset
1530 (put 'Info-read-node-name-1 'completion-base-size-function
67623
465f402362cd (Info-read-node-name-1): In completion-base-size-function's
Juri Linkov <juri@jurta.org>
parents: 67520
diff changeset
1531 (lambda ()
465f402362cd (Info-read-node-name-1): In completion-base-size-function's
Juri Linkov <juri@jurta.org>
parents: 67520
diff changeset
1532 (if (string-match "\\`([^)]*\\'"
465f402362cd (Info-read-node-name-1): In completion-base-size-function's
Juri Linkov <juri@jurta.org>
parents: 67520
diff changeset
1533 (or completion-common-substring
465f402362cd (Info-read-node-name-1): In completion-base-size-function's
Juri Linkov <juri@jurta.org>
parents: 67520
diff changeset
1534 (minibuffer-completion-contents)))
465f402362cd (Info-read-node-name-1): In completion-base-size-function's
Juri Linkov <juri@jurta.org>
parents: 67520
diff changeset
1535 1
465f402362cd (Info-read-node-name-1): In completion-base-size-function's
Juri Linkov <juri@jurta.org>
parents: 67520
diff changeset
1536 0)))
63065
58dcb71db77b (Info-read-node-name-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 63055
diff changeset
1537
4410
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
1538 (defun Info-read-node-name (prompt &optional default)
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
1539 (let* ((completion-ignore-case t)
22760
e080fa4636c7 (Info-read-node-name-1, Info-read-node-name):
Richard M. Stallman <rms@gnu.org>
parents: 22733
diff changeset
1540 (Info-read-node-completion-table (Info-build-node-completions))
17140
a6f8fb00d93e (Info-read-node-name): Caused completing-read to force
Karl Heuer <kwzh@gnu.org>
parents: 16981
diff changeset
1541 (nodename (completing-read prompt 'Info-read-node-name-1 nil t)))
4410
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
1542 (if (equal nodename "")
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
1543 (or default
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
1544 (Info-read-node-name prompt))
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
1545 nodename)))
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
1546
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
1547 (defun Info-build-node-completions ()
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
1548 (or Info-current-file-completions
22951
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
1549 (let ((compl nil)
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
1550 ;; Bind this in case the user sets it to nil.
23923
950f2c278c9a (Info-node-at-bob-matching): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 23904
diff changeset
1551 (case-fold-search t)
950f2c278c9a (Info-node-at-bob-matching): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 23904
diff changeset
1552 (node-regexp "Node: *\\([^,\n]*\\) *[,\n\t]"))
4410
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
1553 (save-excursion
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
1554 (save-restriction
74719
8782777c2f1a (Info-build-node-completions): Signal error if tag-table marker is not
Chong Yidong <cyd@stupidchicken.com>
parents: 74471
diff changeset
1555 (or Info-tag-table-marker
8782777c2f1a (Info-build-node-completions): Signal error if tag-table marker is not
Chong Yidong <cyd@stupidchicken.com>
parents: 74471
diff changeset
1556 (error "No Info tags found"))
4410
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
1557 (if (marker-buffer Info-tag-table-marker)
16981
643e0f90e153 Handle multiple Info buffers.
Richard M. Stallman <rms@gnu.org>
parents: 16790
diff changeset
1558 (let ((marker Info-tag-table-marker))
643e0f90e153 Handle multiple Info buffers.
Richard M. Stallman <rms@gnu.org>
parents: 16790
diff changeset
1559 (set-buffer (marker-buffer marker))
6049
32df2b4d67cf (Info-build-node-completions): Add a call to widen.
Richard M. Stallman <rms@gnu.org>
parents: 5555
diff changeset
1560 (widen)
16981
643e0f90e153 Handle multiple Info buffers.
Richard M. Stallman <rms@gnu.org>
parents: 16790
diff changeset
1561 (goto-char marker)
29621
f03c3a69a809 Doc fixes.
Dave Love <fx@gnu.org>
parents: 29583
diff changeset
1562 (while (re-search-forward "\n\\(Node\\|Ref\\): \\(.*\\)\177" nil t)
4410
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
1563 (setq compl
29621
f03c3a69a809 Doc fixes.
Dave Love <fx@gnu.org>
parents: 29583
diff changeset
1564 (cons (list (match-string-no-properties 2))
4410
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
1565 compl))))
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
1566 (widen)
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
1567 (goto-char (point-min))
23923
950f2c278c9a (Info-node-at-bob-matching): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 23904
diff changeset
1568 ;; If the buffer begins with a node header, process that first.
950f2c278c9a (Info-node-at-bob-matching): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 23904
diff changeset
1569 (if (Info-node-at-bob-matching node-regexp)
26580
d779cb4aa2ae (Info-build-node-completions, Info-search, Info-follow-reference)
Dave Love <fx@gnu.org>
parents: 26172
diff changeset
1570 (setq compl (list (match-string-no-properties 1))))
23923
950f2c278c9a (Info-node-at-bob-matching): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 23904
diff changeset
1571 ;; Now for the rest of the nodes.
4410
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
1572 (while (search-forward "\n\^_" nil t)
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
1573 (forward-line 1)
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
1574 (let ((beg (point)))
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
1575 (forward-line 1)
23923
950f2c278c9a (Info-node-at-bob-matching): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 23904
diff changeset
1576 (if (re-search-backward node-regexp beg t)
28943
36fd90774cf7 (debug-ignored-errors): more errors to ignore.
Sam Steingold <sds@gnu.org>
parents: 28559
diff changeset
1577 (setq compl
26580
d779cb4aa2ae (Info-build-node-completions, Info-search, Info-follow-reference)
Dave Love <fx@gnu.org>
parents: 26172
diff changeset
1578 (cons (list (match-string-no-properties 1))
4410
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
1579 compl))))))))
26172
ac446cf94d51 (Info-build-node-completions): Add '("*") to the
Gerd Moellmann <gerd@gnu.org>
parents: 26004
diff changeset
1580 (setq compl (cons '("*") compl))
38407
4569042ee316 (Info-build-node-completions): Make Info-current-file-completions buffer local.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 38262
diff changeset
1581 (set (make-local-variable 'Info-current-file-completions) compl))))
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1582
540
0840eff2ecd5 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 359
diff changeset
1583 (defun Info-restore-point (hl)
0840eff2ecd5 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 359
diff changeset
1584 "If this node has been visited, restore the point value when we left."
6049
32df2b4d67cf (Info-build-node-completions): Add a call to widen.
Richard M. Stallman <rms@gnu.org>
parents: 5555
diff changeset
1585 (while hl
32df2b4d67cf (Info-build-node-completions): Add a call to widen.
Richard M. Stallman <rms@gnu.org>
parents: 5555
diff changeset
1586 (if (and (equal (nth 0 (car hl)) Info-current-file)
11527
7956811d4d9a (info-insert-file-contents): Set default-directory
Richard M. Stallman <rms@gnu.org>
parents: 11064
diff changeset
1587 ;; Use string-equal, not equal, to ignore text props.
7956811d4d9a (info-insert-file-contents): Set default-directory
Richard M. Stallman <rms@gnu.org>
parents: 11064
diff changeset
1588 (string-equal (nth 1 (car hl)) Info-current-node))
6049
32df2b4d67cf (Info-build-node-completions): Add a call to widen.
Richard M. Stallman <rms@gnu.org>
parents: 5555
diff changeset
1589 (progn
6121
a9caf92da1d3 (Info-restore-point): Don't wipe out hl before using it.
Karl Heuer <kwzh@gnu.org>
parents: 6049
diff changeset
1590 (goto-char (nth 2 (car hl)))
a9caf92da1d3 (Info-restore-point): Don't wipe out hl before using it.
Karl Heuer <kwzh@gnu.org>
parents: 6049
diff changeset
1591 (setq hl nil)) ;terminate the while at next iter
6049
32df2b4d67cf (Info-build-node-completions): Add a call to widen.
Richard M. Stallman <rms@gnu.org>
parents: 5555
diff changeset
1592 (setq hl (cdr hl)))))
540
0840eff2ecd5 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 359
diff changeset
1593
30109
310914da7811 (Info-last-search): Variable removed.
Gerd Moellmann <gerd@gnu.org>
parents: 30020
diff changeset
1594 (defvar Info-search-history nil
310914da7811 (Info-last-search): Variable removed.
Gerd Moellmann <gerd@gnu.org>
parents: 30020
diff changeset
1595 "The history list for `Info-search'.")
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1596
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
1597 (defvar Info-search-case-fold nil
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
1598 "The value of `case-fold-search' from previous `Info-search' command.")
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
1599
56866
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
1600 (defun Info-search (regexp &optional bound noerror count direction)
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
1601 "Search for REGEXP, starting from point, and select node it's found in.
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
1602 If DIRECTION is `backward', search in the reverse direction."
35136
1eb26b81ece0 (Info-search): Print the default as part of the prompt.
Eli Zaretskii <eliz@gnu.org>
parents: 35112
diff changeset
1603 (interactive (list (read-string
1eb26b81ece0 (Info-search): Print the default as part of the prompt.
Eli Zaretskii <eliz@gnu.org>
parents: 35112
diff changeset
1604 (if Info-search-history
65680
ed770a0a7846 2005-09-24 Emilio C. Lopes <eclig@gmx.net>
Romain Francoise <romain@orebokech.com>
parents: 65069
diff changeset
1605 (format "Regexp search%s (default %s): "
ed770a0a7846 2005-09-24 Emilio C. Lopes <eclig@gmx.net>
Romain Francoise <romain@orebokech.com>
parents: 65069
diff changeset
1606 (if case-fold-search "" " case-sensitively")
35136
1eb26b81ece0 (Info-search): Print the default as part of the prompt.
Eli Zaretskii <eliz@gnu.org>
parents: 35112
diff changeset
1607 (car Info-search-history))
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
1608 (format "Regexp search%s: "
65680
ed770a0a7846 2005-09-24 Emilio C. Lopes <eclig@gmx.net>
Romain Francoise <romain@orebokech.com>
parents: 65069
diff changeset
1609 (if case-fold-search "" " case-sensitively")))
35136
1eb26b81ece0 (Info-search): Print the default as part of the prompt.
Eli Zaretskii <eliz@gnu.org>
parents: 35112
diff changeset
1610 nil 'Info-search-history)))
30109
310914da7811 (Info-last-search): Variable removed.
Gerd Moellmann <gerd@gnu.org>
parents: 30020
diff changeset
1611 (when transient-mark-mode
310914da7811 (Info-last-search): Variable removed.
Gerd Moellmann <gerd@gnu.org>
parents: 30020
diff changeset
1612 (deactivate-mark))
310914da7811 (Info-last-search): Variable removed.
Gerd Moellmann <gerd@gnu.org>
parents: 30020
diff changeset
1613 (when (equal regexp "")
310914da7811 (Info-last-search): Variable removed.
Gerd Moellmann <gerd@gnu.org>
parents: 30020
diff changeset
1614 (setq regexp (car Info-search-history)))
24963
a78f0c2654d6 (Info-search): Don't lose with empty regexp.
Dave Love <fx@gnu.org>
parents: 24632
diff changeset
1615 (when regexp
51805
7a3de98ae801 (Info-search): If find invisible text, search again.
Richard M. Stallman <rms@gnu.org>
parents: 51784
diff changeset
1616 (let (found beg-found give-up
56866
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
1617 (backward (eq direction 'backward))
24963
a78f0c2654d6 (Info-search): Don't lose with empty regexp.
Dave Love <fx@gnu.org>
parents: 24632
diff changeset
1618 (onode Info-current-node)
a78f0c2654d6 (Info-search): Don't lose with empty regexp.
Dave Love <fx@gnu.org>
parents: 24632
diff changeset
1619 (ofile Info-current-file)
a78f0c2654d6 (Info-search): Don't lose with empty regexp.
Dave Love <fx@gnu.org>
parents: 24632
diff changeset
1620 (opoint (point))
56866
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
1621 (opoint-min (point-min))
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
1622 (opoint-max (point-max))
24963
a78f0c2654d6 (Info-search): Don't lose with empty regexp.
Dave Love <fx@gnu.org>
parents: 24632
diff changeset
1623 (ostart (window-start))
a78f0c2654d6 (Info-search): Don't lose with empty regexp.
Dave Love <fx@gnu.org>
parents: 24632
diff changeset
1624 (osubfile Info-current-subfile))
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
1625 (setq Info-search-case-fold case-fold-search)
24963
a78f0c2654d6 (Info-search): Don't lose with empty regexp.
Dave Love <fx@gnu.org>
parents: 24632
diff changeset
1626 (save-excursion
a78f0c2654d6 (Info-search): Don't lose with empty regexp.
Dave Love <fx@gnu.org>
parents: 24632
diff changeset
1627 (save-restriction
a78f0c2654d6 (Info-search): Don't lose with empty regexp.
Dave Love <fx@gnu.org>
parents: 24632
diff changeset
1628 (widen)
57958
117144126cd9 (Info-search): Don't search in node header lines and file headers.
Juri Linkov <juri@jurta.org>
parents: 57770
diff changeset
1629 (when backward
117144126cd9 (Info-search): Don't search in node header lines and file headers.
Juri Linkov <juri@jurta.org>
parents: 57770
diff changeset
1630 ;; Hide Info file header for backward search
117144126cd9 (Info-search): Don't search in node header lines and file headers.
Juri Linkov <juri@jurta.org>
parents: 57770
diff changeset
1631 (narrow-to-region (save-excursion
117144126cd9 (Info-search): Don't search in node header lines and file headers.
Juri Linkov <juri@jurta.org>
parents: 57770
diff changeset
1632 (goto-char (point-min))
117144126cd9 (Info-search): Don't search in node header lines and file headers.
Juri Linkov <juri@jurta.org>
parents: 57770
diff changeset
1633 (search-forward "\n\^_")
117144126cd9 (Info-search): Don't search in node header lines and file headers.
Juri Linkov <juri@jurta.org>
parents: 57770
diff changeset
1634 (1- (point)))
117144126cd9 (Info-search): Don't search in node header lines and file headers.
Juri Linkov <juri@jurta.org>
parents: 57770
diff changeset
1635 (point-max)))
51805
7a3de98ae801 (Info-search): If find invisible text, search again.
Richard M. Stallman <rms@gnu.org>
parents: 51784
diff changeset
1636 (while (and (not give-up)
58152
f3726ecfee76 (Info-search): Save match data for isearch. Skip Tag Table node.
Juri Linkov <juri@jurta.org>
parents: 58040
diff changeset
1637 (save-match-data
f3726ecfee76 (Info-search): Save match data for isearch. Skip Tag Table node.
Juri Linkov <juri@jurta.org>
parents: 58040
diff changeset
1638 (or (null found)
f3726ecfee76 (Info-search): Save match data for isearch. Skip Tag Table node.
Juri Linkov <juri@jurta.org>
parents: 58040
diff changeset
1639 (if backward
f3726ecfee76 (Info-search): Save match data for isearch. Skip Tag Table node.
Juri Linkov <juri@jurta.org>
parents: 58040
diff changeset
1640 (isearch-range-invisible found beg-found)
f3726ecfee76 (Info-search): Save match data for isearch. Skip Tag Table node.
Juri Linkov <juri@jurta.org>
parents: 58040
diff changeset
1641 (isearch-range-invisible beg-found found))
f3726ecfee76 (Info-search): Save match data for isearch. Skip Tag Table node.
Juri Linkov <juri@jurta.org>
parents: 58040
diff changeset
1642 ;; Skip node header line
58604
a227196e4498 (Info-search-whitespace-regexp): Remove shy group.
Juri Linkov <juri@jurta.org>
parents: 58350
diff changeset
1643 (and (save-excursion (forward-line -1)
a227196e4498 (Info-search-whitespace-regexp): Remove shy group.
Juri Linkov <juri@jurta.org>
parents: 58350
diff changeset
1644 (looking-at "\^_"))
60577
1bfdd67c0337 (Info-search): Four fixes for backward search.
Juri Linkov <juri@jurta.org>
parents: 60524
diff changeset
1645 (forward-line (if backward -1 1)))
58152
f3726ecfee76 (Info-search): Save match data for isearch. Skip Tag Table node.
Juri Linkov <juri@jurta.org>
parents: 58040
diff changeset
1646 ;; Skip Tag Table node
f3726ecfee76 (Info-search): Save match data for isearch. Skip Tag Table node.
Juri Linkov <juri@jurta.org>
parents: 58040
diff changeset
1647 (save-excursion
f3726ecfee76 (Info-search): Save match data for isearch. Skip Tag Table node.
Juri Linkov <juri@jurta.org>
parents: 58040
diff changeset
1648 (and (search-backward "\^_" nil t)
68984
3399fee3fc7e (Info-search): Skip `Local Variables' node.
Juri Linkov <juri@jurta.org>
parents: 68980
diff changeset
1649 (looking-at
3399fee3fc7e (Info-search): Skip `Local Variables' node.
Juri Linkov <juri@jurta.org>
parents: 68980
diff changeset
1650 "\^_\n\\(Tag Table\\|Local Variables\\)"))))))
69128
ab159a9e1d0a (Info-search): Don't bind search-spaces-regexp to
Juri Linkov <juri@jurta.org>
parents: 68984
diff changeset
1651 (let ((search-spaces-regexp
ab159a9e1d0a (Info-search): Don't bind search-spaces-regexp to
Juri Linkov <juri@jurta.org>
parents: 68984
diff changeset
1652 (if (or (not isearch-mode) isearch-regexp)
ab159a9e1d0a (Info-search): Don't bind search-spaces-regexp to
Juri Linkov <juri@jurta.org>
parents: 68984
diff changeset
1653 Info-search-whitespace-regexp)))
58331
c11ef32aabb7 (Info-search): Use search-whitespace-regexp.
Richard M. Stallman <rms@gnu.org>
parents: 58152
diff changeset
1654 (if (if backward
c11ef32aabb7 (Info-search): Use search-whitespace-regexp.
Richard M. Stallman <rms@gnu.org>
parents: 58152
diff changeset
1655 (re-search-backward regexp bound t)
c11ef32aabb7 (Info-search): Use search-whitespace-regexp.
Richard M. Stallman <rms@gnu.org>
parents: 58152
diff changeset
1656 (re-search-forward regexp bound t))
c11ef32aabb7 (Info-search): Use search-whitespace-regexp.
Richard M. Stallman <rms@gnu.org>
parents: 58152
diff changeset
1657 (setq found (point) beg-found (if backward (match-end 0)
c11ef32aabb7 (Info-search): Use search-whitespace-regexp.
Richard M. Stallman <rms@gnu.org>
parents: 58152
diff changeset
1658 (match-beginning 0)))
c11ef32aabb7 (Info-search): Use search-whitespace-regexp.
Richard M. Stallman <rms@gnu.org>
parents: 58152
diff changeset
1659 (setq give-up t))))))
60615
643e6516a779 (Info-isearch-initial-node): New internal variable.
Juri Linkov <juri@jurta.org>
parents: 60577
diff changeset
1660
643e6516a779 (Info-isearch-initial-node): New internal variable.
Juri Linkov <juri@jurta.org>
parents: 60577
diff changeset
1661 (when (and isearch-mode Info-isearch-search
643e6516a779 (Info-isearch-initial-node): New internal variable.
Juri Linkov <juri@jurta.org>
parents: 60577
diff changeset
1662 (not Info-isearch-initial-node)
643e6516a779 (Info-isearch-initial-node): New internal variable.
Juri Linkov <juri@jurta.org>
parents: 60577
diff changeset
1663 (not bound)
643e6516a779 (Info-isearch-initial-node): New internal variable.
Juri Linkov <juri@jurta.org>
parents: 60577
diff changeset
1664 (or give-up (and found (not (and (> found opoint-min)
643e6516a779 (Info-isearch-initial-node): New internal variable.
Juri Linkov <juri@jurta.org>
parents: 60577
diff changeset
1665 (< found opoint-max))))))
643e6516a779 (Info-isearch-initial-node): New internal variable.
Juri Linkov <juri@jurta.org>
parents: 60577
diff changeset
1666 (signal 'search-failed (list regexp "initial node")))
643e6516a779 (Info-isearch-initial-node): New internal variable.
Juri Linkov <juri@jurta.org>
parents: 60577
diff changeset
1667
51805
7a3de98ae801 (Info-search): If find invisible text, search again.
Richard M. Stallman <rms@gnu.org>
parents: 51784
diff changeset
1668 ;; If no subfiles, give error now.
7a3de98ae801 (Info-search): If find invisible text, search again.
Richard M. Stallman <rms@gnu.org>
parents: 51784
diff changeset
1669 (if give-up
24963
a78f0c2654d6 (Info-search): Don't lose with empty regexp.
Dave Love <fx@gnu.org>
parents: 24632
diff changeset
1670 (if (null Info-current-subfile)
69128
ab159a9e1d0a (Info-search): Don't bind search-spaces-regexp to
Juri Linkov <juri@jurta.org>
parents: 68984
diff changeset
1671 (let ((search-spaces-regexp
ab159a9e1d0a (Info-search): Don't bind search-spaces-regexp to
Juri Linkov <juri@jurta.org>
parents: 68984
diff changeset
1672 (if (or (not isearch-mode) isearch-regexp)
ab159a9e1d0a (Info-search): Don't bind search-spaces-regexp to
Juri Linkov <juri@jurta.org>
parents: 68984
diff changeset
1673 Info-search-whitespace-regexp)))
58604
a227196e4498 (Info-search-whitespace-regexp): Remove shy group.
Juri Linkov <juri@jurta.org>
parents: 58350
diff changeset
1674 (if backward
a227196e4498 (Info-search-whitespace-regexp): Remove shy group.
Juri Linkov <juri@jurta.org>
parents: 58350
diff changeset
1675 (re-search-backward regexp)
a227196e4498 (Info-search-whitespace-regexp): Remove shy group.
Juri Linkov <juri@jurta.org>
parents: 58350
diff changeset
1676 (re-search-forward regexp)))
51805
7a3de98ae801 (Info-search): If find invisible text, search again.
Richard M. Stallman <rms@gnu.org>
parents: 51784
diff changeset
1677 (setq found nil)))
7a3de98ae801 (Info-search): If find invisible text, search again.
Richard M. Stallman <rms@gnu.org>
parents: 51784
diff changeset
1678
60615
643e6516a779 (Info-isearch-initial-node): New internal variable.
Juri Linkov <juri@jurta.org>
parents: 60577
diff changeset
1679 (if (and bound (not found))
643e6516a779 (Info-isearch-initial-node): New internal variable.
Juri Linkov <juri@jurta.org>
parents: 60577
diff changeset
1680 (signal 'search-failed (list regexp)))
643e6516a779 (Info-isearch-initial-node): New internal variable.
Juri Linkov <juri@jurta.org>
parents: 60577
diff changeset
1681
56866
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
1682 (unless (or found bound)
51805
7a3de98ae801 (Info-search): If find invisible text, search again.
Richard M. Stallman <rms@gnu.org>
parents: 51784
diff changeset
1683 (unwind-protect
7a3de98ae801 (Info-search): If find invisible text, search again.
Richard M. Stallman <rms@gnu.org>
parents: 51784
diff changeset
1684 ;; Try other subfiles.
7a3de98ae801 (Info-search): If find invisible text, search again.
Richard M. Stallman <rms@gnu.org>
parents: 51784
diff changeset
1685 (let ((list ()))
7a3de98ae801 (Info-search): If find invisible text, search again.
Richard M. Stallman <rms@gnu.org>
parents: 51784
diff changeset
1686 (save-excursion
7a3de98ae801 (Info-search): If find invisible text, search again.
Richard M. Stallman <rms@gnu.org>
parents: 51784
diff changeset
1687 (set-buffer (marker-buffer Info-tag-table-marker))
7a3de98ae801 (Info-search): If find invisible text, search again.
Richard M. Stallman <rms@gnu.org>
parents: 51784
diff changeset
1688 (goto-char (point-min))
7a3de98ae801 (Info-search): If find invisible text, search again.
Richard M. Stallman <rms@gnu.org>
parents: 51784
diff changeset
1689 (search-forward "\n\^_\nIndirect:")
7a3de98ae801 (Info-search): If find invisible text, search again.
Richard M. Stallman <rms@gnu.org>
parents: 51784
diff changeset
1690 (save-restriction
7a3de98ae801 (Info-search): If find invisible text, search again.
Richard M. Stallman <rms@gnu.org>
parents: 51784
diff changeset
1691 (narrow-to-region (point)
7a3de98ae801 (Info-search): If find invisible text, search again.
Richard M. Stallman <rms@gnu.org>
parents: 51784
diff changeset
1692 (progn (search-forward "\n\^_")
7a3de98ae801 (Info-search): If find invisible text, search again.
Richard M. Stallman <rms@gnu.org>
parents: 51784
diff changeset
1693 (1- (point))))
16981
643e0f90e153 Handle multiple Info buffers.
Richard M. Stallman <rms@gnu.org>
parents: 16790
diff changeset
1694 (goto-char (point-min))
51805
7a3de98ae801 (Info-search): If find invisible text, search again.
Richard M. Stallman <rms@gnu.org>
parents: 51784
diff changeset
1695 ;; Find the subfile we just searched.
7a3de98ae801 (Info-search): If find invisible text, search again.
Richard M. Stallman <rms@gnu.org>
parents: 51784
diff changeset
1696 (search-forward (concat "\n" osubfile ": "))
7a3de98ae801 (Info-search): If find invisible text, search again.
Richard M. Stallman <rms@gnu.org>
parents: 51784
diff changeset
1697 ;; Skip that one.
56866
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
1698 (forward-line (if backward 0 1))
60577
1bfdd67c0337 (Info-search): Four fixes for backward search.
Juri Linkov <juri@jurta.org>
parents: 60524
diff changeset
1699 (if backward (forward-char -1))
51805
7a3de98ae801 (Info-search): If find invisible text, search again.
Richard M. Stallman <rms@gnu.org>
parents: 51784
diff changeset
1700 ;; Make a list of all following subfiles.
7a3de98ae801 (Info-search): If find invisible text, search again.
Richard M. Stallman <rms@gnu.org>
parents: 51784
diff changeset
1701 ;; Each elt has the form (VIRT-POSITION . SUBFILENAME).
56866
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
1702 (while (not (if backward (bobp) (eobp)))
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
1703 (if backward
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
1704 (re-search-backward "\\(^.*\\): [0-9]+$")
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
1705 (re-search-forward "\\(^.*\\): [0-9]+$"))
51805
7a3de98ae801 (Info-search): If find invisible text, search again.
Richard M. Stallman <rms@gnu.org>
parents: 51784
diff changeset
1706 (goto-char (+ (match-end 1) 2))
7a3de98ae801 (Info-search): If find invisible text, search again.
Richard M. Stallman <rms@gnu.org>
parents: 51784
diff changeset
1707 (setq list (cons (cons (+ (point-min)
7a3de98ae801 (Info-search): If find invisible text, search again.
Richard M. Stallman <rms@gnu.org>
parents: 51784
diff changeset
1708 (read (current-buffer)))
7a3de98ae801 (Info-search): If find invisible text, search again.
Richard M. Stallman <rms@gnu.org>
parents: 51784
diff changeset
1709 (match-string-no-properties 1))
7a3de98ae801 (Info-search): If find invisible text, search again.
Richard M. Stallman <rms@gnu.org>
parents: 51784
diff changeset
1710 list))
56866
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
1711 (goto-char (if backward
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
1712 (1- (match-beginning 0))
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
1713 (1+ (match-end 0)))))
51805
7a3de98ae801 (Info-search): If find invisible text, search again.
Richard M. Stallman <rms@gnu.org>
parents: 51784
diff changeset
1714 ;; Put in forward order
7a3de98ae801 (Info-search): If find invisible text, search again.
Richard M. Stallman <rms@gnu.org>
parents: 51784
diff changeset
1715 (setq list (nreverse list))))
7a3de98ae801 (Info-search): If find invisible text, search again.
Richard M. Stallman <rms@gnu.org>
parents: 51784
diff changeset
1716 (while list
7a3de98ae801 (Info-search): If find invisible text, search again.
Richard M. Stallman <rms@gnu.org>
parents: 51784
diff changeset
1717 (message "Searching subfile %s..." (cdr (car list)))
7a3de98ae801 (Info-search): If find invisible text, search again.
Richard M. Stallman <rms@gnu.org>
parents: 51784
diff changeset
1718 (Info-read-subfile (car (car list)))
57958
117144126cd9 (Info-search): Don't search in node header lines and file headers.
Juri Linkov <juri@jurta.org>
parents: 57770
diff changeset
1719 (when backward
117144126cd9 (Info-search): Don't search in node header lines and file headers.
Juri Linkov <juri@jurta.org>
parents: 57770
diff changeset
1720 ;; Hide Info file header for backward search
117144126cd9 (Info-search): Don't search in node header lines and file headers.
Juri Linkov <juri@jurta.org>
parents: 57770
diff changeset
1721 (narrow-to-region (save-excursion
117144126cd9 (Info-search): Don't search in node header lines and file headers.
Juri Linkov <juri@jurta.org>
parents: 57770
diff changeset
1722 (goto-char (point-min))
117144126cd9 (Info-search): Don't search in node header lines and file headers.
Juri Linkov <juri@jurta.org>
parents: 57770
diff changeset
1723 (search-forward "\n\^_")
117144126cd9 (Info-search): Don't search in node header lines and file headers.
Juri Linkov <juri@jurta.org>
parents: 57770
diff changeset
1724 (1- (point)))
117144126cd9 (Info-search): Don't search in node header lines and file headers.
Juri Linkov <juri@jurta.org>
parents: 57770
diff changeset
1725 (point-max))
117144126cd9 (Info-search): Don't search in node header lines and file headers.
Juri Linkov <juri@jurta.org>
parents: 57770
diff changeset
1726 (goto-char (point-max)))
51805
7a3de98ae801 (Info-search): If find invisible text, search again.
Richard M. Stallman <rms@gnu.org>
parents: 51784
diff changeset
1727 (setq list (cdr list))
7a3de98ae801 (Info-search): If find invisible text, search again.
Richard M. Stallman <rms@gnu.org>
parents: 51784
diff changeset
1728 (setq give-up nil found nil)
7a3de98ae801 (Info-search): If find invisible text, search again.
Richard M. Stallman <rms@gnu.org>
parents: 51784
diff changeset
1729 (while (and (not give-up)
58152
f3726ecfee76 (Info-search): Save match data for isearch. Skip Tag Table node.
Juri Linkov <juri@jurta.org>
parents: 58040
diff changeset
1730 (save-match-data
f3726ecfee76 (Info-search): Save match data for isearch. Skip Tag Table node.
Juri Linkov <juri@jurta.org>
parents: 58040
diff changeset
1731 (or (null found)
f3726ecfee76 (Info-search): Save match data for isearch. Skip Tag Table node.
Juri Linkov <juri@jurta.org>
parents: 58040
diff changeset
1732 (if backward
f3726ecfee76 (Info-search): Save match data for isearch. Skip Tag Table node.
Juri Linkov <juri@jurta.org>
parents: 58040
diff changeset
1733 (isearch-range-invisible found beg-found)
f3726ecfee76 (Info-search): Save match data for isearch. Skip Tag Table node.
Juri Linkov <juri@jurta.org>
parents: 58040
diff changeset
1734 (isearch-range-invisible beg-found found))
f3726ecfee76 (Info-search): Save match data for isearch. Skip Tag Table node.
Juri Linkov <juri@jurta.org>
parents: 58040
diff changeset
1735 ;; Skip node header line
58604
a227196e4498 (Info-search-whitespace-regexp): Remove shy group.
Juri Linkov <juri@jurta.org>
parents: 58350
diff changeset
1736 (and (save-excursion (forward-line -1)
a227196e4498 (Info-search-whitespace-regexp): Remove shy group.
Juri Linkov <juri@jurta.org>
parents: 58350
diff changeset
1737 (looking-at "\^_"))
60577
1bfdd67c0337 (Info-search): Four fixes for backward search.
Juri Linkov <juri@jurta.org>
parents: 60524
diff changeset
1738 (forward-line (if backward -1 1)))
58152
f3726ecfee76 (Info-search): Save match data for isearch. Skip Tag Table node.
Juri Linkov <juri@jurta.org>
parents: 58040
diff changeset
1739 ;; Skip Tag Table node
f3726ecfee76 (Info-search): Save match data for isearch. Skip Tag Table node.
Juri Linkov <juri@jurta.org>
parents: 58040
diff changeset
1740 (save-excursion
f3726ecfee76 (Info-search): Save match data for isearch. Skip Tag Table node.
Juri Linkov <juri@jurta.org>
parents: 58040
diff changeset
1741 (and (search-backward "\^_" nil t)
68984
3399fee3fc7e (Info-search): Skip `Local Variables' node.
Juri Linkov <juri@jurta.org>
parents: 68980
diff changeset
1742 (looking-at
3399fee3fc7e (Info-search): Skip `Local Variables' node.
Juri Linkov <juri@jurta.org>
parents: 68980
diff changeset
1743 "\^_\n\\(Tag Table\\|Local Variables\\)"))))))
69128
ab159a9e1d0a (Info-search): Don't bind search-spaces-regexp to
Juri Linkov <juri@jurta.org>
parents: 68984
diff changeset
1744 (let ((search-spaces-regexp
ab159a9e1d0a (Info-search): Don't bind search-spaces-regexp to
Juri Linkov <juri@jurta.org>
parents: 68984
diff changeset
1745 (if (or (not isearch-mode) isearch-regexp)
ab159a9e1d0a (Info-search): Don't bind search-spaces-regexp to
Juri Linkov <juri@jurta.org>
parents: 68984
diff changeset
1746 Info-search-whitespace-regexp)))
58604
a227196e4498 (Info-search-whitespace-regexp): Remove shy group.
Juri Linkov <juri@jurta.org>
parents: 58350
diff changeset
1747 (if (if backward
a227196e4498 (Info-search-whitespace-regexp): Remove shy group.
Juri Linkov <juri@jurta.org>
parents: 58350
diff changeset
1748 (re-search-backward regexp nil t)
a227196e4498 (Info-search-whitespace-regexp): Remove shy group.
Juri Linkov <juri@jurta.org>
parents: 58350
diff changeset
1749 (re-search-forward regexp nil t))
a227196e4498 (Info-search-whitespace-regexp): Remove shy group.
Juri Linkov <juri@jurta.org>
parents: 58350
diff changeset
1750 (setq found (point) beg-found (if backward (match-end 0)
a227196e4498 (Info-search-whitespace-regexp): Remove shy group.
Juri Linkov <juri@jurta.org>
parents: 58350
diff changeset
1751 (match-beginning 0)))
a227196e4498 (Info-search-whitespace-regexp): Remove shy group.
Juri Linkov <juri@jurta.org>
parents: 58350
diff changeset
1752 (setq give-up t))))
51805
7a3de98ae801 (Info-search): If find invisible text, search again.
Richard M. Stallman <rms@gnu.org>
parents: 51784
diff changeset
1753 (if give-up
7a3de98ae801 (Info-search): If find invisible text, search again.
Richard M. Stallman <rms@gnu.org>
parents: 51784
diff changeset
1754 (setq found nil))
24963
a78f0c2654d6 (Info-search): Don't lose with empty regexp.
Dave Love <fx@gnu.org>
parents: 24632
diff changeset
1755 (if found
51805
7a3de98ae801 (Info-search): If find invisible text, search again.
Richard M. Stallman <rms@gnu.org>
parents: 51784
diff changeset
1756 (setq list nil)))
7a3de98ae801 (Info-search): If find invisible text, search again.
Richard M. Stallman <rms@gnu.org>
parents: 51784
diff changeset
1757 (if found
7a3de98ae801 (Info-search): If find invisible text, search again.
Richard M. Stallman <rms@gnu.org>
parents: 51784
diff changeset
1758 (message "")
7a3de98ae801 (Info-search): If find invisible text, search again.
Richard M. Stallman <rms@gnu.org>
parents: 51784
diff changeset
1759 (signal 'search-failed (list regexp))))
7a3de98ae801 (Info-search): If find invisible text, search again.
Richard M. Stallman <rms@gnu.org>
parents: 51784
diff changeset
1760 (if (not found)
7a3de98ae801 (Info-search): If find invisible text, search again.
Richard M. Stallman <rms@gnu.org>
parents: 51784
diff changeset
1761 (progn (Info-read-subfile osubfile)
7a3de98ae801 (Info-search): If find invisible text, search again.
Richard M. Stallman <rms@gnu.org>
parents: 51784
diff changeset
1762 (goto-char opoint)
7a3de98ae801 (Info-search): If find invisible text, search again.
Richard M. Stallman <rms@gnu.org>
parents: 51784
diff changeset
1763 (Info-select-node)
7a3de98ae801 (Info-search): If find invisible text, search again.
Richard M. Stallman <rms@gnu.org>
parents: 51784
diff changeset
1764 (set-window-start (selected-window) ostart)))))
56866
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
1765
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
1766 (if (and (string= osubfile Info-current-subfile)
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
1767 (> found opoint-min)
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
1768 (< found opoint-max))
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
1769 ;; Search landed in the same node
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
1770 (goto-char found)
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
1771 (widen)
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
1772 (goto-char found)
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
1773 (save-match-data (Info-select-node)))
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
1774
29446
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
1775 ;; Use string-equal, not equal, to ignore text props.
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
1776 (or (and (string-equal onode Info-current-node)
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
1777 (equal ofile Info-current-file))
60577
1bfdd67c0337 (Info-search): Four fixes for backward search.
Juri Linkov <juri@jurta.org>
parents: 60524
diff changeset
1778 (and isearch-mode isearch-wrapped
1bfdd67c0337 (Info-search): Four fixes for backward search.
Juri Linkov <juri@jurta.org>
parents: 60524
diff changeset
1779 (eq opoint (if isearch-forward opoint-min opoint-max)))
29446
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
1780 (setq Info-history (cons (list ofile onode opoint)
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
1781 Info-history))))))
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
1782
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
1783 (defun Info-search-case-sensitively ()
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
1784 "Search for a regexp case-sensitively."
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
1785 (interactive)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
1786 (let ((case-fold-search nil))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
1787 (call-interactively 'Info-search)))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
1788
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
1789 (defun Info-search-next ()
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
1790 "Search for next regexp from a previous `Info-search' command."
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
1791 (interactive)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
1792 (let ((case-fold-search Info-search-case-fold))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
1793 (if Info-search-history
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
1794 (Info-search (car Info-search-history))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
1795 (call-interactively 'Info-search))))
56866
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
1796
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
1797 (defun Info-search-backward (regexp &optional bound noerror count)
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
1798 "Search for REGEXP in the reverse direction."
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
1799 (interactive (list (read-string
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
1800 (if Info-search-history
65680
ed770a0a7846 2005-09-24 Emilio C. Lopes <eclig@gmx.net>
Romain Francoise <romain@orebokech.com>
parents: 65069
diff changeset
1801 (format "Regexp search%s backward (default %s): "
ed770a0a7846 2005-09-24 Emilio C. Lopes <eclig@gmx.net>
Romain Francoise <romain@orebokech.com>
parents: 65069
diff changeset
1802 (if case-fold-search "" " case-sensitively")
56866
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
1803 (car Info-search-history))
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
1804 (format "Regexp search%s backward: "
65680
ed770a0a7846 2005-09-24 Emilio C. Lopes <eclig@gmx.net>
Romain Francoise <romain@orebokech.com>
parents: 65069
diff changeset
1805 (if case-fold-search "" " case-sensitively")))
56866
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
1806 nil 'Info-search-history)))
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
1807 (Info-search regexp bound noerror count 'backward))
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
1808
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
1809 (defun Info-isearch-search ()
60524
d77fe7e90fb5 (Info-isearch-search): Emulate word search in
Juri Linkov <juri@jurta.org>
parents: 60222
diff changeset
1810 (if Info-isearch-search
60222
56061feffaa0 (Info-isearch-search): New defcustom.
Juri Linkov <juri@jurta.org>
parents: 59996
diff changeset
1811 (lambda (string &optional bound noerror count)
60615
643e6516a779 (Info-isearch-initial-node): New internal variable.
Juri Linkov <juri@jurta.org>
parents: 60577
diff changeset
1812 (if isearch-word
643e6516a779 (Info-isearch-initial-node): New internal variable.
Juri Linkov <juri@jurta.org>
parents: 60577
diff changeset
1813 (Info-search (concat "\\b" (replace-regexp-in-string
65069
fc42a1decf2d (Info-insert-dir): Use save-excursion around insert-buffer-substring.
Juri Linkov <juri@jurta.org>
parents: 64961
diff changeset
1814 "\\W+" "\\W+"
60615
643e6516a779 (Info-isearch-initial-node): New internal variable.
Juri Linkov <juri@jurta.org>
parents: 60577
diff changeset
1815 (replace-regexp-in-string
65069
fc42a1decf2d (Info-insert-dir): Use save-excursion around insert-buffer-substring.
Juri Linkov <juri@jurta.org>
parents: 64961
diff changeset
1816 "^\\W+\\|\\W+$" "" string)
fc42a1decf2d (Info-insert-dir): Use save-excursion around insert-buffer-substring.
Juri Linkov <juri@jurta.org>
parents: 64961
diff changeset
1817 nil t)
fc42a1decf2d (Info-insert-dir): Use save-excursion around insert-buffer-substring.
Juri Linkov <juri@jurta.org>
parents: 64961
diff changeset
1818 "\\b")
60615
643e6516a779 (Info-isearch-initial-node): New internal variable.
Juri Linkov <juri@jurta.org>
parents: 60577
diff changeset
1819 bound noerror count
643e6516a779 (Info-isearch-initial-node): New internal variable.
Juri Linkov <juri@jurta.org>
parents: 60577
diff changeset
1820 (unless isearch-forward 'backward))
643e6516a779 (Info-isearch-initial-node): New internal variable.
Juri Linkov <juri@jurta.org>
parents: 60577
diff changeset
1821 (Info-search (if isearch-regexp string (regexp-quote string))
643e6516a779 (Info-isearch-initial-node): New internal variable.
Juri Linkov <juri@jurta.org>
parents: 60577
diff changeset
1822 bound noerror count
643e6516a779 (Info-isearch-initial-node): New internal variable.
Juri Linkov <juri@jurta.org>
parents: 60577
diff changeset
1823 (unless isearch-forward 'backward))
643e6516a779 (Info-isearch-initial-node): New internal variable.
Juri Linkov <juri@jurta.org>
parents: 60577
diff changeset
1824 (point)))
60222
56061feffaa0 (Info-isearch-search): New defcustom.
Juri Linkov <juri@jurta.org>
parents: 59996
diff changeset
1825 (let ((isearch-search-fun-function nil))
56061feffaa0 (Info-isearch-search): New defcustom.
Juri Linkov <juri@jurta.org>
parents: 59996
diff changeset
1826 (isearch-search-fun))))
56866
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
1827
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
1828 (defun Info-isearch-wrap ()
60615
643e6516a779 (Info-isearch-initial-node): New internal variable.
Juri Linkov <juri@jurta.org>
parents: 60577
diff changeset
1829 (if Info-isearch-search
643e6516a779 (Info-isearch-initial-node): New internal variable.
Juri Linkov <juri@jurta.org>
parents: 60577
diff changeset
1830 (if Info-isearch-initial-node
643e6516a779 (Info-isearch-initial-node): New internal variable.
Juri Linkov <juri@jurta.org>
parents: 60577
diff changeset
1831 (progn
643e6516a779 (Info-isearch-initial-node): New internal variable.
Juri Linkov <juri@jurta.org>
parents: 60577
diff changeset
1832 (if isearch-forward (Info-top-node) (Info-final-node))
643e6516a779 (Info-isearch-initial-node): New internal variable.
Juri Linkov <juri@jurta.org>
parents: 60577
diff changeset
1833 (goto-char (if isearch-forward (point-min) (point-max))))
643e6516a779 (Info-isearch-initial-node): New internal variable.
Juri Linkov <juri@jurta.org>
parents: 60577
diff changeset
1834 (setq Info-isearch-initial-node Info-current-node)
643e6516a779 (Info-isearch-initial-node): New internal variable.
Juri Linkov <juri@jurta.org>
parents: 60577
diff changeset
1835 (setq isearch-wrapped nil))
56866
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
1836 (goto-char (if isearch-forward (point-min) (point-max)))))
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
1837
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
1838 (defun Info-isearch-push-state ()
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
1839 `(lambda (cmd)
68980
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
1840 (Info-isearch-pop-state cmd ',Info-current-file ',Info-current-node)))
56866
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
1841
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
1842 (defun Info-isearch-pop-state (cmd file node)
68980
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
1843 (or (and (equal Info-current-file file)
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
1844 (equal Info-current-node node))
56866
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
1845 (progn (Info-find-node file node) (sit-for 0))))
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
1846
60615
643e6516a779 (Info-isearch-initial-node): New internal variable.
Juri Linkov <juri@jurta.org>
parents: 60577
diff changeset
1847 (defun Info-isearch-start ()
643e6516a779 (Info-isearch-initial-node): New internal variable.
Juri Linkov <juri@jurta.org>
parents: 60577
diff changeset
1848 (setq Info-isearch-initial-node nil))
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1849
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1850 (defun Info-extract-pointer (name &optional errorname)
29621
f03c3a69a809 Doc fixes.
Dave Love <fx@gnu.org>
parents: 29583
diff changeset
1851 "Extract the value of the node-pointer named NAME.
f03c3a69a809 Doc fixes.
Dave Love <fx@gnu.org>
parents: 29583
diff changeset
1852 If there is none, use ERRORNAME in the error message;
51735
204ae43066d1 (Info-following-node-name-re): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51731
diff changeset
1853 if ERRORNAME is nil, just return nil."
204ae43066d1 (Info-following-node-name-re): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51731
diff changeset
1854 ;; Bind this in case the user sets it to nil.
22951
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
1855 (let ((case-fold-search t))
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
1856 (save-excursion
51735
204ae43066d1 (Info-following-node-name-re): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51731
diff changeset
1857 (goto-char (point-min))
204ae43066d1 (Info-following-node-name-re): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51731
diff changeset
1858 (let ((bound (point)))
204ae43066d1 (Info-following-node-name-re): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51731
diff changeset
1859 (forward-line 1)
204ae43066d1 (Info-following-node-name-re): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51731
diff changeset
1860 (cond ((re-search-backward
204ae43066d1 (Info-following-node-name-re): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51731
diff changeset
1861 (concat name ":" (Info-following-node-name-re)) bound t)
68980
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
1862 (match-string-no-properties 1))
51735
204ae43066d1 (Info-following-node-name-re): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51731
diff changeset
1863 ((not (eq errorname t))
204ae43066d1 (Info-following-node-name-re): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51731
diff changeset
1864 (error "Node has no %s"
204ae43066d1 (Info-following-node-name-re): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51731
diff changeset
1865 (capitalize (or errorname name)))))))))
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1866
51735
204ae43066d1 (Info-following-node-name-re): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51731
diff changeset
1867 (defun Info-following-node-name-re (&optional allowedchars)
204ae43066d1 (Info-following-node-name-re): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51731
diff changeset
1868 "Return a regexp matching a node name.
29621
f03c3a69a809 Doc fixes.
Dave Love <fx@gnu.org>
parents: 29583
diff changeset
1869 ALLOWEDCHARS, if non-nil, goes within [...] to make a regexp
51735
204ae43066d1 (Info-following-node-name-re): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51731
diff changeset
1870 saying which chars may appear in the node name.
204ae43066d1 (Info-following-node-name-re): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51731
diff changeset
1871 Submatch 1 is the complete node name.
204ae43066d1 (Info-following-node-name-re): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51731
diff changeset
1872 Submatch 2 if non-nil is the parenthesized file name part of the node name.
204ae43066d1 (Info-following-node-name-re): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51731
diff changeset
1873 Submatch 3 is the local part of the node name.
204ae43066d1 (Info-following-node-name-re): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51731
diff changeset
1874 End of submatch 0, 1, and 3 are the same, so you can safely concat."
204ae43066d1 (Info-following-node-name-re): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51731
diff changeset
1875 (concat "[ \t]*" ;Skip leading space.
204ae43066d1 (Info-following-node-name-re): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51731
diff changeset
1876 "\\(\\(([^)]+)\\)?" ;Node name can start with a file name.
204ae43066d1 (Info-following-node-name-re): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51731
diff changeset
1877 "\\([" (or allowedchars "^,\t\n") "]*" ;Any number of allowed chars.
204ae43066d1 (Info-following-node-name-re): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51731
diff changeset
1878 "[" (or allowedchars "^,\t\n") " ]" ;The last char can't be a space.
204ae43066d1 (Info-following-node-name-re): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51731
diff changeset
1879 "\\|\\)\\)")) ;Allow empty node names.
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1880
52756
371ac8b3328e (Info-following-node-name): New function.
Richard M. Stallman <rms@gnu.org>
parents: 52688
diff changeset
1881 ;;; For compatibility; other files have used this name.
371ac8b3328e (Info-following-node-name): New function.
Richard M. Stallman <rms@gnu.org>
parents: 52688
diff changeset
1882 (defun Info-following-node-name ()
371ac8b3328e (Info-following-node-name): New function.
Richard M. Stallman <rms@gnu.org>
parents: 52688
diff changeset
1883 (and (looking-at (Info-following-node-name-re))
68980
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
1884 (match-string-no-properties 1)))
52756
371ac8b3328e (Info-following-node-name): New function.
Richard M. Stallman <rms@gnu.org>
parents: 52688
diff changeset
1885
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1886 (defun Info-next ()
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1887 "Go to the next node of this node."
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1888 (interactive)
65825
b89d9c4d5386 * info.el (Info-next, Info-prev, Info-up): Select info buffer, in
Chong Yidong <cyd@stupidchicken.com>
parents: 65780
diff changeset
1889 ;; In case another window is currently selected
b89d9c4d5386 * info.el (Info-next, Info-prev, Info-up): Select info buffer, in
Chong Yidong <cyd@stupidchicken.com>
parents: 65780
diff changeset
1890 (save-window-excursion
b89d9c4d5386 * info.el (Info-next, Info-prev, Info-up): Select info buffer, in
Chong Yidong <cyd@stupidchicken.com>
parents: 65780
diff changeset
1891 (or (eq major-mode 'Info-mode) (pop-to-buffer "*info*"))
b89d9c4d5386 * info.el (Info-next, Info-prev, Info-up): Select info buffer, in
Chong Yidong <cyd@stupidchicken.com>
parents: 65780
diff changeset
1892 (Info-goto-node (Info-extract-pointer "next"))))
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1893
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1894 (defun Info-prev ()
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1895 "Go to the previous node of this node."
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1896 (interactive)
65825
b89d9c4d5386 * info.el (Info-next, Info-prev, Info-up): Select info buffer, in
Chong Yidong <cyd@stupidchicken.com>
parents: 65780
diff changeset
1897 ;; In case another window is currently selected
b89d9c4d5386 * info.el (Info-next, Info-prev, Info-up): Select info buffer, in
Chong Yidong <cyd@stupidchicken.com>
parents: 65780
diff changeset
1898 (save-window-excursion
b89d9c4d5386 * info.el (Info-next, Info-prev, Info-up): Select info buffer, in
Chong Yidong <cyd@stupidchicken.com>
parents: 65780
diff changeset
1899 (or (eq major-mode 'Info-mode) (pop-to-buffer "*info*"))
b89d9c4d5386 * info.el (Info-next, Info-prev, Info-up): Select info buffer, in
Chong Yidong <cyd@stupidchicken.com>
parents: 65780
diff changeset
1900 (Info-goto-node (Info-extract-pointer "prev[ious]*" "previous"))))
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1901
21910
702383d93b75 (Info-up): New arg SAME-FILE: don't move to different file.
Richard M. Stallman <rms@gnu.org>
parents: 21806
diff changeset
1902 (defun Info-up (&optional same-file)
702383d93b75 (Info-up): New arg SAME-FILE: don't move to different file.
Richard M. Stallman <rms@gnu.org>
parents: 21806
diff changeset
1903 "Go to the superior node of this node.
702383d93b75 (Info-up): New arg SAME-FILE: don't move to different file.
Richard M. Stallman <rms@gnu.org>
parents: 21806
diff changeset
1904 If SAME-FILE is non-nil, do not move to a different Info file."
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1905 (interactive)
65825
b89d9c4d5386 * info.el (Info-next, Info-prev, Info-up): Select info buffer, in
Chong Yidong <cyd@stupidchicken.com>
parents: 65780
diff changeset
1906 ;; In case another window is currently selected
b89d9c4d5386 * info.el (Info-next, Info-prev, Info-up): Select info buffer, in
Chong Yidong <cyd@stupidchicken.com>
parents: 65780
diff changeset
1907 (save-window-excursion
b89d9c4d5386 * info.el (Info-next, Info-prev, Info-up): Select info buffer, in
Chong Yidong <cyd@stupidchicken.com>
parents: 65780
diff changeset
1908 (or (eq major-mode 'Info-mode) (pop-to-buffer "*info*"))
b89d9c4d5386 * info.el (Info-next, Info-prev, Info-up): Select info buffer, in
Chong Yidong <cyd@stupidchicken.com>
parents: 65780
diff changeset
1909 (let ((old-node Info-current-node)
b89d9c4d5386 * info.el (Info-next, Info-prev, Info-up): Select info buffer, in
Chong Yidong <cyd@stupidchicken.com>
parents: 65780
diff changeset
1910 (old-file Info-current-file)
b89d9c4d5386 * info.el (Info-next, Info-prev, Info-up): Select info buffer, in
Chong Yidong <cyd@stupidchicken.com>
parents: 65780
diff changeset
1911 (node (Info-extract-pointer "up")) p)
67121
f354001864bf * info.el (Info-on-current-buffer): Record actual filename in
Chong Yidong <cyd@stupidchicken.com>
parents: 67109
diff changeset
1912 (and same-file
65825
b89d9c4d5386 * info.el (Info-next, Info-prev, Info-up): Select info buffer, in
Chong Yidong <cyd@stupidchicken.com>
parents: 65780
diff changeset
1913 (string-match "^(" node)
b89d9c4d5386 * info.el (Info-next, Info-prev, Info-up): Select info buffer, in
Chong Yidong <cyd@stupidchicken.com>
parents: 65780
diff changeset
1914 (error "Up node is in another Info file"))
b89d9c4d5386 * info.el (Info-next, Info-prev, Info-up): Select info buffer, in
Chong Yidong <cyd@stupidchicken.com>
parents: 65780
diff changeset
1915 (Info-goto-node node)
b89d9c4d5386 * info.el (Info-next, Info-prev, Info-up): Select info buffer, in
Chong Yidong <cyd@stupidchicken.com>
parents: 65780
diff changeset
1916 (setq p (point))
b89d9c4d5386 * info.el (Info-next, Info-prev, Info-up): Select info buffer, in
Chong Yidong <cyd@stupidchicken.com>
parents: 65780
diff changeset
1917 (goto-char (point-min))
68980
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
1918 (if (and (stringp old-file)
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
1919 (search-forward "\n* Menu:" nil t)
65825
b89d9c4d5386 * info.el (Info-next, Info-prev, Info-up): Select info buffer, in
Chong Yidong <cyd@stupidchicken.com>
parents: 65780
diff changeset
1920 (re-search-forward
b89d9c4d5386 * info.el (Info-next, Info-prev, Info-up): Select info buffer, in
Chong Yidong <cyd@stupidchicken.com>
parents: 65780
diff changeset
1921 (if (string-equal old-node "Top")
b89d9c4d5386 * info.el (Info-next, Info-prev, Info-up): Select info buffer, in
Chong Yidong <cyd@stupidchicken.com>
parents: 65780
diff changeset
1922 (concat "\n\\*[^:]+: +(" (file-name-nondirectory old-file) ")")
b89d9c4d5386 * info.el (Info-next, Info-prev, Info-up): Select info buffer, in
Chong Yidong <cyd@stupidchicken.com>
parents: 65780
diff changeset
1923 (concat "\n\\* +\\(" (regexp-quote old-node)
b89d9c4d5386 * info.el (Info-next, Info-prev, Info-up): Select info buffer, in
Chong Yidong <cyd@stupidchicken.com>
parents: 65780
diff changeset
1924 ":\\|[^:]+: +" (regexp-quote old-node) "\\)"))
b89d9c4d5386 * info.el (Info-next, Info-prev, Info-up): Select info buffer, in
Chong Yidong <cyd@stupidchicken.com>
parents: 65780
diff changeset
1925 nil t))
b89d9c4d5386 * info.el (Info-next, Info-prev, Info-up): Select info buffer, in
Chong Yidong <cyd@stupidchicken.com>
parents: 65780
diff changeset
1926 (progn (beginning-of-line) (if (looking-at "^\\* ") (forward-char 2)))
b89d9c4d5386 * info.el (Info-next, Info-prev, Info-up): Select info buffer, in
Chong Yidong <cyd@stupidchicken.com>
parents: 65780
diff changeset
1927 (goto-char p)
b89d9c4d5386 * info.el (Info-next, Info-prev, Info-up): Select info buffer, in
Chong Yidong <cyd@stupidchicken.com>
parents: 65780
diff changeset
1928 (Info-restore-point Info-history)))))
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1929
59472
1e81e65f3201 (Info-history-forward): New variable.
Juri Linkov <juri@jurta.org>
parents: 59423
diff changeset
1930 (defun Info-history-back ()
1e81e65f3201 (Info-history-forward): New variable.
Juri Linkov <juri@jurta.org>
parents: 59423
diff changeset
1931 "Go back in the history to the last node visited."
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1932 (interactive)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1933 (or Info-history
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1934 (error "This is the first Info node you looked at"))
59472
1e81e65f3201 (Info-history-forward): New variable.
Juri Linkov <juri@jurta.org>
parents: 59423
diff changeset
1935 (let ((history-forward
1e81e65f3201 (Info-history-forward): New variable.
Juri Linkov <juri@jurta.org>
parents: 59423
diff changeset
1936 (cons (list Info-current-file Info-current-node (point))
1e81e65f3201 (Info-history-forward): New variable.
Juri Linkov <juri@jurta.org>
parents: 59423
diff changeset
1937 Info-history-forward))
1e81e65f3201 (Info-history-forward): New variable.
Juri Linkov <juri@jurta.org>
parents: 59423
diff changeset
1938 filename nodename opoint)
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1939 (setq filename (car (car Info-history)))
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1940 (setq nodename (car (cdr (car Info-history))))
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1941 (setq opoint (car (cdr (cdr (car Info-history)))))
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1942 (setq Info-history (cdr Info-history))
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1943 (Info-find-node filename nodename)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1944 (setq Info-history (cdr Info-history))
59472
1e81e65f3201 (Info-history-forward): New variable.
Juri Linkov <juri@jurta.org>
parents: 59423
diff changeset
1945 (setq Info-history-forward history-forward)
1e81e65f3201 (Info-history-forward): New variable.
Juri Linkov <juri@jurta.org>
parents: 59423
diff changeset
1946 (goto-char opoint)))
1e81e65f3201 (Info-history-forward): New variable.
Juri Linkov <juri@jurta.org>
parents: 59423
diff changeset
1947
1e81e65f3201 (Info-history-forward): New variable.
Juri Linkov <juri@jurta.org>
parents: 59423
diff changeset
1948 (defalias 'Info-last 'Info-history-back)
1e81e65f3201 (Info-history-forward): New variable.
Juri Linkov <juri@jurta.org>
parents: 59423
diff changeset
1949
1e81e65f3201 (Info-history-forward): New variable.
Juri Linkov <juri@jurta.org>
parents: 59423
diff changeset
1950 (defun Info-history-forward ()
1e81e65f3201 (Info-history-forward): New variable.
Juri Linkov <juri@jurta.org>
parents: 59423
diff changeset
1951 "Go forward in the history of visited nodes."
1e81e65f3201 (Info-history-forward): New variable.
Juri Linkov <juri@jurta.org>
parents: 59423
diff changeset
1952 (interactive)
1e81e65f3201 (Info-history-forward): New variable.
Juri Linkov <juri@jurta.org>
parents: 59423
diff changeset
1953 (or Info-history-forward
1e81e65f3201 (Info-history-forward): New variable.
Juri Linkov <juri@jurta.org>
parents: 59423
diff changeset
1954 (error "This is the last Info node you looked at"))
1e81e65f3201 (Info-history-forward): New variable.
Juri Linkov <juri@jurta.org>
parents: 59423
diff changeset
1955 (let ((history-forward (cdr Info-history-forward))
1e81e65f3201 (Info-history-forward): New variable.
Juri Linkov <juri@jurta.org>
parents: 59423
diff changeset
1956 filename nodename opoint)
1e81e65f3201 (Info-history-forward): New variable.
Juri Linkov <juri@jurta.org>
parents: 59423
diff changeset
1957 (setq filename (car (car Info-history-forward)))
1e81e65f3201 (Info-history-forward): New variable.
Juri Linkov <juri@jurta.org>
parents: 59423
diff changeset
1958 (setq nodename (car (cdr (car Info-history-forward))))
1e81e65f3201 (Info-history-forward): New variable.
Juri Linkov <juri@jurta.org>
parents: 59423
diff changeset
1959 (setq opoint (car (cdr (cdr (car Info-history-forward)))))
1e81e65f3201 (Info-history-forward): New variable.
Juri Linkov <juri@jurta.org>
parents: 59423
diff changeset
1960 (Info-find-node filename nodename)
1e81e65f3201 (Info-history-forward): New variable.
Juri Linkov <juri@jurta.org>
parents: 59423
diff changeset
1961 (setq Info-history-forward history-forward)
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1962 (goto-char opoint)))
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1963
28558
3fb49903ed9d Add debug-ignored-errors.
Dave Love <fx@gnu.org>
parents: 28168
diff changeset
1964 ;;;###autoload
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1965 (defun Info-directory ()
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1966 "Go to the Info directory node."
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1967 (interactive)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1968 (Info-find-node "dir" "top"))
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1969
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
1970 (defun Info-history ()
55074
dd4c270b21af Restore 2004-04-18 changes.
Juri Linkov <juri@jurta.org>
parents: 55061
diff changeset
1971 "Go to a node with a menu of visited nodes."
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
1972 (interactive)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
1973 (let ((curr-file Info-current-file)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
1974 (curr-node Info-current-node)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
1975 p)
55074
dd4c270b21af Restore 2004-04-18 changes.
Juri Linkov <juri@jurta.org>
parents: 55061
diff changeset
1976 (with-current-buffer (get-buffer-create " *info-history*")
dd4c270b21af Restore 2004-04-18 changes.
Juri Linkov <juri@jurta.org>
parents: 55061
diff changeset
1977 (let ((inhibit-read-only t))
dd4c270b21af Restore 2004-04-18 changes.
Juri Linkov <juri@jurta.org>
parents: 55061
diff changeset
1978 (erase-buffer)
dd4c270b21af Restore 2004-04-18 changes.
Juri Linkov <juri@jurta.org>
parents: 55061
diff changeset
1979 (goto-char (point-min))
57329
52649ba67540 (Info-history, Info-toc): Fix Info headers.
Juri Linkov <juri@jurta.org>
parents: 56991
diff changeset
1980 (insert "\n\^_\nFile: history, Node: Top, Up: (dir)\n\n")
55074
dd4c270b21af Restore 2004-04-18 changes.
Juri Linkov <juri@jurta.org>
parents: 55061
diff changeset
1981 (insert "Recently Visited Nodes\n**********************\n\n")
dd4c270b21af Restore 2004-04-18 changes.
Juri Linkov <juri@jurta.org>
parents: 55061
diff changeset
1982 (insert "* Menu:\n\n")
dd4c270b21af Restore 2004-04-18 changes.
Juri Linkov <juri@jurta.org>
parents: 55061
diff changeset
1983 (let ((hl (delete '("history" "Top") Info-history-list)))
dd4c270b21af Restore 2004-04-18 changes.
Juri Linkov <juri@jurta.org>
parents: 55061
diff changeset
1984 (while hl
dd4c270b21af Restore 2004-04-18 changes.
Juri Linkov <juri@jurta.org>
parents: 55061
diff changeset
1985 (let ((file (nth 0 (car hl)))
dd4c270b21af Restore 2004-04-18 changes.
Juri Linkov <juri@jurta.org>
parents: 55061
diff changeset
1986 (node (nth 1 (car hl))))
68980
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
1987 (if (and (equal file curr-file)
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
1988 (equal node curr-node))
55074
dd4c270b21af Restore 2004-04-18 changes.
Juri Linkov <juri@jurta.org>
parents: 55061
diff changeset
1989 (setq p (point)))
68980
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
1990 (if (stringp file)
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
1991 (insert "* " node ": ("
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
1992 (propertize (or (file-name-directory file) "") 'invisible t)
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
1993 (file-name-nondirectory file)
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
1994 ")" node ".\n")))
55074
dd4c270b21af Restore 2004-04-18 changes.
Juri Linkov <juri@jurta.org>
parents: 55061
diff changeset
1995 (setq hl (cdr hl))))))
68980
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
1996 (Info-find-node 'history "Top")
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
1997 (goto-char (or p (point-min)))))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
1998
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
1999 (defun Info-toc ()
56044
7aad97855e39 (Info-goto-node): Add autoload.
Juri Linkov <juri@jurta.org>
parents: 55797
diff changeset
2000 "Go to a node with table of contents of the current Info file.
7aad97855e39 (Info-goto-node): Add autoload.
Juri Linkov <juri@jurta.org>
parents: 55797
diff changeset
2001 Table of contents is created from the tree structure of menus."
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2002 (interactive)
68980
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
2003 (if (stringp Info-current-file)
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
2004 (let ((curr-file (substring-no-properties Info-current-file))
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
2005 (curr-node (substring-no-properties Info-current-node))
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
2006 p)
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
2007 (with-current-buffer (get-buffer-create " *info-toc*")
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
2008 (let ((inhibit-read-only t)
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
2009 (node-list (Info-build-toc curr-file)))
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
2010 (erase-buffer)
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
2011 (goto-char (point-min))
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
2012 (insert "\n\^_\nFile: toc, Node: Top, Up: (dir)\n\n")
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
2013 (insert "Table of Contents\n*****************\n\n")
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
2014 (insert "*Note Top: (" curr-file ")Top.\n")
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
2015 (Info-insert-toc
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
2016 (nth 2 (assoc "Top" node-list)) ; get Top nodes
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
2017 node-list 0 curr-file))
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
2018 (if (not (bobp))
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
2019 (let ((Info-hide-note-references 'hide)
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
2020 (Info-fontify-visited-nodes nil))
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
2021 (Info-mode)
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
2022 (setq Info-current-file 'toc Info-current-node "Top")
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
2023 (goto-char (point-min))
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
2024 (narrow-to-region (or (re-search-forward "\n[\^_\f]\n" nil t)
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
2025 (point-min))
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
2026 (point-max))
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
2027 (Info-fontify-node)
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
2028 (widen)))
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
2029 (goto-char (point-min))
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
2030 (if (setq p (search-forward (concat "*Note " curr-node ":") nil t))
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
2031 (setq p (- p (length curr-node) 2))))
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
2032 (Info-find-node 'toc "Top")
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
2033 (goto-char (or p (point-min))))))
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2034
55074
dd4c270b21af Restore 2004-04-18 changes.
Juri Linkov <juri@jurta.org>
parents: 55061
diff changeset
2035 (defun Info-insert-toc (nodes node-list level curr-file)
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2036 "Insert table of contents with references to nodes."
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2037 (let ((section "Top"))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2038 (while nodes
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2039 (let ((node (assoc (car nodes) node-list)))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2040 (unless (member (nth 1 node) (list nil section))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2041 (insert (setq section (nth 1 node)) "\n"))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2042 (insert (make-string level ?\t))
55074
dd4c270b21af Restore 2004-04-18 changes.
Juri Linkov <juri@jurta.org>
parents: 55061
diff changeset
2043 (insert "*Note " (car nodes) ": (" curr-file ")" (car nodes) ".\n")
dd4c270b21af Restore 2004-04-18 changes.
Juri Linkov <juri@jurta.org>
parents: 55061
diff changeset
2044 (Info-insert-toc (nth 2 node) node-list (1+ level) curr-file)
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2045 (setq nodes (cdr nodes))))))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2046
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2047 (defun Info-build-toc (file)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2048 "Build table of contents from menus of Info FILE and its subfiles."
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2049 (with-temp-buffer
57329
52649ba67540 (Info-history, Info-toc): Fix Info headers.
Juri Linkov <juri@jurta.org>
parents: 56991
diff changeset
2050 (let* ((file (and (stringp file) (Info-find-file file)))
52649ba67540 (Info-history, Info-toc): Fix Info headers.
Juri Linkov <juri@jurta.org>
parents: 56991
diff changeset
2051 (default-directory (or (and (stringp file)
52649ba67540 (Info-history, Info-toc): Fix Info headers.
Juri Linkov <juri@jurta.org>
parents: 56991
diff changeset
2052 (file-name-directory file))
55751
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2053 default-directory))
57329
52649ba67540 (Info-history, Info-toc): Fix Info headers.
Juri Linkov <juri@jurta.org>
parents: 56991
diff changeset
2054 (main-file (and (stringp file) file))
55751
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2055 (sections '(("Top" "Top")))
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2056 nodes subfiles)
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2057 (while (or main-file subfiles)
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2058 (or main-file (message "Searching subfile %s..." (car subfiles)))
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2059 (erase-buffer)
55751
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2060 (info-insert-file-contents (or main-file (car subfiles)))
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2061 (goto-char (point-min))
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2062 (while (and (search-forward "\n\^_\nFile:" nil 'move)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2063 (search-forward "Node: " nil 'move))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2064 (let ((nodename (substring-no-properties (Info-following-node-name)))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2065 (bound (- (or (save-excursion (search-forward "\n\^_" nil t))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2066 (point-max)) 2))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2067 (section "Top")
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2068 menu-items)
55751
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2069 (when (and (not (Info-index-node nodename file))
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2070 (re-search-forward "^\\* Menu:" bound t))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2071 (forward-line 1)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2072 (beginning-of-line)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2073 (setq bound (or (and (equal nodename "Top")
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2074 (save-excursion
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2075 (re-search-forward
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2076 "^[ \t-]*The Detailed Node Listing" nil t)))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2077 bound))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2078 (while (< (point) bound)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2079 (cond
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2080 ;; Menu item line
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2081 ((looking-at "^\\* +[^:]+:")
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2082 (beginning-of-line)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2083 (forward-char 2)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2084 (let ((menu-node-name (substring-no-properties
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2085 (Info-extract-menu-node-name))))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2086 (setq menu-items (cons menu-node-name menu-items))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2087 (if (equal nodename "Top")
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2088 (setq sections
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2089 (cons (list menu-node-name section) sections)))))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2090 ;; Other non-empty strings in the Top node are section names
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2091 ((and (equal nodename "Top")
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2092 (looking-at "^\\([^ \t\n*=.-][^:\n]*\\)"))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2093 (setq section (match-string-no-properties 1))))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2094 (forward-line 1)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2095 (beginning-of-line)))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2096 (setq nodes (cons (list nodename
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2097 (cadr (assoc nodename sections))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2098 (nreverse menu-items))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2099 nodes))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2100 (goto-char bound)))
55751
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2101 (if main-file
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2102 (save-excursion
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2103 (goto-char (point-min))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2104 (if (search-forward "\n\^_\nIndirect:" nil t)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2105 (let ((bound (save-excursion (search-forward "\n\^_" nil t))))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2106 (while (re-search-forward "^\\(.*\\): [0-9]+$" bound t)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2107 (setq subfiles (cons (match-string-no-properties 1)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2108 subfiles)))))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2109 (setq subfiles (nreverse subfiles)
55751
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2110 main-file nil))
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2111 (setq subfiles (cdr subfiles))))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2112 (message "")
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2113 (nreverse nodes))))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2114
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2115 (defun Info-follow-reference (footnotename &optional fork)
29621
f03c3a69a809 Doc fixes.
Dave Love <fx@gnu.org>
parents: 29583
diff changeset
2116 "Follow cross reference named FOOTNOTENAME to the node it refers to.
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2117 FOOTNOTENAME may be an abbreviation of the reference name.
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2118 If FORK is non-nil (interactively with a prefix arg), show the node in
64812
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
2119 a new Info buffer. If FORK is a string, it is the name to use for the
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2120 new buffer."
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2121 (interactive
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2122 (let ((completion-ignore-case t)
22951
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
2123 (case-fold-search t)
5555
38f8bfd91cca (Info-follow-reference): If point is not in middle of a
Richard M. Stallman <rms@gnu.org>
parents: 5482
diff changeset
2124 completions default alt-default (start-point (point)) str i bol eol)
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2125 (save-excursion
5555
38f8bfd91cca (Info-follow-reference): If point is not in middle of a
Richard M. Stallman <rms@gnu.org>
parents: 5482
diff changeset
2126 ;; Store end and beginning of line.
38f8bfd91cca (Info-follow-reference): If point is not in middle of a
Richard M. Stallman <rms@gnu.org>
parents: 5482
diff changeset
2127 (end-of-line)
38f8bfd91cca (Info-follow-reference): If point is not in middle of a
Richard M. Stallman <rms@gnu.org>
parents: 5482
diff changeset
2128 (setq eol (point))
38f8bfd91cca (Info-follow-reference): If point is not in middle of a
Richard M. Stallman <rms@gnu.org>
parents: 5482
diff changeset
2129 (beginning-of-line)
38f8bfd91cca (Info-follow-reference): If point is not in middle of a
Richard M. Stallman <rms@gnu.org>
parents: 5482
diff changeset
2130 (setq bol (point))
38f8bfd91cca (Info-follow-reference): If point is not in middle of a
Richard M. Stallman <rms@gnu.org>
parents: 5482
diff changeset
2131
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2132 (goto-char (point-min))
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2133 (while (re-search-forward "\\*note[ \n\t]+\\([^:]*\\):" nil t)
51735
204ae43066d1 (Info-following-node-name-re): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51731
diff changeset
2134 (setq str (match-string-no-properties 1))
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2135 ;; See if this one should be the default.
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2136 (and (null default)
5146
aa2236a14893 (Info-follow-reference): Correct one-off error in comparing start-point.
Richard M. Stallman <rms@gnu.org>
parents: 5091
diff changeset
2137 (<= (match-beginning 0) start-point)
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2138 (<= start-point (point))
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2139 (setq default t))
5555
38f8bfd91cca (Info-follow-reference): If point is not in middle of a
Richard M. Stallman <rms@gnu.org>
parents: 5482
diff changeset
2140 ;; See if this one should be the alternate default.
38f8bfd91cca (Info-follow-reference): If point is not in middle of a
Richard M. Stallman <rms@gnu.org>
parents: 5482
diff changeset
2141 (and (null alt-default)
38f8bfd91cca (Info-follow-reference): If point is not in middle of a
Richard M. Stallman <rms@gnu.org>
parents: 5482
diff changeset
2142 (and (<= bol (match-beginning 0))
38f8bfd91cca (Info-follow-reference): If point is not in middle of a
Richard M. Stallman <rms@gnu.org>
parents: 5482
diff changeset
2143 (<= (point) eol))
38f8bfd91cca (Info-follow-reference): If point is not in middle of a
Richard M. Stallman <rms@gnu.org>
parents: 5482
diff changeset
2144 (setq alt-default t))
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2145 (setq i 0)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2146 (while (setq i (string-match "[ \n\t]+" str i))
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2147 (setq str (concat (substring str 0 i) " "
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2148 (substring str (match-end 0))))
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2149 (setq i (1+ i)))
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2150 ;; Record as a completion and perhaps as default.
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2151 (if (eq default t) (setq default str))
5555
38f8bfd91cca (Info-follow-reference): If point is not in middle of a
Richard M. Stallman <rms@gnu.org>
parents: 5482
diff changeset
2152 (if (eq alt-default t) (setq alt-default str))
16609
21c4e4e580a9 (Info-follow-reference): Add each cross-reference to
Karl Heuer <kwzh@gnu.org>
parents: 16590
diff changeset
2153 ;; Don't add this string if it's a duplicate.
51735
204ae43066d1 (Info-following-node-name-re): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51731
diff changeset
2154 (or (assoc-string str completions t)
204ae43066d1 (Info-following-node-name-re): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51731
diff changeset
2155 (push str completions))))
5555
38f8bfd91cca (Info-follow-reference): If point is not in middle of a
Richard M. Stallman <rms@gnu.org>
parents: 5482
diff changeset
2156 ;; If no good default was found, try an alternate.
38f8bfd91cca (Info-follow-reference): If point is not in middle of a
Richard M. Stallman <rms@gnu.org>
parents: 5482
diff changeset
2157 (or default
38f8bfd91cca (Info-follow-reference): If point is not in middle of a
Richard M. Stallman <rms@gnu.org>
parents: 5482
diff changeset
2158 (setq default alt-default))
38f8bfd91cca (Info-follow-reference): If point is not in middle of a
Richard M. Stallman <rms@gnu.org>
parents: 5482
diff changeset
2159 ;; If only one cross-reference found, then make it default.
38f8bfd91cca (Info-follow-reference): If point is not in middle of a
Richard M. Stallman <rms@gnu.org>
parents: 5482
diff changeset
2160 (if (eq (length completions) 1)
51735
204ae43066d1 (Info-following-node-name-re): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51731
diff changeset
2161 (setq default (car completions)))
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2162 (if completions
3565
bd87ecca04f6 (Info-follow-reference): Fix completion defaulting.
Richard M. Stallman <rms@gnu.org>
parents: 3451
diff changeset
2163 (let ((input (completing-read (if default
39757
0597a7bc10a2 (Info-follow-reference): Display default values in prompts as
Miles Bader <miles@gnu.org>
parents: 39746
diff changeset
2164 (concat
65680
ed770a0a7846 2005-09-24 Emilio C. Lopes <eclig@gmx.net>
Romain Francoise <romain@orebokech.com>
parents: 65069
diff changeset
2165 "Follow reference named (default "
ed770a0a7846 2005-09-24 Emilio C. Lopes <eclig@gmx.net>
Romain Francoise <romain@orebokech.com>
parents: 65069
diff changeset
2166 default "): ")
3565
bd87ecca04f6 (Info-follow-reference): Fix completion defaulting.
Richard M. Stallman <rms@gnu.org>
parents: 3451
diff changeset
2167 "Follow reference named: ")
bd87ecca04f6 (Info-follow-reference): Fix completion defaulting.
Richard M. Stallman <rms@gnu.org>
parents: 3451
diff changeset
2168 completions nil t)))
bd87ecca04f6 (Info-follow-reference): Fix completion defaulting.
Richard M. Stallman <rms@gnu.org>
parents: 3451
diff changeset
2169 (list (if (equal input "")
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2170 default input) current-prefix-arg))
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2171 (error "No cross-references in this node"))))
23038
10ad03c5d326 (Info-follow-reference): Nice error msg if there was no arg.
Richard M. Stallman <rms@gnu.org>
parents: 23019
diff changeset
2172
10ad03c5d326 (Info-follow-reference): Nice error msg if there was no arg.
Richard M. Stallman <rms@gnu.org>
parents: 23019
diff changeset
2173 (unless footnotename
10ad03c5d326 (Info-follow-reference): Nice error msg if there was no arg.
Richard M. Stallman <rms@gnu.org>
parents: 23019
diff changeset
2174 (error "No reference was specified"))
10ad03c5d326 (Info-follow-reference): Nice error msg if there was no arg.
Richard M. Stallman <rms@gnu.org>
parents: 23019
diff changeset
2175
51434
4c85e6a5a9d2 (Info-mode-hook): Obey obsolete `Info-fontify'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51310
diff changeset
2176 (let (target i (str (concat "\\*note " (regexp-quote footnotename)))
22951
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
2177 (case-fold-search t))
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2178 (while (setq i (string-match " " str i))
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2179 (setq str (concat (substring str 0 i) "[ \t\n]+" (substring str (1+ i))))
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2180 (setq i (+ i 6)))
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2181 (save-excursion
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2182 ;; Move point to the beginning of reference if point is on reference
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2183 (or (looking-at "\\*note[ \n\t]+")
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2184 (and (looking-back "\\*note[ \n\t]+")
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2185 (goto-char (match-beginning 0)))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2186 (if (and (save-excursion
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2187 (goto-char (+ (point) 5)) ; skip a possible *note
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2188 (re-search-backward "\\*note[ \n\t]+" nil t)
55174
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
2189 (looking-at str))
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2190 (<= (point) (match-end 0)))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2191 (goto-char (match-beginning 0))))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2192 ;; Go to the reference closest to point
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2193 (let ((next-ref (save-excursion (and (re-search-forward str nil t)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2194 (+ (match-beginning 0) 5))))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2195 (prev-ref (save-excursion (and (re-search-backward str nil t)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2196 (+ (match-beginning 0) 5)))))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2197 (goto-char (cond ((and next-ref prev-ref)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2198 (if (< (abs (- next-ref (point)))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2199 (abs (- prev-ref (point))))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2200 next-ref prev-ref))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2201 ((or next-ref prev-ref))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2202 ((error "No cross-reference named %s" footnotename))))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2203 (setq target (Info-extract-menu-node-name t))))
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2204 (while (setq i (string-match "[ \t\n]+" target i))
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2205 (setq target (concat (substring target 0 i) " "
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2206 (substring target (match-end 0))))
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2207 (setq i (+ i 1)))
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2208 (Info-goto-node target fork)))
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2209
51943
4ab63324776e (Info-menu-entry-name-re): Allow newlines in menu entry names.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51805
diff changeset
2210 (defconst Info-menu-entry-name-re "\\(?:[^:]\\|:[^:,.;() \t\n]\\)*"
4ab63324776e (Info-menu-entry-name-re): Allow newlines in menu entry names.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51805
diff changeset
2211 ;; We allow newline because this is also used in Info-follow-reference,
4ab63324776e (Info-menu-entry-name-re): Allow newlines in menu entry names.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51805
diff changeset
2212 ;; where the xref name might be wrapped over two lines.
51735
204ae43066d1 (Info-following-node-name-re): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51731
diff changeset
2213 "Regexp that matches a menu entry name upto but not including the colon.
204ae43066d1 (Info-following-node-name-re): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51731
diff changeset
2214 Because of ambiguities, this should be concatenated with something like
204ae43066d1 (Info-following-node-name-re): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51731
diff changeset
2215 `:' and `Info-following-node-name-re'.")
204ae43066d1 (Info-following-node-name-re): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51731
diff changeset
2216
55174
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
2217 (defun Info-extract-menu-node-name (&optional multi-line index-node)
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2218 (skip-chars-forward " \t\n")
51735
204ae43066d1 (Info-following-node-name-re): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51731
diff changeset
2219 (when (looking-at (concat Info-menu-entry-name-re ":\\(:\\|"
204ae43066d1 (Info-following-node-name-re): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51731
diff changeset
2220 (Info-following-node-name-re
55174
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
2221 (cond
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
2222 (index-node "^,\t\n")
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
2223 (multi-line "^.,\t")
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
2224 (t "^.,\t\n")))
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
2225 "\\)"
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
2226 (if index-node
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
2227 "\\.\\(?:[ \t\n]+(line +\\([0-9]+\\))\\)?"
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
2228 "")))
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
2229 (if index-node
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
2230 (setq Info-point-loc
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
2231 (if (match-beginning 5)
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
2232 (string-to-number (match-string 5))
68980
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
2233 (buffer-substring-no-properties
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
2234 (match-beginning 0) (1- (match-beginning 1)))))
57770
c7ff2d3a33ee (Info-file-list-for-emacs): Add ("Info" . "info")
Juri Linkov <juri@jurta.org>
parents: 57672
diff changeset
2235 ;;; Uncomment next line to use names of cross-references in non-index nodes:
55174
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
2236 ;;; (setq Info-point-loc
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
2237 ;;; (buffer-substring (match-beginning 0) (1- (match-beginning 1))))
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
2238 )
51735
204ae43066d1 (Info-following-node-name-re): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51731
diff changeset
2239 (replace-regexp-in-string
204ae43066d1 (Info-following-node-name-re): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51731
diff changeset
2240 "[ \n]+" " "
68980
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
2241 (or (match-string-no-properties 2)
51735
204ae43066d1 (Info-following-node-name-re): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51731
diff changeset
2242 ;; If the node name is the menu entry name (using `entry::').
68980
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
2243 (buffer-substring-no-properties
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
2244 (match-beginning 0) (1- (match-beginning 1)))))))
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2245
7837
bad6366d4f16 (Info-complete-menu-item): New function.
Richard M. Stallman <rms@gnu.org>
parents: 7789
diff changeset
2246 ;; No one calls this.
1484
6c2a714566d3 Rename buffer-flush-undo to buffer-disable-undo.
Richard M. Stallman <rms@gnu.org>
parents: 1477
diff changeset
2247 ;;(defun Info-menu-item-sequence (list)
6c2a714566d3 Rename buffer-flush-undo to buffer-disable-undo.
Richard M. Stallman <rms@gnu.org>
parents: 1477
diff changeset
2248 ;; (while list
7837
bad6366d4f16 (Info-complete-menu-item): New function.
Richard M. Stallman <rms@gnu.org>
parents: 7789
diff changeset
2249 ;; (Info-menu (car list))
1484
6c2a714566d3 Rename buffer-flush-undo to buffer-disable-undo.
Richard M. Stallman <rms@gnu.org>
parents: 1477
diff changeset
2250 ;; (setq list (cdr list))))
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2251
22761
ad14990a5efc (Info-complete-menu-buffer): Add defvar.
Richard M. Stallman <rms@gnu.org>
parents: 22760
diff changeset
2252 (defvar Info-complete-menu-buffer)
41690
c9c839b993b9 (Info-complete-next-re, Info-complete-cache): New vars.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 40967
diff changeset
2253 (defvar Info-complete-next-re nil)
55751
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2254 (defvar Info-complete-nodes nil)
41690
c9c839b993b9 (Info-complete-next-re, Info-complete-cache): New vars.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 40967
diff changeset
2255 (defvar Info-complete-cache nil)
22761
ad14990a5efc (Info-complete-menu-buffer): Add defvar.
Richard M. Stallman <rms@gnu.org>
parents: 22760
diff changeset
2256
51735
204ae43066d1 (Info-following-node-name-re): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51731
diff changeset
2257 (defconst Info-node-spec-re
204ae43066d1 (Info-following-node-name-re): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51731
diff changeset
2258 (concat (Info-following-node-name-re "^.,:") "[,:.]")
51437
63b62b12e01c (Info-extract-menu-node-name): Remove unused arg `errmessage'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51436
diff changeset
2259 "Regexp to match the text after a : until the terminating `.'.")
63b62b12e01c (Info-extract-menu-node-name): Remove unused arg `errmessage'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51436
diff changeset
2260
7837
bad6366d4f16 (Info-complete-menu-item): New function.
Richard M. Stallman <rms@gnu.org>
parents: 7789
diff changeset
2261 (defun Info-complete-menu-item (string predicate action)
41798
b04cfaf9585d Add explanatory comment.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 41713
diff changeset
2262 ;; This uses two dynamically bound variables:
b04cfaf9585d Add explanatory comment.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 41713
diff changeset
2263 ;; - `Info-complete-menu-buffer' which contains the buffer in which
b04cfaf9585d Add explanatory comment.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 41713
diff changeset
2264 ;; is the menu of items we're trying to complete.
b04cfaf9585d Add explanatory comment.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 41713
diff changeset
2265 ;; - `Info-complete-next-re' which, if non-nil, indicates that we should
b04cfaf9585d Add explanatory comment.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 41713
diff changeset
2266 ;; also look for menu items in subsequent nodes as long as those
b04cfaf9585d Add explanatory comment.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 41713
diff changeset
2267 ;; nodes' names match `Info-complete-next-re'. This feature is currently
55751
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2268 ;; not used.
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2269 ;; - `Info-complete-nodes' which, if non-nil, indicates that we should
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2270 ;; also look for menu items in these nodes. This feature is currently
41798
b04cfaf9585d Add explanatory comment.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 41713
diff changeset
2271 ;; only used for completion in Info-index.
51517
46101da952e7 (Info-complete-menu-item): Revert change of 2003-06-03.
Lute Kamstra <lute@gnu.org>
parents: 51513
diff changeset
2272
46101da952e7 (Info-complete-menu-item): Revert change of 2003-06-03.
Lute Kamstra <lute@gnu.org>
parents: 51513
diff changeset
2273 ;; Note that `Info-complete-menu-buffer' could be current already,
46101da952e7 (Info-complete-menu-item): Revert change of 2003-06-03.
Lute Kamstra <lute@gnu.org>
parents: 51513
diff changeset
2274 ;; so we want to save point.
46101da952e7 (Info-complete-menu-item): Revert change of 2003-06-03.
Lute Kamstra <lute@gnu.org>
parents: 51513
diff changeset
2275 (save-excursion
46101da952e7 (Info-complete-menu-item): Revert change of 2003-06-03.
Lute Kamstra <lute@gnu.org>
parents: 51513
diff changeset
2276 (set-buffer Info-complete-menu-buffer)
41690
c9c839b993b9 (Info-complete-next-re, Info-complete-cache): New vars.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 40967
diff changeset
2277 (let ((completion-ignore-case t)
c9c839b993b9 (Info-complete-next-re, Info-complete-cache): New vars.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 40967
diff changeset
2278 (case-fold-search t)
c9c839b993b9 (Info-complete-next-re, Info-complete-cache): New vars.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 40967
diff changeset
2279 (orignode Info-current-node)
c9c839b993b9 (Info-complete-next-re, Info-complete-cache): New vars.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 40967
diff changeset
2280 nextnode)
c9c839b993b9 (Info-complete-next-re, Info-complete-cache): New vars.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 40967
diff changeset
2281 (goto-char (point-min))
c9c839b993b9 (Info-complete-next-re, Info-complete-cache): New vars.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 40967
diff changeset
2282 (search-forward "\n* Menu:")
c9c839b993b9 (Info-complete-next-re, Info-complete-cache): New vars.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 40967
diff changeset
2283 (if (not (memq action '(nil t)))
c9c839b993b9 (Info-complete-next-re, Info-complete-cache): New vars.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 40967
diff changeset
2284 (re-search-forward
c9c839b993b9 (Info-complete-next-re, Info-complete-cache): New vars.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 40967
diff changeset
2285 (concat "\n\\* +" (regexp-quote string) ":") nil t)
c9c839b993b9 (Info-complete-next-re, Info-complete-cache): New vars.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 40967
diff changeset
2286 (let ((pattern (concat "\n\\* +\\("
c9c839b993b9 (Info-complete-next-re, Info-complete-cache): New vars.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 40967
diff changeset
2287 (regexp-quote string)
51735
204ae43066d1 (Info-following-node-name-re): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51731
diff changeset
2288 Info-menu-entry-name-re "\\):" Info-node-spec-re))
67778
0c0bb618627a (info-other-window, info): Rename function argument
Juri Linkov <juri@jurta.org>
parents: 67623
diff changeset
2289 completions
0c0bb618627a (info-other-window, info): Rename function argument
Juri Linkov <juri@jurta.org>
parents: 67623
diff changeset
2290 (complete-nodes Info-complete-nodes))
41690
c9c839b993b9 (Info-complete-next-re, Info-complete-cache): New vars.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 40967
diff changeset
2291 ;; Check the cache.
c9c839b993b9 (Info-complete-next-re, Info-complete-cache): New vars.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 40967
diff changeset
2292 (if (and (equal (nth 0 Info-complete-cache) Info-current-file)
c9c839b993b9 (Info-complete-next-re, Info-complete-cache): New vars.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 40967
diff changeset
2293 (equal (nth 1 Info-complete-cache) Info-current-node)
c9c839b993b9 (Info-complete-next-re, Info-complete-cache): New vars.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 40967
diff changeset
2294 (equal (nth 2 Info-complete-cache) Info-complete-next-re)
55751
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2295 (equal (nth 5 Info-complete-cache) Info-complete-nodes)
41690
c9c839b993b9 (Info-complete-next-re, Info-complete-cache): New vars.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 40967
diff changeset
2296 (let ((prev (nth 3 Info-complete-cache)))
c9c839b993b9 (Info-complete-next-re, Info-complete-cache): New vars.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 40967
diff changeset
2297 (eq t (compare-strings string 0 (length prev)
c9c839b993b9 (Info-complete-next-re, Info-complete-cache): New vars.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 40967
diff changeset
2298 prev 0 nil t))))
c9c839b993b9 (Info-complete-next-re, Info-complete-cache): New vars.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 40967
diff changeset
2299 ;; We can reuse the previous list.
c9c839b993b9 (Info-complete-next-re, Info-complete-cache): New vars.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 40967
diff changeset
2300 (setq completions (nth 4 Info-complete-cache))
c9c839b993b9 (Info-complete-next-re, Info-complete-cache): New vars.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 40967
diff changeset
2301 ;; The cache can't be used.
c9c839b993b9 (Info-complete-next-re, Info-complete-cache): New vars.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 40967
diff changeset
2302 (while
c9c839b993b9 (Info-complete-next-re, Info-complete-cache): New vars.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 40967
diff changeset
2303 (progn
c9c839b993b9 (Info-complete-next-re, Info-complete-cache): New vars.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 40967
diff changeset
2304 (while (re-search-forward pattern nil t)
45014
a590e8ab89d0 (Info-find-in-tag-table-1, Info-read-subfile): Use point-min.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44902
diff changeset
2305 (push (match-string-no-properties 1)
41690
c9c839b993b9 (Info-complete-next-re, Info-complete-cache): New vars.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 40967
diff changeset
2306 completions))
c9c839b993b9 (Info-complete-next-re, Info-complete-cache): New vars.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 40967
diff changeset
2307 ;; Check subsequent nodes if applicable.
55751
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2308 (or (and Info-complete-next-re
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2309 (setq nextnode (Info-extract-pointer "next" t))
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2310 (string-match Info-complete-next-re nextnode))
67778
0c0bb618627a (info-other-window, info): Rename function argument
Juri Linkov <juri@jurta.org>
parents: 67623
diff changeset
2311 (and complete-nodes
0c0bb618627a (info-other-window, info): Rename function argument
Juri Linkov <juri@jurta.org>
parents: 67623
diff changeset
2312 (setq complete-nodes (cdr complete-nodes)
0c0bb618627a (info-other-window, info): Rename function argument
Juri Linkov <juri@jurta.org>
parents: 67623
diff changeset
2313 nextnode (car complete-nodes)))))
41690
c9c839b993b9 (Info-complete-next-re, Info-complete-cache): New vars.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 40967
diff changeset
2314 (Info-goto-node nextnode))
c9c839b993b9 (Info-complete-next-re, Info-complete-cache): New vars.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 40967
diff changeset
2315 ;; Go back to the start node (for the next completion).
c9c839b993b9 (Info-complete-next-re, Info-complete-cache): New vars.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 40967
diff changeset
2316 (unless (equal Info-current-node orignode)
c9c839b993b9 (Info-complete-next-re, Info-complete-cache): New vars.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 40967
diff changeset
2317 (Info-goto-node orignode))
c9c839b993b9 (Info-complete-next-re, Info-complete-cache): New vars.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 40967
diff changeset
2318 ;; Update the cache.
48977
ef739be93187 (Info-complete-menu-item): Make `Info-complete-cache' a buffer-local variable.
Miles Bader <miles@gnu.org>
parents: 48933
diff changeset
2319 (set (make-local-variable 'Info-complete-cache)
ef739be93187 (Info-complete-menu-item): Make `Info-complete-cache' a buffer-local variable.
Miles Bader <miles@gnu.org>
parents: 48933
diff changeset
2320 (list Info-current-file Info-current-node
55751
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2321 Info-complete-next-re string completions
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2322 Info-complete-nodes)))
41690
c9c839b993b9 (Info-complete-next-re, Info-complete-cache): New vars.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 40967
diff changeset
2323 (if action
c9c839b993b9 (Info-complete-next-re, Info-complete-cache): New vars.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 40967
diff changeset
2324 (all-completions string completions predicate)
c9c839b993b9 (Info-complete-next-re, Info-complete-cache): New vars.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 40967
diff changeset
2325 (try-completion string completions predicate)))))))
7837
bad6366d4f16 (Info-complete-menu-item): New function.
Richard M. Stallman <rms@gnu.org>
parents: 7789
diff changeset
2326
bad6366d4f16 (Info-complete-menu-item): New function.
Richard M. Stallman <rms@gnu.org>
parents: 7789
diff changeset
2327
26004
11f91800bec3 (Info-on-current-buffer): new entry point.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 25878
diff changeset
2328 (defun Info-menu (menu-item &optional fork)
39382
18515f20ccce (Info-goto-node, Info-menu): Doc fix. Suggested by
Eli Zaretskii <eliz@gnu.org>
parents: 39364
diff changeset
2329 "Go to the node pointed to by the menu item named (or abbreviated) MENU-ITEM.
18515f20ccce (Info-goto-node, Info-menu): Doc fix. Suggested by
Eli Zaretskii <eliz@gnu.org>
parents: 39364
diff changeset
2330 The menu item should one of those listed in the current node's menu.
18515f20ccce (Info-goto-node, Info-menu): Doc fix. Suggested by
Eli Zaretskii <eliz@gnu.org>
parents: 39364
diff changeset
2331 Completion is allowed, and the default menu item is the one point is on.
32286
c0b19a2770ca (Info-goto-node, Info-menu): Doc fix.
Dave Love <fx@gnu.org>
parents: 32007
diff changeset
2332 If FORK is non-nil (interactively with a prefix arg), show the node in
64812
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
2333 a new Info buffer. If FORK is a string, it is the name to use for the
32286
c0b19a2770ca (Info-goto-node, Info-menu): Doc fix.
Dave Love <fx@gnu.org>
parents: 32007
diff changeset
2334 new buffer."
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2335 (interactive
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2336 (let ((completions '())
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2337 ;; If point is within a menu item, use that item as the default
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2338 (default nil)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2339 (p (point))
10957
6d3568e33019 (Info-menu): Bind beg with let.
Richard M. Stallman <rms@gnu.org>
parents: 10918
diff changeset
2340 beg
29446
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2341 (last nil)
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2342 (case-fold-search t))
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2343 (save-excursion
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2344 (goto-char (point-min))
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2345 (if (not (search-forward "\n* menu:" nil t))
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2346 (error "No menu in this node"))
7837
bad6366d4f16 (Info-complete-menu-item): New function.
Richard M. Stallman <rms@gnu.org>
parents: 7789
diff changeset
2347 (setq beg (point))
bad6366d4f16 (Info-complete-menu-item): New function.
Richard M. Stallman <rms@gnu.org>
parents: 7789
diff changeset
2348 (and (< (point) p)
bad6366d4f16 (Info-complete-menu-item): New function.
Richard M. Stallman <rms@gnu.org>
parents: 7789
diff changeset
2349 (save-excursion
bad6366d4f16 (Info-complete-menu-item): New function.
Richard M. Stallman <rms@gnu.org>
parents: 7789
diff changeset
2350 (goto-char p)
bad6366d4f16 (Info-complete-menu-item): New function.
Richard M. Stallman <rms@gnu.org>
parents: 7789
diff changeset
2351 (end-of-line)
51784
abcb358beb61 (Info-menu): Use Info-menu-entry-name-re.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51760
diff changeset
2352 (if (re-search-backward (concat "\n\\* +\\("
abcb358beb61 (Info-menu): Use Info-menu-entry-name-re.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51760
diff changeset
2353 Info-menu-entry-name-re
abcb358beb61 (Info-menu): Use Info-menu-entry-name-re.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51760
diff changeset
2354 "\\):") beg t)
26580
d779cb4aa2ae (Info-build-node-completions, Info-search, Info-follow-reference)
Dave Love <fx@gnu.org>
parents: 26172
diff changeset
2355 (setq default (match-string-no-properties 1))))))
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2356 (let ((item nil))
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2357 (while (null item)
7837
bad6366d4f16 (Info-complete-menu-item): New function.
Richard M. Stallman <rms@gnu.org>
parents: 7789
diff changeset
2358 (setq item (let ((completion-ignore-case t)
bad6366d4f16 (Info-complete-menu-item): New function.
Richard M. Stallman <rms@gnu.org>
parents: 7789
diff changeset
2359 (Info-complete-menu-buffer (current-buffer)))
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2360 (completing-read (if default
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2361 (format "Menu item (default %s): "
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2362 default)
29446
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2363 "Menu item: ")
7837
bad6366d4f16 (Info-complete-menu-item): New function.
Richard M. Stallman <rms@gnu.org>
parents: 7789
diff changeset
2364 'Info-complete-menu-item nil t)))
540
0840eff2ecd5 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 359
diff changeset
2365 ;; we rely on the fact that completing-read accepts an input
0840eff2ecd5 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 359
diff changeset
2366 ;; of "" even when the require-match argument is true and ""
0840eff2ecd5 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 359
diff changeset
2367 ;; is not a valid possibility
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2368 (if (string= item "")
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2369 (if default
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2370 (setq item default)
29446
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2371 ;; ask again
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2372 (setq item nil))))
26004
11f91800bec3 (Info-on-current-buffer): new entry point.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 25878
diff changeset
2373 (list item current-prefix-arg))))
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2374 ;; there is a problem here in that if several menu items have the same
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2375 ;; name you can only go to the node of the first with this command.
26004
11f91800bec3 (Info-on-current-buffer): new entry point.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 25878
diff changeset
2376 (Info-goto-node (Info-extract-menu-item menu-item) (if fork menu-item)))
28943
36fd90774cf7 (debug-ignored-errors): more errors to ignore.
Sam Steingold <sds@gnu.org>
parents: 28559
diff changeset
2377
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2378 (defun Info-extract-menu-item (menu-item)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2379 (setq menu-item (regexp-quote menu-item))
22951
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
2380 (let ((case-fold-search t))
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
2381 (save-excursion
29446
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2382 (let ((case-fold-search t))
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2383 (goto-char (point-min))
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2384 (or (search-forward "\n* menu:" nil t)
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2385 (error "No menu in this node"))
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2386 (or (re-search-forward (concat "\n\\* +" menu-item ":") nil t)
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2387 (re-search-forward (concat "\n\\* +" menu-item) nil t)
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2388 (error "No such item in menu"))
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2389 (beginning-of-line)
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2390 (forward-char 2)
55751
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2391 (Info-extract-menu-node-name nil (Info-index-node))))))
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2392
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2393 ;; If COUNT is nil, use the last item in the menu.
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2394 (defun Info-extract-menu-counting (count)
22951
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
2395 (let ((case-fold-search t))
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
2396 (save-excursion
29446
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2397 (let ((case-fold-search t))
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2398 (goto-char (point-min))
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2399 (or (search-forward "\n* menu:" nil t)
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2400 (error "No menu in this node"))
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2401 (if count
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2402 (or (search-forward "\n* " nil t count)
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2403 (error "Too few items in menu"))
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2404 (while (search-forward "\n* " nil t)
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2405 nil))
55751
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2406 (Info-extract-menu-node-name nil (Info-index-node))))))
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2407
1666
c12fbca81b63 (Info-{first,second,third,fourth,fifth}-menu-item): Removed.
Roland McGrath <roland@gnu.org>
parents: 1613
diff changeset
2408 (defun Info-nth-menu-item ()
c12fbca81b63 (Info-{first,second,third,fourth,fifth}-menu-item): Removed.
Roland McGrath <roland@gnu.org>
parents: 1613
diff changeset
2409 "Go to the node of the Nth menu item.
c12fbca81b63 (Info-{first,second,third,fourth,fifth}-menu-item): Removed.
Roland McGrath <roland@gnu.org>
parents: 1613
diff changeset
2410 N is the digit argument used to invoke this command."
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2411 (interactive)
1666
c12fbca81b63 (Info-{first,second,third,fourth,fifth}-menu-item): Removed.
Roland McGrath <roland@gnu.org>
parents: 1613
diff changeset
2412 (Info-goto-node
c12fbca81b63 (Info-{first,second,third,fourth,fifth}-menu-item): Removed.
Roland McGrath <roland@gnu.org>
parents: 1613
diff changeset
2413 (Info-extract-menu-counting
c12fbca81b63 (Info-{first,second,third,fourth,fifth}-menu-item): Removed.
Roland McGrath <roland@gnu.org>
parents: 1613
diff changeset
2414 (- (aref (this-command-keys) (1- (length (this-command-keys)))) ?0))))
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2415
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2416 (defun Info-top-node ()
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2417 "Go to the Top node of this file."
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2418 (interactive)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2419 (Info-goto-node "Top"))
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2420
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2421 (defun Info-final-node ()
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2422 "Go to the final node in this file."
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2423 (interactive)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2424 (Info-goto-node "Top")
29446
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2425 (let ((Info-history nil)
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2426 (case-fold-search t))
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2427 ;; Go to the last node in the menu of Top.
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2428 (Info-goto-node (Info-extract-menu-counting nil))
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2429 ;; If the last node in the menu is not last in pointer structure,
28943
36fd90774cf7 (debug-ignored-errors): more errors to ignore.
Sam Steingold <sds@gnu.org>
parents: 28559
diff changeset
2430 ;; move forward until we can't go any farther.
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2431 (while (Info-forward-node t t) nil)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2432 ;; Then keep moving down to last subnode, unless we reach an index.
55751
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2433 (while (and (not (Info-index-node))
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2434 (save-excursion (search-forward "\n* Menu:" nil t)))
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2435 (Info-goto-node (Info-extract-menu-counting nil)))))
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2436
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2437 (defun Info-forward-node (&optional not-down no-error)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2438 "Go forward one node, considering all nodes as forming one sequence."
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2439 (interactive)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2440 (goto-char (point-min))
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2441 (forward-line 1)
29446
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2442 (let ((case-fold-search t))
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2443 ;; three possibilities, in order of priority:
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2444 ;; 1. next node is in a menu in this node (but not in an index)
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2445 ;; 2. next node is next at same level
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2446 ;; 3. next node is up and next
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2447 (cond ((and (not not-down)
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2448 (save-excursion (search-forward "\n* menu:" nil t))
55751
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2449 (not (Info-index-node)))
29446
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2450 (Info-goto-node (Info-extract-menu-counting 1))
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2451 t)
48135
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
2452 ((save-excursion (search-backward "next:" nil t))
29446
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2453 (Info-next)
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2454 t)
48135
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
2455 ((and (save-excursion (search-backward "up:" nil t))
29446
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2456 ;; Use string-equal, not equal, to ignore text props.
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2457 (not (string-equal (downcase (Info-extract-pointer "up"))
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2458 "top")))
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2459 (let ((old-node Info-current-node))
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2460 (Info-up)
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2461 (let (Info-history success)
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2462 (unwind-protect
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2463 (setq success (Info-forward-node t no-error))
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2464 (or success (Info-goto-node old-node))))))
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2465 (no-error nil)
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2466 (t (error "No pointer forward from this node")))))
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2467
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2468 (defun Info-backward-node ()
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2469 "Go backward one node, considering all nodes as forming one sequence."
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2470 (interactive)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2471 (let ((prevnode (Info-extract-pointer "prev[ious]*" t))
29446
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2472 (upnode (Info-extract-pointer "up" t))
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2473 (case-fold-search t))
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2474 (cond ((and upnode (string-match "(" upnode))
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2475 (error "First node in file"))
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2476 ((and upnode (or (null prevnode)
11527
7956811d4d9a (info-insert-file-contents): Set default-directory
Richard M. Stallman <rms@gnu.org>
parents: 11064
diff changeset
2477 ;; Use string-equal, not equal,
7956811d4d9a (info-insert-file-contents): Set default-directory
Richard M. Stallman <rms@gnu.org>
parents: 11064
diff changeset
2478 ;; to ignore text properties.
7956811d4d9a (info-insert-file-contents): Set default-directory
Richard M. Stallman <rms@gnu.org>
parents: 11064
diff changeset
2479 (string-equal (downcase prevnode)
7956811d4d9a (info-insert-file-contents): Set default-directory
Richard M. Stallman <rms@gnu.org>
parents: 11064
diff changeset
2480 (downcase upnode))))
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2481 (Info-up))
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2482 (prevnode
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2483 ;; If we move back at the same level,
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2484 ;; go down to find the last subnode*.
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2485 (Info-prev)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2486 (let (Info-history)
55751
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2487 (while (and (not (Info-index-node))
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2488 (save-excursion (search-forward "\n* Menu:" nil t)))
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2489 (Info-goto-node (Info-extract-menu-counting nil)))))
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2490 (t
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2491 (error "No pointer backward from this node")))))
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2492
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2493 (defun Info-exit ()
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2494 "Exit Info by selecting some other buffer."
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2495 (interactive)
4410
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
2496 (if Info-standalone
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
2497 (save-buffers-kill-emacs)
22331
fcc3db2d9778 (Info-exit): Use quit-window.
Karl Heuer <kwzh@gnu.org>
parents: 22067
diff changeset
2498 (quit-window)))
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2499
929
27262a6c632a *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 846
diff changeset
2500 (defun Info-next-menu-item ()
47794
c460856d1bfd (Info-next-menu-item, Info-last-menu-item)
John Paul Wallington <jpw@pobox.com>
parents: 47376
diff changeset
2501 "Go to the node of the next menu item."
929
27262a6c632a *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 846
diff changeset
2502 (interactive)
29621
f03c3a69a809 Doc fixes.
Dave Love <fx@gnu.org>
parents: 29583
diff changeset
2503 ;; Bind this in case the user sets it to nil.
29446
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2504 (let* ((case-fold-search t)
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2505 (node
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2506 (save-excursion
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2507 (forward-line -1)
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2508 (search-forward "\n* menu:" nil t)
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2509 (and (search-forward "\n* " nil t)
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2510 (Info-extract-menu-node-name)))))
23533
10a3478e3432 (Info-next-menu-item): Stay on top of node.
Richard M. Stallman <rms@gnu.org>
parents: 23416
diff changeset
2511 (if node (Info-goto-node node)
10a3478e3432 (Info-next-menu-item): Stay on top of node.
Richard M. Stallman <rms@gnu.org>
parents: 23416
diff changeset
2512 (error "No more items in menu"))))
929
27262a6c632a *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 846
diff changeset
2513
27262a6c632a *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 846
diff changeset
2514 (defun Info-last-menu-item ()
47794
c460856d1bfd (Info-next-menu-item, Info-last-menu-item)
John Paul Wallington <jpw@pobox.com>
parents: 47376
diff changeset
2515 "Go to the node of the previous menu item."
929
27262a6c632a *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 846
diff changeset
2516 (interactive)
27262a6c632a *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 846
diff changeset
2517 (save-excursion
27262a6c632a *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 846
diff changeset
2518 (forward-line 1)
29621
f03c3a69a809 Doc fixes.
Dave Love <fx@gnu.org>
parents: 29583
diff changeset
2519 ;; Bind this in case the user sets it to nil.
29446
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2520 (let* ((case-fold-search t)
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2521 (beg (save-excursion
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2522 (and (search-backward "\n* menu:" nil t)
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2523 (point)))))
8489
c6088e3005cf (Info-last-menu-item): Fix gross logic errors.
Richard M. Stallman <rms@gnu.org>
parents: 8480
diff changeset
2524 (or (and beg (search-backward "\n* " beg t))
c6088e3005cf (Info-last-menu-item): Fix gross logic errors.
Richard M. Stallman <rms@gnu.org>
parents: 8480
diff changeset
2525 (error "No previous items in menu")))
c6088e3005cf (Info-last-menu-item): Fix gross logic errors.
Richard M. Stallman <rms@gnu.org>
parents: 8480
diff changeset
2526 (Info-goto-node (save-excursion
c6088e3005cf (Info-last-menu-item): Fix gross logic errors.
Richard M. Stallman <rms@gnu.org>
parents: 8480
diff changeset
2527 (goto-char (match-end 0))
c6088e3005cf (Info-last-menu-item): Fix gross logic errors.
Richard M. Stallman <rms@gnu.org>
parents: 8480
diff changeset
2528 (Info-extract-menu-node-name)))))
929
27262a6c632a *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 846
diff changeset
2529
4410
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
2530 (defmacro Info-no-error (&rest body)
929
27262a6c632a *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 846
diff changeset
2531 (list 'condition-case nil (cons 'progn (append body '(t))) '(error nil)))
27262a6c632a *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 846
diff changeset
2532
27262a6c632a *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 846
diff changeset
2533 (defun Info-next-preorder ()
8018
518971c497f5 (Info-next-preorder-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 7990
diff changeset
2534 "Go to the next subnode or the next node, or go up a level."
518971c497f5 (Info-next-preorder-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 7990
diff changeset
2535 (interactive)
518971c497f5 (Info-next-preorder-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 7990
diff changeset
2536 (cond ((Info-no-error (Info-next-menu-item)))
518971c497f5 (Info-next-preorder-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 7990
diff changeset
2537 ((Info-no-error (Info-next)))
21910
702383d93b75 (Info-up): New arg SAME-FILE: don't move to different file.
Richard M. Stallman <rms@gnu.org>
parents: 21806
diff changeset
2538 ((Info-no-error (Info-up t))
12156
1620a60ab7ca (Info-mode): Doco fix.
Karl Heuer <kwzh@gnu.org>
parents: 11959
diff changeset
2539 ;; Since we have already gone thru all the items in this menu,
1620a60ab7ca (Info-mode): Doco fix.
Karl Heuer <kwzh@gnu.org>
parents: 11959
diff changeset
2540 ;; go up to the end of this node.
15575
6beab08ee094 (Info-next-preorder): After we move up, move forward again.
Richard M. Stallman <rms@gnu.org>
parents: 15304
diff changeset
2541 (goto-char (point-max))
6beab08ee094 (Info-next-preorder): After we move up, move forward again.
Richard M. Stallman <rms@gnu.org>
parents: 15304
diff changeset
2542 ;; Since logically we are done with the node with that menu,
6beab08ee094 (Info-next-preorder): After we move up, move forward again.
Richard M. Stallman <rms@gnu.org>
parents: 15304
diff changeset
2543 ;; move on from it.
6beab08ee094 (Info-next-preorder): After we move up, move forward again.
Richard M. Stallman <rms@gnu.org>
parents: 15304
diff changeset
2544 (Info-next-preorder))
8018
518971c497f5 (Info-next-preorder-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 7990
diff changeset
2545 (t
518971c497f5 (Info-next-preorder-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 7990
diff changeset
2546 (error "No more nodes"))))
929
27262a6c632a *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 846
diff changeset
2547
27262a6c632a *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 846
diff changeset
2548 (defun Info-last-preorder ()
27262a6c632a *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 846
diff changeset
2549 "Go to the last node, popping up a level if there is none."
27262a6c632a *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 846
diff changeset
2550 (interactive)
8489
c6088e3005cf (Info-last-menu-item): Fix gross logic errors.
Richard M. Stallman <rms@gnu.org>
parents: 8480
diff changeset
2551 (cond ((Info-no-error
c6088e3005cf (Info-last-menu-item): Fix gross logic errors.
Richard M. Stallman <rms@gnu.org>
parents: 8480
diff changeset
2552 (Info-last-menu-item)
c6088e3005cf (Info-last-menu-item): Fix gross logic errors.
Richard M. Stallman <rms@gnu.org>
parents: 8480
diff changeset
2553 ;; If we go down a menu item, go to the end of the node
c6088e3005cf (Info-last-menu-item): Fix gross logic errors.
Richard M. Stallman <rms@gnu.org>
parents: 8480
diff changeset
2554 ;; so we can scroll back through it.
12156
1620a60ab7ca (Info-mode): Doco fix.
Karl Heuer <kwzh@gnu.org>
parents: 11959
diff changeset
2555 (goto-char (point-max)))
15575
6beab08ee094 (Info-next-preorder): After we move up, move forward again.
Richard M. Stallman <rms@gnu.org>
parents: 15304
diff changeset
2556 ;; Keep going down, as long as there are nested menu nodes.
6beab08ee094 (Info-next-preorder): After we move up, move forward again.
Richard M. Stallman <rms@gnu.org>
parents: 15304
diff changeset
2557 (while (Info-no-error
6beab08ee094 (Info-next-preorder): After we move up, move forward again.
Richard M. Stallman <rms@gnu.org>
parents: 15304
diff changeset
2558 (Info-last-menu-item)
6beab08ee094 (Info-next-preorder): After we move up, move forward again.
Richard M. Stallman <rms@gnu.org>
parents: 15304
diff changeset
2559 ;; If we go down a menu item, go to the end of the node
6beab08ee094 (Info-next-preorder): After we move up, move forward again.
Richard M. Stallman <rms@gnu.org>
parents: 15304
diff changeset
2560 ;; so we can scroll back through it.
6beab08ee094 (Info-next-preorder): After we move up, move forward again.
Richard M. Stallman <rms@gnu.org>
parents: 15304
diff changeset
2561 (goto-char (point-max))))
12156
1620a60ab7ca (Info-mode): Doco fix.
Karl Heuer <kwzh@gnu.org>
parents: 11959
diff changeset
2562 (recenter -1))
34468
7ae9e37868e6 (Info-last-preorder): Don't barf on nodes without a prev.
Miles Bader <miles@gnu.org>
parents: 34182
diff changeset
2563 ((and (Info-no-error (Info-extract-pointer "prev"))
7ae9e37868e6 (Info-last-preorder): Don't barf on nodes without a prev.
Miles Bader <miles@gnu.org>
parents: 34182
diff changeset
2564 (not (equal (Info-extract-pointer "up")
21910
702383d93b75 (Info-up): New arg SAME-FILE: don't move to different file.
Richard M. Stallman <rms@gnu.org>
parents: 21806
diff changeset
2565 (Info-extract-pointer "prev"))))
702383d93b75 (Info-up): New arg SAME-FILE: don't move to different file.
Richard M. Stallman <rms@gnu.org>
parents: 21806
diff changeset
2566 (Info-no-error (Info-prev))
12156
1620a60ab7ca (Info-mode): Doco fix.
Karl Heuer <kwzh@gnu.org>
parents: 11959
diff changeset
2567 (goto-char (point-max))
15575
6beab08ee094 (Info-next-preorder): After we move up, move forward again.
Richard M. Stallman <rms@gnu.org>
parents: 15304
diff changeset
2568 (while (Info-no-error
6beab08ee094 (Info-next-preorder): After we move up, move forward again.
Richard M. Stallman <rms@gnu.org>
parents: 15304
diff changeset
2569 (Info-last-menu-item)
6beab08ee094 (Info-next-preorder): After we move up, move forward again.
Richard M. Stallman <rms@gnu.org>
parents: 15304
diff changeset
2570 ;; If we go down a menu item, go to the end of the node
6beab08ee094 (Info-next-preorder): After we move up, move forward again.
Richard M. Stallman <rms@gnu.org>
parents: 15304
diff changeset
2571 ;; so we can scroll back through it.
6beab08ee094 (Info-next-preorder): After we move up, move forward again.
Richard M. Stallman <rms@gnu.org>
parents: 15304
diff changeset
2572 (goto-char (point-max))))
12156
1620a60ab7ca (Info-mode): Doco fix.
Karl Heuer <kwzh@gnu.org>
parents: 11959
diff changeset
2573 (recenter -1))
21910
702383d93b75 (Info-up): New arg SAME-FILE: don't move to different file.
Richard M. Stallman <rms@gnu.org>
parents: 21806
diff changeset
2574 ((Info-no-error (Info-up t))
12156
1620a60ab7ca (Info-mode): Doco fix.
Karl Heuer <kwzh@gnu.org>
parents: 11959
diff changeset
2575 (goto-char (point-min))
29446
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2576 (let ((case-fold-search t))
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2577 (or (search-forward "\n* Menu:" nil t)
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2578 (goto-char (point-max)))))
12156
1620a60ab7ca (Info-mode): Doco fix.
Karl Heuer <kwzh@gnu.org>
parents: 11959
diff changeset
2579 (t (error "No previous nodes"))))
929
27262a6c632a *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 846
diff changeset
2580
27262a6c632a *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 846
diff changeset
2581 (defun Info-scroll-up ()
9222
b18f51df31b3 (Info-scroll-down, Info-scroll-up): Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 8913
diff changeset
2582 "Scroll one screenful forward in Info, considering all nodes as one sequence.
16498
791b96e8f25e (Info-scroll-up): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 16462
diff changeset
2583 Once you scroll far enough in a node that its menu appears on the screen
34182
3f2ee9f3d8bf (Info-scroll-prefer-subnodes): New defcustom.
Eli Zaretskii <eliz@gnu.org>
parents: 33621
diff changeset
2584 but after point, the next scroll moves into its first subnode, unless
3f2ee9f3d8bf (Info-scroll-prefer-subnodes): New defcustom.
Eli Zaretskii <eliz@gnu.org>
parents: 33621
diff changeset
2585 `Info-scroll-prefer-subnodes' is nil.
16498
791b96e8f25e (Info-scroll-up): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 16462
diff changeset
2586
34182
3f2ee9f3d8bf (Info-scroll-prefer-subnodes): New defcustom.
Eli Zaretskii <eliz@gnu.org>
parents: 33621
diff changeset
2587 When you scroll past the end of a node, that goes to the next node if
3f2ee9f3d8bf (Info-scroll-prefer-subnodes): New defcustom.
Eli Zaretskii <eliz@gnu.org>
parents: 33621
diff changeset
2588 `Info-scroll-prefer-subnodes' is non-nil and to the first subnode otherwise;
3f2ee9f3d8bf (Info-scroll-prefer-subnodes): New defcustom.
Eli Zaretskii <eliz@gnu.org>
parents: 33621
diff changeset
2589 if this node has no successor, it moves to the parent node's successor,
3f2ee9f3d8bf (Info-scroll-prefer-subnodes): New defcustom.
Eli Zaretskii <eliz@gnu.org>
parents: 33621
diff changeset
2590 and so on. If `Info-scroll-prefer-subnodes' is non-nil and point is inside
3f2ee9f3d8bf (Info-scroll-prefer-subnodes): New defcustom.
Eli Zaretskii <eliz@gnu.org>
parents: 33621
diff changeset
2591 the menu of a node, it moves to subnode indicated by the following menu
3f2ee9f3d8bf (Info-scroll-prefer-subnodes): New defcustom.
Eli Zaretskii <eliz@gnu.org>
parents: 33621
diff changeset
2592 item. (That case won't normally result from this command, but can happen
3f2ee9f3d8bf (Info-scroll-prefer-subnodes): New defcustom.
Eli Zaretskii <eliz@gnu.org>
parents: 33621
diff changeset
2593 in other ways.)"
16498
791b96e8f25e (Info-scroll-up): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 16462
diff changeset
2594
929
27262a6c632a *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 846
diff changeset
2595 (interactive)
8489
c6088e3005cf (Info-last-menu-item): Fix gross logic errors.
Richard M. Stallman <rms@gnu.org>
parents: 8480
diff changeset
2596 (if (or (< (window-start) (point-min))
c6088e3005cf (Info-last-menu-item): Fix gross logic errors.
Richard M. Stallman <rms@gnu.org>
parents: 8480
diff changeset
2597 (> (window-start) (point-max)))
c6088e3005cf (Info-last-menu-item): Fix gross logic errors.
Richard M. Stallman <rms@gnu.org>
parents: 8480
diff changeset
2598 (set-window-start (selected-window) (point)))
29446
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2599 (let* ((case-fold-search t)
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2600 (virtual-end (save-excursion
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2601 (goto-char (point-min))
34182
3f2ee9f3d8bf (Info-scroll-prefer-subnodes): New defcustom.
Eli Zaretskii <eliz@gnu.org>
parents: 33621
diff changeset
2602 (if (and Info-scroll-prefer-subnodes
3f2ee9f3d8bf (Info-scroll-prefer-subnodes): New defcustom.
Eli Zaretskii <eliz@gnu.org>
parents: 33621
diff changeset
2603 (search-forward "\n* Menu:" nil t))
29446
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2604 (point)
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2605 (point-max)))))
8489
c6088e3005cf (Info-last-menu-item): Fix gross logic errors.
Richard M. Stallman <rms@gnu.org>
parents: 8480
diff changeset
2606 (if (or (< virtual-end (window-start))
c6088e3005cf (Info-last-menu-item): Fix gross logic errors.
Richard M. Stallman <rms@gnu.org>
parents: 8480
diff changeset
2607 (pos-visible-in-window-p virtual-end))
34182
3f2ee9f3d8bf (Info-scroll-prefer-subnodes): New defcustom.
Eli Zaretskii <eliz@gnu.org>
parents: 33621
diff changeset
2608 (cond
3f2ee9f3d8bf (Info-scroll-prefer-subnodes): New defcustom.
Eli Zaretskii <eliz@gnu.org>
parents: 33621
diff changeset
2609 (Info-scroll-prefer-subnodes (Info-next-preorder))
3f2ee9f3d8bf (Info-scroll-prefer-subnodes): New defcustom.
Eli Zaretskii <eliz@gnu.org>
parents: 33621
diff changeset
2610 ((Info-no-error (Info-goto-node (Info-extract-menu-counting 1))))
3f2ee9f3d8bf (Info-scroll-prefer-subnodes): New defcustom.
Eli Zaretskii <eliz@gnu.org>
parents: 33621
diff changeset
2611 (t (Info-next-preorder)))
8489
c6088e3005cf (Info-last-menu-item): Fix gross logic errors.
Richard M. Stallman <rms@gnu.org>
parents: 8480
diff changeset
2612 (scroll-up))))
929
27262a6c632a *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 846
diff changeset
2613
27262a6c632a *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 846
diff changeset
2614 (defun Info-scroll-down ()
9222
b18f51df31b3 (Info-scroll-down, Info-scroll-up): Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 8913
diff changeset
2615 "Scroll one screenful back in Info, considering all nodes as one sequence.
34468
7ae9e37868e6 (Info-last-preorder): Don't barf on nodes without a prev.
Miles Bader <miles@gnu.org>
parents: 34182
diff changeset
2616 If point is within the menu of a node, and `Info-scroll-prefer-subnodes'
7ae9e37868e6 (Info-last-preorder): Don't barf on nodes without a prev.
Miles Bader <miles@gnu.org>
parents: 34182
diff changeset
2617 is non-nil, this goes to its last subnode. When you scroll past the
7ae9e37868e6 (Info-last-preorder): Don't barf on nodes without a prev.
Miles Bader <miles@gnu.org>
parents: 34182
diff changeset
2618 beginning of a node, that goes to the previous node or back up to the
7ae9e37868e6 (Info-last-preorder): Don't barf on nodes without a prev.
Miles Bader <miles@gnu.org>
parents: 34182
diff changeset
2619 parent node."
929
27262a6c632a *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 846
diff changeset
2620 (interactive)
8489
c6088e3005cf (Info-last-menu-item): Fix gross logic errors.
Richard M. Stallman <rms@gnu.org>
parents: 8480
diff changeset
2621 (if (or (< (window-start) (point-min))
c6088e3005cf (Info-last-menu-item): Fix gross logic errors.
Richard M. Stallman <rms@gnu.org>
parents: 8480
diff changeset
2622 (> (window-start) (point-max)))
c6088e3005cf (Info-last-menu-item): Fix gross logic errors.
Richard M. Stallman <rms@gnu.org>
parents: 8480
diff changeset
2623 (set-window-start (selected-window) (point)))
29446
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2624 (let* ((case-fold-search t)
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2625 (current-point (point))
34468
7ae9e37868e6 (Info-last-preorder): Don't barf on nodes without a prev.
Miles Bader <miles@gnu.org>
parents: 34182
diff changeset
2626 (virtual-end
7ae9e37868e6 (Info-last-preorder): Don't barf on nodes without a prev.
Miles Bader <miles@gnu.org>
parents: 34182
diff changeset
2627 (and Info-scroll-prefer-subnodes
7ae9e37868e6 (Info-last-preorder): Don't barf on nodes without a prev.
Miles Bader <miles@gnu.org>
parents: 34182
diff changeset
2628 (save-excursion
7ae9e37868e6 (Info-last-preorder): Don't barf on nodes without a prev.
Miles Bader <miles@gnu.org>
parents: 34182
diff changeset
2629 (beginning-of-line)
7ae9e37868e6 (Info-last-preorder): Don't barf on nodes without a prev.
Miles Bader <miles@gnu.org>
parents: 34182
diff changeset
2630 (setq current-point (point))
7ae9e37868e6 (Info-last-preorder): Don't barf on nodes without a prev.
Miles Bader <miles@gnu.org>
parents: 34182
diff changeset
2631 (goto-char (point-min))
7ae9e37868e6 (Info-last-preorder): Don't barf on nodes without a prev.
Miles Bader <miles@gnu.org>
parents: 34182
diff changeset
2632 (search-forward "\n* Menu:"
7ae9e37868e6 (Info-last-preorder): Don't barf on nodes without a prev.
Miles Bader <miles@gnu.org>
parents: 34182
diff changeset
2633 current-point
7ae9e37868e6 (Info-last-preorder): Don't barf on nodes without a prev.
Miles Bader <miles@gnu.org>
parents: 34182
diff changeset
2634 t)))))
47794
c460856d1bfd (Info-next-menu-item, Info-last-menu-item)
John Paul Wallington <jpw@pobox.com>
parents: 47376
diff changeset
2635 (if (or virtual-end
36894
b63c94fafcde (Info-scroll-down): Add missing WINDOW arg for
Gerd Moellmann <gerd@gnu.org>
parents: 36644
diff changeset
2636 (pos-visible-in-window-p (point-min) nil t))
8489
c6088e3005cf (Info-last-menu-item): Fix gross logic errors.
Richard M. Stallman <rms@gnu.org>
parents: 8480
diff changeset
2637 (Info-last-preorder)
c6088e3005cf (Info-last-menu-item): Fix gross logic errors.
Richard M. Stallman <rms@gnu.org>
parents: 8480
diff changeset
2638 (scroll-down))))
929
27262a6c632a *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 846
diff changeset
2639
15055
60ff6e57ddbd (Info-next-reference, Info-prev-reference): Add optional
Richard M. Stallman <rms@gnu.org>
parents: 14664
diff changeset
2640 (defun Info-next-reference (&optional recur)
4410
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
2641 "Move cursor to the next cross-reference or menu item in the node."
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
2642 (interactive)
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2643 (let ((pat "\\*note[ \n\t]+\\([^:]+\\):\\|^\\* .*:\\|[hf]t?tp://")
22951
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
2644 (old-pt (point))
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
2645 (case-fold-search t))
4410
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
2646 (or (eobp) (forward-char 1))
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
2647 (or (re-search-forward pat nil t)
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
2648 (progn
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
2649 (goto-char (point-min))
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
2650 (or (re-search-forward pat nil t)
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
2651 (progn
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
2652 (goto-char old-pt)
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
2653 (error "No cross references in this node")))))
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2654 (goto-char (or (match-beginning 1) (match-beginning 0)))
4410
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
2655 (if (looking-at "\\* Menu:")
15055
60ff6e57ddbd (Info-next-reference, Info-prev-reference): Add optional
Richard M. Stallman <rms@gnu.org>
parents: 14664
diff changeset
2656 (if recur
60ff6e57ddbd (Info-next-reference, Info-prev-reference): Add optional
Richard M. Stallman <rms@gnu.org>
parents: 14664
diff changeset
2657 (error "No cross references in this node")
64812
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
2658 (Info-next-reference t))
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
2659 (if (looking-at "^\\* ")
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
2660 (forward-char 2)))))
4410
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
2661
15055
60ff6e57ddbd (Info-next-reference, Info-prev-reference): Add optional
Richard M. Stallman <rms@gnu.org>
parents: 14664
diff changeset
2662 (defun Info-prev-reference (&optional recur)
4410
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
2663 "Move cursor to the previous cross-reference or menu item in the node."
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
2664 (interactive)
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2665 (let ((pat "\\*note[ \n\t]+\\([^:]+\\):\\|^\\* .*:\\|[hf]t?tp://")
22951
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
2666 (old-pt (point))
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
2667 (case-fold-search t))
4410
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
2668 (or (re-search-backward pat nil t)
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
2669 (progn
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
2670 (goto-char (point-max))
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
2671 (or (re-search-backward pat nil t)
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
2672 (progn
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
2673 (goto-char old-pt)
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
2674 (error "No cross references in this node")))))
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
2675 (goto-char (or (match-beginning 1) (match-beginning 0)))
4410
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
2676 (if (looking-at "\\* Menu:")
15055
60ff6e57ddbd (Info-next-reference, Info-prev-reference): Add optional
Richard M. Stallman <rms@gnu.org>
parents: 14664
diff changeset
2677 (if recur
60ff6e57ddbd (Info-next-reference, Info-prev-reference): Add optional
Richard M. Stallman <rms@gnu.org>
parents: 14664
diff changeset
2678 (error "No cross references in this node")
64812
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
2679 (Info-prev-reference t))
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
2680 (if (looking-at "^\\* ")
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
2681 (forward-char 2)))))
55751
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2682
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2683 (defvar Info-index-nodes nil
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2684 "Alist of cached index node names of visited Info files.
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2685 Each element has the form (INFO-FILE INDEX-NODE-NAMES-LIST).")
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2686
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2687 (defun Info-index-nodes (&optional file)
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2688 "Return a list of names of all index nodes in Info FILE.
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2689 If FILE is omitted, it defaults to the current Info file.
55774
8926d01558fa (Info-toc): Call Info-mode on intermediate buffer.
Juri Linkov <juri@jurta.org>
parents: 55751
diff changeset
2690 First look in a list of cached index node names. Then scan Info
8926d01558fa (Info-toc): Call Info-mode on intermediate buffer.
Juri Linkov <juri@jurta.org>
parents: 55751
diff changeset
2691 file and its subfiles for nodes with the index cookie. Then try
8926d01558fa (Info-toc): Call Info-mode on intermediate buffer.
Juri Linkov <juri@jurta.org>
parents: 55751
diff changeset
2692 to find index nodes starting from the first node in the top level
8926d01558fa (Info-toc): Call Info-mode on intermediate buffer.
Juri Linkov <juri@jurta.org>
parents: 55751
diff changeset
2693 menu whose name contains the word \"Index\", plus any immediately
8926d01558fa (Info-toc): Call Info-mode on intermediate buffer.
Juri Linkov <juri@jurta.org>
parents: 55751
diff changeset
2694 following nodes whose names also contain the word \"Index\"."
55751
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2695 (or file (setq file Info-current-file))
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2696 (or (assoc file Info-index-nodes)
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2697 ;; Skip virtual Info files
68980
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
2698 (and (member file '("dir" apropos history toc))
55774
8926d01558fa (Info-toc): Call Info-mode on intermediate buffer.
Juri Linkov <juri@jurta.org>
parents: 55751
diff changeset
2699 (setq Info-index-nodes (cons (cons file nil) Info-index-nodes)))
8926d01558fa (Info-toc): Call Info-mode on intermediate buffer.
Juri Linkov <juri@jurta.org>
parents: 55751
diff changeset
2700 (not (stringp file))
66602
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2701 (if Info-file-supports-index-cookies
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2702 ;; Find nodes with index cookie
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2703 (let* ((default-directory (or (and (stringp file)
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2704 (file-name-directory
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2705 (setq file (Info-find-file file))))
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2706 default-directory))
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2707 Info-history Info-history-list Info-fontify-maximum-menu-size
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2708 (main-file file) subfiles nodes node)
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2709 (condition-case nil
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2710 (with-temp-buffer
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2711 (while (or main-file subfiles)
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2712 (erase-buffer)
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2713 (info-insert-file-contents (or main-file (car subfiles)))
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2714 (goto-char (point-min))
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2715 (while (search-forward "\0\b[index\0\b]" nil 'move)
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2716 (save-excursion
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2717 (re-search-backward "^\^_")
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2718 (search-forward "Node: ")
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2719 (setq nodes (cons (Info-following-node-name) nodes))))
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2720 (if main-file
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2721 (save-excursion
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2722 (goto-char (point-min))
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2723 (if (search-forward "\n\^_\nIndirect:" nil t)
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2724 (let ((bound (save-excursion (search-forward "\n\^_" nil t))))
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2725 (while (re-search-forward "^\\(.*\\): [0-9]+$" bound t)
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2726 (setq subfiles (cons (match-string-no-properties 1)
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2727 subfiles)))))
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2728 (setq subfiles (nreverse subfiles)
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2729 main-file nil))
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2730 (setq subfiles (cdr subfiles)))))
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2731 (error nil))
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2732 (if nodes
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2733 (setq nodes (nreverse nodes)
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2734 Info-index-nodes (cons (cons file nodes) Info-index-nodes)))
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2735 nodes)
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2736 ;; Else find nodes with the word "Index" in the node name
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2737 (let ((case-fold-search t)
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2738 Info-history Info-history-list Info-fontify-maximum-menu-size
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2739 nodes node)
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2740 (condition-case nil
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2741 (with-temp-buffer
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2742 (Info-mode)
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2743 (Info-find-node file "Top")
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2744 (when (and (search-forward "\n* menu:" nil t)
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2745 (re-search-forward "\n\\* \\(.*\\<Index\\>\\)" nil t))
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2746 (goto-char (match-beginning 1))
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2747 (setq nodes (list (Info-extract-menu-node-name)))
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2748 (Info-goto-node (car nodes))
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2749 (while (and (setq node (Info-extract-pointer "next" t))
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2750 (string-match "\\<Index\\>" node))
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2751 (setq nodes (cons node nodes))
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2752 (Info-goto-node node))))
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2753 (error nil))
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2754 (if nodes
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2755 (setq nodes (nreverse nodes)
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2756 Info-index-nodes (cons (cons file nodes) Info-index-nodes)))
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2757 nodes))
55774
8926d01558fa (Info-toc): Call Info-mode on intermediate buffer.
Juri Linkov <juri@jurta.org>
parents: 55751
diff changeset
2758 ;; If file has no index nodes, still add it to the cache
8926d01558fa (Info-toc): Call Info-mode on intermediate buffer.
Juri Linkov <juri@jurta.org>
parents: 55751
diff changeset
2759 (setq Info-index-nodes (cons (cons file nil) Info-index-nodes)))
55751
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2760 (cdr (assoc file Info-index-nodes)))
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2761
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2762 (defun Info-index-node (&optional node file)
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2763 "Return non-nil value if NODE is an index node.
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2764 If NODE is nil, check the current Info node.
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2765 If FILE is nil, check the current Info file."
55774
8926d01558fa (Info-toc): Call Info-mode on intermediate buffer.
Juri Linkov <juri@jurta.org>
parents: 55751
diff changeset
2766 (if (or (and node (not (equal node Info-current-node)))
8926d01558fa (Info-toc): Call Info-mode on intermediate buffer.
Juri Linkov <juri@jurta.org>
parents: 55751
diff changeset
2767 (assoc (or file Info-current-file) Info-index-nodes))
8926d01558fa (Info-toc): Call Info-mode on intermediate buffer.
Juri Linkov <juri@jurta.org>
parents: 55751
diff changeset
2768 (member (or node Info-current-node) (Info-index-nodes file))
8926d01558fa (Info-toc): Call Info-mode on intermediate buffer.
Juri Linkov <juri@jurta.org>
parents: 55751
diff changeset
2769 ;; Don't search all index nodes if request is only for the current node
8926d01558fa (Info-toc): Call Info-mode on intermediate buffer.
Juri Linkov <juri@jurta.org>
parents: 55751
diff changeset
2770 ;; and file is not in the cache of index nodes
66602
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2771 (if Info-file-supports-index-cookies
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2772 (save-excursion
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2773 (goto-char (+ (or (save-excursion
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2774 (search-backward "\n\^_" nil t))
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2775 (point-min)) 2))
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2776 (search-forward "\0\b[index\0\b]"
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2777 (or (save-excursion
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2778 (search-forward "\n\^_" nil t))
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2779 (point-max)) t))
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2780 (save-match-data
f1d7e489a526 (Info-file-supports-index-cookies): New variable.
Juri Linkov <juri@jurta.org>
parents: 66459
diff changeset
2781 (string-match "\\<Index\\>" (or node Info-current-node ""))))))
4410
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
2782
41690
c9c839b993b9 (Info-complete-next-re, Info-complete-cache): New vars.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 40967
diff changeset
2783 (defun Info-goto-index ()
55751
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2784 "Go to the first index node."
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2785 (let ((node (car (Info-index-nodes))))
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2786 (or node (error "No index"))
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2787 (Info-goto-node node)))
41690
c9c839b993b9 (Info-complete-next-re, Info-complete-cache): New vars.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 40967
diff changeset
2788
51283
956ab3f2a864 (Info-index): Add autoload cookie.
Richard M. Stallman <rms@gnu.org>
parents: 50707
diff changeset
2789 ;;;###autoload
2561
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
2790 (defun Info-index (topic)
68609
303bb77ca438 (Info-index, Info-mode): Improve the description of the `i' command.
Eli Zaretskii <eliz@gnu.org>
parents: 68342
diff changeset
2791 "Look up a string TOPIC in the index for this manual and go to that entry.
2561
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
2792 If there are no exact matches to the specified topic, this chooses
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
2793 the first match which is a case-insensitive substring of a topic.
55074
dd4c270b21af Restore 2004-04-18 changes.
Juri Linkov <juri@jurta.org>
parents: 55061
diff changeset
2794 Use the \\<Info-mode-map>\\[Info-index-next] command to see the other matches.
68609
303bb77ca438 (Info-index, Info-mode): Improve the description of the `i' command.
Eli Zaretskii <eliz@gnu.org>
parents: 68342
diff changeset
2795 Give an empty topic name to go to the Index node itself."
41690
c9c839b993b9 (Info-complete-next-re, Info-complete-cache): New vars.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 40967
diff changeset
2796 (interactive
c9c839b993b9 (Info-complete-next-re, Info-complete-cache): New vars.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 40967
diff changeset
2797 (list
72698
b74e908df972 * info.el (Info-index): Bind completion-ignore-case.
Chong Yidong <cyd@stupidchicken.com>
parents: 72320
diff changeset
2798 (let ((completion-ignore-case t)
b74e908df972 * info.el (Info-index): Bind completion-ignore-case.
Chong Yidong <cyd@stupidchicken.com>
parents: 72320
diff changeset
2799 (Info-complete-menu-buffer (clone-buffer))
55751
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2800 (Info-complete-nodes (Info-index-nodes))
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2801 (Info-history-list nil))
46104
ee6975afddef (Info-index): Get immediate error if used in `dir'.
Richard M. Stallman <rms@gnu.org>
parents: 46029
diff changeset
2802 (if (equal Info-current-file "dir")
ee6975afddef (Info-index): Get immediate error if used in `dir'.
Richard M. Stallman <rms@gnu.org>
parents: 46029
diff changeset
2803 (error "The Info directory node has no index; use m to select a manual"))
41690
c9c839b993b9 (Info-complete-next-re, Info-complete-cache): New vars.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 40967
diff changeset
2804 (unwind-protect
c9c839b993b9 (Info-complete-next-re, Info-complete-cache): New vars.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 40967
diff changeset
2805 (with-current-buffer Info-complete-menu-buffer
c9c839b993b9 (Info-complete-next-re, Info-complete-cache): New vars.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 40967
diff changeset
2806 (Info-goto-index)
c9c839b993b9 (Info-complete-next-re, Info-complete-cache): New vars.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 40967
diff changeset
2807 (completing-read "Index topic: " 'Info-complete-menu-item))
c9c839b993b9 (Info-complete-next-re, Info-complete-cache): New vars.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 40967
diff changeset
2808 (kill-buffer Info-complete-menu-buffer)))))
46104
ee6975afddef (Info-index): Get immediate error if used in `dir'.
Richard M. Stallman <rms@gnu.org>
parents: 46029
diff changeset
2809 (if (equal Info-current-file "dir")
ee6975afddef (Info-index): Get immediate error if used in `dir'.
Richard M. Stallman <rms@gnu.org>
parents: 46029
diff changeset
2810 (error "The Info directory node has no index; use m to select a manual"))
74471
2584fedc2373 (Info-index): Strip leading colon from topic.
Kim F. Storm <storm@cua.dk>
parents: 72698
diff changeset
2811 ;; Strip leading colon in topic; index format does not allow them.
2584fedc2373 (Info-index): Strip leading colon from topic.
Kim F. Storm <storm@cua.dk>
parents: 72698
diff changeset
2812 (if (and (stringp topic)
2584fedc2373 (Info-index): Strip leading colon from topic.
Kim F. Storm <storm@cua.dk>
parents: 72698
diff changeset
2813 (> (length topic) 0)
2584fedc2373 (Info-index): Strip leading colon from topic.
Kim F. Storm <storm@cua.dk>
parents: 72698
diff changeset
2814 (= (aref topic 0) ?:))
2584fedc2373 (Info-index): Strip leading colon from topic.
Kim F. Storm <storm@cua.dk>
parents: 72698
diff changeset
2815 (setq topic (substring topic 1)))
2561
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
2816 (let ((orignode Info-current-node)
55174
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
2817 (pattern (format "\n\\* +\\([^\n]*%s[^\n]*\\):[ \t]+\\([^\n]*\\)\\.\\(?:[ \t\n]*(line +\\([0-9]+\\))\\)?"
2561
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
2818 (regexp-quote topic)))
55751
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2819 node (nodes (Info-index-nodes))
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2820 (ohist-list Info-history-list)
22951
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
2821 (case-fold-search t))
41691
3317b62de647 (Info-goto-index): One register one step in the history.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 41690
diff changeset
2822 (Info-goto-index)
2561
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
2823 (or (equal topic "")
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
2824 (let ((matches nil)
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
2825 (exact nil)
41691
3317b62de647 (Info-goto-index): One register one step in the history.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 41690
diff changeset
2826 ;; We bind Info-history to nil for internal node-switches so
3317b62de647 (Info-goto-index): One register one step in the history.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 41690
diff changeset
2827 ;; that we don't put junk in the history. In the first
3317b62de647 (Info-goto-index): One register one step in the history.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 41690
diff changeset
2828 ;; Info-goto-index call, above, we do update the history
3317b62de647 (Info-goto-index): One register one step in the history.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 41690
diff changeset
2829 ;; because that is what the user's previous node choice into it.
10758
a66a29e6efc9 (Info-index): Bind Info-history, not Info-keep-history.
Richard M. Stallman <rms@gnu.org>
parents: 10061
diff changeset
2830 (Info-history nil)
2561
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
2831 found)
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
2832 (while
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
2833 (progn
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
2834 (goto-char (point-min))
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
2835 (while (re-search-forward pattern nil t)
31942
55dd93c0d728 (Info-extract-pointer):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31798
diff changeset
2836 (push (list (match-string-no-properties 1)
55dd93c0d728 (Info-extract-pointer):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31798
diff changeset
2837 (match-string-no-properties 2)
55dd93c0d728 (Info-extract-pointer):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31798
diff changeset
2838 Info-current-node
47794
c460856d1bfd (Info-next-menu-item, Info-last-menu-item)
John Paul Wallington <jpw@pobox.com>
parents: 47376
diff changeset
2839 (string-to-number (concat "0"
c460856d1bfd (Info-next-menu-item, Info-last-menu-item)
John Paul Wallington <jpw@pobox.com>
parents: 47376
diff changeset
2840 (match-string 3))))
31942
55dd93c0d728 (Info-extract-pointer):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 31798
diff changeset
2841 matches))
55751
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2842 (setq nodes (cdr nodes) node (car nodes)))
2561
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
2843 (Info-goto-node node))
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
2844 (or matches
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
2845 (progn
14664
f77b58df548c (Info-index): If fail, go back to original node.
Richard M. Stallman <rms@gnu.org>
parents: 14577
diff changeset
2846 (Info-goto-node orignode)
14560
b0df80fef82c (Info-find-index-name): New subroutine, from Info-index-next.
Richard M. Stallman <rms@gnu.org>
parents: 14529
diff changeset
2847 (error "No `%s' in index" topic)))
2561
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
2848 ;; Here it is a feature that assoc is case-sensitive.
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
2849 (while (setq found (assoc topic matches))
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
2850 (setq exact (cons found exact)
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
2851 matches (delq found matches)))
55751
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2852 (setq Info-history-list ohist-list)
2561
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
2853 (setq Info-index-alternatives (nconc exact (nreverse matches)))
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
2854 (Info-index-next 0)))))
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
2855
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
2856 (defun Info-index-next (num)
55074
dd4c270b21af Restore 2004-04-18 changes.
Juri Linkov <juri@jurta.org>
parents: 55061
diff changeset
2857 "Go to the next matching index item from the last \\<Info-mode-map>\\[Info-index] command."
2561
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
2858 (interactive "p")
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
2859 (or Info-index-alternatives
16790
3663fc0c2036 (Info-find-node): Don't clear Info-index-alternatives.
Richard M. Stallman <rms@gnu.org>
parents: 16672
diff changeset
2860 (error "No previous `i' command"))
2561
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
2861 (while (< num 0)
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
2862 (setq num (+ num (length Info-index-alternatives))))
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
2863 (while (> num 0)
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
2864 (setq Info-index-alternatives
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
2865 (nconc (cdr Info-index-alternatives)
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
2866 (list (car Info-index-alternatives)))
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
2867 num (1- num)))
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
2868 (Info-goto-node (nth 1 (car Info-index-alternatives)))
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
2869 (if (> (nth 3 (car Info-index-alternatives)) 0)
55174
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
2870 (forward-line (1- (nth 3 (car Info-index-alternatives))))
29446
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
2871 (forward-line 3) ; don't search in headers
2561
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
2872 (let ((name (car (car Info-index-alternatives))))
14560
b0df80fef82c (Info-find-index-name): New subroutine, from Info-index-next.
Richard M. Stallman <rms@gnu.org>
parents: 14529
diff changeset
2873 (Info-find-index-name name)))
b0df80fef82c (Info-find-index-name): New subroutine, from Info-index-next.
Richard M. Stallman <rms@gnu.org>
parents: 14529
diff changeset
2874 (message "Found `%s' in %s. %s"
2561
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
2875 (car (car Info-index-alternatives))
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
2876 (nth 2 (car Info-index-alternatives))
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
2877 (if (cdr Info-index-alternatives)
70973
4477a2e46659 (Info-index-next): Use where-is-internal to report actual binding of
Eli Zaretskii <eliz@gnu.org>
parents: 70791
diff changeset
2878 (format "(%s total; use `%s' for next)"
4477a2e46659 (Info-index-next): Use where-is-internal to report actual binding of
Eli Zaretskii <eliz@gnu.org>
parents: 70791
diff changeset
2879 (length Info-index-alternatives)
4477a2e46659 (Info-index-next): Use where-is-internal to report actual binding of
Eli Zaretskii <eliz@gnu.org>
parents: 70791
diff changeset
2880 (key-description (where-is-internal
4477a2e46659 (Info-index-next): Use where-is-internal to report actual binding of
Eli Zaretskii <eliz@gnu.org>
parents: 70791
diff changeset
2881 'Info-index-next overriding-local-map
4477a2e46659 (Info-index-next): Use where-is-internal to report actual binding of
Eli Zaretskii <eliz@gnu.org>
parents: 70791
diff changeset
2882 t)))
2561
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
2883 "(Only match)")))
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
2884
14560
b0df80fef82c (Info-find-index-name): New subroutine, from Info-index-next.
Richard M. Stallman <rms@gnu.org>
parents: 14529
diff changeset
2885 (defun Info-find-index-name (name)
b0df80fef82c (Info-find-index-name): New subroutine, from Info-index-next.
Richard M. Stallman <rms@gnu.org>
parents: 14529
diff changeset
2886 "Move point to the place within the current node where NAME is defined."
22951
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
2887 (let ((case-fold-search t))
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
2888 (if (or (re-search-forward (format
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
2889 "[a-zA-Z]+: %s\\( \\|$\\)"
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
2890 (regexp-quote name)) nil t)
46691
ac544e207278 (Info-find-index-name): Search for a function definition with a return type.
Richard M. Stallman <rms@gnu.org>
parents: 46326
diff changeset
2891 ;; Find a function definition with a return type.
ac544e207278 (Info-find-index-name): Search for a function definition with a return type.
Richard M. Stallman <rms@gnu.org>
parents: 46326
diff changeset
2892 (re-search-forward (format
46714
bebf069404ac (Info-find-index-name): Improve last change.
Richard M. Stallman <rms@gnu.org>
parents: 46691
diff changeset
2893 "[a-zA-Z]+: [a-zA-Z0-9_ *&]+ %s\\( \\|$\\)"
46691
ac544e207278 (Info-find-index-name): Search for a function definition with a return type.
Richard M. Stallman <rms@gnu.org>
parents: 46326
diff changeset
2894 (regexp-quote name)) nil t)
22951
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
2895 (search-forward (format "`%s'" name) nil t)
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
2896 (and (string-match "\\`.*\\( (.*)\\)\\'" name)
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
2897 (search-forward
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
2898 (format "`%s'" (substring name 0 (match-beginning 1)))
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
2899 nil t))
52648
928f0fb38bfa (Info-find-index-name): Search both with and without the " <1>" etc.
Eli Zaretskii <eliz@gnu.org>
parents: 52401
diff changeset
2900 (search-forward name nil t)
928f0fb38bfa (Info-find-index-name): Search both with and without the " <1>" etc.
Eli Zaretskii <eliz@gnu.org>
parents: 52401
diff changeset
2901 ;; Try again without the " <1>" makeinfo can append
928f0fb38bfa (Info-find-index-name): Search both with and without the " <1>" etc.
Eli Zaretskii <eliz@gnu.org>
parents: 52401
diff changeset
2902 (and (string-match "\\`\\(.*\\) <[0-9]+>\\'" name)
928f0fb38bfa (Info-find-index-name): Search both with and without the " <1>" etc.
Eli Zaretskii <eliz@gnu.org>
parents: 52401
diff changeset
2903 (Info-find-index-name (match-string 1 name))))
928f0fb38bfa (Info-find-index-name): Search both with and without the " <1>" etc.
Eli Zaretskii <eliz@gnu.org>
parents: 52401
diff changeset
2904 (progn (beginning-of-line) t) ;; non-nil for recursive call
22951
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
2905 (goto-char (point-min)))))
14560
b0df80fef82c (Info-find-index-name): New subroutine, from Info-index-next.
Richard M. Stallman <rms@gnu.org>
parents: 14529
diff changeset
2906
54718
fd0577e11e88 (info-apropos): New function.
Jesper Harder <harder@ifa.au.dk>
parents: 54506
diff changeset
2907 ;;;###autoload
fd0577e11e88 (info-apropos): New function.
Jesper Harder <harder@ifa.au.dk>
parents: 54506
diff changeset
2908 (defun info-apropos (string)
fd0577e11e88 (info-apropos): New function.
Jesper Harder <harder@ifa.au.dk>
parents: 54506
diff changeset
2909 "Grovel indices of all known Info files on your system for STRING.
fd0577e11e88 (info-apropos): New function.
Jesper Harder <harder@ifa.au.dk>
parents: 54506
diff changeset
2910 Build a menu of the possible matches."
fd0577e11e88 (info-apropos): New function.
Jesper Harder <harder@ifa.au.dk>
parents: 54506
diff changeset
2911 (interactive "sIndex apropos: ")
fd0577e11e88 (info-apropos): New function.
Jesper Harder <harder@ifa.au.dk>
parents: 54506
diff changeset
2912 (unless (string= string "")
55174
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
2913 (let ((pattern (format "\n\\* +\\([^\n]*%s[^\n]*\\):[ \t]+\\([^\n]+\\)\\.\\(?:[ \t\n]*(line +\\([0-9]+\\))\\)?"
54718
fd0577e11e88 (info-apropos): New function.
Jesper Harder <harder@ifa.au.dk>
parents: 54506
diff changeset
2914 (regexp-quote string)))
fd0577e11e88 (info-apropos): New function.
Jesper Harder <harder@ifa.au.dk>
parents: 54506
diff changeset
2915 (ohist Info-history)
54865
50d070a98492 (info-apropos): Don't clobber Info-history-list.
Jesper Harder <harder@ifa.au.dk>
parents: 54809
diff changeset
2916 (ohist-list Info-history-list)
54718
fd0577e11e88 (info-apropos): New function.
Jesper Harder <harder@ifa.au.dk>
parents: 54506
diff changeset
2917 (current-node Info-current-node)
fd0577e11e88 (info-apropos): New function.
Jesper Harder <harder@ifa.au.dk>
parents: 54506
diff changeset
2918 (current-file Info-current-file)
55751
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2919 manuals matches node nodes)
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2920 (let ((Info-fontify-maximum-menu-size nil))
54718
fd0577e11e88 (info-apropos): New function.
Jesper Harder <harder@ifa.au.dk>
parents: 54506
diff changeset
2921 (Info-directory)
70789
ab54c05cde25 (info-apropos): Make sure current-file and current-node have non-nil values.
Eli Zaretskii <eliz@gnu.org>
parents: 69858
diff changeset
2922 ;; current-node and current-file are nil when they invoke info-apropos
ab54c05cde25 (info-apropos): Make sure current-file and current-node have non-nil values.
Eli Zaretskii <eliz@gnu.org>
parents: 69858
diff changeset
2923 ;; as the first Info command, i.e. info-apropos loads info.el. In that
ab54c05cde25 (info-apropos): Make sure current-file and current-node have non-nil values.
Eli Zaretskii <eliz@gnu.org>
parents: 69858
diff changeset
2924 ;; case, we use (DIR)Top instead, to avoid signalling an error after
ab54c05cde25 (info-apropos): Make sure current-file and current-node have non-nil values.
Eli Zaretskii <eliz@gnu.org>
parents: 69858
diff changeset
2925 ;; the search is complete.
ab54c05cde25 (info-apropos): Make sure current-file and current-node have non-nil values.
Eli Zaretskii <eliz@gnu.org>
parents: 69858
diff changeset
2926 (when (null current-node)
ab54c05cde25 (info-apropos): Make sure current-file and current-node have non-nil values.
Eli Zaretskii <eliz@gnu.org>
parents: 69858
diff changeset
2927 (setq current-file Info-current-file)
ab54c05cde25 (info-apropos): Make sure current-file and current-node have non-nil values.
Eli Zaretskii <eliz@gnu.org>
parents: 69858
diff changeset
2928 (setq current-node Info-current-node))
54718
fd0577e11e88 (info-apropos): New function.
Jesper Harder <harder@ifa.au.dk>
parents: 54506
diff changeset
2929 (message "Searching indices...")
fd0577e11e88 (info-apropos): New function.
Jesper Harder <harder@ifa.au.dk>
parents: 54506
diff changeset
2930 (goto-char (point-min))
fd0577e11e88 (info-apropos): New function.
Jesper Harder <harder@ifa.au.dk>
parents: 54506
diff changeset
2931 (re-search-forward "\\* Menu: *\n" nil t)
54765
3129d46cd5b6 (info-apropos): Improve menu item regexp.
Jesper Harder <harder@ifa.au.dk>
parents: 54754
diff changeset
2932 (while (re-search-forward "\\*.*: *(\\([^)]+\\))" nil t)
70791
e8009af8c1e1 (info-apropos): Speed up by using add-to-list instead of manual consing.
Eli Zaretskii <eliz@gnu.org>
parents: 70789
diff changeset
2933 ;; add-to-list makes sure we don't have duplicates in `manuals',
e8009af8c1e1 (info-apropos): Speed up by using add-to-list instead of manual consing.
Eli Zaretskii <eliz@gnu.org>
parents: 70789
diff changeset
2934 ;; so that the following dolist loop runs faster.
e8009af8c1e1 (info-apropos): Speed up by using add-to-list instead of manual consing.
Eli Zaretskii <eliz@gnu.org>
parents: 70789
diff changeset
2935 (add-to-list 'manuals (match-string 1)))
64812
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
2936 (dolist (manual (nreverse manuals))
54718
fd0577e11e88 (info-apropos): New function.
Jesper Harder <harder@ifa.au.dk>
parents: 54506
diff changeset
2937 (message "Searching %s" manual)
64812
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
2938 (condition-case err
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
2939 (if (setq nodes (Info-index-nodes (Info-find-file manual)))
55751
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2940 (save-excursion
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2941 (Info-find-node manual (car nodes))
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2942 (while
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2943 (progn
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2944 (goto-char (point-min))
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2945 (while (re-search-forward pattern nil t)
64812
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
2946 (setq matches
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
2947 (cons (list manual
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
2948 (match-string-no-properties 1)
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
2949 (match-string-no-properties 2)
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
2950 (match-string-no-properties 3))
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
2951 matches)))
55751
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2952 (setq nodes (cdr nodes) node (car nodes)))
64812
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
2953 (Info-goto-node node))))
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
2954 (error
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
2955 (message "%s" (if (eq (car-safe err) 'error)
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
2956 (nth 1 err) err))
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
2957 (sit-for 1 t)))))
68980
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
2958 (Info-find-node current-file current-node)
54865
50d070a98492 (info-apropos): Don't clobber Info-history-list.
Jesper Harder <harder@ifa.au.dk>
parents: 54809
diff changeset
2959 (setq Info-history ohist
50d070a98492 (info-apropos): Don't clobber Info-history-list.
Jesper Harder <harder@ifa.au.dk>
parents: 54809
diff changeset
2960 Info-history-list ohist-list)
54718
fd0577e11e88 (info-apropos): New function.
Jesper Harder <harder@ifa.au.dk>
parents: 54506
diff changeset
2961 (message "Searching indices...done")
fd0577e11e88 (info-apropos): New function.
Jesper Harder <harder@ifa.au.dk>
parents: 54506
diff changeset
2962 (if (null matches)
fd0577e11e88 (info-apropos): New function.
Jesper Harder <harder@ifa.au.dk>
parents: 54506
diff changeset
2963 (message "No matches found")
fd0577e11e88 (info-apropos): New function.
Jesper Harder <harder@ifa.au.dk>
parents: 54506
diff changeset
2964 (with-current-buffer (get-buffer-create " *info-apropos*")
fd0577e11e88 (info-apropos): New function.
Jesper Harder <harder@ifa.au.dk>
parents: 54506
diff changeset
2965 (erase-buffer)
55751
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
2966 (insert "\n\^_\nFile: apropos, Node: Index, Up: (dir)\n")
64812
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
2967 (insert "* Menu: \nNodes whose indices contain `" string "':\n\n")
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
2968 (dolist (entry (nreverse matches))
55200
3616e8c83bfa (info-apropos): Make it an index node. Align node names
Jesper Harder <harder@ifa.au.dk>
parents: 55174
diff changeset
2969 (insert
3616e8c83bfa (info-apropos): Make it an index node. Align node names
Jesper Harder <harder@ifa.au.dk>
parents: 55174
diff changeset
2970 (format "* %-38s (%s)%s.%s\n"
3616e8c83bfa (info-apropos): Make it an index node. Align node names
Jesper Harder <harder@ifa.au.dk>
parents: 55174
diff changeset
2971 (concat (nth 1 entry) " [" (nth 0 entry) "]:")
3616e8c83bfa (info-apropos): Make it an index node. Align node names
Jesper Harder <harder@ifa.au.dk>
parents: 55174
diff changeset
2972 (nth 0 entry)
3616e8c83bfa (info-apropos): Make it an index node. Align node names
Jesper Harder <harder@ifa.au.dk>
parents: 55174
diff changeset
2973 (nth 2 entry)
3616e8c83bfa (info-apropos): Make it an index node. Align node names
Jesper Harder <harder@ifa.au.dk>
parents: 55174
diff changeset
2974 (if (nth 3 entry)
3616e8c83bfa (info-apropos): Make it an index node. Align node names
Jesper Harder <harder@ifa.au.dk>
parents: 55174
diff changeset
2975 (concat " (line " (nth 3 entry) ")")
3616e8c83bfa (info-apropos): Make it an index node. Align node names
Jesper Harder <harder@ifa.au.dk>
parents: 55174
diff changeset
2976 "")))))
68980
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
2977 (Info-find-node 'apropos "Index")
55134
1f59134413ff (info-apropos): Reset Info-complete-cache.
Jesper Harder <harder@ifa.au.dk>
parents: 55084
diff changeset
2978 (setq Info-complete-cache nil)))))
54718
fd0577e11e88 (info-apropos): New function.
Jesper Harder <harder@ifa.au.dk>
parents: 54506
diff changeset
2979
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2980 (defun Info-undefined ()
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2981 "Make command be undefined in Info."
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2982 (interactive)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2983 (ding))
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2984
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2985 (defun Info-help ()
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2986 "Enter the Info tutorial."
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2987 (interactive)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2988 (delete-other-windows)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2989 (Info-find-node "info"
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2990 (if (< (window-height) 23)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2991 "Help-Small-Screen"
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2992 "Help")))
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2993
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2994 (defun Info-summary ()
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2995 "Display a brief summary of all Info commands."
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2996 (interactive)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2997 (save-window-excursion
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2998 (switch-to-buffer "*Help*")
20910
e46446e4af2d (Info-summary): Clear buffer-read-only.
Richard M. Stallman <rms@gnu.org>
parents: 20755
diff changeset
2999 (setq buffer-read-only nil)
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3000 (erase-buffer)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3001 (insert (documentation 'Info-mode))
9852
b3a6fdcd63df (Info-summary): Set help-mode in *Help* buffer.
Karl Heuer <kwzh@gnu.org>
parents: 9782
diff changeset
3002 (help-mode)
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3003 (goto-char (point-min))
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3004 (let (ch flag)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3005 (while (progn (setq flag (not (pos-visible-in-window-p (point-max))))
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3006 (message (if flag "Type Space to see more"
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3007 "Type Space to return to Info"))
64013
9ee64186bcf1 (info): Finish `defgroup' description with period.
Juanma Barranquero <lekktu@gmail.com>
parents: 63935
diff changeset
3008 (if (not (eq ?\s (setq ch (read-event))))
1821
04fb1d3d6992 JimB's changes since January 18th
Jim Blandy <jimb@redhat.com>
parents: 1667
diff changeset
3009 (progn (setq unread-command-events (list ch)) nil)
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3010 flag))
4410
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
3011 (scroll-up)))
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
3012 (bury-buffer "*Help*")))
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3013
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3014 (defun Info-get-token (pos start all &optional errorstring)
29621
f03c3a69a809 Doc fixes.
Dave Love <fx@gnu.org>
parents: 29583
diff changeset
3015 "Return the token around POS.
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3016 POS must be somewhere inside the token
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3017 START is a regular expression which will match the
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3018 beginning of the tokens delimited string
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3019 ALL is a regular expression with a single
13990
155a595b6083 (Info-get-token): Doc fix.
Karl Heuer <kwzh@gnu.org>
parents: 13620
diff changeset
3020 parenthesized subpattern which is the token to be
29621
f03c3a69a809 Doc fixes.
Dave Love <fx@gnu.org>
parents: 29583
diff changeset
3021 returned. E.g. '{\(.*\)}' would return any string
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3022 enclosed in braces around POS.
29621
f03c3a69a809 Doc fixes.
Dave Love <fx@gnu.org>
parents: 29583
diff changeset
3023 ERRORSTRING optional fourth argument, controls action on no match
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3024 nil: return nil
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3025 t: beep
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3026 a string: signal an error, using that string."
22951
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
3027 (let ((case-fold-search t))
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
3028 (save-excursion
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
3029 (goto-char pos)
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
3030 ;; First look for a match for START that goes across POS.
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
3031 (while (and (not (bobp)) (> (point) (- pos (length start)))
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
3032 (not (looking-at start)))
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
3033 (forward-char -1))
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
3034 ;; If we did not find one, search back for START
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
3035 ;; (this finds only matches that end at or before POS).
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
3036 (or (looking-at start)
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
3037 (progn
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
3038 (goto-char pos)
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
3039 (re-search-backward start (max (point-min) (- pos 200)) 'yes)))
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
3040 (let (found)
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
3041 (while (and (re-search-forward all (min (point-max) (+ pos 200)) 'yes)
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
3042 (not (setq found (and (<= (match-beginning 0) pos)
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
3043 (> (match-end 0) pos))))))
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
3044 (if (and found (<= (match-beginning 0) pos)
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
3045 (> (match-end 0) pos))
26580
d779cb4aa2ae (Info-build-node-completions, Info-search, Info-follow-reference)
Dave Love <fx@gnu.org>
parents: 26172
diff changeset
3046 (match-string-no-properties 1)
22951
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
3047 (cond ((null errorstring)
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
3048 nil)
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
3049 ((eq errorstring t)
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
3050 (beep)
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
3051 nil)
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
3052 (t
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
3053 (error "No %s around position %d" errorstring pos))))))))
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3054
7007
52b0ebfd3191 (Info-next-preorder): Don't follow footnotes here.
Karl Heuer <kwzh@gnu.org>
parents: 6716
diff changeset
3055 (defun Info-mouse-follow-nearest-node (click)
1309
aa286e6e7bec (Info-follow-nearest-node): Handle line breaks after *note.
Richard M. Stallman <rms@gnu.org>
parents: 998
diff changeset
3056 "\\<Info-mode-map>Follow a node reference near point.
aa286e6e7bec (Info-follow-nearest-node): Handle line breaks after *note.
Richard M. Stallman <rms@gnu.org>
parents: 998
diff changeset
3057 Like \\[Info-menu], \\[Info-follow-reference], \\[Info-next], \\[Info-prev] or \\[Info-up] command, depending on where you click.
7007
52b0ebfd3191 (Info-next-preorder): Don't follow footnotes here.
Karl Heuer <kwzh@gnu.org>
parents: 6716
diff changeset
3058 At end of the node's text, moves to the next node, or up if none."
1309
aa286e6e7bec (Info-follow-nearest-node): Handle line breaks after *note.
Richard M. Stallman <rms@gnu.org>
parents: 998
diff changeset
3059 (interactive "e")
32500
5f2aedbe47b5 (Info-mouse-follow-nearest-node): Use mouse-set-point.
Dave Love <fx@gnu.org>
parents: 32391
diff changeset
3060 (mouse-set-point click)
7007
52b0ebfd3191 (Info-next-preorder): Don't follow footnotes here.
Karl Heuer <kwzh@gnu.org>
parents: 6716
diff changeset
3061 (and (not (Info-try-follow-nearest-node))
52b0ebfd3191 (Info-next-preorder): Don't follow footnotes here.
Karl Heuer <kwzh@gnu.org>
parents: 6716
diff changeset
3062 (save-excursion (forward-line 1) (eobp))
12156
1620a60ab7ca (Info-mode): Doco fix.
Karl Heuer <kwzh@gnu.org>
parents: 11959
diff changeset
3063 (Info-next-preorder)))
7007
52b0ebfd3191 (Info-next-preorder): Don't follow footnotes here.
Karl Heuer <kwzh@gnu.org>
parents: 6716
diff changeset
3064
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3065 (defun Info-follow-nearest-node (&optional fork)
49678
0ae2b48491f7 (Info-follow-nearest-node): Implement new behavior.
Juanma Barranquero <lekktu@gmail.com>
parents: 49502
diff changeset
3066 "Follow a node reference near point.
0ae2b48491f7 (Info-follow-nearest-node): Implement new behavior.
Juanma Barranquero <lekktu@gmail.com>
parents: 49502
diff changeset
3067 If point is on a reference, follow that reference. Otherwise,
69782
ae7fd157df4b doumented for fork in (Info-follow-nearest-node &optional fork)
Ramprasad B <ramprasad_i82@yahoo.com>
parents: 69415
diff changeset
3068 if point is in a menu item description, follow that menu item.
ae7fd157df4b doumented for fork in (Info-follow-nearest-node &optional fork)
Ramprasad B <ramprasad_i82@yahoo.com>
parents: 69415
diff changeset
3069
69858
568a39da33b5 (Info-follow-nearest-node): Doc fix.
Eli Zaretskii <eliz@gnu.org>
parents: 69782
diff changeset
3070 If FORK is non-nil (interactively with a prefix arg), show the node in
69782
ae7fd157df4b doumented for fork in (Info-follow-nearest-node &optional fork)
Ramprasad B <ramprasad_i82@yahoo.com>
parents: 69415
diff changeset
3071 a new Info buffer.
69858
568a39da33b5 (Info-follow-nearest-node): Doc fix.
Eli Zaretskii <eliz@gnu.org>
parents: 69782
diff changeset
3072 If FORK is a string, it is the name to use for the new buffer."
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3073 (interactive "P")
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3074 (or (Info-try-follow-nearest-node fork)
49678
0ae2b48491f7 (Info-follow-nearest-node): Implement new behavior.
Juanma Barranquero <lekktu@gmail.com>
parents: 49502
diff changeset
3075 (when (save-excursion
0ae2b48491f7 (Info-follow-nearest-node): Implement new behavior.
Juanma Barranquero <lekktu@gmail.com>
parents: 49502
diff changeset
3076 (search-backward "\n* menu:" nil t))
0ae2b48491f7 (Info-follow-nearest-node): Implement new behavior.
Juanma Barranquero <lekktu@gmail.com>
parents: 49502
diff changeset
3077 (save-excursion
0ae2b48491f7 (Info-follow-nearest-node): Implement new behavior.
Juanma Barranquero <lekktu@gmail.com>
parents: 49502
diff changeset
3078 (beginning-of-line)
0ae2b48491f7 (Info-follow-nearest-node): Implement new behavior.
Juanma Barranquero <lekktu@gmail.com>
parents: 49502
diff changeset
3079 (while (not (or (bobp) (looking-at "[^ \t]\\|[ \t]*$")))
0ae2b48491f7 (Info-follow-nearest-node): Implement new behavior.
Juanma Barranquero <lekktu@gmail.com>
parents: 49502
diff changeset
3080 (beginning-of-line 0))
0ae2b48491f7 (Info-follow-nearest-node): Implement new behavior.
Juanma Barranquero <lekktu@gmail.com>
parents: 49502
diff changeset
3081 (when (looking-at "\\* +\\([^\t\n]*\\):")
0ae2b48491f7 (Info-follow-nearest-node): Implement new behavior.
Juanma Barranquero <lekktu@gmail.com>
parents: 49502
diff changeset
3082 (Info-goto-node
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3083 (Info-extract-menu-item (match-string-no-properties 1)) fork)
49678
0ae2b48491f7 (Info-follow-nearest-node): Implement new behavior.
Juanma Barranquero <lekktu@gmail.com>
parents: 49502
diff changeset
3084 t)))
0ae2b48491f7 (Info-follow-nearest-node): Implement new behavior.
Juanma Barranquero <lekktu@gmail.com>
parents: 49502
diff changeset
3085 (error "Point neither on reference nor in menu item description")))
7007
52b0ebfd3191 (Info-next-preorder): Don't follow footnotes here.
Karl Heuer <kwzh@gnu.org>
parents: 6716
diff changeset
3086
52b0ebfd3191 (Info-next-preorder): Don't follow footnotes here.
Karl Heuer <kwzh@gnu.org>
parents: 6716
diff changeset
3087 ;; Common subroutine.
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3088 (defun Info-try-follow-nearest-node (&optional fork)
71853
ede3900365e4 (Info-try-follow-nearest-node): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 71533
diff changeset
3089 "Follow a node reference near point. Return non-nil if successful.
ede3900365e4 (Info-try-follow-nearest-node): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 71533
diff changeset
3090 If FORK is non-nil, it i spassed to `Info-goto-node'."
48135
2c6154347319 (Info-streamline-headings): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 48118
diff changeset
3091 (let (node)
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3092 (cond
58936
92b24762a33f (info-xref-visited): Use `default' instead of t.
Richard M. Stallman <rms@gnu.org>
parents: 58604
diff changeset
3093 ((Info-get-token (point) "[hf]t?tp://" "[hf]t?tp://\\([^ \t\n\"`({<>})']+\\)")
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3094 (setq node t)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3095 (browse-url (browse-url-url-at-point)))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3096 ((setq node (Info-get-token (point) "\\*note[ \n\t]+"
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3097 "\\*note[ \n\t]+\\([^:]*\\):\\(:\\|[ \n\t]*(\\)?"))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3098 (Info-follow-reference node fork))
49426
7ac32aa920b9 (Info-extract-menu-node-name): When looking for end of
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 49424
diff changeset
3099 ;; menu item: node name
21641
1174b1d6cbf6 (Info-menu): Allow extra spaces at start of menu item.
Richard M. Stallman <rms@gnu.org>
parents: 21197
diff changeset
3100 ((setq node (Info-get-token (point) "\\* +" "\\* +\\([^:]*\\)::"))
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3101 (Info-goto-node node fork))
55174
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
3102 ;; menu item: node name or index entry
49426
7ac32aa920b9 (Info-extract-menu-node-name): When looking for end of
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 49424
diff changeset
3103 ((Info-get-token (point) "\\* +" "\\* +\\(.*\\): ")
23019
60f63c8a3837 (Info-try-follow-nearest-node): Get the node name
Richard M. Stallman <rms@gnu.org>
parents: 22951
diff changeset
3104 (beginning-of-line)
60f63c8a3837 (Info-try-follow-nearest-node): Get the node name
Richard M. Stallman <rms@gnu.org>
parents: 22951
diff changeset
3105 (forward-char 2)
55751
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
3106 (setq node (Info-extract-menu-node-name nil (Info-index-node)))
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3107 (Info-goto-node node fork))
3127
dfbada800489 (Info-follow-nearest-node): Omit 4th arg to Info-get-token.
Richard M. Stallman <rms@gnu.org>
parents: 3084
diff changeset
3108 ((setq node (Info-get-token (point) "Up: " "Up: \\([^,\n\t]*\\)"))
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3109 (Info-goto-node node fork))
3127
dfbada800489 (Info-follow-nearest-node): Omit 4th arg to Info-get-token.
Richard M. Stallman <rms@gnu.org>
parents: 3084
diff changeset
3110 ((setq node (Info-get-token (point) "Next: " "Next: \\([^,\n\t]*\\)"))
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3111 (Info-goto-node node fork))
3127
dfbada800489 (Info-follow-nearest-node): Omit 4th arg to Info-get-token.
Richard M. Stallman <rms@gnu.org>
parents: 3084
diff changeset
3112 ((setq node (Info-get-token (point) "File: " "File: \\([^,\n\t]*\\)"))
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3113 (Info-goto-node "Top" fork))
3127
dfbada800489 (Info-follow-nearest-node): Omit 4th arg to Info-get-token.
Richard M. Stallman <rms@gnu.org>
parents: 3084
diff changeset
3114 ((setq node (Info-get-token (point) "Prev: " "Prev: \\([^,\n\t]*\\)"))
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3115 (Info-goto-node node fork)))
7007
52b0ebfd3191 (Info-next-preorder): Don't follow footnotes here.
Karl Heuer <kwzh@gnu.org>
parents: 6716
diff changeset
3116 node))
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3117
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3118 (defvar Info-mode-map nil
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3119 "Keymap containing Info commands.")
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3120 (if Info-mode-map
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3121 nil
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3122 (setq Info-mode-map (make-keymap))
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3123 (suppress-keymap Info-mode-map)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3124 (define-key Info-mode-map "." 'beginning-of-buffer)
929
27262a6c632a *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 846
diff changeset
3125 (define-key Info-mode-map " " 'Info-scroll-up)
7007
52b0ebfd3191 (Info-next-preorder): Don't follow footnotes here.
Karl Heuer <kwzh@gnu.org>
parents: 6716
diff changeset
3126 (define-key Info-mode-map "\C-m" 'Info-follow-nearest-node)
4410
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
3127 (define-key Info-mode-map "\t" 'Info-next-reference)
67374
91886d91f4c3 (Info-mode-map): Bind M-TAB to `Info-prev-reference'.
Juri Linkov <juri@jurta.org>
parents: 67303
diff changeset
3128 (define-key Info-mode-map "\e\t" 'Info-prev-reference)
52368
ef170d234e2d (Info-mode-map): Bind S-tab and <backtab> to
Richard M. Stallman <rms@gnu.org>
parents: 52216
diff changeset
3129 (define-key Info-mode-map [(shift tab)] 'Info-prev-reference)
ef170d234e2d (Info-mode-map): Bind S-tab and <backtab> to
Richard M. Stallman <rms@gnu.org>
parents: 52216
diff changeset
3130 (define-key Info-mode-map [backtab] 'Info-prev-reference)
1666
c12fbca81b63 (Info-{first,second,third,fourth,fifth}-menu-item): Removed.
Roland McGrath <roland@gnu.org>
parents: 1613
diff changeset
3131 (define-key Info-mode-map "1" 'Info-nth-menu-item)
c12fbca81b63 (Info-{first,second,third,fourth,fifth}-menu-item): Removed.
Roland McGrath <roland@gnu.org>
parents: 1613
diff changeset
3132 (define-key Info-mode-map "2" 'Info-nth-menu-item)
c12fbca81b63 (Info-{first,second,third,fourth,fifth}-menu-item): Removed.
Roland McGrath <roland@gnu.org>
parents: 1613
diff changeset
3133 (define-key Info-mode-map "3" 'Info-nth-menu-item)
c12fbca81b63 (Info-{first,second,third,fourth,fifth}-menu-item): Removed.
Roland McGrath <roland@gnu.org>
parents: 1613
diff changeset
3134 (define-key Info-mode-map "4" 'Info-nth-menu-item)
c12fbca81b63 (Info-{first,second,third,fourth,fifth}-menu-item): Removed.
Roland McGrath <roland@gnu.org>
parents: 1613
diff changeset
3135 (define-key Info-mode-map "5" 'Info-nth-menu-item)
c12fbca81b63 (Info-{first,second,third,fourth,fifth}-menu-item): Removed.
Roland McGrath <roland@gnu.org>
parents: 1613
diff changeset
3136 (define-key Info-mode-map "6" 'Info-nth-menu-item)
c12fbca81b63 (Info-{first,second,third,fourth,fifth}-menu-item): Removed.
Roland McGrath <roland@gnu.org>
parents: 1613
diff changeset
3137 (define-key Info-mode-map "7" 'Info-nth-menu-item)
c12fbca81b63 (Info-{first,second,third,fourth,fifth}-menu-item): Removed.
Roland McGrath <roland@gnu.org>
parents: 1613
diff changeset
3138 (define-key Info-mode-map "8" 'Info-nth-menu-item)
c12fbca81b63 (Info-{first,second,third,fourth,fifth}-menu-item): Removed.
Roland McGrath <roland@gnu.org>
parents: 1613
diff changeset
3139 (define-key Info-mode-map "9" 'Info-nth-menu-item)
1667
9c0e14881b8f (Info-{first,second,third,fourth,fifth}-menu-item): Removed.
Roland McGrath <roland@gnu.org>
parents: 1666
diff changeset
3140 (define-key Info-mode-map "0" 'undefined)
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3141 (define-key Info-mode-map "?" 'Info-summary)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3142 (define-key Info-mode-map "]" 'Info-forward-node)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3143 (define-key Info-mode-map "[" 'Info-backward-node)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3144 (define-key Info-mode-map "<" 'Info-top-node)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3145 (define-key Info-mode-map ">" 'Info-final-node)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3146 (define-key Info-mode-map "b" 'beginning-of-buffer)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3147 (define-key Info-mode-map "d" 'Info-directory)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3148 (define-key Info-mode-map "e" 'Info-edit)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3149 (define-key Info-mode-map "f" 'Info-follow-reference)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3150 (define-key Info-mode-map "g" 'Info-goto-node)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3151 (define-key Info-mode-map "h" 'Info-help)
2561
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
3152 (define-key Info-mode-map "i" 'Info-index)
59472
1e81e65f3201 (Info-history-forward): New variable.
Juri Linkov <juri@jurta.org>
parents: 59423
diff changeset
3153 (define-key Info-mode-map "l" 'Info-history-back)
56044
7aad97855e39 (Info-goto-node): Add autoload.
Juri Linkov <juri@jurta.org>
parents: 55797
diff changeset
3154 (define-key Info-mode-map "L" 'Info-history)
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3155 (define-key Info-mode-map "m" 'Info-menu)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3156 (define-key Info-mode-map "n" 'Info-next)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3157 (define-key Info-mode-map "p" 'Info-prev)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3158 (define-key Info-mode-map "q" 'Info-exit)
59472
1e81e65f3201 (Info-history-forward): New variable.
Juri Linkov <juri@jurta.org>
parents: 59423
diff changeset
3159 (define-key Info-mode-map "r" 'Info-history-forward)
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3160 (define-key Info-mode-map "s" 'Info-search)
55774
8926d01558fa (Info-toc): Call Info-mode on intermediate buffer.
Juri Linkov <juri@jurta.org>
parents: 55751
diff changeset
3161 (define-key Info-mode-map "S" 'Info-search-case-sensitively)
8739
f89682e90658 (Info-mode-map): Bind M-s like s.
Richard M. Stallman <rms@gnu.org>
parents: 8692
diff changeset
3162 ;; For consistency with Rmail.
f89682e90658 (Info-mode-map): Bind M-s like s.
Richard M. Stallman <rms@gnu.org>
parents: 8692
diff changeset
3163 (define-key Info-mode-map "\M-s" 'Info-search)
26004
11f91800bec3 (Info-on-current-buffer): new entry point.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 25878
diff changeset
3164 (define-key Info-mode-map "\M-n" 'clone-buffer)
3313
34f2db3916fe (Info-mode-map): Correct Info-top to Info-top-node.
Richard M. Stallman <rms@gnu.org>
parents: 3225
diff changeset
3165 (define-key Info-mode-map "t" 'Info-top-node)
56044
7aad97855e39 (Info-goto-node): Add autoload.
Juri Linkov <juri@jurta.org>
parents: 55797
diff changeset
3166 (define-key Info-mode-map "T" 'Info-toc)
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3167 (define-key Info-mode-map "u" 'Info-up)
64812
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
3168 ;; `w' for consistency with `dired-copy-filename-as-kill'.
55774
8926d01558fa (Info-toc): Call Info-mode on intermediate buffer.
Juri Linkov <juri@jurta.org>
parents: 55751
diff changeset
3169 (define-key Info-mode-map "w" 'Info-copy-current-node-name)
64812
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
3170 (define-key Info-mode-map "c" 'Info-copy-current-node-name)
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
3171 ;; `^' for consistency with `dired-up-directory'.
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
3172 (define-key Info-mode-map "^" 'Info-up)
2561
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
3173 (define-key Info-mode-map "," 'Info-index-next)
930
1dac458b5117 *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 929
diff changeset
3174 (define-key Info-mode-map "\177" 'Info-scroll-down)
7007
52b0ebfd3191 (Info-next-preorder): Don't follow footnotes here.
Karl Heuer <kwzh@gnu.org>
parents: 6716
diff changeset
3175 (define-key Info-mode-map [mouse-2] 'Info-mouse-follow-nearest-node)
59423
3eca2bed63e4 (Info-mode-map, Info-next-link-keymap)
Kim F. Storm <storm@cua.dk>
parents: 58936
diff changeset
3176 (define-key Info-mode-map [follow-link] 'mouse-face)
540
0840eff2ecd5 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 359
diff changeset
3177 )
16043
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3178
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3179 (defun Info-check-pointer (item)
29621
f03c3a69a809 Doc fixes.
Dave Love <fx@gnu.org>
parents: 29583
diff changeset
3180 "Non-nil if ITEM is present in this node."
16043
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3181 (condition-case nil
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3182 (Info-extract-pointer item)
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3183 (error nil)))
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3184
30220
e4628d420030 (Info-mode-menu): Fix use of :help, :enable.
Dave Love <fx@gnu.org>
parents: 30109
diff changeset
3185 (easy-menu-define
e4628d420030 (Info-mode-menu): Fix use of :help, :enable.
Dave Love <fx@gnu.org>
parents: 30109
diff changeset
3186 Info-mode-menu Info-mode-map
64812
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
3187 "Menu for Info files."
30220
e4628d420030 (Info-mode-menu): Fix use of :help, :enable.
Dave Love <fx@gnu.org>
parents: 30109
diff changeset
3188 '("Info"
e4628d420030 (Info-mode-menu): Fix use of :help, :enable.
Dave Love <fx@gnu.org>
parents: 30109
diff changeset
3189 ["Up" Info-up :active (Info-check-pointer "up")
e4628d420030 (Info-mode-menu): Fix use of :help, :enable.
Dave Love <fx@gnu.org>
parents: 30109
diff changeset
3190 :help "Go up in the Info tree"]
e4628d420030 (Info-mode-menu): Fix use of :help, :enable.
Dave Love <fx@gnu.org>
parents: 30109
diff changeset
3191 ["Next" Info-next :active (Info-check-pointer "next")
e4628d420030 (Info-mode-menu): Fix use of :help, :enable.
Dave Love <fx@gnu.org>
parents: 30109
diff changeset
3192 :help "Go to the next node"]
e4628d420030 (Info-mode-menu): Fix use of :help, :enable.
Dave Love <fx@gnu.org>
parents: 30109
diff changeset
3193 ["Previous" Info-prev :active (Info-check-pointer "prev[ious]*")
e4628d420030 (Info-mode-menu): Fix use of :help, :enable.
Dave Love <fx@gnu.org>
parents: 30109
diff changeset
3194 :help "Go to the previous node"]
e4628d420030 (Info-mode-menu): Fix use of :help, :enable.
Dave Love <fx@gnu.org>
parents: 30109
diff changeset
3195 ["Backward" Info-backward-node
e4628d420030 (Info-mode-menu): Fix use of :help, :enable.
Dave Love <fx@gnu.org>
parents: 30109
diff changeset
3196 :help "Go backward one node, considering all as a sequence"]
e4628d420030 (Info-mode-menu): Fix use of :help, :enable.
Dave Love <fx@gnu.org>
parents: 30109
diff changeset
3197 ["Forward" Info-forward-node
e4628d420030 (Info-mode-menu): Fix use of :help, :enable.
Dave Love <fx@gnu.org>
parents: 30109
diff changeset
3198 :help "Go forward one node, considering all as a sequence"]
32286
c0b19a2770ca (Info-goto-node, Info-menu): Doc fix.
Dave Love <fx@gnu.org>
parents: 32007
diff changeset
3199 ["Beginning" beginning-of-buffer
c0b19a2770ca (Info-goto-node, Info-menu): Doc fix.
Dave Love <fx@gnu.org>
parents: 32007
diff changeset
3200 :help "Go to beginning of this node"]
30220
e4628d420030 (Info-mode-menu): Fix use of :help, :enable.
Dave Love <fx@gnu.org>
parents: 30109
diff changeset
3201 ["Top" Info-top-node
e4628d420030 (Info-mode-menu): Fix use of :help, :enable.
Dave Love <fx@gnu.org>
parents: 30109
diff changeset
3202 :help "Go to top node of file"]
e4628d420030 (Info-mode-menu): Fix use of :help, :enable.
Dave Love <fx@gnu.org>
parents: 30109
diff changeset
3203 ["Final Node" Info-final-node
e4628d420030 (Info-mode-menu): Fix use of :help, :enable.
Dave Love <fx@gnu.org>
parents: 30109
diff changeset
3204 :help "Go to final node in this file"]
e4628d420030 (Info-mode-menu): Fix use of :help, :enable.
Dave Love <fx@gnu.org>
parents: 30109
diff changeset
3205 ("Menu Item" ["You should never see this" report-emacs-bug t])
e4628d420030 (Info-mode-menu): Fix use of :help, :enable.
Dave Love <fx@gnu.org>
parents: 30109
diff changeset
3206 ("Reference" ["You should never see this" report-emacs-bug t])
e4628d420030 (Info-mode-menu): Fix use of :help, :enable.
Dave Love <fx@gnu.org>
parents: 30109
diff changeset
3207 ["Search..." Info-search
e4628d420030 (Info-mode-menu): Fix use of :help, :enable.
Dave Love <fx@gnu.org>
parents: 30109
diff changeset
3208 :help "Search for regular expression in this Info file"]
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3209 ["Search Next" Info-search-next
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3210 :help "Search for another occurrence of regular expression"]
32500
5f2aedbe47b5 (Info-mouse-follow-nearest-node): Use mouse-set-point.
Dave Love <fx@gnu.org>
parents: 32391
diff changeset
3211 ["Go to Node..." Info-goto-node
30220
e4628d420030 (Info-mode-menu): Fix use of :help, :enable.
Dave Love <fx@gnu.org>
parents: 30109
diff changeset
3212 :help "Go to a named node"]
59472
1e81e65f3201 (Info-history-forward): New variable.
Juri Linkov <juri@jurta.org>
parents: 59423
diff changeset
3213 ["Back in history" Info-history-back :active Info-history
1e81e65f3201 (Info-history-forward): New variable.
Juri Linkov <juri@jurta.org>
parents: 59423
diff changeset
3214 :help "Go back in history to the last node you were at"]
1e81e65f3201 (Info-history-forward): New variable.
Juri Linkov <juri@jurta.org>
parents: 59423
diff changeset
3215 ["Forward in history" Info-history-forward :active Info-history-forward
1e81e65f3201 (Info-history-forward): New variable.
Juri Linkov <juri@jurta.org>
parents: 59423
diff changeset
3216 :help "Go forward in history"]
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3217 ["History" Info-history :active Info-history-list
56044
7aad97855e39 (Info-goto-node): Add autoload.
Juri Linkov <juri@jurta.org>
parents: 55797
diff changeset
3218 :help "Go to menu of visited nodes"]
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3219 ["Table of Contents" Info-toc
56044
7aad97855e39 (Info-goto-node): Add autoload.
Juri Linkov <juri@jurta.org>
parents: 55797
diff changeset
3220 :help "Go to table of contents"]
61029
ea8106ee0289 (Info-mode-menu): Remove ellipsis from "Index".
Juri Linkov <juri@jurta.org>
parents: 60626
diff changeset
3221 ("Index"
ea8106ee0289 (Info-mode-menu): Remove ellipsis from "Index".
Juri Linkov <juri@jurta.org>
parents: 60626
diff changeset
3222 ["Lookup a String..." Info-index
30220
e4628d420030 (Info-mode-menu): Fix use of :help, :enable.
Dave Love <fx@gnu.org>
parents: 30109
diff changeset
3223 :help "Look for a string in the index items"]
61029
ea8106ee0289 (Info-mode-menu): Remove ellipsis from "Index".
Juri Linkov <juri@jurta.org>
parents: 60626
diff changeset
3224 ["Next Matching Item" Info-index-next :active Info-index-alternatives
54718
fd0577e11e88 (info-apropos): New function.
Jesper Harder <harder@ifa.au.dk>
parents: 54506
diff changeset
3225 :help "Look for another occurrence of previous item"]
61029
ea8106ee0289 (Info-mode-menu): Remove ellipsis from "Index".
Juri Linkov <juri@jurta.org>
parents: 60626
diff changeset
3226 ["Lookup a string in all indices..." info-apropos
54718
fd0577e11e88 (info-apropos): New function.
Jesper Harder <harder@ifa.au.dk>
parents: 54506
diff changeset
3227 :help "Look for a string in the indices of all manuals"])
36092
bf55849c91fb (Info-copy-current-node-name): New function.
Miles Bader <miles@gnu.org>
parents: 35934
diff changeset
3228 ["Copy Node Name" Info-copy-current-node-name
bf55849c91fb (Info-copy-current-node-name): New function.
Miles Bader <miles@gnu.org>
parents: 35934
diff changeset
3229 :help "Copy the name of the current node into the kill ring"]
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3230 ["Clone Info buffer" clone-buffer
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3231 :help "Create a twin copy of the current Info buffer."]
32391
5c381664251f (Info-mode-menu): Fix some help.
Dave Love <fx@gnu.org>
parents: 32286
diff changeset
3232 ["Exit" Info-exit :help "Stop reading Info"]))
16043
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3233
32286
c0b19a2770ca (Info-goto-node, Info-menu): Doc fix.
Dave Love <fx@gnu.org>
parents: 32007
diff changeset
3234
c0b19a2770ca (Info-goto-node, Info-menu): Doc fix.
Dave Love <fx@gnu.org>
parents: 32007
diff changeset
3235 (defvar info-tool-bar-map
c0b19a2770ca (Info-goto-node, Info-menu): Doc fix.
Dave Love <fx@gnu.org>
parents: 32007
diff changeset
3236 (if (display-graphic-p)
44306
33a65a57f38a (info-tool-bar-map): Use tool-bar-local-item-from-menu.
Richard M. Stallman <rms@gnu.org>
parents: 43776
diff changeset
3237 (let ((map (make-sparse-keymap)))
33a65a57f38a (info-tool-bar-map): Use tool-bar-local-item-from-menu.
Richard M. Stallman <rms@gnu.org>
parents: 43776
diff changeset
3238 (tool-bar-local-item-from-menu 'Info-exit "close" map Info-mode-map)
67267
bf8d1c67233d Move back/forward history at the beginning of the tool bar.
Jan Djärv <jan.h.d@swipnet.se>
parents: 67184
diff changeset
3239 (tool-bar-local-item-from-menu 'Info-history-back "left-arrow" map Info-mode-map)
bf8d1c67233d Move back/forward history at the beginning of the tool bar.
Jan Djärv <jan.h.d@swipnet.se>
parents: 67184
diff changeset
3240 (tool-bar-local-item-from-menu 'Info-history-forward "right-arrow" map Info-mode-map)
66710
ff5bc4e6c882 New images for info.
Jan Djärv <jan.h.d@swipnet.se>
parents: 66670
diff changeset
3241 (tool-bar-local-item-from-menu 'Info-prev "prev-node" map Info-mode-map)
ff5bc4e6c882 New images for info.
Jan Djärv <jan.h.d@swipnet.se>
parents: 66670
diff changeset
3242 (tool-bar-local-item-from-menu 'Info-next "next-node" map Info-mode-map)
ff5bc4e6c882 New images for info.
Jan Djärv <jan.h.d@swipnet.se>
parents: 66670
diff changeset
3243 (tool-bar-local-item-from-menu 'Info-up "up-node" map Info-mode-map)
44306
33a65a57f38a (info-tool-bar-map): Use tool-bar-local-item-from-menu.
Richard M. Stallman <rms@gnu.org>
parents: 43776
diff changeset
3244 (tool-bar-local-item-from-menu 'Info-top-node "home" map Info-mode-map)
67778
0c0bb618627a (info-other-window, info): Rename function argument
Juri Linkov <juri@jurta.org>
parents: 67623
diff changeset
3245 (tool-bar-local-item-from-menu 'Info-goto-node "jump-to" map Info-mode-map)
44306
33a65a57f38a (info-tool-bar-map): Use tool-bar-local-item-from-menu.
Richard M. Stallman <rms@gnu.org>
parents: 43776
diff changeset
3246 (tool-bar-local-item-from-menu 'Info-index "index" map Info-mode-map)
33a65a57f38a (info-tool-bar-map): Use tool-bar-local-item-from-menu.
Richard M. Stallman <rms@gnu.org>
parents: 43776
diff changeset
3247 (tool-bar-local-item-from-menu 'Info-search "search" map Info-mode-map)
33a65a57f38a (info-tool-bar-map): Use tool-bar-local-item-from-menu.
Richard M. Stallman <rms@gnu.org>
parents: 43776
diff changeset
3248 map)))
32286
c0b19a2770ca (Info-goto-node, Info-menu): Doc fix.
Dave Love <fx@gnu.org>
parents: 32007
diff changeset
3249
16043
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3250 (defvar Info-menu-last-node nil)
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3251 ;; Last node the menu was created for.
21197
e4b99d1db55a (Info-menu-update): Set Info-menu-last-node
Richard M. Stallman <rms@gnu.org>
parents: 21003
diff changeset
3252 ;; Value is a list, (FILE-NAME NODE-NAME).
16043
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3253
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3254 (defun Info-menu-update ()
29621
f03c3a69a809 Doc fixes.
Dave Love <fx@gnu.org>
parents: 29583
diff changeset
3255 "Update the Info menu for the current node."
16043
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3256 (condition-case nil
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3257 (if (or (not (eq major-mode 'Info-mode))
21197
e4b99d1db55a (Info-menu-update): Set Info-menu-last-node
Richard M. Stallman <rms@gnu.org>
parents: 21003
diff changeset
3258 (equal (list Info-current-file Info-current-node)
e4b99d1db55a (Info-menu-update): Set Info-menu-last-node
Richard M. Stallman <rms@gnu.org>
parents: 21003
diff changeset
3259 Info-menu-last-node))
16043
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3260 ()
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3261 ;; Update menu menu.
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3262 (let* ((Info-complete-menu-buffer (current-buffer))
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3263 (items (nreverse (condition-case nil
41690
c9c839b993b9 (Info-complete-next-re, Info-complete-cache): New vars.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 40967
diff changeset
3264 (Info-complete-menu-item "" nil t)
16043
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3265 (error nil))))
28943
36fd90774cf7 (debug-ignored-errors): more errors to ignore.
Sam Steingold <sds@gnu.org>
parents: 28559
diff changeset
3266 entries current
16043
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3267 (number 0))
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3268 (while (and items (< number 9))
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3269 (setq current (car items)
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3270 items (cdr items)
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3271 number (1+ number))
28943
36fd90774cf7 (debug-ignored-errors): more errors to ignore.
Sam Steingold <sds@gnu.org>
parents: 28559
diff changeset
3272 (setq entries (cons `[,current
16043
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3273 (Info-menu ,current)
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3274 :keys ,(format "%d" number)]
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3275 entries)))
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3276 (if items
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3277 (setq entries (cons ["Other..." Info-menu t] entries)))
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3278 (or entries
37370
3a3bed48a714 (Info-menu-update): When there are no menus and/or no
Eli Zaretskii <eliz@gnu.org>
parents: 37351
diff changeset
3279 (setq entries (list ["No menu" nil nil] nil :active)))
30220
e4628d420030 (Info-mode-menu): Fix use of :help, :enable.
Dave Love <fx@gnu.org>
parents: 30109
diff changeset
3280 (easy-menu-change '("Info") "Menu Item" (nreverse entries)))
16043
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3281 ;; Update reference menu. Code stolen from `Info-follow-reference'.
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3282 (let ((items nil)
28943
36fd90774cf7 (debug-ignored-errors): more errors to ignore.
Sam Steingold <sds@gnu.org>
parents: 28559
diff changeset
3283 str i entries current
22951
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
3284 (number 0)
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
3285 (case-fold-search t))
16043
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3286 (save-excursion
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3287 (goto-char (point-min))
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3288 (while (re-search-forward "\\*note[ \n\t]+\\([^:]*\\):" nil t)
51735
204ae43066d1 (Info-following-node-name-re): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51731
diff changeset
3289 (setq str (match-string 1))
16043
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3290 (setq i 0)
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3291 (while (setq i (string-match "[ \n\t]+" str i))
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3292 (setq str (concat (substring str 0 i) " "
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3293 (substring str (match-end 0))))
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3294 (setq i (1+ i)))
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3295 (setq items
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3296 (cons str items))))
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3297 (while (and items (< number 9))
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3298 (setq current (car items)
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3299 items (cdr items)
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3300 number (1+ number))
28943
36fd90774cf7 (debug-ignored-errors): more errors to ignore.
Sam Steingold <sds@gnu.org>
parents: 28559
diff changeset
3301 (setq entries (cons `[,current
16043
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3302 (Info-follow-reference ,current)
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3303 t]
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3304 entries)))
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3305 (if items
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3306 (setq entries (cons ["Other..." Info-follow-reference t]
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3307 entries)))
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3308 (or entries
37370
3a3bed48a714 (Info-menu-update): When there are no menus and/or no
Eli Zaretskii <eliz@gnu.org>
parents: 37351
diff changeset
3309 (setq entries (list ["No references" nil nil] nil :active)))
16043
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3310 (easy-menu-change '("Info") "Reference" (nreverse entries)))
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3311 ;; Update last seen node.
21197
e4b99d1db55a (Info-menu-update): Set Info-menu-last-node
Richard M. Stallman <rms@gnu.org>
parents: 21003
diff changeset
3312 (setq Info-menu-last-node (list Info-current-file Info-current-node)))
16043
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3313 ;; Try to avoid entering infinite beep mode in case of errors.
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3314 (error (ding))))
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3315
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3316
55774
8926d01558fa (Info-toc): Call Info-mode on intermediate buffer.
Juri Linkov <juri@jurta.org>
parents: 55751
diff changeset
3317 (defun Info-copy-current-node-name (&optional arg)
64812
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
3318 "Put the name of the current Info node into the kill ring.
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
3319 The name of the Info file is prepended to the node name in parentheses.
55774
8926d01558fa (Info-toc): Call Info-mode on intermediate buffer.
Juri Linkov <juri@jurta.org>
parents: 55751
diff changeset
3320 With a zero prefix arg, put the name inside a function call to `info'."
8926d01558fa (Info-toc): Call Info-mode on intermediate buffer.
Juri Linkov <juri@jurta.org>
parents: 55751
diff changeset
3321 (interactive "P")
36092
bf55849c91fb (Info-copy-current-node-name): New function.
Miles Bader <miles@gnu.org>
parents: 35934
diff changeset
3322 (unless Info-current-node
64812
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
3323 (error "No current Info node"))
68980
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
3324 (let ((node (if (stringp Info-current-file)
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
3325 (concat "(" (file-name-nondirectory Info-current-file) ")"
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
3326 Info-current-node))))
55774
8926d01558fa (Info-toc): Call Info-mode on intermediate buffer.
Juri Linkov <juri@jurta.org>
parents: 55751
diff changeset
3327 (if (zerop (prefix-numeric-value arg))
8926d01558fa (Info-toc): Call Info-mode on intermediate buffer.
Juri Linkov <juri@jurta.org>
parents: 55751
diff changeset
3328 (setq node (concat "(info \"" node "\")")))
68980
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
3329 (unless (stringp Info-current-file)
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
3330 (setq node (format "(Info-find-node '%S '%S)"
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
3331 Info-current-file Info-current-node)))
55774
8926d01558fa (Info-toc): Call Info-mode on intermediate buffer.
Juri Linkov <juri@jurta.org>
parents: 55751
diff changeset
3332 (kill-new node)
8926d01558fa (Info-toc): Call Info-mode on intermediate buffer.
Juri Linkov <juri@jurta.org>
parents: 55751
diff changeset
3333 (message "%s" node)))
36092
bf55849c91fb (Info-copy-current-node-name): New function.
Miles Bader <miles@gnu.org>
parents: 35934
diff changeset
3334
bf55849c91fb (Info-copy-current-node-name): New function.
Miles Bader <miles@gnu.org>
parents: 35934
diff changeset
3335
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3336 ;; Info mode is suitable only for specially formatted data.
31798
460c3cd7b368 Use the correct capitalization when making Info-mode and Info-edit-mode
Miles Bader <miles@gnu.org>
parents: 31755
diff changeset
3337 (put 'Info-mode 'mode-class 'special)
40967
ab0564ba441e (Info-mode): Add a no-clone-indirect property.
Richard M. Stallman <rms@gnu.org>
parents: 40845
diff changeset
3338 (put 'Info-mode 'no-clone-indirect t)
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3339
63935
9eca51cb6ae3 (tool-bar-map): Add defvar.
Richard M. Stallman <rms@gnu.org>
parents: 63503
diff changeset
3340 (defvar tool-bar-map)
9eca51cb6ae3 (tool-bar-map): Add defvar.
Richard M. Stallman <rms@gnu.org>
parents: 63503
diff changeset
3341
64896
a7d19794a559 Add handler to desktop-buffer-mode-handlers.
Lars Hansen <larsh@soem.dk>
parents: 64812
diff changeset
3342 ;; Autoload cookie needed by desktop.el
a7d19794a559 Add handler to desktop-buffer-mode-handlers.
Lars Hansen <larsh@soem.dk>
parents: 64812
diff changeset
3343 ;;;###autoload
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3344 (defun Info-mode ()
29621
f03c3a69a809 Doc fixes.
Dave Love <fx@gnu.org>
parents: 29583
diff changeset
3345 "Info mode provides commands for browsing through the Info documentation tree.
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3346 Documentation in Info is divided into \"nodes\", each of which discusses
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3347 one topic and contains references to other nodes which discuss related
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3348 topics. Info has commands to follow the references and show you other nodes.
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3349
29621
f03c3a69a809 Doc fixes.
Dave Love <fx@gnu.org>
parents: 29583
diff changeset
3350 \\<Info-mode-map>\
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3351 \\[Info-help] Invoke the Info tutorial.
21806
d17bf0e8a170 (Info-mode): Doc fix.
Dave Love <fx@gnu.org>
parents: 21704
diff changeset
3352 \\[Info-exit] Quit Info: reselect previously selected buffer.
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3353
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3354 Selecting other nodes:
8564
ca09c53c16a6 (Info-mode): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 8489
diff changeset
3355 \\[Info-mouse-follow-nearest-node]
ca09c53c16a6 (Info-mode): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 8489
diff changeset
3356 Follow a node reference you click on.
ca09c53c16a6 (Info-mode): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 8489
diff changeset
3357 This works with menu items, cross references, and
ca09c53c16a6 (Info-mode): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 8489
diff changeset
3358 the \"next\", \"previous\" and \"up\", depending on where you click.
21806
d17bf0e8a170 (Info-mode): Doc fix.
Dave Love <fx@gnu.org>
parents: 21704
diff changeset
3359 \\[Info-follow-nearest-node] Follow a node reference near point, like \\[Info-mouse-follow-nearest-node].
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3360 \\[Info-next] Move to the \"next\" node of this node.
3127
dfbada800489 (Info-follow-nearest-node): Omit 4th arg to Info-get-token.
Richard M. Stallman <rms@gnu.org>
parents: 3084
diff changeset
3361 \\[Info-prev] Move to the \"previous\" node of this node.
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3362 \\[Info-up] Move \"up\" from this node.
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3363 \\[Info-menu] Pick menu item specified by name (or abbreviation).
42406
4c72bc09992b (Info-mode): Reindent the doc-string.
Pavel Janík <Pavel@Janik.cz>
parents: 42243
diff changeset
3364 Picking a menu item causes another node to be selected.
540
0840eff2ecd5 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 359
diff changeset
3365 \\[Info-directory] Go to the Info directory node.
66010
c4bdbe18630e (Info-mode-menu): Delete menu item "Edit".
Juri Linkov <juri@jurta.org>
parents: 65825
diff changeset
3366 \\[Info-top-node] Go to the Top node of this file.
c4bdbe18630e (Info-mode-menu): Delete menu item "Edit".
Juri Linkov <juri@jurta.org>
parents: 65825
diff changeset
3367 \\[Info-final-node] Go to the final node in this file.
c4bdbe18630e (Info-mode-menu): Delete menu item "Edit".
Juri Linkov <juri@jurta.org>
parents: 65825
diff changeset
3368 \\[Info-backward-node] Go backward one node, considering all nodes as forming one sequence.
c4bdbe18630e (Info-mode-menu): Delete menu item "Edit".
Juri Linkov <juri@jurta.org>
parents: 65825
diff changeset
3369 \\[Info-forward-node] Go forward one node, considering all nodes as forming one sequence.
c4bdbe18630e (Info-mode-menu): Delete menu item "Edit".
Juri Linkov <juri@jurta.org>
parents: 65825
diff changeset
3370 \\[Info-next-reference] Move cursor to next cross-reference or menu item.
c4bdbe18630e (Info-mode-menu): Delete menu item "Edit".
Juri Linkov <juri@jurta.org>
parents: 65825
diff changeset
3371 \\[Info-prev-reference] Move cursor to previous cross-reference or menu item.
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3372 \\[Info-follow-reference] Follow a cross reference. Reads name of reference.
59472
1e81e65f3201 (Info-history-forward): New variable.
Juri Linkov <juri@jurta.org>
parents: 59423
diff changeset
3373 \\[Info-history-back] Move back in history to the last node you were at.
1e81e65f3201 (Info-history-forward): New variable.
Juri Linkov <juri@jurta.org>
parents: 59423
diff changeset
3374 \\[Info-history-forward] Move forward in history to the node you returned from after using \\[Info-history-back].
56044
7aad97855e39 (Info-goto-node): Add autoload.
Juri Linkov <juri@jurta.org>
parents: 55797
diff changeset
3375 \\[Info-history] Go to menu of visited nodes.
7aad97855e39 (Info-goto-node): Add autoload.
Juri Linkov <juri@jurta.org>
parents: 55797
diff changeset
3376 \\[Info-toc] Go to table of contents of the current Info file.
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3377
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3378 Moving within a node:
20514
dd15be266d88 (Info-mode): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 20421
diff changeset
3379 \\[Info-scroll-up] Normally, scroll forward a full screen.
42406
4c72bc09992b (Info-mode): Reindent the doc-string.
Pavel Janík <Pavel@Janik.cz>
parents: 42243
diff changeset
3380 Once you scroll far enough in a node that its menu appears on the
4c72bc09992b (Info-mode): Reindent the doc-string.
Pavel Janík <Pavel@Janik.cz>
parents: 42243
diff changeset
3381 screen but after point, the next scroll moves into its first
4c72bc09992b (Info-mode): Reindent the doc-string.
Pavel Janík <Pavel@Janik.cz>
parents: 42243
diff changeset
3382 subnode. When after all menu items (or if there is no menu),
4c72bc09992b (Info-mode): Reindent the doc-string.
Pavel Janík <Pavel@Janik.cz>
parents: 42243
diff changeset
3383 move up to the parent node.
20514
dd15be266d88 (Info-mode): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 20421
diff changeset
3384 \\[Info-scroll-down] Normally, scroll backward. If the beginning of the buffer is
42406
4c72bc09992b (Info-mode): Reindent the doc-string.
Pavel Janík <Pavel@Janik.cz>
parents: 42243
diff changeset
3385 already visible, try to go to the previous menu entry, or up
4c72bc09992b (Info-mode): Reindent the doc-string.
Pavel Janík <Pavel@Janik.cz>
parents: 42243
diff changeset
3386 if there is none.
28943
36fd90774cf7 (debug-ignored-errors): more errors to ignore.
Sam Steingold <sds@gnu.org>
parents: 28559
diff changeset
3387 \\[beginning-of-buffer] Go to beginning of node.
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3388
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3389 Advanced commands:
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3390 \\[Info-search] Search through this Info file for specified regexp,
42406
4c72bc09992b (Info-mode): Reindent the doc-string.
Pavel Janík <Pavel@Janik.cz>
parents: 42243
diff changeset
3391 and select the node in which the next occurrence is found.
56044
7aad97855e39 (Info-goto-node): Add autoload.
Juri Linkov <juri@jurta.org>
parents: 55797
diff changeset
3392 \\[Info-search-case-sensitively] Search through this Info file for specified regexp case-sensitively.
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3393 \\[Info-search-next] Search for another occurrence of regexp
55074
dd4c270b21af Restore 2004-04-18 changes.
Juri Linkov <juri@jurta.org>
parents: 55061
diff changeset
3394 from a previous \\<Info-mode-map>\\[Info-search] command.
68826
17c561f80e48 (Info-mode): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 68651
diff changeset
3395 \\[Info-index] Search for a topic in this manual's Index and go to index entry.
66010
c4bdbe18630e (Info-mode-menu): Delete menu item "Edit".
Juri Linkov <juri@jurta.org>
parents: 65825
diff changeset
3396 \\[Info-index-next] (comma) Move to the next match from a previous \\<Info-mode-map>\\[Info-index] command.
c4bdbe18630e (Info-mode-menu): Delete menu item "Edit".
Juri Linkov <juri@jurta.org>
parents: 65825
diff changeset
3397 \\[info-apropos] Look for a string in the indices of all manuals.
c4bdbe18630e (Info-mode-menu): Delete menu item "Edit".
Juri Linkov <juri@jurta.org>
parents: 65825
diff changeset
3398 \\[Info-goto-node] Move to node specified by name.
c4bdbe18630e (Info-mode-menu): Delete menu item "Edit".
Juri Linkov <juri@jurta.org>
parents: 65825
diff changeset
3399 You may include a filename as well, as (FILENAME)NODENAME.
c4bdbe18630e (Info-mode-menu): Delete menu item "Edit".
Juri Linkov <juri@jurta.org>
parents: 65825
diff changeset
3400 1 .. 9 Pick first ... ninth item in node's menu.
c4bdbe18630e (Info-mode-menu): Delete menu item "Edit".
Juri Linkov <juri@jurta.org>
parents: 65825
diff changeset
3401 Every third `*' is highlighted to help pick the right number.
c4bdbe18630e (Info-mode-menu): Delete menu item "Edit".
Juri Linkov <juri@jurta.org>
parents: 65825
diff changeset
3402 \\[Info-copy-current-node-name] Put name of current Info node in the kill ring.
c4bdbe18630e (Info-mode-menu): Delete menu item "Edit".
Juri Linkov <juri@jurta.org>
parents: 65825
diff changeset
3403 \\[clone-buffer] Select a new cloned Info buffer in another window.
c4bdbe18630e (Info-mode-menu): Delete menu item "Edit".
Juri Linkov <juri@jurta.org>
parents: 65825
diff changeset
3404 \\[universal-argument] \\[info] Move to new Info file with completion.
c4bdbe18630e (Info-mode-menu): Delete menu item "Edit".
Juri Linkov <juri@jurta.org>
parents: 65825
diff changeset
3405 \\[universal-argument] N \\[info] Select Info buffer with prefix number in the name *info*<N>."
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3406 (kill-all-local-variables)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3407 (setq major-mode 'Info-mode)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3408 (setq mode-name "Info")
16672
1facf218a14f (Info-mode): Default for `tab-width'.
Richard M. Stallman <rms@gnu.org>
parents: 16638
diff changeset
3409 (setq tab-width 8)
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3410 (use-local-map Info-mode-map)
16043
f3a7e1cb07d6 Add menu items and xrefs to the menu bar menu.
Richard M. Stallman <rms@gnu.org>
parents: 15821
diff changeset
3411 (add-hook 'activate-menubar-hook 'Info-menu-update nil t)
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3412 (set-syntax-table text-mode-syntax-table)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3413 (setq local-abbrev-table text-mode-abbrev-table)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3414 (setq case-fold-search t)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3415 (setq buffer-read-only t)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3416 (make-local-variable 'Info-current-file)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3417 (make-local-variable 'Info-current-subfile)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3418 (make-local-variable 'Info-current-node)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3419 (make-local-variable 'Info-tag-table-marker)
16981
643e0f90e153 Handle multiple Info buffers.
Richard M. Stallman <rms@gnu.org>
parents: 16790
diff changeset
3420 (setq Info-tag-table-marker (make-marker))
643e0f90e153 Handle multiple Info buffers.
Richard M. Stallman <rms@gnu.org>
parents: 16790
diff changeset
3421 (make-local-variable 'Info-tag-table-buffer)
643e0f90e153 Handle multiple Info buffers.
Richard M. Stallman <rms@gnu.org>
parents: 16790
diff changeset
3422 (setq Info-tag-table-buffer nil)
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3423 (make-local-variable 'Info-history)
59472
1e81e65f3201 (Info-history-forward): New variable.
Juri Linkov <juri@jurta.org>
parents: 59423
diff changeset
3424 (make-local-variable 'Info-history-forward)
2561
1bd4cf98df68 (Info-find-node, Info-insert-subfile): Do the right thing if info files have
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2038
diff changeset
3425 (make-local-variable 'Info-index-alternatives)
51434
4c85e6a5a9d2 (Info-mode-hook): Obey obsolete `Info-fontify'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51310
diff changeset
3426 (setq header-line-format
4c85e6a5a9d2 (Info-mode-hook): Obey obsolete `Info-fontify'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51310
diff changeset
3427 (if Info-use-header-line
52767
92416cd1e028 (Info-mode): Revert previous change.
Lute Kamstra <lute@gnu.org>
parents: 52756
diff changeset
3428 '(:eval (get-text-property (point-min) 'header-line))
51434
4c85e6a5a9d2 (Info-mode-hook): Obey obsolete `Info-fontify'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51310
diff changeset
3429 nil)) ; so the header line isn't displayed
32286
c0b19a2770ca (Info-goto-node, Info-menu): Doc fix.
Dave Love <fx@gnu.org>
parents: 32007
diff changeset
3430 (set (make-local-variable 'tool-bar-map) info-tool-bar-map)
19043
a2853a75ce57 (info-node, info-xref, info-menu-5):
Richard M. Stallman <rms@gnu.org>
parents: 17968
diff changeset
3431 ;; This is for the sake of the invisible text we use handling titles.
a2853a75ce57 (info-node, info-xref, info-menu-5):
Richard M. Stallman <rms@gnu.org>
parents: 17968
diff changeset
3432 (make-local-variable 'line-move-ignore-invisible)
a2853a75ce57 (info-node, info-xref, info-menu-5):
Richard M. Stallman <rms@gnu.org>
parents: 17968
diff changeset
3433 (setq line-move-ignore-invisible t)
55153
33f0fdb8887c (Info-mode): Rename desktop-buffer-misc-data-function
Lars Hansen <larsh@soem.dk>
parents: 55134
diff changeset
3434 (make-local-variable 'desktop-save-buffer)
61987
aabdcfa2f3d6 (Info-mode): Set widen-automatically to nil, locally.
Richard M. Stallman <rms@gnu.org>
parents: 61450
diff changeset
3435 (make-local-variable 'widen-automatically)
aabdcfa2f3d6 (Info-mode): Set widen-automatically to nil, locally.
Richard M. Stallman <rms@gnu.org>
parents: 61450
diff changeset
3436 (setq widen-automatically nil)
55153
33f0fdb8887c (Info-mode): Rename desktop-buffer-misc-data-function
Lars Hansen <larsh@soem.dk>
parents: 55134
diff changeset
3437 (setq desktop-save-buffer 'Info-desktop-buffer-misc-data)
61363
eebed65dbe97 (Info-mode): Add `Info-kill-buffer' to `kill-buffer-hook'
Juri Linkov <juri@jurta.org>
parents: 61029
diff changeset
3438 (add-hook 'kill-buffer-hook 'Info-kill-buffer nil t)
33189
069c840c65d8 (Info-mode): Don't both with make-local-hook.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33136
diff changeset
3439 (add-hook 'clone-buffer-hook 'Info-clone-buffer-hook nil t)
47376
05b10b9cd8bb (Info-mode): Add font-lock-defontify to change-major-mode-hook.
Richard M. Stallman <rms@gnu.org>
parents: 47327
diff changeset
3440 (add-hook 'change-major-mode-hook 'font-lock-defontify nil t)
60615
643e6516a779 (Info-isearch-initial-node): New internal variable.
Juri Linkov <juri@jurta.org>
parents: 60577
diff changeset
3441 (add-hook 'isearch-mode-hook 'Info-isearch-start nil t)
56866
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
3442 (set (make-local-variable 'isearch-search-fun-function)
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
3443 'Info-isearch-search)
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
3444 (set (make-local-variable 'isearch-wrap-function)
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
3445 'Info-isearch-wrap)
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
3446 (set (make-local-variable 'isearch-push-state-function)
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
3447 'Info-isearch-push-state)
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
3448 (set (make-local-variable 'search-whitespace-regexp)
867d96c29584 (Info-search-whitespace-regexp): Fix backslashes.
Juri Linkov <juri@jurta.org>
parents: 56044
diff changeset
3449 Info-search-whitespace-regexp)
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3450 (Info-set-mode-line)
62733
545cba9e95d4 (Info-mode, Info-edit-mode): Use run-mode-hooks.
Lute Kamstra <lute@gnu.org>
parents: 61987
diff changeset
3451 (run-mode-hooks 'Info-mode-hook))
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3452
61363
eebed65dbe97 (Info-mode): Add `Info-kill-buffer' to `kill-buffer-hook'
Juri Linkov <juri@jurta.org>
parents: 61029
diff changeset
3453 ;; When an Info buffer is killed, make sure the associated tags buffer
eebed65dbe97 (Info-mode): Add `Info-kill-buffer' to `kill-buffer-hook'
Juri Linkov <juri@jurta.org>
parents: 61029
diff changeset
3454 ;; is killed too.
eebed65dbe97 (Info-mode): Add `Info-kill-buffer' to `kill-buffer-hook'
Juri Linkov <juri@jurta.org>
parents: 61029
diff changeset
3455 (defun Info-kill-buffer ()
eebed65dbe97 (Info-mode): Add `Info-kill-buffer' to `kill-buffer-hook'
Juri Linkov <juri@jurta.org>
parents: 61029
diff changeset
3456 (and (eq major-mode 'Info-mode)
eebed65dbe97 (Info-mode): Add `Info-kill-buffer' to `kill-buffer-hook'
Juri Linkov <juri@jurta.org>
parents: 61029
diff changeset
3457 Info-tag-table-buffer
eebed65dbe97 (Info-mode): Add `Info-kill-buffer' to `kill-buffer-hook'
Juri Linkov <juri@jurta.org>
parents: 61029
diff changeset
3458 (kill-buffer Info-tag-table-buffer)))
eebed65dbe97 (Info-mode): Add `Info-kill-buffer' to `kill-buffer-hook'
Juri Linkov <juri@jurta.org>
parents: 61029
diff changeset
3459
26004
11f91800bec3 (Info-on-current-buffer): new entry point.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 25878
diff changeset
3460 (defun Info-clone-buffer-hook ()
11f91800bec3 (Info-on-current-buffer): new entry point.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 25878
diff changeset
3461 (when (bufferp Info-tag-table-buffer)
11f91800bec3 (Info-on-current-buffer): new entry point.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 25878
diff changeset
3462 (setq Info-tag-table-buffer
38262
03f0515fe575 (Info-clone-buffer-hook): Really unconditionally copy marker.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 38225
diff changeset
3463 (with-current-buffer Info-tag-table-buffer (clone-buffer))))
03f0515fe575 (Info-clone-buffer-hook): Really unconditionally copy marker.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 38225
diff changeset
3464 (let ((m Info-tag-table-marker))
03f0515fe575 (Info-clone-buffer-hook): Really unconditionally copy marker.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 38225
diff changeset
3465 (when (markerp m)
38225
5d26670f49df (Info-clone-buffer-hook): Unconditionally copy marker.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37837
diff changeset
3466 (setq Info-tag-table-marker
38262
03f0515fe575 (Info-clone-buffer-hook): Really unconditionally copy marker.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 38225
diff changeset
3467 (if (and (marker-position m) (bufferp Info-tag-table-buffer))
38225
5d26670f49df (Info-clone-buffer-hook): Unconditionally copy marker.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37837
diff changeset
3468 (with-current-buffer Info-tag-table-buffer
5d26670f49df (Info-clone-buffer-hook): Unconditionally copy marker.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37837
diff changeset
3469 (copy-marker (marker-position m)))
5d26670f49df (Info-clone-buffer-hook): Unconditionally copy marker.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37837
diff changeset
3470 (make-marker))))))
26004
11f91800bec3 (Info-on-current-buffer): new entry point.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 25878
diff changeset
3471
32286
c0b19a2770ca (Info-goto-node, Info-menu): Doc fix.
Dave Love <fx@gnu.org>
parents: 32007
diff changeset
3472 (defvar Info-edit-map (let ((map (make-sparse-keymap)))
c0b19a2770ca (Info-goto-node, Info-menu): Doc fix.
Dave Love <fx@gnu.org>
parents: 32007
diff changeset
3473 (set-keymap-parent map text-mode-map)
c0b19a2770ca (Info-goto-node, Info-menu): Doc fix.
Dave Love <fx@gnu.org>
parents: 32007
diff changeset
3474 (define-key map "\C-c\C-c" 'Info-cease-edit)
c0b19a2770ca (Info-goto-node, Info-menu): Doc fix.
Dave Love <fx@gnu.org>
parents: 32007
diff changeset
3475 map)
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3476 "Local keymap used within `e' command of Info.")
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3477
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3478 ;; Info-edit mode is suitable only for specially formatted data.
31798
460c3cd7b368 Use the correct capitalization when making Info-mode and Info-edit-mode
Miles Bader <miles@gnu.org>
parents: 31755
diff changeset
3479 (put 'Info-edit-mode 'mode-class 'special)
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3480
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3481 (defun Info-edit-mode ()
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3482 "Major mode for editing the contents of an Info node.
1477
e31496f6289d Dox fix.
Christopher Zaborsky <rogue@erratum.com>
parents: 1340
diff changeset
3483 Like text mode with the addition of `Info-cease-edit'
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3484 which returns to Info mode for browsing.
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3485 \\{Info-edit-map}"
8805
6d8297d65d78 (Info-edit): Move the customary mode-initialization calls out of here.
Karl Heuer <kwzh@gnu.org>
parents: 8739
diff changeset
3486 (use-local-map Info-edit-map)
6d8297d65d78 (Info-edit): Move the customary mode-initialization calls out of here.
Karl Heuer <kwzh@gnu.org>
parents: 8739
diff changeset
3487 (setq major-mode 'Info-edit-mode)
6d8297d65d78 (Info-edit): Move the customary mode-initialization calls out of here.
Karl Heuer <kwzh@gnu.org>
parents: 8739
diff changeset
3488 (setq mode-name "Info Edit")
6d8297d65d78 (Info-edit): Move the customary mode-initialization calls out of here.
Karl Heuer <kwzh@gnu.org>
parents: 8739
diff changeset
3489 (kill-local-variable 'mode-line-buffer-identification)
6d8297d65d78 (Info-edit): Move the customary mode-initialization calls out of here.
Karl Heuer <kwzh@gnu.org>
parents: 8739
diff changeset
3490 (setq buffer-read-only nil)
11580
7f357fe2cda5 (Info-edit-mode, Info-cease-edit): Use force-mode-line-update.
Karl Heuer <kwzh@gnu.org>
parents: 11527
diff changeset
3491 (force-mode-line-update)
8805
6d8297d65d78 (Info-edit): Move the customary mode-initialization calls out of here.
Karl Heuer <kwzh@gnu.org>
parents: 8739
diff changeset
3492 (buffer-enable-undo (current-buffer))
62733
545cba9e95d4 (Info-mode, Info-edit-mode): Use run-mode-hooks.
Lute Kamstra <lute@gnu.org>
parents: 61987
diff changeset
3493 (run-mode-hooks 'Info-edit-mode-hook))
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3494
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3495 (defun Info-edit ()
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3496 "Edit the contents of this Info node.
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3497 Allowed only if variable `Info-enable-edit' is non-nil."
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3498 (interactive)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3499 (or Info-enable-edit
64812
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
3500 (error "Editing Info nodes is not enabled"))
8805
6d8297d65d78 (Info-edit): Move the customary mode-initialization calls out of here.
Karl Heuer <kwzh@gnu.org>
parents: 8739
diff changeset
3501 (Info-edit-mode)
14319
e39a2eb75dbe (Info-edit, Info-goto-emacs-command-node): Pass proper format string to message.
Karl Heuer <kwzh@gnu.org>
parents: 14169
diff changeset
3502 (message "%s" (substitute-command-keys
29446
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
3503 "Editing: Type \\<Info-edit-map>\\[Info-cease-edit] to return to info")))
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3504
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3505 (defun Info-cease-edit ()
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3506 "Finish editing Info node; switch back to Info proper."
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3507 (interactive)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3508 ;; Do this first, so nothing has changed if user C-g's at query.
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3509 (and (buffer-modified-p)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3510 (y-or-n-p "Save the file? ")
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3511 (save-buffer))
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3512 (use-local-map Info-mode-map)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3513 (setq major-mode 'Info-mode)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3514 (setq mode-name "Info")
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3515 (Info-set-mode-line)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3516 (setq buffer-read-only t)
11580
7f357fe2cda5 (Info-edit-mode, Info-cease-edit): Use force-mode-line-update.
Karl Heuer <kwzh@gnu.org>
parents: 11527
diff changeset
3517 (force-mode-line-update)
325
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3518 (and (marker-position Info-tag-table-marker)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3519 (buffer-modified-p)
3f3710052f22 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3520 (message "Tags may have changed. Use Info-tagify if necessary")))
359
da45fa7bc8d1 *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 325
diff changeset
3521
12889
d912ac1e1f00 (Info-file-list-for-emacs): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 12779
diff changeset
3522 (defvar Info-file-list-for-emacs
57770
c7ff2d3a33ee (Info-file-list-for-emacs): Add ("Info" . "info")
Juri Linkov <juri@jurta.org>
parents: 57672
diff changeset
3523 '("ediff" "eudc" "forms" "gnus" "info" ("Info" . "info") ("mh" . "mh-e")
39364
bd687d055024 (Info-file-list-for-emacs): Add elements for ada-mode, ccmode,
Eli Zaretskii <eliz@gnu.org>
parents: 39213
diff changeset
3524 "sc" "message" ("dired" . "dired-x") "viper" "vip" "idlwave"
bd687d055024 (Info-file-list-for-emacs): Add elements for ada-mode, ccmode,
Eli Zaretskii <eliz@gnu.org>
parents: 39213
diff changeset
3525 ("c" . "ccmode") ("c++" . "ccmode") ("objc" . "ccmode")
bd687d055024 (Info-file-list-for-emacs): Add elements for ada-mode, ccmode,
Eli Zaretskii <eliz@gnu.org>
parents: 39213
diff changeset
3526 ("java" . "ccmode") ("idl" . "ccmode") ("pike" . "ccmode")
30738
5d4414327c06 (Info-file-list-for-emacs): More elements for the
Eli Zaretskii <eliz@gnu.org>
parents: 30686
diff changeset
3527 ("skeleton" . "autotype") ("auto-insert" . "autotype")
5d4414327c06 (Info-file-list-for-emacs): More elements for the
Eli Zaretskii <eliz@gnu.org>
parents: 30686
diff changeset
3528 ("copyright" . "autotype") ("executable" . "autotype")
5d4414327c06 (Info-file-list-for-emacs): More elements for the
Eli Zaretskii <eliz@gnu.org>
parents: 30686
diff changeset
3529 ("time-stamp" . "autotype") ("quickurl" . "autotype")
5d4414327c06 (Info-file-list-for-emacs): More elements for the
Eli Zaretskii <eliz@gnu.org>
parents: 30686
diff changeset
3530 ("tempo" . "autotype") ("hippie-expand" . "autotype")
40845
9d0c6150e159 (Info-file-list-for-emacs): Add entries for Calc.
Eli Zaretskii <eliz@gnu.org>
parents: 40793
diff changeset
3531 ("cvs" . "pcl-cvs") ("ada" . "ada-mode") "calc"
9d0c6150e159 (Info-file-list-for-emacs): Add entries for Calc.
Eli Zaretskii <eliz@gnu.org>
parents: 40793
diff changeset
3532 ("calcAlg" . "calc") ("calcDigit" . "calc") ("calcVar" . "calc")
39364
bd687d055024 (Info-file-list-for-emacs): Add elements for ada-mode, ccmode,
Eli Zaretskii <eliz@gnu.org>
parents: 39213
diff changeset
3533 "ebrowse" "eshell" "cl" "reftex" "speedbar" "widget" "woman"
bd687d055024 (Info-file-list-for-emacs): Add elements for ada-mode, ccmode,
Eli Zaretskii <eliz@gnu.org>
parents: 39213
diff changeset
3534 ("mail-header" . "emacs-mime") ("mail-content" . "emacs-mime")
bd687d055024 (Info-file-list-for-emacs): Add elements for ada-mode, ccmode,
Eli Zaretskii <eliz@gnu.org>
parents: 39213
diff changeset
3535 ("mail-encode" . "emacs-mime") ("mail-decode" . "emacs-mime")
bd687d055024 (Info-file-list-for-emacs): Add elements for ada-mode, ccmode,
Eli Zaretskii <eliz@gnu.org>
parents: 39213
diff changeset
3536 ("rfc2045" . "emacs-mime")
bd687d055024 (Info-file-list-for-emacs): Add elements for ada-mode, ccmode,
Eli Zaretskii <eliz@gnu.org>
parents: 39213
diff changeset
3537 ("rfc2231" . "emacs-mime") ("rfc2047" . "emacs-mime")
bd687d055024 (Info-file-list-for-emacs): Add elements for ada-mode, ccmode,
Eli Zaretskii <eliz@gnu.org>
parents: 39213
diff changeset
3538 ("rfc2045" . "emacs-mime") ("rfc1843" . "emacs-mime")
bd687d055024 (Info-file-list-for-emacs): Add elements for ada-mode, ccmode,
Eli Zaretskii <eliz@gnu.org>
parents: 39213
diff changeset
3539 ("ietf-drums" . "emacs-mime") ("quoted-printable" . "emacs-mime")
bd687d055024 (Info-file-list-for-emacs): Add elements for ada-mode, ccmode,
Eli Zaretskii <eliz@gnu.org>
parents: 39213
diff changeset
3540 ("binhex" . "emacs-mime") ("uudecode" . "emacs-mime")
bd687d055024 (Info-file-list-for-emacs): Add elements for ada-mode, ccmode,
Eli Zaretskii <eliz@gnu.org>
parents: 39213
diff changeset
3541 ("mailcap" . "emacs-mime") ("mm" . "emacs-mime")
bd687d055024 (Info-file-list-for-emacs): Add elements for ada-mode, ccmode,
Eli Zaretskii <eliz@gnu.org>
parents: 39213
diff changeset
3542 ("mml" . "emacs-mime"))
12889
d912ac1e1f00 (Info-file-list-for-emacs): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 12779
diff changeset
3543 "List of Info files that describe Emacs commands.
d912ac1e1f00 (Info-file-list-for-emacs): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 12779
diff changeset
3544 An element can be a file name, or a list of the form (PREFIX . FILE)
d912ac1e1f00 (Info-file-list-for-emacs): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 12779
diff changeset
3545 where PREFIX is a name prefix and FILE is the file to look in.
d912ac1e1f00 (Info-file-list-for-emacs): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 12779
diff changeset
3546 If the element is just a file name, the file name also serves as the prefix.")
d912ac1e1f00 (Info-file-list-for-emacs): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 12779
diff changeset
3547
359
da45fa7bc8d1 *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 325
diff changeset
3548 (defun Info-find-emacs-command-nodes (command)
12889
d912ac1e1f00 (Info-file-list-for-emacs): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 12779
diff changeset
3549 "Return a list of locations documenting COMMAND.
12892
8b902b24d749 (Info-find-emacs-command-nodes): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 12889
diff changeset
3550 The `info-file' property of COMMAND says which Info manual to search.
8b902b24d749 (Info-find-emacs-command-nodes): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 12889
diff changeset
3551 If COMMAND has no property, the variable `Info-file-list-for-emacs'
8b902b24d749 (Info-find-emacs-command-nodes): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 12889
diff changeset
3552 defines heuristics for which Info manual to try.
29621
f03c3a69a809 Doc fixes.
Dave Love <fx@gnu.org>
parents: 29583
diff changeset
3553 The locations are of the format used in `Info-history', i.e.
57770
c7ff2d3a33ee (Info-file-list-for-emacs): Add ("Info" . "info")
Juri Linkov <juri@jurta.org>
parents: 57672
diff changeset
3554 \(FILENAME NODENAME BUFFERPOS\), where BUFFERPOS is the line number
c7ff2d3a33ee (Info-file-list-for-emacs): Add ("Info" . "info")
Juri Linkov <juri@jurta.org>
parents: 57672
diff changeset
3555 in the first element of the returned list (which is treated specially in
c7ff2d3a33ee (Info-file-list-for-emacs): Add ("Info" . "info")
Juri Linkov <juri@jurta.org>
parents: 57672
diff changeset
3556 `Info-goto-emacs-command-node'), and 0 for the rest elements of a list."
c7ff2d3a33ee (Info-file-list-for-emacs): Add ("Info" . "info")
Juri Linkov <juri@jurta.org>
parents: 57672
diff changeset
3557 (let ((where '()) line-number
21641
1174b1d6cbf6 (Info-menu): Allow extra spaces at start of menu item.
Richard M. Stallman <rms@gnu.org>
parents: 21197
diff changeset
3558 (cmd-desc (concat "^\\* +" (regexp-quote (symbol-name command))
57672
d8b07169ce26 (Info-find-emacs-command-nodes): Adapt to Texinfo-4.7 style indexes.
Luc Teirlinck <teirllm@auburn.edu>
parents: 57567
diff changeset
3559 "\\( <[0-9]+>\\)?:\\s *\\(.*\\)\\."
57770
c7ff2d3a33ee (Info-file-list-for-emacs): Add ("Info" . "info")
Juri Linkov <juri@jurta.org>
parents: 57672
diff changeset
3560 "\\(?:[ \t\n]+(line +\\([0-9]+\\))\\)?"))
12889
d912ac1e1f00 (Info-file-list-for-emacs): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 12779
diff changeset
3561 (info-file "emacs")) ;default
64812
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
3562 ;; Determine which Info file this command is documented in.
12889
d912ac1e1f00 (Info-file-list-for-emacs): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 12779
diff changeset
3563 (if (get command 'info-file)
d912ac1e1f00 (Info-file-list-for-emacs): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 12779
diff changeset
3564 (setq info-file (get command 'info-file))
d912ac1e1f00 (Info-file-list-for-emacs): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 12779
diff changeset
3565 ;; If it doesn't say explicitly, test its name against
d912ac1e1f00 (Info-file-list-for-emacs): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 12779
diff changeset
3566 ;; various prefixes that we know.
d912ac1e1f00 (Info-file-list-for-emacs): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 12779
diff changeset
3567 (let ((file-list Info-file-list-for-emacs))
d912ac1e1f00 (Info-file-list-for-emacs): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 12779
diff changeset
3568 (while file-list
d912ac1e1f00 (Info-file-list-for-emacs): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 12779
diff changeset
3569 (let* ((elt (car file-list))
d912ac1e1f00 (Info-file-list-for-emacs): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 12779
diff changeset
3570 (name (if (consp elt)
d912ac1e1f00 (Info-file-list-for-emacs): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 12779
diff changeset
3571 (car elt)
d912ac1e1f00 (Info-file-list-for-emacs): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 12779
diff changeset
3572 elt))
d912ac1e1f00 (Info-file-list-for-emacs): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 12779
diff changeset
3573 (file (if (consp elt) (cdr elt) elt))
57468
478f1e91eac3 (info-xref): Add underlining.
Richard M. Stallman <rms@gnu.org>
parents: 57329
diff changeset
3574 (case-fold-search nil)
12892
8b902b24d749 (Info-find-emacs-command-nodes): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 12889
diff changeset
3575 (regexp (concat "\\`" (regexp-quote name)
12889
d912ac1e1f00 (Info-file-list-for-emacs): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 12779
diff changeset
3576 "\\(\\'\\|-\\)")))
d912ac1e1f00 (Info-file-list-for-emacs): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 12779
diff changeset
3577 (if (string-match regexp (symbol-name command))
d912ac1e1f00 (Info-file-list-for-emacs): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 12779
diff changeset
3578 (setq info-file file file-list nil))
d912ac1e1f00 (Info-file-list-for-emacs): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 12779
diff changeset
3579 (setq file-list (cdr file-list))))))
30763
46173131cdc4 (Info-find-emacs-command-nodes): Rewrite to use
Eli Zaretskii <eliz@gnu.org>
parents: 30738
diff changeset
3580 (Info-find-node info-file "Top")
46173131cdc4 (Info-find-emacs-command-nodes): Rewrite to use
Eli Zaretskii <eliz@gnu.org>
parents: 30738
diff changeset
3581 ;; Bind Info-history to nil, to prevent the index nodes from
46173131cdc4 (Info-find-emacs-command-nodes): Rewrite to use
Eli Zaretskii <eliz@gnu.org>
parents: 30738
diff changeset
3582 ;; getting into the node history.
46173131cdc4 (Info-find-emacs-command-nodes): Rewrite to use
Eli Zaretskii <eliz@gnu.org>
parents: 30738
diff changeset
3583 (let ((Info-history nil)
55751
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
3584 (Info-history-list nil)
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
3585 node (nodes (Info-index-nodes)))
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
3586 (Info-goto-node (car nodes))
30763
46173131cdc4 (Info-find-emacs-command-nodes): Rewrite to use
Eli Zaretskii <eliz@gnu.org>
parents: 30738
diff changeset
3587 (while
46173131cdc4 (Info-find-emacs-command-nodes): Rewrite to use
Eli Zaretskii <eliz@gnu.org>
parents: 30738
diff changeset
3588 (progn
46173131cdc4 (Info-find-emacs-command-nodes): Rewrite to use
Eli Zaretskii <eliz@gnu.org>
parents: 30738
diff changeset
3589 (goto-char (point-min))
46173131cdc4 (Info-find-emacs-command-nodes): Rewrite to use
Eli Zaretskii <eliz@gnu.org>
parents: 30738
diff changeset
3590 (while (re-search-forward cmd-desc nil t)
46173131cdc4 (Info-find-emacs-command-nodes): Rewrite to use
Eli Zaretskii <eliz@gnu.org>
parents: 30738
diff changeset
3591 (setq where
46173131cdc4 (Info-find-emacs-command-nodes): Rewrite to use
Eli Zaretskii <eliz@gnu.org>
parents: 30738
diff changeset
3592 (cons (list Info-current-file
46173131cdc4 (Info-find-emacs-command-nodes): Rewrite to use
Eli Zaretskii <eliz@gnu.org>
parents: 30738
diff changeset
3593 (match-string-no-properties 2)
29446
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
3594 0)
57770
c7ff2d3a33ee (Info-file-list-for-emacs): Add ("Info" . "info")
Juri Linkov <juri@jurta.org>
parents: 57672
diff changeset
3595 where))
c7ff2d3a33ee (Info-file-list-for-emacs): Add ("Info" . "info")
Juri Linkov <juri@jurta.org>
parents: 57672
diff changeset
3596 (setq line-number (and (match-beginning 3)
c7ff2d3a33ee (Info-file-list-for-emacs): Add ("Info" . "info")
Juri Linkov <juri@jurta.org>
parents: 57672
diff changeset
3597 (string-to-number (match-string 3)))))
55751
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
3598 (and (setq nodes (cdr nodes) node (car nodes))))
30763
46173131cdc4 (Info-find-emacs-command-nodes): Rewrite to use
Eli Zaretskii <eliz@gnu.org>
parents: 30738
diff changeset
3599 (Info-goto-node node)))
57770
c7ff2d3a33ee (Info-file-list-for-emacs): Add ("Info" . "info")
Juri Linkov <juri@jurta.org>
parents: 57672
diff changeset
3600 (if (and line-number where)
c7ff2d3a33ee (Info-file-list-for-emacs): Add ("Info" . "info")
Juri Linkov <juri@jurta.org>
parents: 57672
diff changeset
3601 (cons (list (nth 0 (car where)) (nth 1 (car where)) line-number)
c7ff2d3a33ee (Info-file-list-for-emacs): Add ("Info" . "info")
Juri Linkov <juri@jurta.org>
parents: 57672
diff changeset
3602 (cdr where))
c7ff2d3a33ee (Info-file-list-for-emacs): Add ("Info" . "info")
Juri Linkov <juri@jurta.org>
parents: 57672
diff changeset
3603 where)))
359
da45fa7bc8d1 *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 325
diff changeset
3604
57770
c7ff2d3a33ee (Info-file-list-for-emacs): Add ("Info" . "info")
Juri Linkov <juri@jurta.org>
parents: 57672
diff changeset
3605 ;;;###autoload (put 'Info-goto-emacs-command-node 'info-file "emacs")
359
da45fa7bc8d1 *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 325
diff changeset
3606 ;;;###autoload
da45fa7bc8d1 *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 325
diff changeset
3607 (defun Info-goto-emacs-command-node (command)
4468
5e9224dac452 (Info-goto-emacs-command-node, Info-goto-emacs-key-command-node): Doc fix.
Roland McGrath <roland@gnu.org>
parents: 4410
diff changeset
3608 "Go to the Info node in the Emacs manual for command COMMAND.
35112
dfb7567dbcfd (Info-goto-emacs-key-command-node): Doc fix.
Eli Zaretskii <eliz@gnu.org>
parents: 35079
diff changeset
3609 The command is found by looking up in Emacs manual's indices
12892
8b902b24d749 (Info-find-emacs-command-nodes): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 12889
diff changeset
3610 or in another manual found via COMMAND's `info-file' property or
53246
c07db7df7073 (Info-unescape-quotes, Info-split-parameter-string)
John Paul Wallington <jpw@pobox.com>
parents: 52767
diff changeset
3611 the variable `Info-file-list-for-emacs'.
c07db7df7073 (Info-unescape-quotes, Info-split-parameter-string)
John Paul Wallington <jpw@pobox.com>
parents: 52767
diff changeset
3612 COMMAND must be a symbol or string."
359
da45fa7bc8d1 *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 325
diff changeset
3613 (interactive "CFind documentation for command: ")
50454
583825022e8f (Info-goto-emacs-command-node): If command
Masatake YAMATO <jet@gyve.org>
parents: 50072
diff changeset
3614 ;; If command is given as a string, convert it to a symbol.
583825022e8f (Info-goto-emacs-command-node): If command
Masatake YAMATO <jet@gyve.org>
parents: 50072
diff changeset
3615 (if (stringp command)
53246
c07db7df7073 (Info-unescape-quotes, Info-split-parameter-string)
John Paul Wallington <jpw@pobox.com>
parents: 52767
diff changeset
3616 (setq command (intern command)))
359
da45fa7bc8d1 *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 325
diff changeset
3617 (or (commandp command)
da45fa7bc8d1 *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 325
diff changeset
3618 (signal 'wrong-type-argument (list 'commandp command)))
da45fa7bc8d1 *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 325
diff changeset
3619 (let ((where (Info-find-emacs-command-nodes command)))
da45fa7bc8d1 *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 325
diff changeset
3620 (if where
da45fa7bc8d1 *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 325
diff changeset
3621 (let ((num-matches (length where)))
da45fa7bc8d1 *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 325
diff changeset
3622 ;; Get Info running, and pop to it in another window.
da45fa7bc8d1 *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 325
diff changeset
3623 (save-window-excursion
da45fa7bc8d1 *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 325
diff changeset
3624 (info))
55074
dd4c270b21af Restore 2004-04-18 changes.
Juri Linkov <juri@jurta.org>
parents: 55061
diff changeset
3625 (or (eq major-mode 'Info-mode) (pop-to-buffer "*info*"))
30763
46173131cdc4 (Info-find-emacs-command-nodes): Rewrite to use
Eli Zaretskii <eliz@gnu.org>
parents: 30738
diff changeset
3626 ;; Bind Info-history to nil, to prevent the last Index node
46173131cdc4 (Info-find-emacs-command-nodes): Rewrite to use
Eli Zaretskii <eliz@gnu.org>
parents: 30738
diff changeset
3627 ;; visited by Info-find-emacs-command-nodes from being
46173131cdc4 (Info-find-emacs-command-nodes): Rewrite to use
Eli Zaretskii <eliz@gnu.org>
parents: 30738
diff changeset
3628 ;; pushed onto the history.
57770
c7ff2d3a33ee (Info-file-list-for-emacs): Add ("Info" . "info")
Juri Linkov <juri@jurta.org>
parents: 57672
diff changeset
3629 (let ((Info-history nil) (Info-history-list nil)
c7ff2d3a33ee (Info-file-list-for-emacs): Add ("Info" . "info")
Juri Linkov <juri@jurta.org>
parents: 57672
diff changeset
3630 (line-number (nth 2 (car where))))
c7ff2d3a33ee (Info-file-list-for-emacs): Add ("Info" . "info")
Juri Linkov <juri@jurta.org>
parents: 57672
diff changeset
3631 (Info-find-node (nth 0 (car where)) (nth 1 (car where)))
c7ff2d3a33ee (Info-file-list-for-emacs): Add ("Info" . "info")
Juri Linkov <juri@jurta.org>
parents: 57672
diff changeset
3632 (if (and (integerp line-number) (> line-number 0))
c7ff2d3a33ee (Info-file-list-for-emacs): Add ("Info" . "info")
Juri Linkov <juri@jurta.org>
parents: 57672
diff changeset
3633 (forward-line (1- line-number))))
359
da45fa7bc8d1 *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 325
diff changeset
3634 (if (> num-matches 1)
da45fa7bc8d1 *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 325
diff changeset
3635 (progn
30763
46173131cdc4 (Info-find-emacs-command-nodes): Rewrite to use
Eli Zaretskii <eliz@gnu.org>
parents: 30738
diff changeset
3636 ;; (car where) will be pushed onto Info-history
46173131cdc4 (Info-find-emacs-command-nodes): Rewrite to use
Eli Zaretskii <eliz@gnu.org>
parents: 30738
diff changeset
3637 ;; when/if they go to another node. Put the other
46173131cdc4 (Info-find-emacs-command-nodes): Rewrite to use
Eli Zaretskii <eliz@gnu.org>
parents: 30738
diff changeset
3638 ;; nodes that were found on the history.
359
da45fa7bc8d1 *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 325
diff changeset
3639 (setq Info-history (nconc (cdr where) Info-history))
14319
e39a2eb75dbe (Info-edit, Info-goto-emacs-command-node): Pass proper format string to message.
Karl Heuer <kwzh@gnu.org>
parents: 14169
diff changeset
3640 (message "Found %d other entr%s. Use %s to see %s."
6049
32df2b4d67cf (Info-build-node-completions): Add a call to widen.
Richard M. Stallman <rms@gnu.org>
parents: 5555
diff changeset
3641 (1- num-matches)
32df2b4d67cf (Info-build-node-completions): Add a call to widen.
Richard M. Stallman <rms@gnu.org>
parents: 5555
diff changeset
3642 (if (> num-matches 2) "ies" "y")
59472
1e81e65f3201 (Info-history-forward): New variable.
Juri Linkov <juri@jurta.org>
parents: 59423
diff changeset
3643 (substitute-command-keys "\\[Info-history-back]")
6049
32df2b4d67cf (Info-build-node-completions): Add a call to widen.
Richard M. Stallman <rms@gnu.org>
parents: 5555
diff changeset
3644 (if (> num-matches 2) "them" "it")))))
14355
87fde6ef6c95 (Info-goto-emacs-command-node): Fix error text.
Karl Heuer <kwzh@gnu.org>
parents: 14319
diff changeset
3645 (error "Couldn't find documentation for %s" command))))
359
da45fa7bc8d1 *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 325
diff changeset
3646
57770
c7ff2d3a33ee (Info-file-list-for-emacs): Add ("Info" . "info")
Juri Linkov <juri@jurta.org>
parents: 57672
diff changeset
3647 ;;;###autoload (put 'Info-goto-emacs-key-command-node 'info-file "emacs")
359
da45fa7bc8d1 *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 325
diff changeset
3648 ;;;###autoload
da45fa7bc8d1 *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 325
diff changeset
3649 (defun Info-goto-emacs-key-command-node (key)
35112
dfb7567dbcfd (Info-goto-emacs-key-command-node): Doc fix.
Eli Zaretskii <eliz@gnu.org>
parents: 35079
diff changeset
3650 "Go to the node in the Emacs manual which describes the command bound to KEY.
dfb7567dbcfd (Info-goto-emacs-key-command-node): Doc fix.
Eli Zaretskii <eliz@gnu.org>
parents: 35079
diff changeset
3651 KEY is a string.
29621
f03c3a69a809 Doc fixes.
Dave Love <fx@gnu.org>
parents: 29583
diff changeset
3652 Interactively, if the binding is `execute-extended-command', a command is read.
35112
dfb7567dbcfd (Info-goto-emacs-key-command-node): Doc fix.
Eli Zaretskii <eliz@gnu.org>
parents: 35079
diff changeset
3653 The command is found by looking up in Emacs manual's indices
12892
8b902b24d749 (Info-find-emacs-command-nodes): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 12889
diff changeset
3654 or in another manual found via COMMAND's `info-file' property or
8b902b24d749 (Info-find-emacs-command-nodes): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 12889
diff changeset
3655 the variable `Info-file-list-for-emacs'."
30423
424236a05a4f (Info-goto-emacs-key-command-node): Leave a space after
Eli Zaretskii <eliz@gnu.org>
parents: 30287
diff changeset
3656 (interactive "kFind documentation for key: ")
359
da45fa7bc8d1 *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 325
diff changeset
3657 (let ((command (key-binding key)))
da45fa7bc8d1 *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 325
diff changeset
3658 (cond ((null command)
1484
6c2a714566d3 Rename buffer-flush-undo to buffer-disable-undo.
Richard M. Stallman <rms@gnu.org>
parents: 1477
diff changeset
3659 (message "%s is undefined" (key-description key)))
359
da45fa7bc8d1 *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 325
diff changeset
3660 ((and (interactive-p)
da45fa7bc8d1 *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 325
diff changeset
3661 (eq command 'execute-extended-command))
da45fa7bc8d1 *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 325
diff changeset
3662 (Info-goto-emacs-command-node
da45fa7bc8d1 *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 325
diff changeset
3663 (read-command "Find documentation for command: ")))
da45fa7bc8d1 *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 325
diff changeset
3664 (t
da45fa7bc8d1 *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 325
diff changeset
3665 (Info-goto-emacs-command-node command)))))
4410
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
3666
45784
95b7f625cdf5 (Info-fontify-node): Compute header line specially
Richard M. Stallman <rms@gnu.org>
parents: 45775
diff changeset
3667 (defvar Info-next-link-keymap
95b7f625cdf5 (Info-fontify-node): Compute header line specially
Richard M. Stallman <rms@gnu.org>
parents: 45775
diff changeset
3668 (let ((keymap (make-sparse-keymap)))
95b7f625cdf5 (Info-fontify-node): Compute header line specially
Richard M. Stallman <rms@gnu.org>
parents: 45775
diff changeset
3669 (define-key keymap [header-line mouse-1] 'Info-next)
95b7f625cdf5 (Info-fontify-node): Compute header line specially
Richard M. Stallman <rms@gnu.org>
parents: 45775
diff changeset
3670 (define-key keymap [header-line mouse-2] 'Info-next)
95b7f625cdf5 (Info-fontify-node): Compute header line specially
Richard M. Stallman <rms@gnu.org>
parents: 45775
diff changeset
3671 (define-key keymap [header-line down-mouse-1] 'ignore)
95b7f625cdf5 (Info-fontify-node): Compute header line specially
Richard M. Stallman <rms@gnu.org>
parents: 45775
diff changeset
3672 (define-key keymap [mouse-2] 'Info-next)
59423
3eca2bed63e4 (Info-mode-map, Info-next-link-keymap)
Kim F. Storm <storm@cua.dk>
parents: 58936
diff changeset
3673 (define-key keymap [follow-link] 'mouse-face)
45784
95b7f625cdf5 (Info-fontify-node): Compute header line specially
Richard M. Stallman <rms@gnu.org>
parents: 45775
diff changeset
3674 keymap)
95b7f625cdf5 (Info-fontify-node): Compute header line specially
Richard M. Stallman <rms@gnu.org>
parents: 45775
diff changeset
3675 "Keymap to put on the Next link in the text or the header line.")
95b7f625cdf5 (Info-fontify-node): Compute header line specially
Richard M. Stallman <rms@gnu.org>
parents: 45775
diff changeset
3676
95b7f625cdf5 (Info-fontify-node): Compute header line specially
Richard M. Stallman <rms@gnu.org>
parents: 45775
diff changeset
3677 (defvar Info-prev-link-keymap
95b7f625cdf5 (Info-fontify-node): Compute header line specially
Richard M. Stallman <rms@gnu.org>
parents: 45775
diff changeset
3678 (let ((keymap (make-sparse-keymap)))
95b7f625cdf5 (Info-fontify-node): Compute header line specially
Richard M. Stallman <rms@gnu.org>
parents: 45775
diff changeset
3679 (define-key keymap [header-line mouse-1] 'Info-prev)
95b7f625cdf5 (Info-fontify-node): Compute header line specially
Richard M. Stallman <rms@gnu.org>
parents: 45775
diff changeset
3680 (define-key keymap [header-line mouse-2] 'Info-prev)
95b7f625cdf5 (Info-fontify-node): Compute header line specially
Richard M. Stallman <rms@gnu.org>
parents: 45775
diff changeset
3681 (define-key keymap [header-line down-mouse-1] 'ignore)
95b7f625cdf5 (Info-fontify-node): Compute header line specially
Richard M. Stallman <rms@gnu.org>
parents: 45775
diff changeset
3682 (define-key keymap [mouse-2] 'Info-prev)
59423
3eca2bed63e4 (Info-mode-map, Info-next-link-keymap)
Kim F. Storm <storm@cua.dk>
parents: 58936
diff changeset
3683 (define-key keymap [follow-link] 'mouse-face)
45784
95b7f625cdf5 (Info-fontify-node): Compute header line specially
Richard M. Stallman <rms@gnu.org>
parents: 45775
diff changeset
3684 keymap)
95b7f625cdf5 (Info-fontify-node): Compute header line specially
Richard M. Stallman <rms@gnu.org>
parents: 45775
diff changeset
3685 "Keymap to put on the Prev link in the text or the header line.")
95b7f625cdf5 (Info-fontify-node): Compute header line specially
Richard M. Stallman <rms@gnu.org>
parents: 45775
diff changeset
3686
95b7f625cdf5 (Info-fontify-node): Compute header line specially
Richard M. Stallman <rms@gnu.org>
parents: 45775
diff changeset
3687 (defvar Info-up-link-keymap
95b7f625cdf5 (Info-fontify-node): Compute header line specially
Richard M. Stallman <rms@gnu.org>
parents: 45775
diff changeset
3688 (let ((keymap (make-sparse-keymap)))
95b7f625cdf5 (Info-fontify-node): Compute header line specially
Richard M. Stallman <rms@gnu.org>
parents: 45775
diff changeset
3689 (define-key keymap [header-line mouse-1] 'Info-up)
95b7f625cdf5 (Info-fontify-node): Compute header line specially
Richard M. Stallman <rms@gnu.org>
parents: 45775
diff changeset
3690 (define-key keymap [header-line mouse-2] 'Info-up)
95b7f625cdf5 (Info-fontify-node): Compute header line specially
Richard M. Stallman <rms@gnu.org>
parents: 45775
diff changeset
3691 (define-key keymap [header-line down-mouse-1] 'ignore)
95b7f625cdf5 (Info-fontify-node): Compute header line specially
Richard M. Stallman <rms@gnu.org>
parents: 45775
diff changeset
3692 (define-key keymap [mouse-2] 'Info-up)
59423
3eca2bed63e4 (Info-mode-map, Info-next-link-keymap)
Kim F. Storm <storm@cua.dk>
parents: 58936
diff changeset
3693 (define-key keymap [follow-link] 'mouse-face)
45784
95b7f625cdf5 (Info-fontify-node): Compute header line specially
Richard M. Stallman <rms@gnu.org>
parents: 45775
diff changeset
3694 keymap)
95b7f625cdf5 (Info-fontify-node): Compute header line specially
Richard M. Stallman <rms@gnu.org>
parents: 45775
diff changeset
3695 "Keymap to put on the Up link in the text or the header line.")
95b7f625cdf5 (Info-fontify-node): Compute header line specially
Richard M. Stallman <rms@gnu.org>
parents: 45775
diff changeset
3696
4410
25fb71fc2643 (Info-fontify-node): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4261
diff changeset
3697 (defun Info-fontify-node ()
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3698 "Fontify the node."
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3699 (save-excursion
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3700 (let* ((inhibit-read-only t)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3701 (case-fold-search t)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3702 paragraph-markers
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3703 (not-fontified-p ; the node hasn't already been fontified
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3704 (not (let ((where (next-property-change (point-min))))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3705 (and where (not (= where (point-max)))))))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3706 (fontify-visited-p ; visited nodes need to be re-fontified
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3707 (and Info-fontify-visited-nodes
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3708 ;; Don't take time to refontify visited nodes in huge nodes
75750
9d47b3ad340e (Info-fontify-maximum-menu-size): Document the effect of a nil value.
Eli Zaretskii <eliz@gnu.org>
parents: 75347
diff changeset
3709 Info-fontify-maximum-menu-size
57567
b313796ea830 (Info-fontify-node): For multiline refs,
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 57468
diff changeset
3710 (< (- (point-max) (point-min)) Info-fontify-maximum-menu-size)))
b313796ea830 (Info-fontify-node): For multiline refs,
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 57468
diff changeset
3711 rbeg rend)
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3712
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3713 ;; Fontify header line
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3714 (goto-char (point-min))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3715 (when (and not-fontified-p (looking-at "^\\(File: [^,: \t]+,?[ \t]+\\)?"))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3716 (goto-char (match-end 0))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3717 (while (looking-at "[ \t]*\\([^:, \t\n]+\\):[ \t]+\\([^:,\t\n]+\\),?")
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3718 (goto-char (match-end 0))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3719 (let* ((nbeg (match-beginning 2))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3720 (nend (match-end 2))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3721 (tbeg (match-beginning 1))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3722 (tag (match-string 1)))
66604
8c3381fde2cc (Info-fontify-node): Downcase node header keywords Node,
Juri Linkov <juri@jurta.org>
parents: 66602
diff changeset
3723 (if (string-equal (downcase tag) "node")
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3724 (put-text-property nbeg nend 'font-lock-face 'info-header-node)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3725 (put-text-property nbeg nend 'font-lock-face 'info-header-xref)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3726 (put-text-property tbeg nend 'mouse-face 'highlight)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3727 (put-text-property tbeg nend
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3728 'help-echo
59423
3eca2bed63e4 (Info-mode-map, Info-next-link-keymap)
Kim F. Storm <storm@cua.dk>
parents: 58936
diff changeset
3729 (concat "mouse-2: Go to node "
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3730 (buffer-substring nbeg nend)))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3731 ;; Always set up the text property keymap.
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3732 ;; It will either be used in the buffer
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3733 ;; or copied in the header line.
66604
8c3381fde2cc (Info-fontify-node): Downcase node header keywords Node,
Juri Linkov <juri@jurta.org>
parents: 66602
diff changeset
3734 (put-text-property
8c3381fde2cc (Info-fontify-node): Downcase node header keywords Node,
Juri Linkov <juri@jurta.org>
parents: 66602
diff changeset
3735 tbeg nend 'keymap
8c3381fde2cc (Info-fontify-node): Downcase node header keywords Node,
Juri Linkov <juri@jurta.org>
parents: 66602
diff changeset
3736 (cond
8c3381fde2cc (Info-fontify-node): Downcase node header keywords Node,
Juri Linkov <juri@jurta.org>
parents: 66602
diff changeset
3737 ((string-equal (downcase tag) "prev") Info-prev-link-keymap)
8c3381fde2cc (Info-fontify-node): Downcase node header keywords Node,
Juri Linkov <juri@jurta.org>
parents: 66602
diff changeset
3738 ((string-equal (downcase tag) "next") Info-next-link-keymap)
8c3381fde2cc (Info-fontify-node): Downcase node header keywords Node,
Juri Linkov <juri@jurta.org>
parents: 66602
diff changeset
3739 ((string-equal (downcase tag) "up" ) Info-up-link-keymap))))))
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3740 (when Info-use-header-line
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3741 (goto-char (point-min))
66057
709ea6d61dbd (Info-fontify-node): Don't be fooled by a lone "...".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 66010
diff changeset
3742 (let* ((header-end (line-end-position))
709ea6d61dbd (Info-fontify-node): Don't be fooled by a lone "...".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 66010
diff changeset
3743 (header
709ea6d61dbd (Info-fontify-node): Don't be fooled by a lone "...".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 66010
diff changeset
3744 ;; If we find neither Next: nor Prev: link, show the entire
709ea6d61dbd (Info-fontify-node): Don't be fooled by a lone "...".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 66010
diff changeset
3745 ;; node header. Otherwise, don't show the File: and Node:
709ea6d61dbd (Info-fontify-node): Don't be fooled by a lone "...".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 66010
diff changeset
3746 ;; parts, to avoid wasting precious space on information that
709ea6d61dbd (Info-fontify-node): Don't be fooled by a lone "...".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 66010
diff changeset
3747 ;; is available in the mode line.
709ea6d61dbd (Info-fontify-node): Don't be fooled by a lone "...".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 66010
diff changeset
3748 (if (re-search-forward
709ea6d61dbd (Info-fontify-node): Don't be fooled by a lone "...".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 66010
diff changeset
3749 "\\(next\\|up\\|prev[ious]*\\): "
709ea6d61dbd (Info-fontify-node): Don't be fooled by a lone "...".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 66010
diff changeset
3750 header-end t)
709ea6d61dbd (Info-fontify-node): Don't be fooled by a lone "...".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 66010
diff changeset
3751 (progn
709ea6d61dbd (Info-fontify-node): Don't be fooled by a lone "...".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 66010
diff changeset
3752 (goto-char (match-beginning 1))
709ea6d61dbd (Info-fontify-node): Don't be fooled by a lone "...".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 66010
diff changeset
3753 (buffer-substring (point) header-end))
709ea6d61dbd (Info-fontify-node): Don't be fooled by a lone "...".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 66010
diff changeset
3754 (if (re-search-forward "node:[ \t]*[^ \t]+[ \t]*"
709ea6d61dbd (Info-fontify-node): Don't be fooled by a lone "...".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 66010
diff changeset
3755 header-end t)
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3756 (concat "No next, prev or up links -- "
66057
709ea6d61dbd (Info-fontify-node): Don't be fooled by a lone "...".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 66010
diff changeset
3757 (buffer-substring (point) header-end))
709ea6d61dbd (Info-fontify-node): Don't be fooled by a lone "...".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 66010
diff changeset
3758 (buffer-substring (point) header-end)))))
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3759 (put-text-property (point-min) (1+ (point-min))
65069
fc42a1decf2d (Info-insert-dir): Use save-excursion around insert-buffer-substring.
Juri Linkov <juri@jurta.org>
parents: 64961
diff changeset
3760 'header-line
fc42a1decf2d (Info-insert-dir): Use save-excursion around insert-buffer-substring.
Juri Linkov <juri@jurta.org>
parents: 64961
diff changeset
3761 (replace-regexp-in-string
fc42a1decf2d (Info-insert-dir): Use save-excursion around insert-buffer-substring.
Juri Linkov <juri@jurta.org>
parents: 64961
diff changeset
3762 "%"
fc42a1decf2d (Info-insert-dir): Use save-excursion around insert-buffer-substring.
Juri Linkov <juri@jurta.org>
parents: 64961
diff changeset
3763 ;; Preserve text properties on duplicated `%'.
fc42a1decf2d (Info-insert-dir): Use save-excursion around insert-buffer-substring.
Juri Linkov <juri@jurta.org>
parents: 64961
diff changeset
3764 (lambda (s) (concat s s)) header))
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3765 ;; Hide the part of the first line
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3766 ;; that is in the header, if it is just part.
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3767 (unless (bobp)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3768 ;; Hide the punctuation at the end, too.
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3769 (skip-chars-backward " \t,")
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3770 (put-text-property (point) header-end 'invisible t)))))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3771
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3772 ;; Fontify titles
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3773 (goto-char (point-min))
66057
709ea6d61dbd (Info-fontify-node): Don't be fooled by a lone "...".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 66010
diff changeset
3774 (when (and font-lock-mode not-fontified-p)
709ea6d61dbd (Info-fontify-node): Don't be fooled by a lone "...".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 66010
diff changeset
3775 (while (and (re-search-forward "\n\\([^ \t\n].+\\)\n\\(\\*\\*+\\|==+\\|--+\\|\\.\\.+\\)$"
709ea6d61dbd (Info-fontify-node): Don't be fooled by a lone "...".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 66010
diff changeset
3776 nil t)
709ea6d61dbd (Info-fontify-node): Don't be fooled by a lone "...".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 66010
diff changeset
3777 ;; Only consider it as an underlined title if the ASCII
709ea6d61dbd (Info-fontify-node): Don't be fooled by a lone "...".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 66010
diff changeset
3778 ;; underline has the same size as the text. A typical
709ea6d61dbd (Info-fontify-node): Don't be fooled by a lone "...".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 66010
diff changeset
3779 ;; counter example is when a continuation "..." is alone
709ea6d61dbd (Info-fontify-node): Don't be fooled by a lone "...".
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 66010
diff changeset
3780 ;; on a line.
66606
a39846866a71 (Info-fontify-node): Use `string-width' for fontifying underlined titles.
Juri Linkov <juri@jurta.org>
parents: 66604
diff changeset
3781 (= (string-width (match-string 1))
a39846866a71 (Info-fontify-node): Use `string-width' for fontifying underlined titles.
Juri Linkov <juri@jurta.org>
parents: 66604
diff changeset
3782 (string-width (match-string 2))))
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3783 (let* ((c (preceding-char))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3784 (face
63208
0502430a647c Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-378
Miles Bader <miles@gnu.org>
parents: 63065
diff changeset
3785 (cond ((= c ?*) 'info-title-1)
0502430a647c Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-378
Miles Bader <miles@gnu.org>
parents: 63065
diff changeset
3786 ((= c ?=) 'info-title-2)
0502430a647c Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-378
Miles Bader <miles@gnu.org>
parents: 63065
diff changeset
3787 ((= c ?-) 'info-title-3)
0502430a647c Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-378
Miles Bader <miles@gnu.org>
parents: 63065
diff changeset
3788 (t 'info-title-4))))
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3789 (put-text-property (match-beginning 1) (match-end 1)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3790 'font-lock-face face))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3791 ;; This is a serious problem for trying to handle multiple
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3792 ;; frame types at once. We want this text to be invisible
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3793 ;; on frames that can display the font above.
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3794 (when (memq (framep (selected-frame)) '(x pc w32 mac))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3795 (add-text-properties (1- (match-beginning 2)) (match-end 2)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3796 '(invisible t front-sticky nil rear-nonsticky t)))))
49424
59c37b87bb18 (Info-try-follow-nearest-node): Add case: Handle menu item
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 49390
diff changeset
3797
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3798 ;; Fontify cross references
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3799 (goto-char (point-min))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3800 (when (or not-fontified-p fontify-visited-p)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3801 (while (re-search-forward "\\(\\*Note[ \n\t]+\\)\\([^:]*\\)\\(:[ \t]*\\([^.,:(]*\\)\\(\\(([^)]*)\\)[^.,:]*\\)?[,:]?\n?\\)" nil t)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3802 (let ((start (match-beginning 0))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3803 (next (point))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3804 other-tag)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3805 (when not-fontified-p
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3806 (when Info-hide-note-references
56882
dca3dbca04cc (Info-fontify-node): Don't compute other-tag if Info-hide-note-references=hide.
Juri Linkov <juri@jurta.org>
parents: 56866
diff changeset
3807 (when (not (eq Info-hide-note-references 'hide))
dca3dbca04cc (Info-fontify-node): Don't compute other-tag if Info-hide-note-references=hide.
Juri Linkov <juri@jurta.org>
parents: 56866
diff changeset
3808 ;; *Note is often used where *note should have been
dca3dbca04cc (Info-fontify-node): Don't compute other-tag if Info-hide-note-references=hide.
Juri Linkov <juri@jurta.org>
parents: 56866
diff changeset
3809 (goto-char start)
dca3dbca04cc (Info-fontify-node): Don't compute other-tag if Info-hide-note-references=hide.
Juri Linkov <juri@jurta.org>
parents: 56866
diff changeset
3810 (skip-syntax-backward " ")
66459
bdc911746f64 (Info-fontify-node): Fix detection of sentence-break before *Note.
Richard M. Stallman <rms@gnu.org>
parents: 66279
diff changeset
3811 (when (memq (char-before) '(?\( ?\[ ?\{))
bdc911746f64 (Info-fontify-node): Fix detection of sentence-break before *Note.
Richard M. Stallman <rms@gnu.org>
parents: 66279
diff changeset
3812 ;; Check whether the paren is preceded by
bdc911746f64 (Info-fontify-node): Fix detection of sentence-break before *Note.
Richard M. Stallman <rms@gnu.org>
parents: 66279
diff changeset
3813 ;; an end of sentence
bdc911746f64 (Info-fontify-node): Fix detection of sentence-break before *Note.
Richard M. Stallman <rms@gnu.org>
parents: 66279
diff changeset
3814 (skip-syntax-backward " ("))
56882
dca3dbca04cc (Info-fontify-node): Don't compute other-tag if Info-hide-note-references=hide.
Juri Linkov <juri@jurta.org>
parents: 56866
diff changeset
3815 (setq other-tag
66670
d5afffbc0c96 (Info-fontify-node): Don't display extra "see" if there already is one here.
Richard M. Stallman <rms@gnu.org>
parents: 66606
diff changeset
3816 (cond ((save-match-data (looking-back "\\<see"))
d5afffbc0c96 (Info-fontify-node): Don't display extra "see" if there already is one here.
Richard M. Stallman <rms@gnu.org>
parents: 66606
diff changeset
3817 "")
72320
becc8b8af23b * info.el (Info-fontify-node): Handle preceding `in' for note
Chong Yidong <cyd@stupidchicken.com>
parents: 71853
diff changeset
3818 ((save-match-data (looking-back "\\<in"))
becc8b8af23b * info.el (Info-fontify-node): Handle preceding `in' for note
Chong Yidong <cyd@stupidchicken.com>
parents: 71853
diff changeset
3819 "")
66670
d5afffbc0c96 (Info-fontify-node): Don't display extra "see" if there already is one here.
Richard M. Stallman <rms@gnu.org>
parents: 66606
diff changeset
3820 ((memq (char-before) '(nil ?\. ?! ??))
56882
dca3dbca04cc (Info-fontify-node): Don't compute other-tag if Info-hide-note-references=hide.
Juri Linkov <juri@jurta.org>
parents: 56866
diff changeset
3821 "See ")
66459
bdc911746f64 (Info-fontify-node): Fix detection of sentence-break before *Note.
Richard M. Stallman <rms@gnu.org>
parents: 66279
diff changeset
3822 ((save-match-data
bdc911746f64 (Info-fontify-node): Fix detection of sentence-break before *Note.
Richard M. Stallman <rms@gnu.org>
parents: 66279
diff changeset
3823 (save-excursion
bdc911746f64 (Info-fontify-node): Fix detection of sentence-break before *Note.
Richard M. Stallman <rms@gnu.org>
parents: 66279
diff changeset
3824 (search-forward "\n\n" start t)))
bdc911746f64 (Info-fontify-node): Fix detection of sentence-break before *Note.
Richard M. Stallman <rms@gnu.org>
parents: 66279
diff changeset
3825 "See ")
bdc911746f64 (Info-fontify-node): Fix detection of sentence-break before *Note.
Richard M. Stallman <rms@gnu.org>
parents: 66279
diff changeset
3826 (t "see "))))
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3827 (goto-char next)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3828 (add-text-properties
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3829 (match-beginning 1)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3830 (or (save-match-data
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3831 ;; Don't hide \n after *Note
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3832 (let ((start1 (match-beginning 1)))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3833 (if (string-match "\n" (match-string 1))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3834 (+ start1 (match-beginning 0)))))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3835 (match-end 1))
56882
dca3dbca04cc (Info-fontify-node): Don't compute other-tag if Info-hide-note-references=hide.
Juri Linkov <juri@jurta.org>
parents: 56866
diff changeset
3836 (if other-tag
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3837 `(display ,other-tag front-sticky nil rear-nonsticky t)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3838 '(invisible t front-sticky nil rear-nonsticky t))))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3839 (add-text-properties
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3840 (match-beginning 2) (match-end 2)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3841 (list
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3842 'help-echo (if (or (match-end 5)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3843 (not (equal (match-string 4) "")))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3844 (concat "mouse-2: go to " (or (match-string 5)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3845 (match-string 4)))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3846 "mouse-2: go to this node")
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3847 'mouse-face 'highlight)))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3848 (when (or not-fontified-p fontify-visited-p)
57567
b313796ea830 (Info-fontify-node): For multiline refs,
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 57468
diff changeset
3849 (setq rbeg (match-beginning 2)
b313796ea830 (Info-fontify-node): For multiline refs,
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 57468
diff changeset
3850 rend (match-end 2))
b313796ea830 (Info-fontify-node): For multiline refs,
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 57468
diff changeset
3851 (put-text-property
b313796ea830 (Info-fontify-node): For multiline refs,
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 57468
diff changeset
3852 rbeg rend
b313796ea830 (Info-fontify-node): For multiline refs,
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 57468
diff changeset
3853 'font-lock-face
b313796ea830 (Info-fontify-node): For multiline refs,
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 57468
diff changeset
3854 ;; Display visited nodes in a different face
b313796ea830 (Info-fontify-node): For multiline refs,
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 57468
diff changeset
3855 (if (and Info-fontify-visited-nodes
b313796ea830 (Info-fontify-node): For multiline refs,
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 57468
diff changeset
3856 (save-match-data
b313796ea830 (Info-fontify-node): For multiline refs,
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 57468
diff changeset
3857 (let* ((node (replace-regexp-in-string
b313796ea830 (Info-fontify-node): For multiline refs,
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 57468
diff changeset
3858 "^[ \t]+" ""
b313796ea830 (Info-fontify-node): For multiline refs,
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 57468
diff changeset
3859 (replace-regexp-in-string
b313796ea830 (Info-fontify-node): For multiline refs,
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 57468
diff changeset
3860 "[ \t\n]+" " "
68980
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
3861 (or (match-string-no-properties 5)
57567
b313796ea830 (Info-fontify-node): For multiline refs,
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 57468
diff changeset
3862 (and (not (equal (match-string 4) ""))
68980
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
3863 (match-string-no-properties 4))
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
3864 (match-string-no-properties 2)))))
67303
7bd56e8182b2 * info.el (Info-fontify-node): Match external links using
Chong Yidong <cyd@stupidchicken.com>
parents: 67267
diff changeset
3865 (external-link-p
7bd56e8182b2 * info.el (Info-fontify-node): Match external links using
Chong Yidong <cyd@stupidchicken.com>
parents: 67267
diff changeset
3866 (string-match "(\\([^)]+\\))\\([^)]*\\)" node))
7bd56e8182b2 * info.el (Info-fontify-node): Match external links using
Chong Yidong <cyd@stupidchicken.com>
parents: 67267
diff changeset
3867 (file (if external-link-p
7bd56e8182b2 * info.el (Info-fontify-node): Match external links using
Chong Yidong <cyd@stupidchicken.com>
parents: 67267
diff changeset
3868 (file-name-nondirectory
68980
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
3869 (match-string-no-properties 1 node))
67303
7bd56e8182b2 * info.el (Info-fontify-node): Match external links using
Chong Yidong <cyd@stupidchicken.com>
parents: 67267
diff changeset
3870 Info-current-file))
57567
b313796ea830 (Info-fontify-node): For multiline refs,
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 57468
diff changeset
3871 (hl Info-history-list)
b313796ea830 (Info-fontify-node): For multiline refs,
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 57468
diff changeset
3872 res)
67303
7bd56e8182b2 * info.el (Info-fontify-node): Match external links using
Chong Yidong <cyd@stupidchicken.com>
parents: 67267
diff changeset
3873 (if external-link-p
7bd56e8182b2 * info.el (Info-fontify-node): Match external links using
Chong Yidong <cyd@stupidchicken.com>
parents: 67267
diff changeset
3874 (setq node (if (equal (match-string 2 node) "")
57567
b313796ea830 (Info-fontify-node): For multiline refs,
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 57468
diff changeset
3875 "Top"
68980
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
3876 (match-string-no-properties 2 node))))
67121
f354001864bf * info.el (Info-on-current-buffer): Record actual filename in
Chong Yidong <cyd@stupidchicken.com>
parents: 67109
diff changeset
3877 (while hl
f354001864bf * info.el (Info-on-current-buffer): Record actual filename in
Chong Yidong <cyd@stupidchicken.com>
parents: 67109
diff changeset
3878 (if (and (string-equal node (nth 1 (car hl)))
68980
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
3879 (equal file
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
3880 (if (and external-link-p
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
3881 (stringp (caar hl)))
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
3882 (file-name-nondirectory
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
3883 (caar hl))
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
3884 (caar hl))))
67121
f354001864bf * info.el (Info-on-current-buffer): Record actual filename in
Chong Yidong <cyd@stupidchicken.com>
parents: 67109
diff changeset
3885 (setq res (car hl) hl nil)
f354001864bf * info.el (Info-on-current-buffer): Record actual filename in
Chong Yidong <cyd@stupidchicken.com>
parents: 67109
diff changeset
3886 (setq hl (cdr hl))))
57567
b313796ea830 (Info-fontify-node): For multiline refs,
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 57468
diff changeset
3887 res))) 'info-xref-visited 'info-xref))
b313796ea830 (Info-fontify-node): For multiline refs,
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 57468
diff changeset
3888 ;; For multiline ref, unfontify newline and surrounding whitespace
b313796ea830 (Info-fontify-node): For multiline refs,
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 57468
diff changeset
3889 (save-excursion
b313796ea830 (Info-fontify-node): For multiline refs,
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 57468
diff changeset
3890 (goto-char rbeg)
b313796ea830 (Info-fontify-node): For multiline refs,
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 57468
diff changeset
3891 (save-match-data
b313796ea830 (Info-fontify-node): For multiline refs,
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 57468
diff changeset
3892 (while (re-search-forward "\\s-*\n\\s-*" rend t nil)
b313796ea830 (Info-fontify-node): For multiline refs,
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 57468
diff changeset
3893 (remove-text-properties (match-beginning 0)
b313796ea830 (Info-fontify-node): For multiline refs,
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 57468
diff changeset
3894 (match-end 0)
b313796ea830 (Info-fontify-node): For multiline refs,
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 57468
diff changeset
3895 '(font-lock-face t))))))
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3896 (when not-fontified-p
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3897 (when (memq Info-hide-note-references '(t hide))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3898 (add-text-properties (match-beginning 3) (match-end 3)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3899 '(invisible t front-sticky nil rear-nonsticky t))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3900 ;; Unhide the file name of the external reference in parens
55074
dd4c270b21af Restore 2004-04-18 changes.
Juri Linkov <juri@jurta.org>
parents: 55061
diff changeset
3901 (if (and (match-string 6) (not (eq Info-hide-note-references 'hide)))
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3902 (remove-text-properties (match-beginning 6) (match-end 6)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3903 '(invisible t front-sticky nil rear-nonsticky t)))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3904 ;; Unhide newline because hidden newlines cause too long lines
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3905 (save-match-data
55074
dd4c270b21af Restore 2004-04-18 changes.
Juri Linkov <juri@jurta.org>
parents: 55061
diff changeset
3906 (let ((beg3 (match-beginning 3))
dd4c270b21af Restore 2004-04-18 changes.
Juri Linkov <juri@jurta.org>
parents: 55061
diff changeset
3907 (end3 (match-end 3)))
dd4c270b21af Restore 2004-04-18 changes.
Juri Linkov <juri@jurta.org>
parents: 55061
diff changeset
3908 (if (and (string-match "\n[ \t]*" (match-string 3))
dd4c270b21af Restore 2004-04-18 changes.
Juri Linkov <juri@jurta.org>
parents: 55061
diff changeset
3909 (not (save-match-data
dd4c270b21af Restore 2004-04-18 changes.
Juri Linkov <juri@jurta.org>
parents: 55061
diff changeset
3910 (save-excursion
dd4c270b21af Restore 2004-04-18 changes.
Juri Linkov <juri@jurta.org>
parents: 55061
diff changeset
3911 (goto-char (1+ end3))
dd4c270b21af Restore 2004-04-18 changes.
Juri Linkov <juri@jurta.org>
parents: 55061
diff changeset
3912 (looking-at "[.)]*$")))))
dd4c270b21af Restore 2004-04-18 changes.
Juri Linkov <juri@jurta.org>
parents: 55061
diff changeset
3913 (remove-text-properties (+ beg3 (match-beginning 0))
dd4c270b21af Restore 2004-04-18 changes.
Juri Linkov <juri@jurta.org>
parents: 55061
diff changeset
3914 (+ beg3 (match-end 0))
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3915 '(invisible t front-sticky nil rear-nonsticky t))))))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3916 (when (and Info-refill-paragraphs Info-hide-note-references)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3917 (push (set-marker (make-marker) start)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3918 paragraph-markers))))))
48287
205cb7dc9d47 (Info-fontify-node): New local list paragraph-markers.
Kim F. Storm <storm@cua.dk>
parents: 48161
diff changeset
3919
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3920 ;; Refill paragraphs (experimental feature)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3921 (when (and not-fontified-p
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3922 Info-refill-paragraphs
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3923 paragraph-markers)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3924 (let ((fill-nobreak-invisible t)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3925 (fill-individual-varying-indent nil)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3926 (paragraph-start "\f\\|[ \t]*[-*]\\|[ \t]*$")
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3927 (paragraph-separate ".*\\.[ \t]*\n[ \t]\\|[ \t]*[-*]\\|[ \t\f]*$")
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3928 (adaptive-fill-mode nil))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3929 (goto-char (point-max))
66117
634ee145589e (Info-fontify-node): Use dolist.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 66057
diff changeset
3930 (dolist (m paragraph-markers)
634ee145589e (Info-fontify-node): Use dolist.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 66057
diff changeset
3931 (when (< m (point))
634ee145589e (Info-fontify-node): Use dolist.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 66057
diff changeset
3932 (goto-char m)
634ee145589e (Info-fontify-node): Use dolist.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 66057
diff changeset
3933 (beginning-of-line)
634ee145589e (Info-fontify-node): Use dolist.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 66057
diff changeset
3934 (let ((beg (point)))
634ee145589e (Info-fontify-node): Use dolist.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 66057
diff changeset
3935 (when (zerop (forward-paragraph))
634ee145589e (Info-fontify-node): Use dolist.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 66057
diff changeset
3936 (fill-individual-paragraphs beg (point) nil nil)
634ee145589e (Info-fontify-node): Use dolist.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 66057
diff changeset
3937 (goto-char beg))))
634ee145589e (Info-fontify-node): Use dolist.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 66057
diff changeset
3938 (set-marker m nil))))
48103
7d7f2b855580 (Info-follow-reference, Info-next-reference)
Kim F. Storm <storm@cua.dk>
parents: 47794
diff changeset
3939
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3940 ;; Fontify menu items
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3941 (goto-char (point-min))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3942 (when (and (or not-fontified-p fontify-visited-p)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3943 (search-forward "\n* Menu:" nil t)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3944 ;; Don't take time to annotate huge menus
75750
9d47b3ad340e (Info-fontify-maximum-menu-size): Document the effect of a nil value.
Eli Zaretskii <eliz@gnu.org>
parents: 75347
diff changeset
3945 Info-fontify-maximum-menu-size
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3946 (< (- (point-max) (point)) Info-fontify-maximum-menu-size))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3947 (let ((n 0)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3948 cont)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3949 (while (re-search-forward
61450
4ccc4c9adf16 (Info-fontify-node): Handle fontification of multiple * Menu lines in one node.
Richard M. Stallman <rms@gnu.org>
parents: 61394
diff changeset
3950 (concat "^\\* Menu:\\|\\(?:^\\* +\\(" Info-menu-entry-name-re "\\)\\(:"
4ccc4c9adf16 (Info-fontify-node): Handle fontification of multiple * Menu lines in one node.
Richard M. Stallman <rms@gnu.org>
parents: 61394
diff changeset
3951 Info-node-spec-re "\\([ \t]*\\)\\)\\)")
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
3952 nil t)
61450
4ccc4c9adf16 (Info-fontify-node): Handle fontification of multiple * Menu lines in one node.
Richard M. Stallman <rms@gnu.org>
parents: 61394
diff changeset
3953 (when (match-beginning 1)
4ccc4c9adf16 (Info-fontify-node): Handle fontification of multiple * Menu lines in one node.
Richard M. Stallman <rms@gnu.org>
parents: 61394
diff changeset
3954 (when not-fontified-p
4ccc4c9adf16 (Info-fontify-node): Handle fontification of multiple * Menu lines in one node.
Richard M. Stallman <rms@gnu.org>
parents: 61394
diff changeset
3955 (setq n (1+ n))
4ccc4c9adf16 (Info-fontify-node): Handle fontification of multiple * Menu lines in one node.
Richard M. Stallman <rms@gnu.org>
parents: 61394
diff changeset
3956 (if (and (<= n 9) (zerop (% n 3))) ; visual aids to help with 1-9 keys
4ccc4c9adf16 (Info-fontify-node): Handle fontification of multiple * Menu lines in one node.
Richard M. Stallman <rms@gnu.org>
parents: 61394
diff changeset
3957 (put-text-property (match-beginning 0)
4ccc4c9adf16 (Info-fontify-node): Handle fontification of multiple * Menu lines in one node.
Richard M. Stallman <rms@gnu.org>
parents: 61394
diff changeset
3958 (1+ (match-beginning 0))
64812
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
3959 'font-lock-face 'info-menu-star)))
61450
4ccc4c9adf16 (Info-fontify-node): Handle fontification of multiple * Menu lines in one node.
Richard M. Stallman <rms@gnu.org>
parents: 61394
diff changeset
3960 (when not-fontified-p
4ccc4c9adf16 (Info-fontify-node): Handle fontification of multiple * Menu lines in one node.
Richard M. Stallman <rms@gnu.org>
parents: 61394
diff changeset
3961 (add-text-properties
4ccc4c9adf16 (Info-fontify-node): Handle fontification of multiple * Menu lines in one node.
Richard M. Stallman <rms@gnu.org>
parents: 61394
diff changeset
3962 (match-beginning 1) (match-end 1)
4ccc4c9adf16 (Info-fontify-node): Handle fontification of multiple * Menu lines in one node.
Richard M. Stallman <rms@gnu.org>
parents: 61394
diff changeset
3963 (list
4ccc4c9adf16 (Info-fontify-node): Handle fontification of multiple * Menu lines in one node.
Richard M. Stallman <rms@gnu.org>
parents: 61394
diff changeset
3964 'help-echo (if (and (match-end 3)
4ccc4c9adf16 (Info-fontify-node): Handle fontification of multiple * Menu lines in one node.
Richard M. Stallman <rms@gnu.org>
parents: 61394
diff changeset
3965 (not (equal (match-string 3) "")))
4ccc4c9adf16 (Info-fontify-node): Handle fontification of multiple * Menu lines in one node.
Richard M. Stallman <rms@gnu.org>
parents: 61394
diff changeset
3966 (concat "mouse-2: go to " (match-string 3))
4ccc4c9adf16 (Info-fontify-node): Handle fontification of multiple * Menu lines in one node.
Richard M. Stallman <rms@gnu.org>
parents: 61394
diff changeset
3967 "mouse-2: go to this node")
4ccc4c9adf16 (Info-fontify-node): Handle fontification of multiple * Menu lines in one node.
Richard M. Stallman <rms@gnu.org>
parents: 61394
diff changeset
3968 'mouse-face 'highlight)))
4ccc4c9adf16 (Info-fontify-node): Handle fontification of multiple * Menu lines in one node.
Richard M. Stallman <rms@gnu.org>
parents: 61394
diff changeset
3969 (when (or not-fontified-p fontify-visited-p)
66117
634ee145589e (Info-fontify-node): Use dolist.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 66057
diff changeset
3970 (put-text-property
61450
4ccc4c9adf16 (Info-fontify-node): Handle fontification of multiple * Menu lines in one node.
Richard M. Stallman <rms@gnu.org>
parents: 61394
diff changeset
3971 (match-beginning 1) (match-end 1)
66117
634ee145589e (Info-fontify-node): Use dolist.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 66057
diff changeset
3972 'font-lock-face
634ee145589e (Info-fontify-node): Use dolist.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 66057
diff changeset
3973 ;; Display visited menu items in a different face
634ee145589e (Info-fontify-node): Use dolist.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 66057
diff changeset
3974 (if (and Info-fontify-visited-nodes
634ee145589e (Info-fontify-node): Use dolist.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 66057
diff changeset
3975 (save-match-data
67303
7bd56e8182b2 * info.el (Info-fontify-node): Match external links using
Chong Yidong <cyd@stupidchicken.com>
parents: 67267
diff changeset
3976 (let* ((node (if (equal (match-string 3) "")
68980
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
3977 (match-string-no-properties 1)
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
3978 (match-string-no-properties 3)))
67303
7bd56e8182b2 * info.el (Info-fontify-node): Match external links using
Chong Yidong <cyd@stupidchicken.com>
parents: 67267
diff changeset
3979 (external-link-p
7bd56e8182b2 * info.el (Info-fontify-node): Match external links using
Chong Yidong <cyd@stupidchicken.com>
parents: 67267
diff changeset
3980 (string-match "(\\([^)]+\\))\\([^)]*\\)" node))
7bd56e8182b2 * info.el (Info-fontify-node): Match external links using
Chong Yidong <cyd@stupidchicken.com>
parents: 67267
diff changeset
3981 (file (if external-link-p
7bd56e8182b2 * info.el (Info-fontify-node): Match external links using
Chong Yidong <cyd@stupidchicken.com>
parents: 67267
diff changeset
3982 (file-name-nondirectory
68980
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
3983 (match-string-no-properties 1 node))
67303
7bd56e8182b2 * info.el (Info-fontify-node): Match external links using
Chong Yidong <cyd@stupidchicken.com>
parents: 67267
diff changeset
3984 Info-current-file))
7bd56e8182b2 * info.el (Info-fontify-node): Match external links using
Chong Yidong <cyd@stupidchicken.com>
parents: 67267
diff changeset
3985 (hl Info-history-list)
7bd56e8182b2 * info.el (Info-fontify-node): Match external links using
Chong Yidong <cyd@stupidchicken.com>
parents: 67267
diff changeset
3986 res)
7bd56e8182b2 * info.el (Info-fontify-node): Match external links using
Chong Yidong <cyd@stupidchicken.com>
parents: 67267
diff changeset
3987 (if external-link-p
7bd56e8182b2 * info.el (Info-fontify-node): Match external links using
Chong Yidong <cyd@stupidchicken.com>
parents: 67267
diff changeset
3988 (setq node (if (equal (match-string 2 node) "")
66117
634ee145589e (Info-fontify-node): Use dolist.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 66057
diff changeset
3989 "Top"
68980
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
3990 (match-string-no-properties 2 node))))
67121
f354001864bf * info.el (Info-on-current-buffer): Record actual filename in
Chong Yidong <cyd@stupidchicken.com>
parents: 67109
diff changeset
3991 (while hl
f354001864bf * info.el (Info-on-current-buffer): Record actual filename in
Chong Yidong <cyd@stupidchicken.com>
parents: 67109
diff changeset
3992 (if (and (string-equal node (nth 1 (car hl)))
68980
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
3993 (equal file
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
3994 (if (and external-link-p
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
3995 (stringp (caar hl)))
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
3996 (file-name-nondirectory
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
3997 (caar hl))
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
3998 (caar hl))))
67121
f354001864bf * info.el (Info-on-current-buffer): Record actual filename in
Chong Yidong <cyd@stupidchicken.com>
parents: 67109
diff changeset
3999 (setq res (car hl) hl nil)
f354001864bf * info.el (Info-on-current-buffer): Record actual filename in
Chong Yidong <cyd@stupidchicken.com>
parents: 67109
diff changeset
4000 (setq hl (cdr hl))))
66117
634ee145589e (Info-fontify-node): Use dolist.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 66057
diff changeset
4001 res))) 'info-xref-visited 'info-xref)))
75165
220431f80579 (Info-fontify-node): Don't hide node names of index entries.
Juri Linkov <juri@jurta.org>
parents: 74809
diff changeset
4002 (when (and not-fontified-p
220431f80579 (Info-fontify-node): Don't hide node names of index entries.
Juri Linkov <juri@jurta.org>
parents: 74809
diff changeset
4003 (memq Info-hide-note-references '(t hide))
220431f80579 (Info-fontify-node): Don't hide node names of index entries.
Juri Linkov <juri@jurta.org>
parents: 74809
diff changeset
4004 (not (Info-index-node)))
61450
4ccc4c9adf16 (Info-fontify-node): Handle fontification of multiple * Menu lines in one node.
Richard M. Stallman <rms@gnu.org>
parents: 61394
diff changeset
4005 (put-text-property (match-beginning 2) (1- (match-end 6))
4ccc4c9adf16 (Info-fontify-node): Handle fontification of multiple * Menu lines in one node.
Richard M. Stallman <rms@gnu.org>
parents: 61394
diff changeset
4006 'invisible t)
4ccc4c9adf16 (Info-fontify-node): Handle fontification of multiple * Menu lines in one node.
Richard M. Stallman <rms@gnu.org>
parents: 61394
diff changeset
4007 ;; Unhide the file name in parens
4ccc4c9adf16 (Info-fontify-node): Handle fontification of multiple * Menu lines in one node.
Richard M. Stallman <rms@gnu.org>
parents: 61394
diff changeset
4008 (if (and (match-end 4) (not (eq (char-after (match-end 4)) ?.)))
4ccc4c9adf16 (Info-fontify-node): Handle fontification of multiple * Menu lines in one node.
Richard M. Stallman <rms@gnu.org>
parents: 61394
diff changeset
4009 (remove-text-properties (match-beginning 4) (match-end 4)
4ccc4c9adf16 (Info-fontify-node): Handle fontification of multiple * Menu lines in one node.
Richard M. Stallman <rms@gnu.org>
parents: 61394
diff changeset
4010 '(invisible t)))
4ccc4c9adf16 (Info-fontify-node): Handle fontification of multiple * Menu lines in one node.
Richard M. Stallman <rms@gnu.org>
parents: 61394
diff changeset
4011 ;; We need a stretchable space like :align-to but with
4ccc4c9adf16 (Info-fontify-node): Handle fontification of multiple * Menu lines in one node.
Richard M. Stallman <rms@gnu.org>
parents: 61394
diff changeset
4012 ;; a minimum value.
4ccc4c9adf16 (Info-fontify-node): Handle fontification of multiple * Menu lines in one node.
Richard M. Stallman <rms@gnu.org>
parents: 61394
diff changeset
4013 (put-text-property (1- (match-end 6)) (match-end 6) 'display
4ccc4c9adf16 (Info-fontify-node): Handle fontification of multiple * Menu lines in one node.
Richard M. Stallman <rms@gnu.org>
parents: 61394
diff changeset
4014 (if (>= 22 (- (match-end 1)
4ccc4c9adf16 (Info-fontify-node): Handle fontification of multiple * Menu lines in one node.
Richard M. Stallman <rms@gnu.org>
parents: 61394
diff changeset
4015 (match-beginning 0)))
4ccc4c9adf16 (Info-fontify-node): Handle fontification of multiple * Menu lines in one node.
Richard M. Stallman <rms@gnu.org>
parents: 61394
diff changeset
4016 '(space :align-to 24)
4ccc4c9adf16 (Info-fontify-node): Handle fontification of multiple * Menu lines in one node.
Richard M. Stallman <rms@gnu.org>
parents: 61394
diff changeset
4017 '(space :width 2)))
4ccc4c9adf16 (Info-fontify-node): Handle fontification of multiple * Menu lines in one node.
Richard M. Stallman <rms@gnu.org>
parents: 61394
diff changeset
4018 (setq cont (looking-at "."))
4ccc4c9adf16 (Info-fontify-node): Handle fontification of multiple * Menu lines in one node.
Richard M. Stallman <rms@gnu.org>
parents: 61394
diff changeset
4019 (while (and (= (forward-line 1) 0)
4ccc4c9adf16 (Info-fontify-node): Handle fontification of multiple * Menu lines in one node.
Richard M. Stallman <rms@gnu.org>
parents: 61394
diff changeset
4020 (looking-at "\\([ \t]+\\)[^*\n]"))
4ccc4c9adf16 (Info-fontify-node): Handle fontification of multiple * Menu lines in one node.
Richard M. Stallman <rms@gnu.org>
parents: 61394
diff changeset
4021 (put-text-property (match-beginning 1) (1- (match-end 1))
4ccc4c9adf16 (Info-fontify-node): Handle fontification of multiple * Menu lines in one node.
Richard M. Stallman <rms@gnu.org>
parents: 61394
diff changeset
4022 'invisible t)
4ccc4c9adf16 (Info-fontify-node): Handle fontification of multiple * Menu lines in one node.
Richard M. Stallman <rms@gnu.org>
parents: 61394
diff changeset
4023 (put-text-property (1- (match-end 1)) (match-end 1)
4ccc4c9adf16 (Info-fontify-node): Handle fontification of multiple * Menu lines in one node.
Richard M. Stallman <rms@gnu.org>
parents: 61394
diff changeset
4024 'display
4ccc4c9adf16 (Info-fontify-node): Handle fontification of multiple * Menu lines in one node.
Richard M. Stallman <rms@gnu.org>
parents: 61394
diff changeset
4025 (if cont
4ccc4c9adf16 (Info-fontify-node): Handle fontification of multiple * Menu lines in one node.
Richard M. Stallman <rms@gnu.org>
parents: 61394
diff changeset
4026 '(space :align-to 26)
4ccc4c9adf16 (Info-fontify-node): Handle fontification of multiple * Menu lines in one node.
Richard M. Stallman <rms@gnu.org>
parents: 61394
diff changeset
4027 '(space :align-to 24)))
4ccc4c9adf16 (Info-fontify-node): Handle fontification of multiple * Menu lines in one node.
Richard M. Stallman <rms@gnu.org>
parents: 61394
diff changeset
4028 (setq cont t)))))))
48103
7d7f2b855580 (Info-follow-reference, Info-next-reference)
Kim F. Storm <storm@cua.dk>
parents: 47794
diff changeset
4029
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
4030 ;; Fontify menu headers
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
4031 ;; Add the face `info-menu-header' to any header before a menu entry
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
4032 (goto-char (point-min))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
4033 (when (and not-fontified-p (re-search-forward "^\\* Menu:" nil t))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
4034 (put-text-property (match-beginning 0) (match-end 0)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
4035 'font-lock-face 'info-menu-header)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
4036 (while (re-search-forward "\n\n\\([^*\n ].*\\)\n\n?[*]" nil t)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
4037 (put-text-property (match-beginning 1) (match-end 1)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
4038 'font-lock-face 'info-menu-header)))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
4039
55174
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
4040 ;; Hide index line numbers
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
4041 (goto-char (point-min))
55751
450a4292b3b7 (Info-index-nodes): New var and fun.
Juri Linkov <juri@jurta.org>
parents: 55200
diff changeset
4042 (when (and not-fontified-p (Info-index-node))
55174
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
4043 (while (re-search-forward "[ \t\n]*(line +[0-9]+)" nil t)
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
4044 (put-text-property (match-beginning 0) (match-end 0)
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
4045 'invisible t)))
084cf910857b Add *info*<[0-9]+> to same-window-regexps instead of
Juri Linkov <juri@jurta.org>
parents: 55153
diff changeset
4046
54754
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
4047 ;; Fontify http and ftp references
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
4048 (goto-char (point-min))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
4049 (when not-fontified-p
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
4050 (while (re-search-forward "[hf]t?tp://[^ \t\n\"`({<>})']+" nil t)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
4051 (add-text-properties (match-beginning 0) (match-end 0)
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
4052 '(font-lock-face info-xref
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
4053 mouse-face highlight
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
4054 help-echo "mouse-2: go to this URL"))))
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
4055
fe0b01c2265f (Info-history): Doc fix.
Juri Linkov <juri@jurta.org>
parents: 54752
diff changeset
4056 (set-buffer-modified-p nil))))
16981
643e0f90e153 Handle multiple Info buffers.
Richard M. Stallman <rms@gnu.org>
parents: 16790
diff changeset
4057
20755
0ceaf8e0782b Added speedbar support function `Info-speedbar-buttons',
Eric M. Ludlam <zappo@gnu.org>
parents: 20514
diff changeset
4058 ;;; Speedbar support:
0ceaf8e0782b Added speedbar support function `Info-speedbar-buttons',
Eric M. Ludlam <zappo@gnu.org>
parents: 20514
diff changeset
4059 ;; These functions permit speedbar to display the "tags" in the
64812
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
4060 ;; current Info node.
22733
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4061 (eval-when-compile (require 'speedbar))
20755
0ceaf8e0782b Added speedbar support function `Info-speedbar-buttons',
Eric M. Ludlam <zappo@gnu.org>
parents: 20514
diff changeset
4062
22733
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4063 (defvar Info-speedbar-key-map nil
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4064 "Keymap used when in the info display mode.")
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4065
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4066 (defun Info-install-speedbar-variables ()
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4067 "Install those variables used by speedbar to enhance Info."
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4068 (if Info-speedbar-key-map
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4069 nil
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4070 (setq Info-speedbar-key-map (speedbar-make-specialized-keymap))
20755
0ceaf8e0782b Added speedbar support function `Info-speedbar-buttons',
Eric M. Ludlam <zappo@gnu.org>
parents: 20514
diff changeset
4071
22733
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4072 ;; Basic tree features
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4073 (define-key Info-speedbar-key-map "e" 'speedbar-edit-line)
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4074 (define-key Info-speedbar-key-map "\C-m" 'speedbar-edit-line)
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4075 (define-key Info-speedbar-key-map "+" 'speedbar-expand-line)
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4076 (define-key Info-speedbar-key-map "-" 'speedbar-contract-line)
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4077 )
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4078
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4079 (speedbar-add-expansion-list '("Info" Info-speedbar-menu-items
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4080 Info-speedbar-key-map
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4081 Info-speedbar-hierarchy-buttons)))
20755
0ceaf8e0782b Added speedbar support function `Info-speedbar-buttons',
Eric M. Ludlam <zappo@gnu.org>
parents: 20514
diff changeset
4082
0ceaf8e0782b Added speedbar support function `Info-speedbar-buttons',
Eric M. Ludlam <zappo@gnu.org>
parents: 20514
diff changeset
4083 (defvar Info-speedbar-menu-items
22733
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4084 '(["Browse Node" speedbar-edit-line t]
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4085 ["Expand Node" speedbar-expand-line
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4086 (save-excursion (beginning-of-line)
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4087 (looking-at "[0-9]+: *.\\+. "))]
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4088 ["Contract Node" speedbar-contract-line
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4089 (save-excursion (beginning-of-line)
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4090 (looking-at "[0-9]+: *.-. "))]
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4091 )
20755
0ceaf8e0782b Added speedbar support function `Info-speedbar-buttons',
Eric M. Ludlam <zappo@gnu.org>
parents: 20514
diff changeset
4092 "Additional menu-items to add to speedbar frame.")
0ceaf8e0782b Added speedbar support function `Info-speedbar-buttons',
Eric M. Ludlam <zappo@gnu.org>
parents: 20514
diff changeset
4093
22733
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4094 ;; Make sure our special speedbar major mode is loaded
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4095 (if (featurep 'speedbar)
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4096 (Info-install-speedbar-variables)
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4097 (add-hook 'speedbar-load-hook 'Info-install-speedbar-variables))
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4098
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4099 ;;; Info hierarchy display method
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4100 ;;;###autoload
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4101 (defun Info-speedbar-browser ()
64812
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
4102 "Initialize speedbar to display an Info node browser.
22733
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4103 This will add a speedbar major display mode."
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4104 (interactive)
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4105 (require 'speedbar)
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4106 ;; Make sure that speedbar is active
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4107 (speedbar-frame-mode 1)
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4108 ;; Now, throw us into Info mode on speedbar.
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4109 (speedbar-change-initial-expansion-list "Info")
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4110 )
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4111
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4112 (defun Info-speedbar-hierarchy-buttons (directory depth &optional node)
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4113 "Display an Info directory hierarchy in speedbar.
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4114 DIRECTORY is the current directory in the attached frame.
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4115 DEPTH is the current indentation depth.
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4116 NODE is an optional argument that is used to represent the
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4117 specific node to expand."
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4118 (if (and (not node)
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4119 (save-excursion (goto-char (point-min))
22951
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
4120 (let ((case-fold-search t))
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
4121 (looking-at "Info Nodes:"))))
22733
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4122 ;; Update our "current node" maybe?
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4123 nil
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4124 ;; We cannot use the generic list code, that depends on all leaves
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4125 ;; being known at creation time.
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4126 (if (not node)
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4127 (speedbar-with-writable (insert "Info Nodes:\n")))
65780
6e229fd94815 * speedbar.el: Remove RCS tag.
Chong Yidong <cyd@stupidchicken.com>
parents: 65680
diff changeset
4128 (let ((completions nil))
6e229fd94815 * speedbar.el: Remove RCS tag.
Chong Yidong <cyd@stupidchicken.com>
parents: 65680
diff changeset
4129 (speedbar-select-attached-frame)
22894
186b2098dcd8 (Info-speedbar-hierarchy-buttons): Improved the speedbar frame management.
Eric M. Ludlam <zappo@gnu.org>
parents: 22863
diff changeset
4130 (save-window-excursion
186b2098dcd8 (Info-speedbar-hierarchy-buttons): Improved the speedbar frame management.
Eric M. Ludlam <zappo@gnu.org>
parents: 22863
diff changeset
4131 (setq completions
186b2098dcd8 (Info-speedbar-hierarchy-buttons): Improved the speedbar frame management.
Eric M. Ludlam <zappo@gnu.org>
parents: 22863
diff changeset
4132 (Info-speedbar-fetch-file-nodes (or node '"(dir)top"))))
65825
b89d9c4d5386 * info.el (Info-next, Info-prev, Info-up): Select info buffer, in
Chong Yidong <cyd@stupidchicken.com>
parents: 65780
diff changeset
4133 (select-frame (speedbar-current-frame))
22733
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4134 (if completions
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4135 (speedbar-with-writable
51434
4c85e6a5a9d2 (Info-mode-hook): Obey obsolete `Info-fontify'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51310
diff changeset
4136 (dolist (completion completions)
22733
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4137 (speedbar-make-tag-line 'bracket ?+ 'Info-speedbar-expand-node
51434
4c85e6a5a9d2 (Info-mode-hook): Obey obsolete `Info-fontify'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51310
diff changeset
4138 (cdr completion)
4c85e6a5a9d2 (Info-mode-hook): Obey obsolete `Info-fontify'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51310
diff changeset
4139 (car completion)
22733
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4140 'Info-speedbar-goto-node
51434
4c85e6a5a9d2 (Info-mode-hook): Obey obsolete `Info-fontify'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51310
diff changeset
4141 (cdr completion)
4c85e6a5a9d2 (Info-mode-hook): Obey obsolete `Info-fontify'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51310
diff changeset
4142 'info-xref depth))
22733
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4143 t)
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4144 nil))))
28943
36fd90774cf7 (debug-ignored-errors): more errors to ignore.
Sam Steingold <sds@gnu.org>
parents: 28559
diff changeset
4145
22733
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4146 (defun Info-speedbar-goto-node (text node indent)
32500
5f2aedbe47b5 (Info-mouse-follow-nearest-node): Use mouse-set-point.
Dave Love <fx@gnu.org>
parents: 32391
diff changeset
4147 "When user clicks on TEXT, go to an info NODE.
22733
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4148 The INDENT level is ignored."
65780
6e229fd94815 * speedbar.el: Remove RCS tag.
Chong Yidong <cyd@stupidchicken.com>
parents: 65680
diff changeset
4149 (speedbar-select-attached-frame)
29446
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
4150 (let* ((buff (or (get-buffer "*info*")
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
4151 (progn (info) (get-buffer "*info*"))))
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
4152 (bwin (get-buffer-window buff 0)))
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
4153 (if bwin
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
4154 (progn
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
4155 (select-window bwin)
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
4156 (raise-frame (window-frame bwin)))
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
4157 (if speedbar-power-click
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
4158 (let ((pop-up-frames t)) (select-window (display-buffer buff)))
65780
6e229fd94815 * speedbar.el: Remove RCS tag.
Chong Yidong <cyd@stupidchicken.com>
parents: 65680
diff changeset
4159 (speedbar-select-attached-frame)
29446
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
4160 (switch-to-buffer buff)))
51434
4c85e6a5a9d2 (Info-mode-hook): Obey obsolete `Info-fontify'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51310
diff changeset
4161 (if (not (string-match "^(\\([^)]+\\))\\([^.]+\\)$" node))
4c85e6a5a9d2 (Info-mode-hook): Obey obsolete `Info-fontify'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51310
diff changeset
4162 (error "Invalid node %s" node)
4c85e6a5a9d2 (Info-mode-hook): Obey obsolete `Info-fontify'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51310
diff changeset
4163 (Info-find-node (match-string 1 node) (match-string 2 node))
29446
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
4164 ;; If we do a find-node, and we were in info mode, restore
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
4165 ;; the old default method. Once we are in info mode, it makes
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
4166 ;; sense to return to whatever method the user was using before.
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
4167 (if (string= speedbar-initial-expansion-list-name "Info")
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
4168 (speedbar-change-initial-expansion-list
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
4169 speedbar-previously-used-expansion-list-name)))))
22733
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4170
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4171 (defun Info-speedbar-expand-node (text token indent)
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4172 "Expand the node the user clicked on.
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4173 TEXT is the text of the button we clicked on, a + or - item.
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4174 TOKEN is data related to this node (NAME . FILE).
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4175 INDENT is the current indentation depth."
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4176 (cond ((string-match "+" text) ;we have to expand this file
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4177 (speedbar-change-expand-button-char ?-)
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4178 (if (speedbar-with-writable
29446
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
4179 (save-excursion
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
4180 (end-of-line) (forward-char 1)
009f1caf830f Bind case-fold-search to t when searching in case
Gerd Moellmann <gerd@gnu.org>
parents: 29410
diff changeset
4181 (Info-speedbar-hierarchy-buttons nil (1+ indent) token)))
22733
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4182 (speedbar-change-expand-button-char ?-)
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4183 (speedbar-change-expand-button-char ??)))
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4184 ((string-match "-" text) ;we have to contract this node
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4185 (speedbar-change-expand-button-char ?+)
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4186 (speedbar-delete-subblock indent))
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4187 (t (error "Ooops... not sure what to do")))
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4188 (speedbar-center-buffer-smartly))
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4189
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4190 (defun Info-speedbar-fetch-file-nodes (nodespec)
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4191 "Fetch the subnodes from the info NODESPEC.
64071
5a1b36dec43a (Info-history, Info-history-forward, Info-history-list,
Juanma Barranquero <lekktu@gmail.com>
parents: 64013
diff changeset
4192 NODESPEC is a string of the form: (file)node."
22733
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4193 (save-excursion
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4194 ;; Set up a buffer we can use to fake-out Info.
67109
255a7e893f05 (Info-speedbar-fetch-file-nodes): Prefix temporary buffer name with a
Romain Francoise <romain@orebokech.com>
parents: 67094
diff changeset
4195 (set-buffer (get-buffer-create " *info-browse-tmp*"))
22733
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4196 (if (not (equal major-mode 'Info-mode))
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4197 (Info-mode))
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4198 ;; Get the node into this buffer
51434
4c85e6a5a9d2 (Info-mode-hook): Obey obsolete `Info-fontify'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51310
diff changeset
4199 (if (not (string-match "^(\\([^)]+\\))\\([^.]+\\)$" nodespec))
4c85e6a5a9d2 (Info-mode-hook): Obey obsolete `Info-fontify'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51310
diff changeset
4200 (error "Invalid node specification %s" nodespec)
4c85e6a5a9d2 (Info-mode-hook): Obey obsolete `Info-fontify'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51310
diff changeset
4201 (Info-find-node (match-string 1 nodespec) (match-string 2 nodespec)))
22733
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4202 ;; Scan the created buffer
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4203 (goto-char (point-min))
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4204 (let ((completions nil)
22951
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
4205 (case-fold-search t)
22733
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4206 (thisfile (progn (string-match "^(\\([^)]+\\))" nodespec)
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4207 (match-string 1 nodespec))))
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4208 ;; Always skip the first one...
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4209 (re-search-forward "\n\\* \\([^:\t\n]*\\):" nil t)
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4210 (while (re-search-forward "\n\\* \\([^:\t\n]*\\):" nil t)
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4211 (let ((name (match-string 1)))
51434
4c85e6a5a9d2 (Info-mode-hook): Obey obsolete `Info-fontify'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51310
diff changeset
4212 (push (cons name
4c85e6a5a9d2 (Info-mode-hook): Obey obsolete `Info-fontify'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51310
diff changeset
4213 (if (looking-at " *\\(([^)]+)[^.\n]+\\)\\.")
4c85e6a5a9d2 (Info-mode-hook): Obey obsolete `Info-fontify'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51310
diff changeset
4214 (match-string 1)
4c85e6a5a9d2 (Info-mode-hook): Obey obsolete `Info-fontify'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51310
diff changeset
4215 (if (looking-at " *\\(([^)]+)\\)\\.")
4c85e6a5a9d2 (Info-mode-hook): Obey obsolete `Info-fontify'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51310
diff changeset
4216 (concat (match-string 1) "Top")
4c85e6a5a9d2 (Info-mode-hook): Obey obsolete `Info-fontify'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51310
diff changeset
4217 (concat "(" thisfile ")"
4c85e6a5a9d2 (Info-mode-hook): Obey obsolete `Info-fontify'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51310
diff changeset
4218 (if (looking-at " \\([^.]+\\).")
4c85e6a5a9d2 (Info-mode-hook): Obey obsolete `Info-fontify'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51310
diff changeset
4219 (match-string 1)
4c85e6a5a9d2 (Info-mode-hook): Obey obsolete `Info-fontify'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51310
diff changeset
4220 name)))))
4c85e6a5a9d2 (Info-mode-hook): Obey obsolete `Info-fontify'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 51310
diff changeset
4221 completions)))
22733
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4222 (nreverse completions))))
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4223
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4224 ;;; Info mode node listing
65780
6e229fd94815 * speedbar.el: Remove RCS tag.
Chong Yidong <cyd@stupidchicken.com>
parents: 65680
diff changeset
4225 ;; This is called by `speedbar-add-localized-speedbar-support'
20755
0ceaf8e0782b Added speedbar support function `Info-speedbar-buttons',
Eric M. Ludlam <zappo@gnu.org>
parents: 20514
diff changeset
4226 (defun Info-speedbar-buttons (buffer)
0ceaf8e0782b Added speedbar support function `Info-speedbar-buttons',
Eric M. Ludlam <zappo@gnu.org>
parents: 20514
diff changeset
4227 "Create a speedbar display to help navigation in an Info file.
0ceaf8e0782b Added speedbar support function `Info-speedbar-buttons',
Eric M. Ludlam <zappo@gnu.org>
parents: 20514
diff changeset
4228 BUFFER is the buffer speedbar is requesting buttons for."
22733
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4229 (if (save-excursion (goto-char (point-min))
22951
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
4230 (let ((case-fold-search t))
19b3899582b4 Bind case-fold-search to t in many functions.
Richard M. Stallman <rms@gnu.org>
parents: 22902
diff changeset
4231 (not (looking-at "Info Nodes:"))))
22733
8d8e664f1f6c No longer depends on speedbspec for byte compile.
Karl Heuer <kwzh@gnu.org>
parents: 22692
diff changeset
4232 (erase-buffer))
65780
6e229fd94815 * speedbar.el: Remove RCS tag.
Chong Yidong <cyd@stupidchicken.com>
parents: 65680
diff changeset
4233 (Info-speedbar-hierarchy-buttons nil 0))
584
4cd7543be581 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 540
diff changeset
4234
60626
20a8e6e5ae57 Update error messages for `debug-ignored-errors'.
Juri Linkov <juri@jurta.org>
parents: 60615
diff changeset
4235 (dolist (mess '("^First node in file$"
20a8e6e5ae57 Update error messages for `debug-ignored-errors'.
Juri Linkov <juri@jurta.org>
parents: 60615
diff changeset
4236 "^No `.*' in index$"
20a8e6e5ae57 Update error messages for `debug-ignored-errors'.
Juri Linkov <juri@jurta.org>
parents: 60615
diff changeset
4237 "^No cross-reference named"
20a8e6e5ae57 Update error messages for `debug-ignored-errors'.
Juri Linkov <juri@jurta.org>
parents: 60615
diff changeset
4238 "^No cross.references in this node$"
64812
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
4239 "^No current Info node$"
28558
3fb49903ed9d Add debug-ignored-errors.
Dave Love <fx@gnu.org>
parents: 28168
diff changeset
4240 "^No menu in this node$"
60626
20a8e6e5ae57 Update error messages for `debug-ignored-errors'.
Juri Linkov <juri@jurta.org>
parents: 60615
diff changeset
4241 "^No more items in menu$"
20a8e6e5ae57 Update error messages for `debug-ignored-errors'.
Juri Linkov <juri@jurta.org>
parents: 60615
diff changeset
4242 "^No more nodes$"
20a8e6e5ae57 Update error messages for `debug-ignored-errors'.
Juri Linkov <juri@jurta.org>
parents: 60615
diff changeset
4243 "^No pointer \\(?:forward\\|backward\\) from this node$"
20a8e6e5ae57 Update error messages for `debug-ignored-errors'.
Juri Linkov <juri@jurta.org>
parents: 60615
diff changeset
4244 "^No previous `i' command$"
20a8e6e5ae57 Update error messages for `debug-ignored-errors'.
Juri Linkov <juri@jurta.org>
parents: 60615
diff changeset
4245 "^No previous items in menu$"
20a8e6e5ae57 Update error messages for `debug-ignored-errors'.
Juri Linkov <juri@jurta.org>
parents: 60615
diff changeset
4246 "^No previous nodes$"
20a8e6e5ae57 Update error messages for `debug-ignored-errors'.
Juri Linkov <juri@jurta.org>
parents: 60615
diff changeset
4247 "^No such item in menu$"
20a8e6e5ae57 Update error messages for `debug-ignored-errors'.
Juri Linkov <juri@jurta.org>
parents: 60615
diff changeset
4248 "^No such node or anchor"
20a8e6e5ae57 Update error messages for `debug-ignored-errors'.
Juri Linkov <juri@jurta.org>
parents: 60615
diff changeset
4249 "^Node has no"
20a8e6e5ae57 Update error messages for `debug-ignored-errors'.
Juri Linkov <juri@jurta.org>
parents: 60615
diff changeset
4250 "^Point neither on reference nor in menu item description$"
20a8e6e5ae57 Update error messages for `debug-ignored-errors'.
Juri Linkov <juri@jurta.org>
parents: 60615
diff changeset
4251 "^This is the \\(?:first\\|last\\) Info node you looked at$"
20a8e6e5ae57 Update error messages for `debug-ignored-errors'.
Juri Linkov <juri@jurta.org>
parents: 60615
diff changeset
4252 search-failed))
28558
3fb49903ed9d Add debug-ignored-errors.
Dave Love <fx@gnu.org>
parents: 28168
diff changeset
4253 (add-to-list 'debug-ignored-errors mess))
3fb49903ed9d Add debug-ignored-errors.
Dave Love <fx@gnu.org>
parents: 28168
diff changeset
4254
55057
8ac1373b947e (Info-restore-desktop-buffer): Move from desktop.el. Add Parameters.
Lars Hansen <larsh@soem.dk>
parents: 54971
diff changeset
4255 ;;;; Desktop support
8ac1373b947e (Info-restore-desktop-buffer): Move from desktop.el. Add Parameters.
Lars Hansen <larsh@soem.dk>
parents: 54971
diff changeset
4256
8ac1373b947e (Info-restore-desktop-buffer): Move from desktop.el. Add Parameters.
Lars Hansen <larsh@soem.dk>
parents: 54971
diff changeset
4257 (defun Info-desktop-buffer-misc-data (desktop-dirname)
8ac1373b947e (Info-restore-desktop-buffer): Move from desktop.el. Add Parameters.
Lars Hansen <larsh@soem.dk>
parents: 54971
diff changeset
4258 "Auxiliary information to be saved in desktop file."
68980
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
4259 (unless (member Info-current-file '(apropos history toc nil))
c6a57d4e7a09 (Info-find-file): Check for symbols `apropos', `history',
Juri Linkov <juri@jurta.org>
parents: 68853
diff changeset
4260 (list Info-current-file Info-current-node)))
55057
8ac1373b947e (Info-restore-desktop-buffer): Move from desktop.el. Add Parameters.
Lars Hansen <larsh@soem.dk>
parents: 54971
diff changeset
4261
8ac1373b947e (Info-restore-desktop-buffer): Move from desktop.el. Add Parameters.
Lars Hansen <larsh@soem.dk>
parents: 54971
diff changeset
4262 (defun Info-restore-desktop-buffer (desktop-buffer-file-name
8ac1373b947e (Info-restore-desktop-buffer): Move from desktop.el. Add Parameters.
Lars Hansen <larsh@soem.dk>
parents: 54971
diff changeset
4263 desktop-buffer-name
8ac1373b947e (Info-restore-desktop-buffer): Move from desktop.el. Add Parameters.
Lars Hansen <larsh@soem.dk>
parents: 54971
diff changeset
4264 desktop-buffer-misc)
64812
0d6aa987778c Replace `info' with upper-case `Info' where appropriate.
Juri Linkov <juri@jurta.org>
parents: 64795
diff changeset
4265 "Restore an Info buffer specified in a desktop file."
55057
8ac1373b947e (Info-restore-desktop-buffer): Move from desktop.el. Add Parameters.
Lars Hansen <larsh@soem.dk>
parents: 54971
diff changeset
4266 (let ((first (nth 0 desktop-buffer-misc))
8ac1373b947e (Info-restore-desktop-buffer): Move from desktop.el. Add Parameters.
Lars Hansen <larsh@soem.dk>
parents: 54971
diff changeset
4267 (second (nth 1 desktop-buffer-misc)))
8ac1373b947e (Info-restore-desktop-buffer): Move from desktop.el. Add Parameters.
Lars Hansen <larsh@soem.dk>
parents: 54971
diff changeset
4268 (when (and first second)
55797
954cec4917f6 (Info-desktop-buffer-misc-data): Don't save information
Juri Linkov <juri@jurta.org>
parents: 55774
diff changeset
4269 (when desktop-buffer-name
954cec4917f6 (Info-desktop-buffer-misc-data): Don't save information
Juri Linkov <juri@jurta.org>
parents: 55774
diff changeset
4270 (set-buffer (get-buffer-create desktop-buffer-name))
954cec4917f6 (Info-desktop-buffer-misc-data): Don't save information
Juri Linkov <juri@jurta.org>
parents: 55774
diff changeset
4271 (Info-mode))
55084
b8934c440dd6 (Info-restore-desktop-buffer): Delete with-no-warnings.
Lars Hansen <larsh@soem.dk>
parents: 55074
diff changeset
4272 (Info-find-node first second)
55057
8ac1373b947e (Info-restore-desktop-buffer): Move from desktop.el. Add Parameters.
Lars Hansen <larsh@soem.dk>
parents: 54971
diff changeset
4273 (current-buffer))))
8ac1373b947e (Info-restore-desktop-buffer): Move from desktop.el. Add Parameters.
Lars Hansen <larsh@soem.dk>
parents: 54971
diff changeset
4274
64961
1fa57fbe3d5f Revert last change.
Andreas Schwab <schwab@suse.de>
parents: 64957
diff changeset
4275 (add-to-list 'desktop-buffer-mode-handlers
1fa57fbe3d5f Revert last change.
Andreas Schwab <schwab@suse.de>
parents: 64957
diff changeset
4276 '(Info-mode . Info-restore-desktop-buffer))
64896
a7d19794a559 Add handler to desktop-buffer-mode-handlers.
Lars Hansen <larsh@soem.dk>
parents: 64812
diff changeset
4277
584
4cd7543be581 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 540
diff changeset
4278 (provide 'info)
4cd7543be581 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 540
diff changeset
4279
62822
7f11f471aa34 (Info-goto-node): Revert autoload addition (2004-06-12).
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 62733
diff changeset
4280 ;; arch-tag: f2480fe2-2139-40c1-a49b-6314991164ac
660
08eb386dd0f3 *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 584
diff changeset
4281 ;;; info.el ends here