annotate lisp/ido.el @ 96627:ae085a544367

Use more correct IPA characters for English pronunciation. Add the combining acute accent after the accented vowel in the Russian example like it is used in dictionaries.
author Juri Linkov <juri@jurta.org>
date Sat, 12 Jul 2008 20:41:45 +0000
parents c3309dba6542
children b2098130915f
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1 ;;; ido.el --- interactively do things with buffers and files.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2
64762
41bb365f41c4 Update years in copyright notice; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 64409
diff changeset
3 ;; Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003,
87566
0c4a74c24677 * progmodes/ada-xref.el (ada-prj-find-prj-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 87110
diff changeset
4 ;; 2004, 2005, 2006, 2007, 2008 Free Software Foundation, Inc.
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
5
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
6 ;; Author: Kim F. Storm <storm@cua.dk>
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
7 ;; Based on: iswitchb by Stephen Eglen <stephen@cns.ed.ac.uk>
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
8 ;; Keywords: extensions convenience
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
9
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
10 ;; This file is part of GNU Emacs.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
11
94678
ee5932bf781d Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents: 91509
diff changeset
12 ;; GNU Emacs is free software: you can redistribute it and/or modify
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
13 ;; it under the terms of the GNU General Public License as published by
94678
ee5932bf781d Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents: 91509
diff changeset
14 ;; the Free Software Foundation, either version 3 of the License, or
ee5932bf781d Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents: 91509
diff changeset
15 ;; (at your option) any later version.
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
16
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
17 ;; GNU Emacs is distributed in the hope that it will be useful,
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
18 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
19 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
20 ;; GNU General Public License for more details.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
21
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
22 ;; You should have received a copy of the GNU General Public License
94678
ee5932bf781d Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents: 91509
diff changeset
23 ;; along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>.
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
24
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
25
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
26 ;;; Commentary:
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
27
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
28 ;; Ido - interactive do - switches between buffers and opens files and
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
29 ;; directories with a minimum of keystrokes. It is a superset of
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
30 ;; iswitchb, the interactive buffer switching package by Stephen Eglen.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
31
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
32 ;; Interactive substring matching
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
33 ;; ------------------------------
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
34 ;;
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
35 ;; As you type in a substring, the list of buffers or files currently
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
36 ;; matching the substring are displayed as you type. The list is
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
37 ;; ordered so that the most recent buffers or files visited come at
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
38 ;; the start of the list.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
39 ;;
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
40 ;; The buffer or file at the start of the list will be the one visited
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
41 ;; when you press RETURN. By typing more of the substring, the list is
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
42 ;; narrowed down so that gradually the buffer or file you want will be
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
43 ;; at the top of the list. Alternatively, you can use C-s and C-r (or
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
44 ;; the right and left arrow keys) to rotate buffer or file names in the
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
45 ;; list until the one you want is at the top of the list.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
46 ;;
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
47 ;; Completion is also available so that you can see what is common to
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
48 ;; all of the matching buffers or files as you type.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
49 ;;
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
50 ;; Example:
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
51 ;;
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
52 ;; If I have two buffers called "123456" and "123", with "123456" the
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
53 ;; most recent, when I use ido-switch-buffer, I first of all get
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
54 ;; presented with the list of all the buffers
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
55 ;;
67390
d90725ea1fdb Move Acknowledgements and History after Commentary.
Kim F. Storm <storm@cua.dk>
parents: 67362
diff changeset
56 ;; Buffer: {123456 | 123}
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
57 ;;
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
58 ;; If I then press 2:
67390
d90725ea1fdb Move Acknowledgements and History after Commentary.
Kim F. Storm <storm@cua.dk>
parents: 67362
diff changeset
59 ;; Buffer: 2[3]{123456 | 123}
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
60 ;;
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
61 ;; The list in {...} are the matching buffers, most recent first
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
62 ;; (buffers visible in the current frame are put at the end of the
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
63 ;; list by default). At any time I can select the item at the head of
64341
e461e45e6f66 Fix commentary.
Kim F. Storm <storm@cua.dk>
parents: 64336
diff changeset
64 ;; the list by pressing RET. I can also put the first element at the
e461e45e6f66 Fix commentary.
Kim F. Storm <storm@cua.dk>
parents: 64336
diff changeset
65 ;; end of the list by pressing C-s or [right], or bring the last
e461e45e6f66 Fix commentary.
Kim F. Storm <storm@cua.dk>
parents: 64336
diff changeset
66 ;; element to the head of the list by pressing C-r or [left].
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
67 ;;
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
68 ;; The item in [...] indicates what can be added to my input by
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
69 ;; pressing TAB. In this case, I will get "3" added to my input.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
70
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
71 ;; So, I press TAB:
67390
d90725ea1fdb Move Acknowledgements and History after Commentary.
Kim F. Storm <storm@cua.dk>
parents: 67362
diff changeset
72 ;; Buffer: 23{123456 | 123}
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
73 ;;
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
74 ;; At this point, I still have two matching buffers.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
75 ;; If I want the first buffer in the list, I simply press RET. If I
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
76 ;; wanted the second in the list, I could press C-s to move it to the
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
77 ;; top of the list and then RET to select it.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
78 ;;
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
79 ;; However, if I type 4, I only have one match left:
67390
d90725ea1fdb Move Acknowledgements and History after Commentary.
Kim F. Storm <storm@cua.dk>
parents: 67362
diff changeset
80 ;; Buffer: 234[123456]
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
81 ;;
67390
d90725ea1fdb Move Acknowledgements and History after Commentary.
Kim F. Storm <storm@cua.dk>
parents: 67362
diff changeset
82 ;; Since there is only one matching buffer left, it is given in [] and
d90725ea1fdb Move Acknowledgements and History after Commentary.
Kim F. Storm <storm@cua.dk>
parents: 67362
diff changeset
83 ;; it is shown in the `ido-only-match' face (ForestGreen). I can now
d90725ea1fdb Move Acknowledgements and History after Commentary.
Kim F. Storm <storm@cua.dk>
parents: 67362
diff changeset
84 ;; press TAB or RET to go to that buffer.
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
85 ;;
67390
d90725ea1fdb Move Acknowledgements and History after Commentary.
Kim F. Storm <storm@cua.dk>
parents: 67362
diff changeset
86 ;; If I want to create a new buffer named "234", I press C-j instead of
d90725ea1fdb Move Acknowledgements and History after Commentary.
Kim F. Storm <storm@cua.dk>
parents: 67362
diff changeset
87 ;; TAB or RET.
d90725ea1fdb Move Acknowledgements and History after Commentary.
Kim F. Storm <storm@cua.dk>
parents: 67362
diff changeset
88 ;;
d90725ea1fdb Move Acknowledgements and History after Commentary.
Kim F. Storm <storm@cua.dk>
parents: 67362
diff changeset
89 ;; If instead, I type "a":
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
90 ;; Buffer: 234a [No match]
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
91 ;; There are no matching buffers. If I press RET or TAB, I can be
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
92 ;; prompted to create a new buffer called "234a".
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
93 ;;
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
94 ;; Of course, where this function comes in really useful is when you
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
95 ;; can specify the buffer using only a few keystrokes. In the above
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
96 ;; example, the quickest way to get to the "123456" file would be
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
97 ;; just to type 4 and then RET (assuming there isn't any newer buffer
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
98 ;; with 4 in its name).
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
99
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
100 ;; Likewise, if you use C-x C-f (ido-find-file), the list of files and
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
101 ;; directories in the current directory is provided in the same
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
102 ;; fashion as the buffers above. The files and directories are
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
103 ;; normally sorted in alphabetical order, but the most recently
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
104 ;; visited directory is placed first to speed up navigating to
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
105 ;; directories that you have visited recently.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
106 ;;
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
107 ;; In addition to scrolling through the list using [right] and [left],
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
108 ;; you can use [up] and [down] to quickly scroll the list to the next
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
109 ;; or previous subdirectory.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
110 ;;
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
111 ;; To go down into a subdirectory, and continue the file selection on
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
112 ;; the files in that directory, simply move the directory to the head
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
113 ;; of the list and hit RET.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
114 ;;
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
115 ;; To go up to the parent directory, delete any partial file name
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
116 ;; already specified (e.g. using [backspace]) and hit [backspace].
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
117 ;;
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
118 ;; To go to the root directory (on the current drive), enter two
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
119 ;; slashes. On MS-DOS or Windows, to select the root of another
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
120 ;; drive, enter X:/ where X is the drive letter. You can also visit
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
121 ;; files on other hosts using the ange-ftp notations `/host:' and
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
122 ;; `/user@host:'. See the variable `ido-slow-ftp-hosts' if you want
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
123 ;; to inhibit the ido substring matching for ftp access.
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
124 ;;
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
125 ;; If for some reason you cannot specify the proper file using
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
126 ;; ido-find-file, you can press C-f to enter the normal find-file.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
127 ;; You can also press C-b to drop into ido-switch-buffer.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
128
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
129 ;; See the doc string of ido-switch-buffer and ido-find-file for full
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
130 ;; keybindings and features.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
131 ;; (describe-function 'ido-find-file)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
132
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
133 ;; Hidden buffers and files
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
134 ;; ------------------------
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
135 ;;
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
136 ;; Normally, ido does not include hidden buffers (whose name starts
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
137 ;; with a space) and hidden files and directories (whose name starts
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
138 ;; with `.') in the list of possible completions. However, if the
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
139 ;; substring you enter does not match any of the visible buffers or
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
140 ;; files, ido will automatically look for completions among the hidden
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
141 ;; buffers or files.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
142 ;;
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
143 ;; You can toggle display of the hidden buffers and files with C-a.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
144
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
145 ;; Additional functionality
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
146 ;; ------------------------
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
147 ;;
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
148 ;; After C-x b, the buffer at the head of the list can be killed by
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
149 ;; pressing C-k. If the buffer needs saving, you will be queried
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
150 ;; before the buffer is killed.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
151 ;;
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
152 ;; Likewise, after C-x C-f, you can delete (i.e. physically remove)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
153 ;; the file at the head of the list with C-k. You will always be
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
154 ;; asked for confirmation before the file is deleted.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
155 ;;
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
156 ;; If you enter C-x b to switch to a buffer visiting a given file, and
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
157 ;; you find that the file you are after is not in any buffer, you can
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
158 ;; press C-f to immediately drop into ido-find-file. And you can
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
159 ;; switch back to buffer selection with C-b.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
160
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
161 ;; Prefix matching
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
162 ;; ---------------
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
163 ;;
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
164 ;; The standard way of completion with Unix-shells and Emacs is to insert a
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
165 ;; PREFIX and then hitting TAB (or another completion key). Cause of this
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
166 ;; behavior has become second nature to a lot of emacs users `ido' offers in
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
167 ;; addition to the default substring-matching-method (look above) also the
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
168 ;; prefix-matching-method. The kind of matching is the only difference to
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
169 ;; the description of the substring-matching above.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
170 ;;
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
171 ;; You can toggle prefix matching with C-p.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
172 ;;
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
173 ;; Example:
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
174 ;;
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
175 ;; If you have again two Buffers "123456" and "123" then hitting "2" does
64341
e461e45e6f66 Fix commentary.
Kim F. Storm <storm@cua.dk>
parents: 64336
diff changeset
176 ;; not match because "2" is not a PREFIX in any of the buffer-names.
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
177
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
178 ;; Flexible matching
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
179 ;; -----------------
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
180 ;;
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
181 ;; If you set ido-enable-flex-matching, ido will do a more flexible
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
182 ;; matching (unless regexp matching is active) to find possible matches
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
183 ;; among the available buffer or file names if no matches are found using
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
184 ;; the normal prefix or substring matching.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
185 ;;
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
186 ;; The flexible matching implies that any item which simply contains all
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
187 ;; of the entered characters in the specified sequence will match.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
188 ;;
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
189 ;; Example:
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
190 ;;
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
191 ;; If you have four files "alpha", "beta", "gamma", and "delta",
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
192 ;; entering "aa" will match "alpha" and "gamma", while "ea" matches
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
193 ;; "beta" and "delta". If prefix matching is also active, "aa" only
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
194 ;; matches "alpha", while "ea" does not match any files.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
195
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
196 ;; Regexp matching
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
197 ;; ---------------
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
198 ;;
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
199 ;; There is limited provision for regexp matching within ido,
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
200 ;; enabled through `ido-enable-regexp' (toggle with C-t).
64341
e461e45e6f66 Fix commentary.
Kim F. Storm <storm@cua.dk>
parents: 64336
diff changeset
201 ;; This allows you to type `[ch]$' for example and see all file names
e461e45e6f66 Fix commentary.
Kim F. Storm <storm@cua.dk>
parents: 64336
diff changeset
202 ;; ending in `c' or `h'.
e461e45e6f66 Fix commentary.
Kim F. Storm <storm@cua.dk>
parents: 64336
diff changeset
203 ;;
e461e45e6f66 Fix commentary.
Kim F. Storm <storm@cua.dk>
parents: 64336
diff changeset
204 ;; Note: ido-style completion is inhibited when you enable regexp matching.
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
205
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
206
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
207 ;; Customization
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
208 ;; -------------
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
209 ;;
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
210 ;; Customize the `ido' group to change the `ido' functionality.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
211 ;;
62089
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
212 ;; To modify the keybindings, use the ido-setup-hook. For example:
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
213 ;;(add-hook 'ido-setup-hook 'ido-my-keys)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
214 ;;
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
215 ;;(defun ido-my-keys ()
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
216 ;; "Add my keybindings for ido."
67362
ca155a6d12ad (ido-completion-map): Renamed from ido-mode-map.
Kim F. Storm <storm@cua.dk>
parents: 67141
diff changeset
217 ;; (define-key ido-completion-map " " 'ido-next-match)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
218 ;; )
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
219
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
220 ;; Seeing all the matching buffers or files
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
221 ;; ----------------------------------------
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
222 ;;
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
223 ;; If you have many matching files, they may not all fit onto one
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
224 ;; line of the minibuffer. Normally, the minibuffer window will grow
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
225 ;; to show you more of the matching files (depending on the setting
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
226 ;; of the variables `resize-mini-windows' and `max-mini-window-height').
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
227 ;; If you want ido to behave differently from the default minibuffer
96376
c3309dba6542 American English spelling fix.
Glenn Morris <rgm@gnu.org>
parents: 95057
diff changeset
228 ;; resizing behavior, set the variable `ido-max-window-height'.
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
229 ;;
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
230 ;; Also, to improve the responsiveness of ido, the maximum number of
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
231 ;; matching items is limited to 12, but you can increase or removed
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
232 ;; this limit via the `ido-max-prospects' variable.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
233
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
234 ;; To see a full list of all matching buffers in a separate buffer,
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
235 ;; hit ? or press TAB when there are no further completions to the
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
236 ;; substring. Repeated TAB presses will scroll you through this
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
237 ;; separate buffer.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
238
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
239 ;; Changing the list of files
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
240 ;; --------------------------
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
241
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
242 ;; By default, the list of current files is most recent first,
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
243 ;; oldest last, with the exception that the files visible in the
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
244 ;; current frame are put at the end of the list. A hook exists to
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
245 ;; allow other functions to order the list. For example, if you add:
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
246 ;;
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
247 ;; (add-hook 'ido-make-buffer-list-hook 'ido-summary-buffers-to-end)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
248 ;;
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
249 ;; then all files matching "Summary" are moved to the end of the
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
250 ;; list. (I find this handy for keeping the INBOX Summary and so on
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
251 ;; out of the way.) It also moves files matching "output\*$" to the
56754
5ea587a67aae Update AUCTeX information.
David Kastrup <dak@gnu.org>
parents: 55362
diff changeset
252 ;; end of the list (these are created by AUCTeX when compiling.)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
253 ;; Other functions could be made available which alter the list of
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
254 ;; matching files (either deleting or rearranging elements.)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
255
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
256 ;; Highlighting
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
257 ;; ------------
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
258
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
259 ;; The highlighting of matching items is controlled via ido-use-faces.
63066
bf364cb1c987 (ido-first-match, ido-only-match, ido-subdir)
Kim F. Storm <storm@cua.dk>
parents: 62985
diff changeset
260 ;; The faces used are ido-first-match, ido-only-match and
bf364cb1c987 (ido-first-match, ido-only-match, ido-subdir)
Kim F. Storm <storm@cua.dk>
parents: 62985
diff changeset
261 ;; ido-subdir.
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
262 ;; Colouring of the matching item was suggested by
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
263 ;; Carsten Dominik (dominik@strw.leidenuniv.nl).
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
264
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
265 ;; Replacement for read-buffer and read-file-name
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
266 ;; ----------------------------------------------
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
267
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
268 ;; ido-read-buffer and ido-read-file-name have been written to be drop
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
269 ;; in replacements for the normal buffer and file name reading
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
270 ;; functions `read-buffer' and `read-file-name'.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
271
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
272 ;; To use ido for all buffer and file selections in Emacs, customize the
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
273 ;; variable `ido-everywhere'.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
274
96376
c3309dba6542 American English spelling fix.
Glenn Morris <rgm@gnu.org>
parents: 95057
diff changeset
275 ;; Using ido-like behavior in other lisp packages
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
276 ;; -----------------------------------------------
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
277
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
278 ;; If you don't want to rely on the `ido-everywhere' functionality,
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
279 ;; ido-read-buffer, ido-read-file-name, and ido-read-directory-name
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
280 ;; can be used by other packages to read a buffer name, a file name,
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
281 ;; or a directory name in the `ido' way.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
282
67390
d90725ea1fdb Move Acknowledgements and History after Commentary.
Kim F. Storm <storm@cua.dk>
parents: 67362
diff changeset
283 ;;; Acknowledgements
d90725ea1fdb Move Acknowledgements and History after Commentary.
Kim F. Storm <storm@cua.dk>
parents: 67362
diff changeset
284
d90725ea1fdb Move Acknowledgements and History after Commentary.
Kim F. Storm <storm@cua.dk>
parents: 67362
diff changeset
285 ;; Infinite amounts of gratitude goes to Stephen Eglen <stephen@cns.ed.ac.uk>
d90725ea1fdb Move Acknowledgements and History after Commentary.
Kim F. Storm <storm@cua.dk>
parents: 67362
diff changeset
286 ;; who wrote iswitch-buffer mode - from which I ripped off 99% of the code
d90725ea1fdb Move Acknowledgements and History after Commentary.
Kim F. Storm <storm@cua.dk>
parents: 67362
diff changeset
287 ;; for ido-switch-buffer and found the inspiration for ido-find-file.
d90725ea1fdb Move Acknowledgements and History after Commentary.
Kim F. Storm <storm@cua.dk>
parents: 67362
diff changeset
288 ;; The ido package would never have existed without his work.
d90725ea1fdb Move Acknowledgements and History after Commentary.
Kim F. Storm <storm@cua.dk>
parents: 67362
diff changeset
289
d90725ea1fdb Move Acknowledgements and History after Commentary.
Kim F. Storm <storm@cua.dk>
parents: 67362
diff changeset
290 ;; Also thanks to Klaus Berndl, Rohit Namjoshi, Robert Fenk, Alex
d90725ea1fdb Move Acknowledgements and History after Commentary.
Kim F. Storm <storm@cua.dk>
parents: 67362
diff changeset
291 ;; Schroeder, Bill Benedetto, Stephen Eglen, and many others for bug
d90725ea1fdb Move Acknowledgements and History after Commentary.
Kim F. Storm <storm@cua.dk>
parents: 67362
diff changeset
292 ;; fixes and improvements.
d90725ea1fdb Move Acknowledgements and History after Commentary.
Kim F. Storm <storm@cua.dk>
parents: 67362
diff changeset
293
d90725ea1fdb Move Acknowledgements and History after Commentary.
Kim F. Storm <storm@cua.dk>
parents: 67362
diff changeset
294 ;;; History
d90725ea1fdb Move Acknowledgements and History after Commentary.
Kim F. Storm <storm@cua.dk>
parents: 67362
diff changeset
295
d90725ea1fdb Move Acknowledgements and History after Commentary.
Kim F. Storm <storm@cua.dk>
parents: 67362
diff changeset
296 ;; Since I discovered Stephen Eglen's excellent iswitchb package, I just
d90725ea1fdb Move Acknowledgements and History after Commentary.
Kim F. Storm <storm@cua.dk>
parents: 67362
diff changeset
297 ;; couldn't live without it, but once being addicted to switching buffers
d90725ea1fdb Move Acknowledgements and History after Commentary.
Kim F. Storm <storm@cua.dk>
parents: 67362
diff changeset
298 ;; with a minimum of keystrokes, I soon found that opening files in the
d90725ea1fdb Move Acknowledgements and History after Commentary.
Kim F. Storm <storm@cua.dk>
parents: 67362
diff changeset
299 ;; old-fashioned way was just too slow - so I decided to write a package
d90725ea1fdb Move Acknowledgements and History after Commentary.
Kim F. Storm <storm@cua.dk>
parents: 67362
diff changeset
300 ;; which could open files with the same speed and ease as iswitchb could
d90725ea1fdb Move Acknowledgements and History after Commentary.
Kim F. Storm <storm@cua.dk>
parents: 67362
diff changeset
301 ;; switch buffers.
d90725ea1fdb Move Acknowledgements and History after Commentary.
Kim F. Storm <storm@cua.dk>
parents: 67362
diff changeset
302
d90725ea1fdb Move Acknowledgements and History after Commentary.
Kim F. Storm <storm@cua.dk>
parents: 67362
diff changeset
303 ;; I originally wrote a separate ifindf.el package based on a copy of
d90725ea1fdb Move Acknowledgements and History after Commentary.
Kim F. Storm <storm@cua.dk>
parents: 67362
diff changeset
304 ;; iswitchb.el, which did for opening files what iswitchb did for
d90725ea1fdb Move Acknowledgements and History after Commentary.
Kim F. Storm <storm@cua.dk>
parents: 67362
diff changeset
305 ;; switching buffers. Along the way, I corrected a few errors in
d90725ea1fdb Move Acknowledgements and History after Commentary.
Kim F. Storm <storm@cua.dk>
parents: 67362
diff changeset
306 ;; ifindf which could have found its way back into iswitchb, but since
d90725ea1fdb Move Acknowledgements and History after Commentary.
Kim F. Storm <storm@cua.dk>
parents: 67362
diff changeset
307 ;; most of the functionality of the two package was practically
d90725ea1fdb Move Acknowledgements and History after Commentary.
Kim F. Storm <storm@cua.dk>
parents: 67362
diff changeset
308 ;; identical, I decided that the proper thing to do was to merge my
d90725ea1fdb Move Acknowledgements and History after Commentary.
Kim F. Storm <storm@cua.dk>
parents: 67362
diff changeset
309 ;; ifindf package back into iswitchb.
d90725ea1fdb Move Acknowledgements and History after Commentary.
Kim F. Storm <storm@cua.dk>
parents: 67362
diff changeset
310 ;;
d90725ea1fdb Move Acknowledgements and History after Commentary.
Kim F. Storm <storm@cua.dk>
parents: 67362
diff changeset
311 ;; This is basically what ido (interactively do) is all about; but I
d90725ea1fdb Move Acknowledgements and History after Commentary.
Kim F. Storm <storm@cua.dk>
parents: 67362
diff changeset
312 ;; found it ackward to merge my changes into the "iswitchb-" namespace,
d90725ea1fdb Move Acknowledgements and History after Commentary.
Kim F. Storm <storm@cua.dk>
parents: 67362
diff changeset
313 ;; so I invented a common "ido-" namespace for the merged packages.
d90725ea1fdb Move Acknowledgements and History after Commentary.
Kim F. Storm <storm@cua.dk>
parents: 67362
diff changeset
314 ;;
d90725ea1fdb Move Acknowledgements and History after Commentary.
Kim F. Storm <storm@cua.dk>
parents: 67362
diff changeset
315 ;; This version is based on ido.el version 1.57 released on
d90725ea1fdb Move Acknowledgements and History after Commentary.
Kim F. Storm <storm@cua.dk>
parents: 67362
diff changeset
316 ;; gnu.emacs.sources adapted for emacs 22.1 to use command remapping
d90725ea1fdb Move Acknowledgements and History after Commentary.
Kim F. Storm <storm@cua.dk>
parents: 67362
diff changeset
317 ;; and optionally hooking the read-buffer and read-file-name functions.
d90725ea1fdb Move Acknowledgements and History after Commentary.
Kim F. Storm <storm@cua.dk>
parents: 67362
diff changeset
318 ;;
d90725ea1fdb Move Acknowledgements and History after Commentary.
Kim F. Storm <storm@cua.dk>
parents: 67362
diff changeset
319 ;; Prefix matching was added by Klaus Berndl <klaus.berndl@sdm.de> based on
d90725ea1fdb Move Acknowledgements and History after Commentary.
Kim F. Storm <storm@cua.dk>
parents: 67362
diff changeset
320 ;; an idea of Yuji Minejima <ggb01164@nifty.ne.jp> and his mcomplete-package.
d90725ea1fdb Move Acknowledgements and History after Commentary.
Kim F. Storm <storm@cua.dk>
parents: 67362
diff changeset
321
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
322
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
323 ;;; Code:
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
324
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
325 (provide 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
326
65292
772a2f08bdbd (cua-inhibit-cua-keys): Add defvar.
Juanma Barranquero <lekktu@gmail.com>
parents: 65064
diff changeset
327 (defvar cua-inhibit-cua-keys)
772a2f08bdbd (cua-inhibit-cua-keys): Add defvar.
Juanma Barranquero <lekktu@gmail.com>
parents: 65064
diff changeset
328
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
329 ;;; User Variables
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
330 ;;
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
331 ;; These are some things you might want to change.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
332
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
333 (defun ido-fractionp (n)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
334 (and (numberp n) (> n 0.0) (<= n 1.0)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
335
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
336 (defgroup ido nil
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
337 "Switch between files using substrings."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
338 :group 'extensions
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
339 :group 'convenience
59996
aac0a33f5772 Change release version from 21.4 to 22.1 throughout.
Kim F. Storm <storm@cua.dk>
parents: 59995
diff changeset
340 :version "22.1"
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
341 :link '(emacs-commentary-link :tag "Commentary" "ido.el")
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
342 :link '(emacs-library-link :tag "Lisp File" "ido.el"))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
343
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
344 ;;;###autoload
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
345 (defcustom ido-mode nil
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
346 "Determines for which functional group \(buffer and files) ido behavior
63235
ba92543774db (ido-mode, ido-file-extensions-order, ido-default-file-method,
Juanma Barranquero <lekktu@gmail.com>
parents: 63124
diff changeset
347 should be enabled. The following values are possible:
49438
389e078f2b48 Many doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 49412
diff changeset
348 - `buffer': Turn only on ido buffer behavior \(switching, killing,
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
349 displaying...)
49438
389e078f2b48 Many doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 49412
diff changeset
350 - `file': Turn only on ido file behavior \(finding, writing, inserting...)
389e078f2b48 Many doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 49412
diff changeset
351 - `both': Turn on ido buffer and file behavior.
389e078f2b48 Many doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 49412
diff changeset
352 - `nil': Turn off any ido switching.
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
353
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
354 Setting this variable directly does not take effect;
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
355 use either \\[customize] or the function `ido-mode'."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
356 :set #'(lambda (symbol value)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
357 (ido-mode value))
65802
4c1b9d579db1 (ido-mode): Use custom-initialize-set.
Kim F. Storm <storm@cua.dk>
parents: 65689
diff changeset
358 :initialize 'custom-initialize-set
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
359 :require 'ido
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
360 :link '(emacs-commentary-link "ido.el")
69809
7dd2c54d4afb (ido-mode): Set after ido-unc-hosts and ido-ignore-unc-host-regexps.
Kim F. Storm <storm@cua.dk>
parents: 69748
diff changeset
361 :set-after '(ido-save-directory-list-file
69817
4521b7c3be30 (ido-mode): Remove ido-ignore-unc-host-regexps from the :set-after list.
Kim F. Storm <storm@cua.dk>
parents: 69814
diff changeset
362 ;; This will clear ido-unc-hosts-cache, so set it
69809
7dd2c54d4afb (ido-mode): Set after ido-unc-hosts and ido-ignore-unc-host-regexps.
Kim F. Storm <storm@cua.dk>
parents: 69748
diff changeset
363 ;; before loading history file.
69817
4521b7c3be30 (ido-mode): Remove ido-ignore-unc-host-regexps from the :set-after list.
Kim F. Storm <storm@cua.dk>
parents: 69814
diff changeset
364 ido-unc-hosts)
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
365 :type '(choice (const :tag "Turn on only buffer" buffer)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
366 (const :tag "Turn on only file" file)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
367 (const :tag "Turn on both buffer and file" both)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
368 (const :tag "Switch off all" nil))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
369 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
370
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
371 (defcustom ido-everywhere nil
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
372 "Use ido everywhere for reading file names and directories.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
373 Setting this variable directly does not work. Use `customize' or
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
374 call the function `ido-everywhere'."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
375 :set #'(lambda (symbol value)
65026
e1cc4b0d18d3 (ido-everywhere): Fix defcustom :set function to disable
Kim F. Storm <storm@cua.dk>
parents: 65012
diff changeset
376 (ido-everywhere (if value 1 -1)))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
377 :initialize 'custom-initialize-default
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
378 :type 'boolean
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
379 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
380
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
381 (defcustom ido-case-fold case-fold-search
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
382 "*Non-nil if searching of buffer and file names should ignore case."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
383 :type 'boolean
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
384 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
385
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
386 (defcustom ido-ignore-buffers
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
387 '("\\` ")
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
388 "*List of regexps or functions matching buffer names to ignore.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
389 For example, traditional behavior is not to list buffers whose names begin
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
390 with a space, for which the regexp is `\\` '. See the source file for
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
391 example functions that filter buffernames."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
392 :type '(repeat (choice regexp function))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
393 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
394
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
395 (defcustom ido-ignore-files
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
396 '("\\`CVS/" "\\`#" "\\`.#" "\\`\\.\\./" "\\`\\./")
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
397 "*List of regexps or functions matching file names to ignore.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
398 For example, traditional behavior is not to list files whose names begin
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
399 with a #, for which the regexp is `\\`#'. See the source file for
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
400 example functions that filter filenames."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
401 :type '(repeat (choice regexp function))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
402 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
403
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
404 (defcustom ido-ignore-extensions t
73825
36f23fcd07f8 (ido-ignore-extensions, ido-show-dot-for-dired, ido-max-dir-file-cache,
Juanma Barranquero <lekktu@gmail.com>
parents: 73388
diff changeset
405 "*Non-nil means ignore files in `completion-ignored-extensions' list."
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
406 :type 'boolean
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
407 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
408
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
409 (defcustom ido-show-dot-for-dired nil
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
410 "*Non-nil means to always put . as the first item in file name lists.
73825
36f23fcd07f8 (ido-ignore-extensions, ido-show-dot-for-dired, ido-max-dir-file-cache,
Juanma Barranquero <lekktu@gmail.com>
parents: 73388
diff changeset
411 This allows the current directory to be opened immediately with `dired'."
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
412 :type 'boolean
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
413 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
414
59995
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
415 (defcustom ido-file-extensions-order nil
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
416 "*List of file extensions specifying preferred order of file selections.
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
417 Each element is either a string with `.' as the first char, an empty
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
418 string matching files without extension, or t which is the default order
63235
ba92543774db (ido-mode, ido-file-extensions-order, ido-default-file-method,
Juanma Barranquero <lekktu@gmail.com>
parents: 63124
diff changeset
419 for files with an unlisted file extension."
59995
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
420 :type '(repeat (choice string
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
421 (const :tag "Default order" t)))
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
422 :group 'ido)
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
423
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
424 (defcustom ido-ignore-directories
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
425 '("\\`CVS/" "\\`\\.\\./" "\\`\\./")
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
426 "*List of regexps or functions matching sub-directory names to ignore."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
427 :type '(repeat (choice regexp function))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
428 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
429
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
430 (defcustom ido-ignore-directories-merge nil
49208
5a945cb7d742 (ido-ignore-directories-merge): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 49180
diff changeset
431 "*List of regexps or functions matching directory names to ignore during merge.
5a945cb7d742 (ido-ignore-directories-merge): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 49180
diff changeset
432 Directory names matched by one of the regexps in this list are not inserted
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
433 in merged file and directory lists."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
434 :type '(repeat (choice regexp function))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
435 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
436
87566
0c4a74c24677 * progmodes/ada-xref.el (ada-prj-find-prj-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 87110
diff changeset
437 ;; Examples for setting the value of ido-ignore-buffers
0c4a74c24677 * progmodes/ada-xref.el (ada-prj-find-prj-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 87110
diff changeset
438 ;;(defun ido-ignore-c-mode (name)
0c4a74c24677 * progmodes/ada-xref.el (ada-prj-find-prj-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 87110
diff changeset
439 ;; "Ignore all c mode buffers -- example function for ido."
0c4a74c24677 * progmodes/ada-xref.el (ada-prj-find-prj-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 87110
diff changeset
440 ;; (with-current-buffer name
0c4a74c24677 * progmodes/ada-xref.el (ada-prj-find-prj-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 87110
diff changeset
441 ;; (derived-mode-p 'c-mode)))
0c4a74c24677 * progmodes/ada-xref.el (ada-prj-find-prj-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 87110
diff changeset
442 ;;
0c4a74c24677 * progmodes/ada-xref.el (ada-prj-find-prj-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 87110
diff changeset
443 ;;(setq ido-ignore-buffers '("^ " ido-ignore-c-mode))
0c4a74c24677 * progmodes/ada-xref.el (ada-prj-find-prj-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 87110
diff changeset
444
0c4a74c24677 * progmodes/ada-xref.el (ada-prj-find-prj-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 87110
diff changeset
445 ;; Examples for setting the value of ido-ignore-files
0c4a74c24677 * progmodes/ada-xref.el (ada-prj-find-prj-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 87110
diff changeset
446 ;;(setq ido-ignore-files '("^ " "\\.c\\'" "\\.h\\'"))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
447
71240
0b7ea03b3bcd (ido-default-file-method, ido-default-buffer-method):
Kim F. Storm <storm@cua.dk>
parents: 70797
diff changeset
448 (defcustom ido-default-file-method 'raise-frame
85941
c1676fc08cea (ido-save-history): Write the history file in the current filename
Juanma Barranquero <lekktu@gmail.com>
parents: 84873
diff changeset
449 "*How to visit a new file when using `ido-find-file'.
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
450 Possible values:
71240
0b7ea03b3bcd (ido-default-file-method, ido-default-buffer-method):
Kim F. Storm <storm@cua.dk>
parents: 70797
diff changeset
451 `selected-window' Show new file in selected window
0b7ea03b3bcd (ido-default-file-method, ido-default-buffer-method):
Kim F. Storm <storm@cua.dk>
parents: 70797
diff changeset
452 `other-window' Show new file in another window (same frame)
0b7ea03b3bcd (ido-default-file-method, ido-default-buffer-method):
Kim F. Storm <storm@cua.dk>
parents: 70797
diff changeset
453 `display' Display file in another window without selecting to it
0b7ea03b3bcd (ido-default-file-method, ido-default-buffer-method):
Kim F. Storm <storm@cua.dk>
parents: 70797
diff changeset
454 `other-frame' Show new file in another frame
0b7ea03b3bcd (ido-default-file-method, ido-default-buffer-method):
Kim F. Storm <storm@cua.dk>
parents: 70797
diff changeset
455 `maybe-frame' If a file is visible in another frame, prompt to ask if you
0b7ea03b3bcd (ido-default-file-method, ido-default-buffer-method):
Kim F. Storm <storm@cua.dk>
parents: 70797
diff changeset
456 you want to see the file in the same window of the current
0b7ea03b3bcd (ido-default-file-method, ido-default-buffer-method):
Kim F. Storm <storm@cua.dk>
parents: 70797
diff changeset
457 frame or in the other frame
0b7ea03b3bcd (ido-default-file-method, ido-default-buffer-method):
Kim F. Storm <storm@cua.dk>
parents: 70797
diff changeset
458 `raise-frame' If a file is visible in another frame, raise that
0b7ea03b3bcd (ido-default-file-method, ido-default-buffer-method):
Kim F. Storm <storm@cua.dk>
parents: 70797
diff changeset
459 frame; otherwise, visit the file in the same window"
0b7ea03b3bcd (ido-default-file-method, ido-default-buffer-method):
Kim F. Storm <storm@cua.dk>
parents: 70797
diff changeset
460 :type '(choice (const :tag "Visit in selected window" selected-window)
0b7ea03b3bcd (ido-default-file-method, ido-default-buffer-method):
Kim F. Storm <storm@cua.dk>
parents: 70797
diff changeset
461 (const :tag "Visit in other window" other-window)
0b7ea03b3bcd (ido-default-file-method, ido-default-buffer-method):
Kim F. Storm <storm@cua.dk>
parents: 70797
diff changeset
462 (const :tag "Display (no select) in other window" display)
0b7ea03b3bcd (ido-default-file-method, ido-default-buffer-method):
Kim F. Storm <storm@cua.dk>
parents: 70797
diff changeset
463 (const :tag "Visit in other frame" other-frame)
0b7ea03b3bcd (ido-default-file-method, ido-default-buffer-method):
Kim F. Storm <storm@cua.dk>
parents: 70797
diff changeset
464 (const :tag "Ask to visit in other frame" maybe-frame)
0b7ea03b3bcd (ido-default-file-method, ido-default-buffer-method):
Kim F. Storm <storm@cua.dk>
parents: 70797
diff changeset
465 (const :tag "Raise frame if already visited" raise-frame))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
466 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
467
71240
0b7ea03b3bcd (ido-default-file-method, ido-default-buffer-method):
Kim F. Storm <storm@cua.dk>
parents: 70797
diff changeset
468 (defcustom ido-default-buffer-method 'raise-frame
85941
c1676fc08cea (ido-save-history): Write the history file in the current filename
Juanma Barranquero <lekktu@gmail.com>
parents: 84873
diff changeset
469 "*How to switch to new buffer when using `ido-switch-buffer'.
63235
ba92543774db (ido-mode, ido-file-extensions-order, ido-default-file-method,
Juanma Barranquero <lekktu@gmail.com>
parents: 63124
diff changeset
470 See `ido-default-file-method' for details."
71240
0b7ea03b3bcd (ido-default-file-method, ido-default-buffer-method):
Kim F. Storm <storm@cua.dk>
parents: 70797
diff changeset
471 :type '(choice (const :tag "Show in selected window" selected-window)
0b7ea03b3bcd (ido-default-file-method, ido-default-buffer-method):
Kim F. Storm <storm@cua.dk>
parents: 70797
diff changeset
472 (const :tag "Show in other window" other-window)
0b7ea03b3bcd (ido-default-file-method, ido-default-buffer-method):
Kim F. Storm <storm@cua.dk>
parents: 70797
diff changeset
473 (const :tag "Display (no select) in other window" display)
0b7ea03b3bcd (ido-default-file-method, ido-default-buffer-method):
Kim F. Storm <storm@cua.dk>
parents: 70797
diff changeset
474 (const :tag "Show in other frame" other-frame)
0b7ea03b3bcd (ido-default-file-method, ido-default-buffer-method):
Kim F. Storm <storm@cua.dk>
parents: 70797
diff changeset
475 (const :tag "Ask to show in other frame" maybe-frame)
0b7ea03b3bcd (ido-default-file-method, ido-default-buffer-method):
Kim F. Storm <storm@cua.dk>
parents: 70797
diff changeset
476 (const :tag "Raise frame if already shown" raise-frame))
0b7ea03b3bcd (ido-default-file-method, ido-default-buffer-method):
Kim F. Storm <storm@cua.dk>
parents: 70797
diff changeset
477 :type '(choice (const selected-window)
0b7ea03b3bcd (ido-default-file-method, ido-default-buffer-method):
Kim F. Storm <storm@cua.dk>
parents: 70797
diff changeset
478 (const other-window)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
479 (const display)
71240
0b7ea03b3bcd (ido-default-file-method, ido-default-buffer-method):
Kim F. Storm <storm@cua.dk>
parents: 70797
diff changeset
480 (const other-frame)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
481 (const maybe-frame)
71240
0b7ea03b3bcd (ido-default-file-method, ido-default-buffer-method):
Kim F. Storm <storm@cua.dk>
parents: 70797
diff changeset
482 (const raise-frame))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
483 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
484
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
485 (defcustom ido-enable-flex-matching nil
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
486 "*Non-nil means that `ido' will do flexible string matching.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
487 Flexible matching means that if the entered string does not
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
488 match any item, any item containing the entered characters
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
489 in the given sequence will match."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
490 :type 'boolean
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
491 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
492
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
493
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
494 (defcustom ido-enable-regexp nil
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
495 "*Non-nil means that `ido' will do regexp matching.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
496 Value can be toggled within `ido' using `ido-toggle-regexp'."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
497 :type 'boolean
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
498 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
499
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
500 (defcustom ido-enable-prefix nil
57065
4bf76a50a989 (ido-enable-dot-prefix): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 56754
diff changeset
501 "*Non-nil means only match if the entered text is a prefix of file name.
4bf76a50a989 (ido-enable-dot-prefix): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 56754
diff changeset
502 This behavior is like the standard emacs-completion.
73909
9a271b9a8284 (ido-enable-prefix): Improve previous doc fix.
Glenn Morris <rgm@gnu.org>
parents: 73877
diff changeset
503 If nil, match if the entered text is an arbitrary substring.
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
504 Value can be toggled within `ido' using `ido-toggle-prefix'."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
505 :type 'boolean
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
506 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
507
57065
4bf76a50a989 (ido-enable-dot-prefix): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 56754
diff changeset
508 (defcustom ido-enable-dot-prefix nil
4bf76a50a989 (ido-enable-dot-prefix): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 56754
diff changeset
509 "*Non-nil means to match leading dot as prefix.
4bf76a50a989 (ido-enable-dot-prefix): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 56754
diff changeset
510 I.e. hidden files and buffers will match only if you type a dot
4bf76a50a989 (ido-enable-dot-prefix): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 56754
diff changeset
511 as first char even if `ido-enable-prefix' is nil."
4bf76a50a989 (ido-enable-dot-prefix): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 56754
diff changeset
512 :type 'boolean
4bf76a50a989 (ido-enable-dot-prefix): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 56754
diff changeset
513 :group 'ido)
4bf76a50a989 (ido-enable-dot-prefix): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 56754
diff changeset
514
54776
ae50ef10fab5 (ido-confirm-unique-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 53459
diff changeset
515 (defcustom ido-confirm-unique-completion nil
ae50ef10fab5 (ido-confirm-unique-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 53459
diff changeset
516 "*Non-nil means that even a unique completion must be confirmed.
ae50ef10fab5 (ido-confirm-unique-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 53459
diff changeset
517 This means that \\[ido-complete] must always be followed by \\[ido-exit-minibuffer]
ae50ef10fab5 (ido-confirm-unique-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 53459
diff changeset
518 even when there is only one unique completion."
ae50ef10fab5 (ido-confirm-unique-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 53459
diff changeset
519 :type 'boolean
ae50ef10fab5 (ido-confirm-unique-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 53459
diff changeset
520 :group 'ido)
ae50ef10fab5 (ido-confirm-unique-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 53459
diff changeset
521
48030
4086fbc6ad65 (ido-cannot-complete-command): New defcustom, default to
Kim F. Storm <storm@cua.dk>
parents: 47977
diff changeset
522 (defcustom ido-cannot-complete-command 'ido-completion-help
4086fbc6ad65 (ido-cannot-complete-command): New defcustom, default to
Kim F. Storm <storm@cua.dk>
parents: 47977
diff changeset
523 "*Command run when `ido-complete' can't complete any more.
4086fbc6ad65 (ido-cannot-complete-command): New defcustom, default to
Kim F. Storm <storm@cua.dk>
parents: 47977
diff changeset
524 The most useful values are `ido-completion-help', which pops up a
4086fbc6ad65 (ido-cannot-complete-command): New defcustom, default to
Kim F. Storm <storm@cua.dk>
parents: 47977
diff changeset
525 window with completion alternatives, or `ido-next-match' or
4086fbc6ad65 (ido-cannot-complete-command): New defcustom, default to
Kim F. Storm <storm@cua.dk>
parents: 47977
diff changeset
526 `ido-prev-match', which cycle the buffer list."
4086fbc6ad65 (ido-cannot-complete-command): New defcustom, default to
Kim F. Storm <storm@cua.dk>
parents: 47977
diff changeset
527 :type 'function
4086fbc6ad65 (ido-cannot-complete-command): New defcustom, default to
Kim F. Storm <storm@cua.dk>
parents: 47977
diff changeset
528 :group 'ido)
4086fbc6ad65 (ido-cannot-complete-command): New defcustom, default to
Kim F. Storm <storm@cua.dk>
parents: 47977
diff changeset
529
4086fbc6ad65 (ido-cannot-complete-command): New defcustom, default to
Kim F. Storm <storm@cua.dk>
parents: 47977
diff changeset
530
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
531 (defcustom ido-record-commands t
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
532 "*Non-nil means that `ido' will record commands in command history.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
533 Note that the non-ido equivalent command is recorded."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
534 :type 'boolean
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
535 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
536
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
537 (defcustom ido-max-prospects 12
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
538 "*Non-zero means that the prospect list will be limited to than number of items.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
539 For a long list of prospects, building the full list for the minibuffer can take a
63235
ba92543774db (ido-mode, ido-file-extensions-order, ido-default-file-method,
Juanma Barranquero <lekktu@gmail.com>
parents: 63124
diff changeset
540 non-negligible amount of time; setting this variable reduces that time."
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
541 :type 'integer
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
542 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
543
49211
93a6625a2ef3 Rename ido-max-prompt-width to ido-max-file-prompt-width for consistency.
Kim F. Storm <storm@cua.dk>
parents: 49208
diff changeset
544 (defcustom ido-max-file-prompt-width 0.35
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
545 "*Non-zero means that the prompt string be limited to than number of characters.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
546 If value is a floating point number, it specifies a fraction of the frame width."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
547 :type '(choice
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
548 (integer :tag "Characters" :value 20)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
549 (restricted-sexp :tag "Fraction of frame width"
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
550 :value 0.35
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
551 :match-alternatives (ido-fractionp)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
552 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
553
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
554 (defcustom ido-max-window-height nil
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
555 "*Non-nil specifies a value to override `max-mini-window-height'."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
556 :type '(choice
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
557 (const :tag "Don't override" nil)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
558 (integer :tag "Number of lines" :value 1)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
559 (restricted-sexp
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
560 :tag "Fraction of window height"
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
561 :value 0.25
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
562 :match-alternatives (ido-fractionp)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
563 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
564
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
565 (defcustom ido-enable-last-directory-history t
49208
5a945cb7d742 (ido-ignore-directories-merge): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 49180
diff changeset
566 "*Non-nil means that `ido' will remember latest selected directory names.
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
567 See `ido-last-directory-list' and `ido-save-directory-list-file'."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
568 :type 'boolean
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
569 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
570
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
571 (defcustom ido-max-work-directory-list 50
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
572 "*Maximum number of working directories to record.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
573 This is the list of directories where files have most recently been opened.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
574 See `ido-work-directory-list' and `ido-save-directory-list-file'."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
575 :type 'integer
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
576 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
577
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
578 (defcustom ido-work-directory-list-ignore-regexps nil
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
579 "*List of regexps matching directories which should not be recorded.
49208
5a945cb7d742 (ido-ignore-directories-merge): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 49180
diff changeset
580 Directory names matched by one of the regexps in this list are not inserted in
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
581 the `ido-work-directory-list' list."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
582 :type '(repeat regexp)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
583 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
584
49180
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
585
53166
77088b91def1 * ido.el (ido-use-filename-at-point, ido-use-url-at-point):
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
586 (defcustom ido-use-filename-at-point nil
77088b91def1 * ido.el (ido-use-filename-at-point, ido-use-url-at-point):
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
587 "*Non-nil means that ido shall look for a filename at point.
64168
f7e7dd269327 * ido.el (ido-use-filename-at-point): New choice `guess'.
Kim F. Storm <storm@cua.dk>
parents: 64166
diff changeset
588 May use `ffap-guesser' to guess whether text at point is a filename.
53166
77088b91def1 * ido.el (ido-use-filename-at-point, ido-use-url-at-point):
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
589 If found, use that as the starting point for filename selection."
64168
f7e7dd269327 * ido.el (ido-use-filename-at-point): New choice `guess'.
Kim F. Storm <storm@cua.dk>
parents: 64166
diff changeset
590 :type '(choice
f7e7dd269327 * ido.el (ido-use-filename-at-point): New choice `guess'.
Kim F. Storm <storm@cua.dk>
parents: 64166
diff changeset
591 (const :tag "Disabled" nil)
f7e7dd269327 * ido.el (ido-use-filename-at-point): New choice `guess'.
Kim F. Storm <storm@cua.dk>
parents: 64166
diff changeset
592 (const :tag "Guess filename" guess)
f7e7dd269327 * ido.el (ido-use-filename-at-point): New choice `guess'.
Kim F. Storm <storm@cua.dk>
parents: 64166
diff changeset
593 (other :tag "Use literal filename" t))
53166
77088b91def1 * ido.el (ido-use-filename-at-point, ido-use-url-at-point):
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
594 :group 'ido)
77088b91def1 * ido.el (ido-use-filename-at-point, ido-use-url-at-point):
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
595
77088b91def1 * ido.el (ido-use-filename-at-point, ido-use-url-at-point):
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
596
77088b91def1 * ido.el (ido-use-filename-at-point, ido-use-url-at-point):
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
597 (defcustom ido-use-url-at-point nil
77088b91def1 * ido.el (ido-use-filename-at-point, ido-use-url-at-point):
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
598 "*Non-nil means that ido shall look for a URL at point.
77088b91def1 * ido.el (ido-use-filename-at-point, ido-use-url-at-point):
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
599 If found, call `find-file-at-point' to visit it."
77088b91def1 * ido.el (ido-use-filename-at-point, ido-use-url-at-point):
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
600 :type 'boolean
77088b91def1 * ido.el (ido-use-filename-at-point, ido-use-url-at-point):
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
601 :group 'ido)
77088b91def1 * ido.el (ido-use-filename-at-point, ido-use-url-at-point):
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
602
77088b91def1 * ido.el (ido-use-filename-at-point, ido-use-url-at-point):
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
603
49180
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
604 (defcustom ido-enable-tramp-completion t
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
605 "*Non-nil means that ido shall perform tramp method and server name completion.
49208
5a945cb7d742 (ido-ignore-directories-merge): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 49180
diff changeset
606 A tramp file name uses the following syntax: /method:user@host:filename."
49180
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
607 :type 'boolean
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
608 :group 'ido)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
609
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
610 (defcustom ido-record-ftp-work-directories t
49438
389e078f2b48 Many doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 49412
diff changeset
611 "*Non-nil means record ftp file names in the work directory list."
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
612 :type 'boolean
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
613 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
614
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
615 (defcustom ido-merge-ftp-work-directories nil
49438
389e078f2b48 Many doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 49412
diff changeset
616 "*If nil means merging ignores ftp file names in the work directory list."
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
617 :type 'boolean
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
618 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
619
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
620 (defcustom ido-cache-ftp-work-directory-time 1.0
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
621 "*Maximum time to cache contents of an ftp directory (in hours).
69542
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
622 Use C-l in prompt to refresh list.
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
623 If zero, ftp directories are not cached."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
624 :type 'number
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
625 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
626
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
627 (defcustom ido-slow-ftp-hosts nil
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
628 "*List of slow ftp hosts where ido prompting should not be used.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
629 If an ftp host is on this list, ido automatically switches to the non-ido
63235
ba92543774db (ido-mode, ido-file-extensions-order, ido-default-file-method,
Juanma Barranquero <lekktu@gmail.com>
parents: 63124
diff changeset
630 equivalent function, e.g. `find-file' rather than `ido-find-file'."
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
631 :type '(repeat string)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
632 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
633
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
634 (defcustom ido-slow-ftp-host-regexps nil
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
635 "*List of regexps matching slow ftp hosts (see `ido-slow-ftp-hosts')."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
636 :type '(repeat regexp)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
637 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
638
69748
e44b79389d65 (ido-unc-hosts-cache): New defvar.
Kim F. Storm <storm@cua.dk>
parents: 69738
diff changeset
639 (defvar ido-unc-hosts-cache t
69814
7512e19cdda7 (ido-unc-hosts-cache): Fix typo in docstring.
Juanma Barranquero <lekktu@gmail.com>
parents: 69809
diff changeset
640 "Cached value from `ido-unc-hosts' function.")
69748
e44b79389d65 (ido-unc-hosts-cache): New defvar.
Kim F. Storm <storm@cua.dk>
parents: 69738
diff changeset
641
69542
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
642 (defcustom ido-unc-hosts nil
69748
e44b79389d65 (ido-unc-hosts-cache): New defvar.
Kim F. Storm <storm@cua.dk>
parents: 69738
diff changeset
643 "*List of known UNC host names to complete after initial //.
e44b79389d65 (ido-unc-hosts-cache): New defvar.
Kim F. Storm <storm@cua.dk>
parents: 69738
diff changeset
644 If value is a function, that function is called to search network for
e44b79389d65 (ido-unc-hosts-cache): New defvar.
Kim F. Storm <storm@cua.dk>
parents: 69738
diff changeset
645 hosts on first use of UNC path."
e44b79389d65 (ido-unc-hosts-cache): New defvar.
Kim F. Storm <storm@cua.dk>
parents: 69738
diff changeset
646 :type '(choice (repeat :tag "List of UNC host names" string)
e44b79389d65 (ido-unc-hosts-cache): New defvar.
Kim F. Storm <storm@cua.dk>
parents: 69738
diff changeset
647 (function-item :tag "Use `NET VIEW'"
e44b79389d65 (ido-unc-hosts-cache): New defvar.
Kim F. Storm <storm@cua.dk>
parents: 69738
diff changeset
648 :value ido-unc-hosts-net-view)
e44b79389d65 (ido-unc-hosts-cache): New defvar.
Kim F. Storm <storm@cua.dk>
parents: 69738
diff changeset
649 (function :tag "Your own function"))
e44b79389d65 (ido-unc-hosts-cache): New defvar.
Kim F. Storm <storm@cua.dk>
parents: 69738
diff changeset
650 :set #'(lambda (symbol value)
e44b79389d65 (ido-unc-hosts-cache): New defvar.
Kim F. Storm <storm@cua.dk>
parents: 69738
diff changeset
651 (set symbol value)
e44b79389d65 (ido-unc-hosts-cache): New defvar.
Kim F. Storm <storm@cua.dk>
parents: 69738
diff changeset
652 (setq ido-unc-hosts-cache t))
e44b79389d65 (ido-unc-hosts-cache): New defvar.
Kim F. Storm <storm@cua.dk>
parents: 69738
diff changeset
653 :group 'ido)
e44b79389d65 (ido-unc-hosts-cache): New defvar.
Kim F. Storm <storm@cua.dk>
parents: 69738
diff changeset
654
69817
4521b7c3be30 (ido-mode): Remove ido-ignore-unc-host-regexps from the :set-after list.
Kim F. Storm <storm@cua.dk>
parents: 69814
diff changeset
655 (defcustom ido-downcase-unc-hosts t
4521b7c3be30 (ido-mode): Remove ido-ignore-unc-host-regexps from the :set-after list.
Kim F. Storm <storm@cua.dk>
parents: 69814
diff changeset
656 "*Non-nil if UNC host names should be downcased."
4521b7c3be30 (ido-mode): Remove ido-ignore-unc-host-regexps from the :set-after list.
Kim F. Storm <storm@cua.dk>
parents: 69814
diff changeset
657 :type 'boolean
4521b7c3be30 (ido-mode): Remove ido-ignore-unc-host-regexps from the :set-after list.
Kim F. Storm <storm@cua.dk>
parents: 69814
diff changeset
658 :group 'ido)
4521b7c3be30 (ido-mode): Remove ido-ignore-unc-host-regexps from the :set-after list.
Kim F. Storm <storm@cua.dk>
parents: 69814
diff changeset
659
69748
e44b79389d65 (ido-unc-hosts-cache): New defvar.
Kim F. Storm <storm@cua.dk>
parents: 69738
diff changeset
660 (defcustom ido-ignore-unc-host-regexps nil
69817
4521b7c3be30 (ido-mode): Remove ido-ignore-unc-host-regexps from the :set-after list.
Kim F. Storm <storm@cua.dk>
parents: 69814
diff changeset
661 "*List of regexps matching UNC hosts to ignore.
4521b7c3be30 (ido-mode): Remove ido-ignore-unc-host-regexps from the :set-after list.
Kim F. Storm <storm@cua.dk>
parents: 69814
diff changeset
662 Case is ignored if `ido-downcase-unc-hosts' is set."
69748
e44b79389d65 (ido-unc-hosts-cache): New defvar.
Kim F. Storm <storm@cua.dk>
parents: 69738
diff changeset
663 :type '(repeat regexp)
69542
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
664 :group 'ido)
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
665
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
666 (defcustom ido-cache-unc-host-shares-time 8.0
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
667 "*Maximum time to cache shares of an UNC host (in hours).
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
668 Use C-l in prompt to refresh list.
69733
156c18d0fca4 (ido-cache-unc-host-shares-time, ido-max-work-file-list, ido-switch-buffer):
Juanma Barranquero <lekktu@gmail.com>
parents: 69542
diff changeset
669 If zero, UNC host shares are not cached."
69542
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
670 :type 'number
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
671 :group 'ido)
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
672
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
673 (defcustom ido-max-work-file-list 10
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
674 "*Maximum number of names of recently opened files to record.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
675 This is the list the file names (sans directory) which have most recently
69733
156c18d0fca4 (ido-cache-unc-host-shares-time, ido-max-work-file-list, ido-switch-buffer):
Juanma Barranquero <lekktu@gmail.com>
parents: 69542
diff changeset
676 been opened. See `ido-work-file-list' and `ido-save-directory-list-file'."
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
677 :type 'integer
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
678 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
679
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
680 (defcustom ido-work-directory-match-only t
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
681 "*Non-nil means to skip non-matching directories in the directory history.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
682 When some text is already entered at the `ido-find-file' prompt, using
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
683 \\[ido-prev-work-directory] or \\[ido-next-work-directory] will skip directories
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
684 without any matching entries."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
685 :type 'boolean
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
686 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
687
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
688 (defcustom ido-auto-merge-work-directories-length 0
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
689 "*Automatically switch to merged work directories during file name input.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
690 The value is number of characters to type before switching to merged mode.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
691 If zero, the switch happens when no matches are found in the current directory.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
692 Automatic merging is disabled if the value is negative."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
693 :type 'integer
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
694 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
695
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
696 (defcustom ido-auto-merge-delay-time 0.70
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
697 "*Delay in seconds to wait for more input before doing auto merge."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
698 :type 'number
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
699 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
700
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
701 (defcustom ido-auto-merge-inhibit-characters-regexp "[][*?~]"
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
702 "*Regexp matching characters which should inhibit automatic merging.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
703 When a (partial) file name matches this regexp, merging is inhibited."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
704 :type 'regexp
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
705 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
706
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
707 (defcustom ido-merged-indicator "^"
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
708 "The string appended to first choice if it has multiple directory choices."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
709 :type 'string
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
710 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
711
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
712 (defcustom ido-max-dir-file-cache 100
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
713 "*Maximum number of working directories to be cached.
73825
36f23fcd07f8 (ido-ignore-extensions, ido-show-dot-for-dired, ido-max-dir-file-cache,
Juanma Barranquero <lekktu@gmail.com>
parents: 73388
diff changeset
714 This is the size of the cache of `file-name-all-completions' results.
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
715 Each cache entry is time stamped with the modification time of the
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
716 directory. Some systems, like Windows, have unreliable directory
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
717 modification times, so you may choose to disable caching on such
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
718 systems, or explicitly refresh the cache contents using the command
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
719 `ido-reread-directory' command (C-l) in the minibuffer.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
720 See also `ido-dir-file-cache' and `ido-save-directory-list-file'."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
721 :type 'integer
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
722 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
723
57211
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
724 (defcustom ido-max-directory-size 30000
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
725 "*Maximum size (in bytes) for directories to use ido completion.
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
726 If you enter a directory with a size larger than this size, ido will
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
727 not provide the normal completion. To show the completions, use C-a."
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
728 :type '(choice (const :tag "No limit" nil)
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
729 (integer :tag "Size in bytes" 30000))
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
730 :group 'ido)
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
731
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
732 (defcustom ido-rotate-file-list-default nil
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
733 "*Non-nil means that `ido' will always rotate file list to get default in front."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
734 :type 'boolean
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
735 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
736
65012
70976e57cb56 (ido-enter-matching-directory): Rename from
Kim F. Storm <storm@cua.dk>
parents: 64983
diff changeset
737 (defcustom ido-enter-matching-directory 'only
70976e57cb56 (ido-enter-matching-directory): Rename from
Kim F. Storm <storm@cua.dk>
parents: 64983
diff changeset
738 "*Additional methods to enter sub-directory of first/only matching item.
70976e57cb56 (ido-enter-matching-directory): Rename from
Kim F. Storm <storm@cua.dk>
parents: 64983
diff changeset
739 If value is 'first, enter first matching sub-directory when typing a slash.
70976e57cb56 (ido-enter-matching-directory): Rename from
Kim F. Storm <storm@cua.dk>
parents: 64983
diff changeset
740 If value is 'only, typing a slash only enters the sub-directory if it is
70976e57cb56 (ido-enter-matching-directory): Rename from
Kim F. Storm <storm@cua.dk>
parents: 64983
diff changeset
741 the only matching item.
70976e57cb56 (ido-enter-matching-directory): Rename from
Kim F. Storm <storm@cua.dk>
parents: 64983
diff changeset
742 If value is t, automatically enter a sub-directory when it is the only
70976e57cb56 (ido-enter-matching-directory): Rename from
Kim F. Storm <storm@cua.dk>
parents: 64983
diff changeset
743 matching item, even without typing a slash."
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
744 :type '(choice (const :tag "Never" nil)
65012
70976e57cb56 (ido-enter-matching-directory): Rename from
Kim F. Storm <storm@cua.dk>
parents: 64983
diff changeset
745 (const :tag "Slash enters first directory" first)
70976e57cb56 (ido-enter-matching-directory): Rename from
Kim F. Storm <storm@cua.dk>
parents: 64983
diff changeset
746 (const :tag "Slash enters first and only directory" only)
70976e57cb56 (ido-enter-matching-directory): Rename from
Kim F. Storm <storm@cua.dk>
parents: 64983
diff changeset
747 (other :tag "Always enter unique directory" t))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
748 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
749
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
750 (defcustom ido-create-new-buffer 'prompt
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
751 "*Specify whether a new buffer is created if no buffer matches substring.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
752 Choices are 'always to create new buffers unconditionally, 'prompt to
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
753 ask user whether to create buffer, or 'never to never create new buffer."
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
754 :type '(choice (const always)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
755 (const prompt)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
756 (const never))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
757 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
758
62089
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
759 (defcustom ido-setup-hook nil
63235
ba92543774db (ido-mode, ido-file-extensions-order, ido-default-file-method,
Juanma Barranquero <lekktu@gmail.com>
parents: 63124
diff changeset
760 "*Hook run after the ido variables and keymap have been setup.
62089
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
761 The dynamic variable `ido-cur-item' contains the current type of item that
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
762 is read by ido, possible values are file, dir, buffer, and list.
67362
ca155a6d12ad (ido-completion-map): Renamed from ido-mode-map.
Kim F. Storm <storm@cua.dk>
parents: 67141
diff changeset
763 Additional keys can be defined in `ido-completion-map'."
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
764 :type 'hook
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
765 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
766
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
767 (defcustom ido-separator nil
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
768 "*String used by ido to separate the alternatives in the minibuffer.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
769 Obsolete. Set 3rd element of `ido-decorations' instead."
46631
527b6139edd2 (ido-separator): Fix type.
Markus Rost <rost@math.uni-bielefeld.de>
parents: 46333
diff changeset
770 :type '(choice string (const nil))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
771 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
772
57211
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
773 (defcustom ido-decorations '( "{" "}" " | " " | ..." "[" "]" " [No match]" " [Matched]" " [Not readable]" " [Too big]")
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
774 "*List of strings used by ido to display the alternatives in the minibuffer.
57211
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
775 There are 10 elements in this list:
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
776 1st and 2nd elements are used as brackets around the prospect list,
73825
36f23fcd07f8 (ido-ignore-extensions, ido-show-dot-for-dired, ido-max-dir-file-cache,
Juanma Barranquero <lekktu@gmail.com>
parents: 73388
diff changeset
777 3rd element is the separator between prospects (ignored if `ido-separator' is set),
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
778 4th element is the string inserted at the end of a truncated list of prospects,
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
779 5th and 6th elements are used as brackets around the common match string which
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
780 can be completed using TAB,
63235
ba92543774db (ido-mode, ido-file-extensions-order, ido-default-file-method,
Juanma Barranquero <lekktu@gmail.com>
parents: 63124
diff changeset
781 7th element is the string displayed when there are no matches, and
ba92543774db (ido-mode, ido-file-extensions-order, ido-default-file-method,
Juanma Barranquero <lekktu@gmail.com>
parents: 63124
diff changeset
782 8th element is displayed if there is a single match (and faces are not used),
ba92543774db (ido-mode, ido-file-extensions-order, ido-default-file-method,
Juanma Barranquero <lekktu@gmail.com>
parents: 63124
diff changeset
783 9th element is displayed when the current directory is non-readable,
57211
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
784 10th element is displayed when directory exceeds `ido-max-directory-size'."
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
785 :type '(repeat string)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
786 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
787
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
788 (defcustom ido-use-faces t
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
789 "*Non-nil means use ido faces to highlighting first match, only match and
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
790 subdirs in the alternatives."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
791 :type 'boolean
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
792 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
793
63066
bf364cb1c987 (ido-first-match, ido-only-match, ido-subdir)
Kim F. Storm <storm@cua.dk>
parents: 62985
diff changeset
794 (defface ido-first-match '((t (:bold t)))
73825
36f23fcd07f8 (ido-ignore-extensions, ido-show-dot-for-dired, ido-max-dir-file-cache,
Juanma Barranquero <lekktu@gmail.com>
parents: 73388
diff changeset
795 "*Face used by ido for highlighting first match."
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
796 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
797
63066
bf364cb1c987 (ido-first-match, ido-only-match, ido-subdir)
Kim F. Storm <storm@cua.dk>
parents: 62985
diff changeset
798 (defface ido-only-match '((((class color))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
799 (:foreground "ForestGreen"))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
800 (t (:italic t)))
73825
36f23fcd07f8 (ido-ignore-extensions, ido-show-dot-for-dired, ido-max-dir-file-cache,
Juanma Barranquero <lekktu@gmail.com>
parents: 73388
diff changeset
801 "*Face used by ido for highlighting only match."
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
802 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
803
63066
bf364cb1c987 (ido-first-match, ido-only-match, ido-subdir)
Kim F. Storm <storm@cua.dk>
parents: 62985
diff changeset
804 (defface ido-subdir '((((min-colors 88) (class color))
61394
31aa9a390538 * mh-customize.el (mh-speedbar-selected-folder-face): Special case
Dan Nicolaescu <dann@ics.uci.edu>
parents: 61180
diff changeset
805 (:foreground "red1"))
31aa9a390538 * mh-customize.el (mh-speedbar-selected-folder-face): Special case
Dan Nicolaescu <dann@ics.uci.edu>
parents: 61180
diff changeset
806 (((class color))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
807 (:foreground "red"))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
808 (t (:underline t)))
73825
36f23fcd07f8 (ido-ignore-extensions, ido-show-dot-for-dired, ido-max-dir-file-cache,
Juanma Barranquero <lekktu@gmail.com>
parents: 73388
diff changeset
809 "*Face used by ido for highlighting subdirs in the alternatives."
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
810 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
811
63066
bf364cb1c987 (ido-first-match, ido-only-match, ido-subdir)
Kim F. Storm <storm@cua.dk>
parents: 62985
diff changeset
812 (defface ido-indicator '((((min-colors 88) (class color))
61394
31aa9a390538 * mh-customize.el (mh-speedbar-selected-folder-face): Special case
Dan Nicolaescu <dann@ics.uci.edu>
parents: 61180
diff changeset
813 (:foreground "yellow1"
31aa9a390538 * mh-customize.el (mh-speedbar-selected-folder-face): Special case
Dan Nicolaescu <dann@ics.uci.edu>
parents: 61180
diff changeset
814 :background "red1"
31aa9a390538 * mh-customize.el (mh-speedbar-selected-folder-face): Special case
Dan Nicolaescu <dann@ics.uci.edu>
parents: 61180
diff changeset
815 :width condensed))
31aa9a390538 * mh-customize.el (mh-speedbar-selected-folder-face): Special case
Dan Nicolaescu <dann@ics.uci.edu>
parents: 61180
diff changeset
816 (((class color))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
817 (:foreground "yellow"
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
818 :background "red"
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
819 :width condensed))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
820 (t (:inverse-video t)))
73825
36f23fcd07f8 (ido-ignore-extensions, ido-show-dot-for-dired, ido-max-dir-file-cache,
Juanma Barranquero <lekktu@gmail.com>
parents: 73388
diff changeset
821 "*Face used by ido for highlighting its indicators."
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
822 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
823
63476
a02cb15bf34c 2005-06-15 Matt Hodges <MPHodges@member.fsf.org>
Kim F. Storm <storm@cua.dk>
parents: 63430
diff changeset
824 (defface ido-incomplete-regexp
a02cb15bf34c 2005-06-15 Matt Hodges <MPHodges@member.fsf.org>
Kim F. Storm <storm@cua.dk>
parents: 63430
diff changeset
825 '((t
a02cb15bf34c 2005-06-15 Matt Hodges <MPHodges@member.fsf.org>
Kim F. Storm <storm@cua.dk>
parents: 63430
diff changeset
826 (:inherit font-lock-warning-face)))
a02cb15bf34c 2005-06-15 Matt Hodges <MPHodges@member.fsf.org>
Kim F. Storm <storm@cua.dk>
parents: 63430
diff changeset
827 "Ido face for indicating incomplete regexps."
a02cb15bf34c 2005-06-15 Matt Hodges <MPHodges@member.fsf.org>
Kim F. Storm <storm@cua.dk>
parents: 63430
diff changeset
828 :group 'ido)
a02cb15bf34c 2005-06-15 Matt Hodges <MPHodges@member.fsf.org>
Kim F. Storm <storm@cua.dk>
parents: 63430
diff changeset
829
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
830 (defcustom ido-make-file-list-hook nil
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
831 "*List of functions to run when the list of matching files is created.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
832 Each function on the list may modify the dynamically bound variable
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
833 `ido-temp-list' which contains the current list of matching files."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
834 :type 'hook
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
835 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
836
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
837 (defcustom ido-make-dir-list-hook nil
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
838 "*List of functions to run when the list of matching directories is created.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
839 Each function on the list may modify the dynamically bound variable
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
840 `ido-temp-list' which contains the current list of matching directories."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
841 :type 'hook
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
842 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
843
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
844 (defcustom ido-make-buffer-list-hook nil
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
845 "*List of functions to run when the list of matching buffers is created.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
846 Each function on the list may modify the dynamically bound variable
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
847 `ido-temp-list' which contains the current list of matching buffer names."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
848 :type 'hook
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
849 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
850
49208
5a945cb7d742 (ido-ignore-directories-merge): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 49180
diff changeset
851 (defcustom ido-rewrite-file-prompt-functions nil
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
852 "*List of functions to run when the find-file prompt is created.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
853 Each function on the list may modify the following dynamically bound
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
854 variables:
49438
389e078f2b48 Many doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 49412
diff changeset
855 dirname - the (abbreviated) directory name
389e078f2b48 Many doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 49412
diff changeset
856 to be modified by the hook functions
389e078f2b48 Many doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 49412
diff changeset
857 max-width - the max width of the resulting dirname; nil means no limit
389e078f2b48 Many doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 49412
diff changeset
858 prompt - the basic prompt (e.g. \"Find File: \")
389e078f2b48 Many doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 49412
diff changeset
859 literal - the string shown if doing \"literal\" find; set to nil to omit
389e078f2b48 Many doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 49412
diff changeset
860 vc-off - the string shown if version control is inhibited; set to nit to omit
389e078f2b48 Many doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 49412
diff changeset
861 prefix - either nil or a fixed prefix for the dirname
389e078f2b48 Many doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 49412
diff changeset
862
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
863 The following variables are available, but should not be changed:
73825
36f23fcd07f8 (ido-ignore-extensions, ido-show-dot-for-dired, ido-max-dir-file-cache,
Juanma Barranquero <lekktu@gmail.com>
parents: 73388
diff changeset
864 `ido-current-directory' - the unabbreviated directory name
49438
389e078f2b48 Many doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 49412
diff changeset
865 item - equals `file' or `dir' depending on the current mode."
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
866 :type 'hook
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
867 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
868
49208
5a945cb7d742 (ido-ignore-directories-merge): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 49180
diff changeset
869 (defvar ido-rewrite-file-prompt-rules nil
5a945cb7d742 (ido-ignore-directories-merge): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 49180
diff changeset
870 "*Alist of rewriting rules for directory names in ido prompts.
5a945cb7d742 (ido-ignore-directories-merge): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 49180
diff changeset
871 A list of elements of the form (FROM . TO) or (FROM . FUNC), each
5a945cb7d742 (ido-ignore-directories-merge): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 49180
diff changeset
872 meaning to rewrite the directory name if matched by FROM by either
5a945cb7d742 (ido-ignore-directories-merge): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 49180
diff changeset
873 substituting the matched string by TO or calling the function FUNC
5a945cb7d742 (ido-ignore-directories-merge): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 49180
diff changeset
874 with the current directory name as its only argument and using the
5a945cb7d742 (ido-ignore-directories-merge): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 49180
diff changeset
875 return value as the new directory name. In addition, each FUNC may
5a945cb7d742 (ido-ignore-directories-merge): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 49180
diff changeset
876 also modify the dynamic variables described for the variable
5a945cb7d742 (ido-ignore-directories-merge): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 49180
diff changeset
877 `ido-rewrite-file-prompt-functions'.")
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
878
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
879 (defcustom ido-completion-buffer "*Ido Completions*"
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
880 "*Name of completion buffer used by ido.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
881 Set to nil to disable completion buffers popping up."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
882 :type 'string
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
883 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
884
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
885 (defcustom ido-completion-buffer-all-completions nil
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
886 "*Non-nil means to show all completions in completion buffer.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
887 Otherwise, only the current list of matches is shown."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
888 :type 'boolean
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
889 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
890
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
891 (defvar ido-all-frames 'visible
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
892 "*Argument to pass to `walk-windows' when finding visible files.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
893 See documentation of `walk-windows' for useful values.")
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
894
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
895 (defcustom ido-minibuffer-setup-hook nil
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
896 "*Ido-specific customization of minibuffer setup.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
897
78492
7c8949dbfa0d Replace `iff' in doc-strings and comments.
Glenn Morris <rgm@gnu.org>
parents: 78236
diff changeset
898 This hook is run during minibuffer setup if `ido' is active.
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
899 It is intended for use in customizing ido for interoperation
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
900 with other packages. For instance:
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
901
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
902 \(add-hook 'ido-minibuffer-setup-hook
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
903 \(function
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
904 \(lambda ()
46118
5631b19e689c (ido-minibuffer-setup-hook): Doc fix.
Juanma Barranquero <lekktu@gmail.com>
parents: 46068
diff changeset
905 \(make-local-variable 'max-mini-window-height)
5631b19e689c (ido-minibuffer-setup-hook): Doc fix.
Juanma Barranquero <lekktu@gmail.com>
parents: 46068
diff changeset
906 \(setq max-mini-window-height 3))))
5631b19e689c (ido-minibuffer-setup-hook): Doc fix.
Juanma Barranquero <lekktu@gmail.com>
parents: 46068
diff changeset
907
5631b19e689c (ido-minibuffer-setup-hook): Doc fix.
Juanma Barranquero <lekktu@gmail.com>
parents: 46068
diff changeset
908 will constrain Emacs to a maximum minibuffer height of 3 lines when
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
909 ido is running. Copied from `icomplete-minibuffer-setup-hook'."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
910 :type 'hook
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
911 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
912
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
913 (defcustom ido-save-directory-list-file "~/.ido.last"
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
914 "File in which the ido state is saved between invocations.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
915 Variables stored are: `ido-last-directory-list', `ido-work-directory-list',
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
916 `ido-work-file-list', and `ido-dir-file-cache'.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
917 Must be set before enabling ido mode."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
918 :type 'string
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
919 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
920
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
921 (defcustom ido-read-file-name-as-directory-commands '()
69738
0bfe57fe99ed (ido-report-no-match, ido-switch-buffer,
Juanma Barranquero <lekktu@gmail.com>
parents: 69733
diff changeset
922 "List of commands which uses `read-file-name' to read a directory name.
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
923 When `ido-everywhere' is non-nil, the commands in this list will read
63235
ba92543774db (ido-mode, ido-file-extensions-order, ido-default-file-method,
Juanma Barranquero <lekktu@gmail.com>
parents: 63124
diff changeset
924 the directory using `ido-read-directory-name'."
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
925 :type '(repeat symbol)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
926 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
927
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
928 (defcustom ido-read-file-name-non-ido '()
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
929 "List of commands which shall not read file names the ido way.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
930 When `ido-everywhere' is non-nil, the commands in this list will read
63235
ba92543774db (ido-mode, ido-file-extensions-order, ido-default-file-method,
Juanma Barranquero <lekktu@gmail.com>
parents: 63124
diff changeset
931 the file name using normal `read-file-name' style."
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
932 :type '(repeat symbol)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
933 :group 'ido)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
934
64166
fad9662db4a9 (ido-before-fallback-functions): New hook.
Kim F. Storm <storm@cua.dk>
parents: 64091
diff changeset
935 (defcustom ido-before-fallback-functions '()
fad9662db4a9 (ido-before-fallback-functions): New hook.
Kim F. Storm <storm@cua.dk>
parents: 64091
diff changeset
936 "List of functions to call before calling a fallback command.
fad9662db4a9 (ido-before-fallback-functions): New hook.
Kim F. Storm <storm@cua.dk>
parents: 64091
diff changeset
937 The fallback command is passed as an argument to the functions."
fad9662db4a9 (ido-before-fallback-functions): New hook.
Kim F. Storm <storm@cua.dk>
parents: 64091
diff changeset
938 :type 'hook
fad9662db4a9 (ido-before-fallback-functions): New hook.
Kim F. Storm <storm@cua.dk>
parents: 64091
diff changeset
939 :group 'ido)
fad9662db4a9 (ido-before-fallback-functions): New hook.
Kim F. Storm <storm@cua.dk>
parents: 64091
diff changeset
940
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
941 ;;; Internal Variables
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
942
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
943 ;; Persistent variables
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
944
67362
ca155a6d12ad (ido-completion-map): Renamed from ido-mode-map.
Kim F. Storm <storm@cua.dk>
parents: 67141
diff changeset
945 (defvar ido-completion-map nil
67141
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
946 "Currently active keymap for ido commands.")
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
947
67362
ca155a6d12ad (ido-completion-map): Renamed from ido-mode-map.
Kim F. Storm <storm@cua.dk>
parents: 67141
diff changeset
948 (defvar ido-common-completion-map nil
67141
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
949 "Keymap for all ido commands.")
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
950
67362
ca155a6d12ad (ido-completion-map): Renamed from ido-mode-map.
Kim F. Storm <storm@cua.dk>
parents: 67141
diff changeset
951 (defvar ido-file-completion-map nil
67141
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
952 "Keymap for ido file commands.")
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
953
67362
ca155a6d12ad (ido-completion-map): Renamed from ido-mode-map.
Kim F. Storm <storm@cua.dk>
parents: 67141
diff changeset
954 (defvar ido-file-dir-completion-map nil
67141
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
955 "Keymap for ido file and directory commands.")
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
956
67362
ca155a6d12ad (ido-completion-map): Renamed from ido-mode-map.
Kim F. Storm <storm@cua.dk>
parents: 67141
diff changeset
957 (defvar ido-buffer-completion-map nil
67141
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
958 "Keymap for ido buffer commands.")
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
959
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
960 (defvar ido-file-history nil
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
961 "History of files selected using `ido-find-file'.")
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
962
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
963 (defvar ido-buffer-history nil
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
964 "History of buffers selected using `ido-switch-buffer'.")
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
965
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
966 (defvar ido-last-directory-list nil
49208
5a945cb7d742 (ido-ignore-directories-merge): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 49180
diff changeset
967 "List of last selected directory names.
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
968 See `ido-enable-last-directory-history' for details.")
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
969
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
970 (defvar ido-work-directory-list nil
49208
5a945cb7d742 (ido-ignore-directories-merge): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 49180
diff changeset
971 "List of actual working directory names.
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
972 The current directory is inserted at the front of this list whenever a
63235
ba92543774db (ido-mode, ido-file-extensions-order, ido-default-file-method,
Juanma Barranquero <lekktu@gmail.com>
parents: 63124
diff changeset
973 file is opened with `ido-find-file' and family.")
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
974
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
975 (defvar ido-work-file-list nil
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
976 "List of actual work file names.
49438
389e078f2b48 Many doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 49412
diff changeset
977 Opening a file with `ido-find-file' and similar functions
389e078f2b48 Many doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 49412
diff changeset
978 inserts the current file name (relative to its containing directory)
389e078f2b48 Many doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 49412
diff changeset
979 at the front of this list.")
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
980
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
981 (defvar ido-dir-file-cache nil
49438
389e078f2b48 Many doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 49412
diff changeset
982 "List of `file-name-all-completions' results.
389e078f2b48 Many doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 49412
diff changeset
983 Each element in the list is of the form (DIR (MTIME) FILE...).")
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
984
47203
d7ff55da60cd (ido-ignore-item-temp-list): New variable.
Kim F. Storm <storm@cua.dk>
parents: 46631
diff changeset
985 (defvar ido-ignore-item-temp-list nil
d7ff55da60cd (ido-ignore-item-temp-list): New variable.
Kim F. Storm <storm@cua.dk>
parents: 46631
diff changeset
986 "List of items to ignore in current ido invocation.
63235
ba92543774db (ido-mode, ido-file-extensions-order, ido-default-file-method,
Juanma Barranquero <lekktu@gmail.com>
parents: 63124
diff changeset
987 Intended to be let-bound by functions which call ido repeatedly.
47203
d7ff55da60cd (ido-ignore-item-temp-list): New variable.
Kim F. Storm <storm@cua.dk>
parents: 46631
diff changeset
988 Should never be set permanently.")
d7ff55da60cd (ido-ignore-item-temp-list): New variable.
Kim F. Storm <storm@cua.dk>
parents: 46631
diff changeset
989
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
990 ;; Temporary storage
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
991
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
992 (defvar ido-eoinput 1
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
993 "Point where minibuffer input ends and completion info begins.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
994 Copied from `icomplete-eoinput'.")
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
995 (make-variable-buffer-local 'ido-eoinput)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
996
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
997 (defvar ido-common-match-string nil
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
998 "Stores the string that is common to all matching files.")
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
999
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1000 (defvar ido-rescan nil
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1001 "Non-nil means we need to regenerate the list of matching items.")
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1002
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1003 (defvar ido-rotate nil
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1004 "Non-nil means we are rotating list of matches.")
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1005
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1006 (defvar ido-text nil
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1007 "Stores the users string as it is typed in.")
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1008
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1009 (defvar ido-text-init nil
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1010 "The initial string for the users string it is typed in.")
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1011
62089
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
1012 (defvar ido-input-stack nil
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
1013 "Stores the users strings when user hits M-b/M-f.")
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
1014
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1015 (defvar ido-matches nil
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1016 "List of files currently matching `ido-text'.")
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1017
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1018 (defvar ido-report-no-match t
69738
0bfe57fe99ed (ido-report-no-match, ido-switch-buffer,
Juanma Barranquero <lekktu@gmail.com>
parents: 69733
diff changeset
1019 "Report [No Match] when no completions matches `ido-text'.")
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1020
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
1021 (defvar ido-exit nil
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
1022 "Flag to monitor how `ido-find-file' exits.
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1023 If equal to `takeprompt', we use the prompt as the file name to be
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1024 selected.")
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1025
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1026 (defvar ido-current-directory nil
63235
ba92543774db (ido-mode, ido-file-extensions-order, ido-default-file-method,
Juanma Barranquero <lekktu@gmail.com>
parents: 63124
diff changeset
1027 "Current directory for `ido-find-file'.")
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1028
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1029 (defvar ido-auto-merge-timer nil
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1030 "Delay timer for auto merge.")
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1031
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1032 (defvar ido-use-mycompletion-depth 0
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
1033 "Non-nil means use `ido' completion feedback.
73825
36f23fcd07f8 (ido-ignore-extensions, ido-show-dot-for-dired, ido-max-dir-file-cache,
Juanma Barranquero <lekktu@gmail.com>
parents: 73388
diff changeset
1034 Is set by ido functions to the current `minibuffer-depth',
36f23fcd07f8 (ido-ignore-extensions, ido-show-dot-for-dired, ido-max-dir-file-cache,
Juanma Barranquero <lekktu@gmail.com>
parents: 73388
diff changeset
1035 so that it doesn't interfere with other minibuffer usage.")
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1036
63476
a02cb15bf34c 2005-06-15 Matt Hodges <MPHodges@member.fsf.org>
Kim F. Storm <storm@cua.dk>
parents: 63430
diff changeset
1037 (defvar ido-incomplete-regexp nil
a02cb15bf34c 2005-06-15 Matt Hodges <MPHodges@member.fsf.org>
Kim F. Storm <storm@cua.dk>
parents: 63430
diff changeset
1038 "Non-nil if an incomplete regexp is entered.")
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1039
75391
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
1040 (defvar ido-initial-position nil
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
1041 "Non-nil means to explicitly cursor on entry to minibuffer.
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
1042 Value is an integer which is number of chars to right of prompt.")
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
1043
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1044 ;;; Variables with dynamic bindings.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1045 ;;; Declared here to keep the byte compiler quiet.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1046
57191
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
1047 ;; Stores the current ido item type ('file, 'dir, 'buffer, or 'list).
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1048 (defvar ido-cur-item)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1049
74930
2de62cd68677 (ido-set-matches-1): Fix last change. If default item is
Kim F. Storm <storm@cua.dk>
parents: 74926
diff changeset
1050 ;;; Stores the current default item
2de62cd68677 (ido-set-matches-1): Fix last change. If default item is
Kim F. Storm <storm@cua.dk>
parents: 74926
diff changeset
1051 (defvar ido-default-item)
2de62cd68677 (ido-set-matches-1): Fix last change. If default item is
Kim F. Storm <storm@cua.dk>
parents: 74926
diff changeset
1052
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1053 ;; Stores the current list of items that will be searched through.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1054 ;; The list is ordered, so that the most interesting item comes first,
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1055 ;; although by default, the files visible in the current frame are put
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1056 ;; at the end of the list. Created by `ido-make-item-list'.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1057 (defvar ido-cur-list)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1058
57191
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
1059 ;; Stores the choice list for ido-completing-read
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
1060 (defvar ido-choice-list)
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
1061
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1062 ;; Stores the list of items which are ignored when building
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1063 ;; `ido-cur-list'. It is in no specific order.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1064 (defvar ido-ignored-list)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1065
53323
a053c8c470f3 Handle non-readable directories.
Kim F. Storm <storm@cua.dk>
parents: 53166
diff changeset
1066 ;; Remember if current directory is non-readable (so we cannot do completion).
a053c8c470f3 Handle non-readable directories.
Kim F. Storm <storm@cua.dk>
parents: 53166
diff changeset
1067 (defvar ido-directory-nonreadable)
a053c8c470f3 Handle non-readable directories.
Kim F. Storm <storm@cua.dk>
parents: 53166
diff changeset
1068
57211
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
1069 ;; Remember if current directory is 'huge' (so we don't want to do completion).
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
1070 (defvar ido-directory-too-big)
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
1071
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1072 ;; Keep current item list if non-nil.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1073 (defvar ido-keep-item-list)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1074
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1075 ;; Process ido-ignore-* lists.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1076 (defvar ido-process-ignore-lists)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1077
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1078 ;; Don't process ido-ignore- lists once.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1079 (defvar ido-process-ignore-lists-inhibit)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1080
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1081 ;; Buffer from which ido was entered.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1082 (defvar ido-entry-buffer)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1083
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1084 ;; Non-nil if matching file must be selected.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1085 (defvar ido-require-match)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1086
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1087 ;; Stores a temporary version of the file list being created.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1088 (defvar ido-temp-list)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1089
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1090 ;; Non-nil if default list element should be rotated into place.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1091 (defvar ido-rotate-temp)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1092
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1093 ;; Stores current index in ido-work-directory-list.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1094 (defvar ido-work-directory-index)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1095
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1096 ;; Stores current index in ido-work-file-list.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1097 (defvar ido-work-file-index)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1098
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1099 ;; Set when merged work directory list is in use.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1100 (defvar ido-use-merged-list)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1101
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1102 ;; Set when merged work directory list not yet built.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1103 (defvar ido-try-merged-list)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1104
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1105 ;; Saved state prior to last work directory merge.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1106 ;; Value is a list (ido-text dir cur-list ignored-list matches).
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1107 (defvar ido-pre-merge-state)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1108
53166
77088b91def1 * ido.el (ido-use-filename-at-point, ido-use-url-at-point):
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
1109 ;; Original value of vc-handled-backends for use in ido-toggle-vc.
77088b91def1 * ido.el (ido-use-filename-at-point, ido-use-url-at-point):
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
1110 (defvar ido-saved-vc-hb)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1111
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1112 ;; Stores temporary state of literal find file.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1113 (defvar ido-find-literal)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1114
57191
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
1115 ;; Set to 'ignore to inhibit switching between find-file/switch-buffer.
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
1116 (defvar ido-context-switch-command)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1117
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1118 ;;; FUNCTIONS
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1119
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1120 (defun ido-active (&optional merge)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1121 (if merge
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1122 ido-use-merged-list
75381
3e93f595966f (ido-active): Add xemacs test from ido-minibuffer-setup.
Kim F. Storm <storm@cua.dk>
parents: 75347
diff changeset
1123 (and (boundp 'ido-completing-read)
3e93f595966f (ido-active): Add xemacs test from ido-minibuffer-setup.
Kim F. Storm <storm@cua.dk>
parents: 75347
diff changeset
1124 (or (featurep 'xemacs)
3e93f595966f (ido-active): Add xemacs test from ido-minibuffer-setup.
Kim F. Storm <storm@cua.dk>
parents: 75347
diff changeset
1125 (= ido-use-mycompletion-depth (minibuffer-depth))))))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1126
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1127 (defvar ido-trace-enable nil)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1128
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1129 (defun ido-trace (p &optional s retval)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1130 (if ido-trace-enable
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1131 (let ((b (get-buffer-create " *IDO Trace*"))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1132 (deactivate-mark deactivate-mark))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1133 (save-excursion
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1134 (save-restriction
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1135 (set-buffer b)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1136 (insert p ": " (if (stringp s) s (format "%S" s)) "\n")))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1137 retval)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1138
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1139 (defun ido-toggle-trace (arg)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1140 (interactive "P")
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1141 (setq ido-trace-enable (or arg (not ido-trace-enable)))
49180
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
1142 (if ido-trace-enable
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
1143 (message "IDO trace on"))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1144 (let ((b (get-buffer " *IDO Trace*")))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1145 (if b
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1146 (if ido-trace-enable
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1147 (kill-buffer b)
49180
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
1148 (pop-to-buffer b t t)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
1149 (setq truncate-lines t)))))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
1150
74337
ee9b338cccea 2006-11-30 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents: 74020
diff changeset
1151 (defun ido-local-file-exists-p (file)
ee9b338cccea 2006-11-30 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents: 74020
diff changeset
1152 "Tell if FILE exists locally."
ee9b338cccea 2006-11-30 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents: 74020
diff changeset
1153 (let (file-name-handler-alist)
ee9b338cccea 2006-11-30 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents: 74020
diff changeset
1154 (file-exists-p file)))
ee9b338cccea 2006-11-30 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents: 74020
diff changeset
1155
69748
e44b79389d65 (ido-unc-hosts-cache): New defvar.
Kim F. Storm <storm@cua.dk>
parents: 69738
diff changeset
1156 (defun ido-unc-hosts (&optional query)
e44b79389d65 (ido-unc-hosts-cache): New defvar.
Kim F. Storm <storm@cua.dk>
parents: 69738
diff changeset
1157 "Return list of UNC host names."
69817
4521b7c3be30 (ido-mode): Remove ido-ignore-unc-host-regexps from the :set-after list.
Kim F. Storm <storm@cua.dk>
parents: 69814
diff changeset
1158 (let ((hosts
4521b7c3be30 (ido-mode): Remove ido-ignore-unc-host-regexps from the :set-after list.
Kim F. Storm <storm@cua.dk>
parents: 69814
diff changeset
1159 (cond
4521b7c3be30 (ido-mode): Remove ido-ignore-unc-host-regexps from the :set-after list.
Kim F. Storm <storm@cua.dk>
parents: 69814
diff changeset
1160 ((listp ido-unc-hosts)
4521b7c3be30 (ido-mode): Remove ido-ignore-unc-host-regexps from the :set-after list.
Kim F. Storm <storm@cua.dk>
parents: 69814
diff changeset
1161 ido-unc-hosts) ;; static list or nil
4521b7c3be30 (ido-mode): Remove ido-ignore-unc-host-regexps from the :set-after list.
Kim F. Storm <storm@cua.dk>
parents: 69814
diff changeset
1162 ((listp ido-unc-hosts-cache)
4521b7c3be30 (ido-mode): Remove ido-ignore-unc-host-regexps from the :set-after list.
Kim F. Storm <storm@cua.dk>
parents: 69814
diff changeset
1163 ido-unc-hosts-cache) ;; result of net search
4521b7c3be30 (ido-mode): Remove ido-ignore-unc-host-regexps from the :set-after list.
Kim F. Storm <storm@cua.dk>
parents: 69814
diff changeset
1164 ((and query (fboundp ido-unc-hosts))
4521b7c3be30 (ido-mode): Remove ido-ignore-unc-host-regexps from the :set-after list.
Kim F. Storm <storm@cua.dk>
parents: 69814
diff changeset
1165 (message (propertize "Searching for UNC hosts..." 'face 'highlight))
4521b7c3be30 (ido-mode): Remove ido-ignore-unc-host-regexps from the :set-after list.
Kim F. Storm <storm@cua.dk>
parents: 69814
diff changeset
1166 (setq ido-unc-hosts-cache (funcall ido-unc-hosts))
4521b7c3be30 (ido-mode): Remove ido-ignore-unc-host-regexps from the :set-after list.
Kim F. Storm <storm@cua.dk>
parents: 69814
diff changeset
1167 (message nil)
4521b7c3be30 (ido-mode): Remove ido-ignore-unc-host-regexps from the :set-after list.
Kim F. Storm <storm@cua.dk>
parents: 69814
diff changeset
1168 ido-unc-hosts-cache)
4521b7c3be30 (ido-mode): Remove ido-ignore-unc-host-regexps from the :set-after list.
Kim F. Storm <storm@cua.dk>
parents: 69814
diff changeset
1169 (query
4521b7c3be30 (ido-mode): Remove ido-ignore-unc-host-regexps from the :set-after list.
Kim F. Storm <storm@cua.dk>
parents: 69814
diff changeset
1170 (setq ido-unc-hosts-cache nil))
4521b7c3be30 (ido-mode): Remove ido-ignore-unc-host-regexps from the :set-after list.
Kim F. Storm <storm@cua.dk>
parents: 69814
diff changeset
1171 (t (fboundp ido-unc-hosts)))))
4521b7c3be30 (ido-mode): Remove ido-ignore-unc-host-regexps from the :set-after list.
Kim F. Storm <storm@cua.dk>
parents: 69814
diff changeset
1172 (when query
4521b7c3be30 (ido-mode): Remove ido-ignore-unc-host-regexps from the :set-after list.
Kim F. Storm <storm@cua.dk>
parents: 69814
diff changeset
1173 (let ((case-fold-search ido-downcase-unc-hosts)
4521b7c3be30 (ido-mode): Remove ido-ignore-unc-host-regexps from the :set-after list.
Kim F. Storm <storm@cua.dk>
parents: 69814
diff changeset
1174 res host re-list re)
4521b7c3be30 (ido-mode): Remove ido-ignore-unc-host-regexps from the :set-after list.
Kim F. Storm <storm@cua.dk>
parents: 69814
diff changeset
1175 (while hosts
4521b7c3be30 (ido-mode): Remove ido-ignore-unc-host-regexps from the :set-after list.
Kim F. Storm <storm@cua.dk>
parents: 69814
diff changeset
1176 (setq host (car hosts)
4521b7c3be30 (ido-mode): Remove ido-ignore-unc-host-regexps from the :set-after list.
Kim F. Storm <storm@cua.dk>
parents: 69814
diff changeset
1177 hosts (cdr hosts)
4521b7c3be30 (ido-mode): Remove ido-ignore-unc-host-regexps from the :set-after list.
Kim F. Storm <storm@cua.dk>
parents: 69814
diff changeset
1178 re-list (and ido-process-ignore-lists
4521b7c3be30 (ido-mode): Remove ido-ignore-unc-host-regexps from the :set-after list.
Kim F. Storm <storm@cua.dk>
parents: 69814
diff changeset
1179 ido-ignore-unc-host-regexps))
4521b7c3be30 (ido-mode): Remove ido-ignore-unc-host-regexps from the :set-after list.
Kim F. Storm <storm@cua.dk>
parents: 69814
diff changeset
1180 (while re-list
4521b7c3be30 (ido-mode): Remove ido-ignore-unc-host-regexps from the :set-after list.
Kim F. Storm <storm@cua.dk>
parents: 69814
diff changeset
1181 (setq re (car re-list)
4521b7c3be30 (ido-mode): Remove ido-ignore-unc-host-regexps from the :set-after list.
Kim F. Storm <storm@cua.dk>
parents: 69814
diff changeset
1182 re-list (cdr re-list))
4521b7c3be30 (ido-mode): Remove ido-ignore-unc-host-regexps from the :set-after list.
Kim F. Storm <storm@cua.dk>
parents: 69814
diff changeset
1183 (if (string-match re host)
4521b7c3be30 (ido-mode): Remove ido-ignore-unc-host-regexps from the :set-after list.
Kim F. Storm <storm@cua.dk>
parents: 69814
diff changeset
1184 (setq re-list nil
4521b7c3be30 (ido-mode): Remove ido-ignore-unc-host-regexps from the :set-after list.
Kim F. Storm <storm@cua.dk>
parents: 69814
diff changeset
1185 host nil)))
4521b7c3be30 (ido-mode): Remove ido-ignore-unc-host-regexps from the :set-after list.
Kim F. Storm <storm@cua.dk>
parents: 69814
diff changeset
1186 (when host
4521b7c3be30 (ido-mode): Remove ido-ignore-unc-host-regexps from the :set-after list.
Kim F. Storm <storm@cua.dk>
parents: 69814
diff changeset
1187 (when ido-downcase-unc-hosts
4521b7c3be30 (ido-mode): Remove ido-ignore-unc-host-regexps from the :set-after list.
Kim F. Storm <storm@cua.dk>
parents: 69814
diff changeset
1188 (setq host (downcase host)))
4521b7c3be30 (ido-mode): Remove ido-ignore-unc-host-regexps from the :set-after list.
Kim F. Storm <storm@cua.dk>
parents: 69814
diff changeset
1189 (setq res (cons host res))))
4521b7c3be30 (ido-mode): Remove ido-ignore-unc-host-regexps from the :set-after list.
Kim F. Storm <storm@cua.dk>
parents: 69814
diff changeset
1190 (setq hosts (sort res #'string<))))
4521b7c3be30 (ido-mode): Remove ido-ignore-unc-host-regexps from the :set-after list.
Kim F. Storm <storm@cua.dk>
parents: 69814
diff changeset
1191 hosts))
69748
e44b79389d65 (ido-unc-hosts-cache): New defvar.
Kim F. Storm <storm@cua.dk>
parents: 69738
diff changeset
1192
e44b79389d65 (ido-unc-hosts-cache): New defvar.
Kim F. Storm <storm@cua.dk>
parents: 69738
diff changeset
1193 (defun ido-unc-hosts-net-view ()
e44b79389d65 (ido-unc-hosts-cache): New defvar.
Kim F. Storm <storm@cua.dk>
parents: 69738
diff changeset
1194 "Query network for list of UNC host names using `NET VIEW'."
e44b79389d65 (ido-unc-hosts-cache): New defvar.
Kim F. Storm <storm@cua.dk>
parents: 69738
diff changeset
1195 (let (hosts)
e44b79389d65 (ido-unc-hosts-cache): New defvar.
Kim F. Storm <storm@cua.dk>
parents: 69738
diff changeset
1196 (with-temp-buffer
e44b79389d65 (ido-unc-hosts-cache): New defvar.
Kim F. Storm <storm@cua.dk>
parents: 69738
diff changeset
1197 (shell-command "net view" t)
e44b79389d65 (ido-unc-hosts-cache): New defvar.
Kim F. Storm <storm@cua.dk>
parents: 69738
diff changeset
1198 (goto-char (point-min))
e44b79389d65 (ido-unc-hosts-cache): New defvar.
Kim F. Storm <storm@cua.dk>
parents: 69738
diff changeset
1199 (while (re-search-forward "^\\\\\\\\\\([[:graph:]]+\\)" nil t)
e44b79389d65 (ido-unc-hosts-cache): New defvar.
Kim F. Storm <storm@cua.dk>
parents: 69738
diff changeset
1200 (setq hosts (cons (match-string 1) hosts))))
e44b79389d65 (ido-unc-hosts-cache): New defvar.
Kim F. Storm <storm@cua.dk>
parents: 69738
diff changeset
1201 hosts))
e44b79389d65 (ido-unc-hosts-cache): New defvar.
Kim F. Storm <storm@cua.dk>
parents: 69738
diff changeset
1202
49180
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
1203 (defun ido-is-tramp-root (&optional dir)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
1204 (and ido-enable-tramp-completion
66212
3a5f2ee9f30b (ido-is-tramp-root): Simplify regexp matching tramp root.
Kim F. Storm <storm@cua.dk>
parents: 65802
diff changeset
1205 (string-match "\\`/[^/]+[@:]\\'"
3a5f2ee9f30b (ido-is-tramp-root): Simplify regexp matching tramp root.
Kim F. Storm <storm@cua.dk>
parents: 65802
diff changeset
1206 (or dir ido-current-directory))))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1207
69542
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
1208 (defun ido-is-unc-root (&optional dir)
69748
e44b79389d65 (ido-unc-hosts-cache): New defvar.
Kim F. Storm <storm@cua.dk>
parents: 69738
diff changeset
1209 (and (ido-unc-hosts)
69542
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
1210 (string-equal "//"
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
1211 (or dir ido-current-directory))))
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
1212
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
1213 (defun ido-is-unc-host (&optional dir)
69748
e44b79389d65 (ido-unc-hosts-cache): New defvar.
Kim F. Storm <storm@cua.dk>
parents: 69738
diff changeset
1214 (and (ido-unc-hosts)
69542
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
1215 (string-match "\\`//[^/]+/\\'"
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
1216 (or dir ido-current-directory))))
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
1217
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1218 (defun ido-is-root-directory (&optional dir)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1219 (setq dir (or dir ido-current-directory))
49180
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
1220 (or
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
1221 (string-equal "/" dir)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
1222 (and (memq system-type '(windows-nt ms-dos))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
1223 (string-match "\\`[a-zA-Z]:[/\\]\\'" dir))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
1224 (if ido-enable-tramp-completion
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
1225 (ido-is-tramp-root dir)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
1226 (string-match "\\`/[^:/][^:/]+:\\'" dir))))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1227
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1228 (defun ido-is-ftp-directory (&optional dir)
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
1229 (string-match
49180
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
1230 (if ido-enable-tramp-completion
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
1231 "\\`/[^/:][^/:]+:" ;; like tramp-file-name-regexp-unified, but doesn't match single drive letters
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
1232 "\\`/[^/:][^/:]+:/")
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
1233 (or dir ido-current-directory)))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1234
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1235 (defun ido-is-slow-ftp-host (&optional dir)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1236 (and (or ido-slow-ftp-hosts ido-slow-ftp-host-regexps)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1237 (setq dir (or dir ido-current-directory))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1238 ;; (featurep 'ange-ftp)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1239 ;; (ange-ftp-ftp-name dir)
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
1240 (string-match
49180
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
1241 (if ido-enable-tramp-completion
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
1242 "\\`/\\([^/]+[@:]\\)*\\([^@/:][^@/:]+\\):"
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
1243 "\\`/\\([^/:]*@\\)?\\([^@/:][^@/:]+\\):/")
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
1244 dir)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1245 (let ((host (substring dir (match-beginning 2) (match-end 2))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1246 (or (member host ido-slow-ftp-hosts)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1247 (let ((re ido-slow-ftp-host-regexps))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1248 (while (and re (not (string-match (car re) host)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1249 (setq re (cdr re)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1250 re)))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1251
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1252 (defun ido-time-stamp (&optional time)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1253 ;; Time is a floating point number (fractions of 1 hour)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1254 (setq time (or time (current-time)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1255 (/ (+ (* (car time) 65536.0) (car (cdr time))) 3600.0))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1256
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1257 (defun ido-cache-ftp-valid (&optional time)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1258 (and (numberp ido-cache-ftp-work-directory-time)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1259 (> ido-cache-ftp-work-directory-time 0)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1260 (or (not time)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1261 (< (- (ido-time-stamp) time) ido-cache-ftp-work-directory-time))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1262
69542
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
1263 (defun ido-cache-unc-valid (&optional time)
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
1264 (and (numberp ido-cache-unc-host-shares-time)
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
1265 (> ido-cache-unc-host-shares-time 0)
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
1266 (or (not time)
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
1267 (< (- (ido-time-stamp) time) ido-cache-unc-host-shares-time))))
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
1268
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1269 (defun ido-may-cache-directory (&optional dir)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1270 (setq dir (or dir ido-current-directory))
49180
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
1271 (cond
57211
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
1272 ((ido-directory-too-big-p dir)
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
1273 nil)
49180
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
1274 ((and (ido-is-root-directory dir)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
1275 (or ido-enable-tramp-completion
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
1276 (memq system-type '(windows-nt ms-dos))))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
1277 nil)
69542
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
1278 ((ido-is-unc-host dir)
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
1279 (ido-cache-unc-valid))
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
1280 ((ido-is-ftp-directory dir)
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
1281 (ido-cache-ftp-valid))
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
1282 (t t)))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1283
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1284 (defun ido-pp (list &optional sep)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1285 (let ((print-level nil) (eval-expression-print-level nil)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1286 (print-length nil) (eval-expression-print-length nil))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1287 (insert "\n;; ----- " (symbol-name list) " -----\n(\n ")
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1288 (setq list (symbol-value list))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1289 (while list
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1290 (let* ((elt (car list))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1291 (s (if (consp elt) (car elt) elt)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1292 (if (and (stringp s) (= (length s) 0))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1293 (setq s nil))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1294 (if s
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1295 (prin1 elt (current-buffer)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1296 (if (and (setq list (cdr list)) s)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1297 (insert (or sep "\n ")))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1298 (insert "\n)\n")))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1299
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1300 (defun ido-save-history ()
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1301 "Save ido history and cache information between sessions."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1302 (interactive)
69156
e14bc51fc1eb (ido-save-history, ido-load-history): Simplify. Don't
Kim F. Storm <storm@cua.dk>
parents: 68804
diff changeset
1303 (when (and ido-last-directory-list ido-save-directory-list-file)
e14bc51fc1eb (ido-save-history, ido-load-history): Simplify. Don't
Kim F. Storm <storm@cua.dk>
parents: 68804
diff changeset
1304 (let ((buf (get-buffer-create " *ido session*"))
85998
74574731bb9a (ido-save-history): Save the history file in UTF-8,
Juanma Barranquero <lekktu@gmail.com>
parents: 85941
diff changeset
1305 (version-control 'never))
69156
e14bc51fc1eb (ido-save-history, ido-load-history): Simplify. Don't
Kim F. Storm <storm@cua.dk>
parents: 68804
diff changeset
1306 (unwind-protect
e14bc51fc1eb (ido-save-history, ido-load-history): Simplify. Don't
Kim F. Storm <storm@cua.dk>
parents: 68804
diff changeset
1307 (with-current-buffer buf
e14bc51fc1eb (ido-save-history, ido-load-history): Simplify. Don't
Kim F. Storm <storm@cua.dk>
parents: 68804
diff changeset
1308 (erase-buffer)
87046
9c5b08ec6fce (ido-save-history): Set the `coding' local
Juanma Barranquero <lekktu@gmail.com>
parents: 86406
diff changeset
1309 (insert ";;; -*- coding: utf-8 -*-\n")
85998
74574731bb9a (ido-save-history): Save the history file in UTF-8,
Juanma Barranquero <lekktu@gmail.com>
parents: 85941
diff changeset
1310 (setq buffer-file-coding-system 'utf-8)
69156
e14bc51fc1eb (ido-save-history, ido-load-history): Simplify. Don't
Kim F. Storm <storm@cua.dk>
parents: 68804
diff changeset
1311 (ido-pp 'ido-last-directory-list)
e14bc51fc1eb (ido-save-history, ido-load-history): Simplify. Don't
Kim F. Storm <storm@cua.dk>
parents: 68804
diff changeset
1312 (ido-pp 'ido-work-directory-list)
e14bc51fc1eb (ido-save-history, ido-load-history): Simplify. Don't
Kim F. Storm <storm@cua.dk>
parents: 68804
diff changeset
1313 (ido-pp 'ido-work-file-list)
e14bc51fc1eb (ido-save-history, ido-load-history): Simplify. Don't
Kim F. Storm <storm@cua.dk>
parents: 68804
diff changeset
1314 (ido-pp 'ido-dir-file-cache "\n\n ")
69809
7dd2c54d4afb (ido-mode): Set after ido-unc-hosts and ido-ignore-unc-host-regexps.
Kim F. Storm <storm@cua.dk>
parents: 69748
diff changeset
1315 (if (listp ido-unc-hosts-cache)
7dd2c54d4afb (ido-mode): Set after ido-unc-hosts and ido-ignore-unc-host-regexps.
Kim F. Storm <storm@cua.dk>
parents: 69748
diff changeset
1316 (ido-pp 'ido-unc-hosts-cache)
7dd2c54d4afb (ido-mode): Set after ido-unc-hosts and ido-ignore-unc-host-regexps.
Kim F. Storm <storm@cua.dk>
parents: 69748
diff changeset
1317 (insert "\n;; ----- ido-unc-hosts-cache -----\nt\n"))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1318 (write-file ido-save-directory-list-file nil))
69156
e14bc51fc1eb (ido-save-history, ido-load-history): Simplify. Don't
Kim F. Storm <storm@cua.dk>
parents: 68804
diff changeset
1319 (kill-buffer buf)))))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1320
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1321 (defun ido-load-history (&optional arg)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1322 "Load ido history and cache information from previous session.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1323 With prefix argument, reload history unconditionally."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1324 (interactive "P")
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1325 (if (or arg (and ido-save-directory-list-file (not ido-last-directory-list)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1326 (let ((file (expand-file-name ido-save-directory-list-file))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1327 buf)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1328 (when (file-readable-p file)
69156
e14bc51fc1eb (ido-save-history, ido-load-history): Simplify. Don't
Kim F. Storm <storm@cua.dk>
parents: 68804
diff changeset
1329 (setq buf (get-buffer-create " *ido session*"))
e14bc51fc1eb (ido-save-history, ido-load-history): Simplify. Don't
Kim F. Storm <storm@cua.dk>
parents: 68804
diff changeset
1330 (unwind-protect
e14bc51fc1eb (ido-save-history, ido-load-history): Simplify. Don't
Kim F. Storm <storm@cua.dk>
parents: 68804
diff changeset
1331 (with-current-buffer buf
e14bc51fc1eb (ido-save-history, ido-load-history): Simplify. Don't
Kim F. Storm <storm@cua.dk>
parents: 68804
diff changeset
1332 (erase-buffer)
e14bc51fc1eb (ido-save-history, ido-load-history): Simplify. Don't
Kim F. Storm <storm@cua.dk>
parents: 68804
diff changeset
1333 (insert-file-contents file)
e14bc51fc1eb (ido-save-history, ido-load-history): Simplify. Don't
Kim F. Storm <storm@cua.dk>
parents: 68804
diff changeset
1334 (condition-case nil
e14bc51fc1eb (ido-save-history, ido-load-history): Simplify. Don't
Kim F. Storm <storm@cua.dk>
parents: 68804
diff changeset
1335 (setq ido-last-directory-list (read (current-buffer))
e14bc51fc1eb (ido-save-history, ido-load-history): Simplify. Don't
Kim F. Storm <storm@cua.dk>
parents: 68804
diff changeset
1336 ido-work-directory-list (read (current-buffer))
e14bc51fc1eb (ido-save-history, ido-load-history): Simplify. Don't
Kim F. Storm <storm@cua.dk>
parents: 68804
diff changeset
1337 ido-work-file-list (read (current-buffer))
69809
7dd2c54d4afb (ido-mode): Set after ido-unc-hosts and ido-ignore-unc-host-regexps.
Kim F. Storm <storm@cua.dk>
parents: 69748
diff changeset
1338 ido-dir-file-cache (read (current-buffer))
7dd2c54d4afb (ido-mode): Set after ido-unc-hosts and ido-ignore-unc-host-regexps.
Kim F. Storm <storm@cua.dk>
parents: 69748
diff changeset
1339 ido-unc-hosts-cache (read (current-buffer)))
69156
e14bc51fc1eb (ido-save-history, ido-load-history): Simplify. Don't
Kim F. Storm <storm@cua.dk>
parents: 68804
diff changeset
1340 (error nil)))
e14bc51fc1eb (ido-save-history, ido-load-history): Simplify. Don't
Kim F. Storm <storm@cua.dk>
parents: 68804
diff changeset
1341 (kill-buffer buf)))))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1342 (ido-wash-history))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1343
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1344 (defun ido-wash-history ()
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1345 "Clean-up ido history and cache information.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1346 Removes badly formatted data and ignored directories."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1347 (interactive)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1348 ;; Check format of each of our lists, discard bogus elements
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1349 (setq ido-last-directory-list
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1350 (and (listp ido-last-directory-list)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1351 (let ((l ido-last-directory-list) r)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1352 (while l
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1353 (if (and (consp (car l))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1354 (stringp (car (car l)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1355 (stringp (cdr (car l))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1356 (setq r (cons (car l) r)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1357 (setq l (cdr l)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1358 (nreverse r))))
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
1359 (setq ido-work-directory-list
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1360 (and (listp ido-work-directory-list)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1361 (let ((l ido-work-directory-list) r)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1362 (while l
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1363 (if (and (stringp (car l))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1364 (or ido-record-ftp-work-directories
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1365 (not (ido-is-ftp-directory (car l)))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1366 (setq r (cons (car l) r)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1367 (setq l (cdr l)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1368 (nreverse r))))
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
1369 (setq ido-work-file-list
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1370 (and (listp ido-work-file-list)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1371 (let ((l ido-work-file-list) r)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1372 (while l
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1373 (if (stringp (car l))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1374 (setq r (cons (car l) r)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1375 (setq l (cdr l)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1376 (nreverse r))))
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
1377 (setq ido-dir-file-cache
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1378 (and (listp ido-dir-file-cache)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1379 (let ((l ido-dir-file-cache) r)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1380 (while l
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1381 (if (and (listp (car l))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1382 (> (length (car l)) 2)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1383 (let ((dir (car (car l)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1384 (time (car (cdr (car l))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1385 (files (cdr (cdr (car l)))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1386 (and
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1387 (stringp dir)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1388 (consp time)
69542
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
1389 (cond
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
1390 ((integerp (car time))
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
1391 (and (/= (car time) 0)
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
1392 (integerp (car (cdr time)))
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
1393 (/= (car (cdr time)) 0)
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
1394 (ido-may-cache-directory dir)))
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
1395 ((eq (car time) 'ftp)
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
1396 (and (numberp (cdr time))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1397 (ido-is-ftp-directory dir)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1398 (ido-cache-ftp-valid (cdr time))))
69542
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
1399 ((eq (car time) 'unc)
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
1400 (and (numberp (cdr time))
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
1401 (ido-is-unc-host dir)
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
1402 (ido-cache-unc-valid (cdr time))))
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
1403 (t nil))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1404 (let ((s files) (ok t))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1405 (while s
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1406 (if (stringp (car s))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1407 (setq s (cdr s))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1408 (setq s nil ok nil)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1409 ok))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1410 (setq r (cons (car l) r)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1411 (setq l (cdr l)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1412 (nreverse r))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1413
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1414 ;; Remove ignored directories from work directory list
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1415 ;; according to ido-work-directory-list-ignore-regexps
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1416 (if ido-work-directory-list
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1417 (let ((dirs (reverse ido-work-directory-list)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1418 (setq ido-work-directory-list nil)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1419 (while dirs
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1420 (ido-record-work-directory (car dirs))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1421 (setq dirs (cdr dirs)))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1422 ;; Get rid of text properties
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1423 (let ((l ido-last-directory-list) e)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1424 (while l
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1425 (setq e (car l) l (cdr l))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1426 (set-text-properties 0 (length (car e)) nil (car e))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1427 (set-text-properties 0 (length (cdr e)) nil (cdr e))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1428 (let ((l ido-work-directory-list) e)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1429 (while l
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1430 (setq e (car l) l (cdr l))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1431 (set-text-properties 0 (length e) nil e)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1432 (let ((l ido-work-file-list) e)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1433 (while l
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1434 (setq e (car l) l (cdr l))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1435 (set-text-properties 0 (length e) nil e)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1436 (let ((l ido-dir-file-cache) e d)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1437 (while l
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1438 (setq e (car l) l (cdr l))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1439 (if (listp e)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1440 (while e
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1441 (setq d (car e) e (cdr e))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1442 (if (not (consp d))
67141
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1443 (set-text-properties 0 (length d) nil d)))))))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1444
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1445
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1446 (defun ido-kill-emacs-hook ()
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1447 ;; ido kill emacs hook
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1448 (ido-save-history))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1449
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1450 (defvar ido-minor-mode-map-entry nil)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1451
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1452 ;;;###autoload
50260
78ad1c52e368 (ido-mode): Remove unused NOBIND arg. Fix doc string accordingly.
Kim F. Storm <storm@cua.dk>
parents: 49614
diff changeset
1453 (defun ido-mode (&optional arg)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1454 "Toggle ido speed-ups on or off.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1455 With ARG, turn ido speed-up on if arg is positive, off otherwise.
50260
78ad1c52e368 (ido-mode): Remove unused NOBIND arg. Fix doc string accordingly.
Kim F. Storm <storm@cua.dk>
parents: 49614
diff changeset
1456 Turning on ido-mode will remap (via a minor-mode keymap) the default
78ad1c52e368 (ido-mode): Remove unused NOBIND arg. Fix doc string accordingly.
Kim F. Storm <storm@cua.dk>
parents: 49614
diff changeset
1457 keybindings for the `find-file' and `switch-to-buffer' families of
78ad1c52e368 (ido-mode): Remove unused NOBIND arg. Fix doc string accordingly.
Kim F. Storm <storm@cua.dk>
parents: 49614
diff changeset
1458 commands to the ido versions of these functions.
78ad1c52e368 (ido-mode): Remove unused NOBIND arg. Fix doc string accordingly.
Kim F. Storm <storm@cua.dk>
parents: 49614
diff changeset
1459 However, if ARG arg equals 'files, remap only commands for files, or
78ad1c52e368 (ido-mode): Remove unused NOBIND arg. Fix doc string accordingly.
Kim F. Storm <storm@cua.dk>
parents: 49614
diff changeset
1460 if it equals 'buffers, remap only commands for buffer switching.
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1461 This function also adds a hook to the minibuffer."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1462 (interactive "P")
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1463 (setq ido-mode
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
1464 (cond
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1465 ((null arg) (if ido-mode nil 'both))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1466 ((eq arg t) 'both)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1467 ((eq arg 'files) 'file)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1468 ((eq arg 'buffers) 'buffer)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1469 ((memq arg '(file buffer both)) arg)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1470 ((> (prefix-numeric-value arg) 0) 'both)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1471 (t nil)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1472
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1473 (ido-everywhere (if ido-everywhere 1 -1))
67141
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1474 (when ido-mode
67362
ca155a6d12ad (ido-completion-map): Renamed from ido-mode-map.
Kim F. Storm <storm@cua.dk>
parents: 67141
diff changeset
1475 (ido-init-completion-maps))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1476
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1477 (when ido-mode
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1478 (add-hook 'minibuffer-setup-hook 'ido-minibuffer-setup)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1479 (add-hook 'choose-completion-string-functions 'ido-choose-completion-string)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1480 (ido-load-history)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1481
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1482 (add-hook 'kill-emacs-hook 'ido-kill-emacs-hook)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1483
67362
ca155a6d12ad (ido-completion-map): Renamed from ido-mode-map.
Kim F. Storm <storm@cua.dk>
parents: 67141
diff changeset
1484 (let ((map (make-sparse-keymap)))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1485 (when (memq ido-mode '(file both))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1486 (define-key map [remap find-file] 'ido-find-file)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1487 (define-key map [remap find-file-read-only] 'ido-find-file-read-only)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1488 (define-key map [remap find-alternate-file] 'ido-find-alternate-file)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1489 (define-key map [remap write-file] 'ido-write-file)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1490 (define-key map [remap insert-file] 'ido-insert-file)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1491 (define-key map [remap list-directory] 'ido-list-directory)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1492 (define-key map [remap dired] 'ido-dired)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1493 (define-key map [remap find-file-other-window] 'ido-find-file-other-window)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1494 (define-key map [remap find-file-read-only-other-window] 'ido-find-file-read-only-other-window)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1495 (define-key map [remap find-file-other-frame] 'ido-find-file-other-frame)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1496 (define-key map [remap find-file-read-only-other-frame] 'ido-find-file-read-only-other-frame))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1497
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1498 (when (memq ido-mode '(buffer both))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1499 (define-key map [remap switch-to-buffer] 'ido-switch-buffer)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1500 (define-key map [remap switch-to-buffer-other-window] 'ido-switch-buffer-other-window)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1501 (define-key map [remap switch-to-buffer-other-frame] 'ido-switch-buffer-other-frame)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1502 (define-key map [remap insert-buffer] 'ido-insert-buffer)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1503 (define-key map [remap kill-buffer] 'ido-kill-buffer)
67362
ca155a6d12ad (ido-completion-map): Renamed from ido-mode-map.
Kim F. Storm <storm@cua.dk>
parents: 67141
diff changeset
1504 (define-key map [remap display-buffer] 'ido-display-buffer))
ca155a6d12ad (ido-completion-map): Renamed from ido-mode-map.
Kim F. Storm <storm@cua.dk>
parents: 67141
diff changeset
1505
ca155a6d12ad (ido-completion-map): Renamed from ido-mode-map.
Kim F. Storm <storm@cua.dk>
parents: 67141
diff changeset
1506 (if ido-minor-mode-map-entry
ca155a6d12ad (ido-completion-map): Renamed from ido-mode-map.
Kim F. Storm <storm@cua.dk>
parents: 67141
diff changeset
1507 (setcdr ido-minor-mode-map-entry map)
ca155a6d12ad (ido-completion-map): Renamed from ido-mode-map.
Kim F. Storm <storm@cua.dk>
parents: 67141
diff changeset
1508 (setq ido-minor-mode-map-entry (cons 'ido-mode map))
ca155a6d12ad (ido-completion-map): Renamed from ido-mode-map.
Kim F. Storm <storm@cua.dk>
parents: 67141
diff changeset
1509 (add-to-list 'minor-mode-map-alist ido-minor-mode-map-entry)))))
ca155a6d12ad (ido-completion-map): Renamed from ido-mode-map.
Kim F. Storm <storm@cua.dk>
parents: 67141
diff changeset
1510
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1511
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1512 (defun ido-everywhere (arg)
65026
e1cc4b0d18d3 (ido-everywhere): Fix defcustom :set function to disable
Kim F. Storm <storm@cua.dk>
parents: 65012
diff changeset
1513 "Toggle using ido speed-ups everywhere file and directory names are read.
e1cc4b0d18d3 (ido-everywhere): Fix defcustom :set function to disable
Kim F. Storm <storm@cua.dk>
parents: 65012
diff changeset
1514 With ARG, turn ido speed-up on if arg is positive, off otherwise."
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1515 (interactive "P")
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1516 (setq ido-everywhere (if arg
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
1517 (> (prefix-numeric-value arg) 0)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1518 (not ido-everywhere)))
61808
083f920d9c86 (ido-everywhere): Save and restore old read-buffer-function
Kim F. Storm <storm@cua.dk>
parents: 61738
diff changeset
1519 (when (get 'ido-everywhere 'file)
61919
cdaec25dce2c (ido-everywhere): Fix last change.
Kim F. Storm <storm@cua.dk>
parents: 61808
diff changeset
1520 (setq read-file-name-function (car (get 'ido-everywhere 'file)))
61808
083f920d9c86 (ido-everywhere): Save and restore old read-buffer-function
Kim F. Storm <storm@cua.dk>
parents: 61738
diff changeset
1521 (put 'ido-everywhere 'file nil))
083f920d9c86 (ido-everywhere): Save and restore old read-buffer-function
Kim F. Storm <storm@cua.dk>
parents: 61738
diff changeset
1522 (when (get 'ido-everywhere 'buffer)
61919
cdaec25dce2c (ido-everywhere): Fix last change.
Kim F. Storm <storm@cua.dk>
parents: 61808
diff changeset
1523 (setq read-buffer-function (car (get 'ido-everywhere 'buffer)))
61808
083f920d9c86 (ido-everywhere): Save and restore old read-buffer-function
Kim F. Storm <storm@cua.dk>
parents: 61738
diff changeset
1524 (put 'ido-everywhere 'buffer nil))
083f920d9c86 (ido-everywhere): Save and restore old read-buffer-function
Kim F. Storm <storm@cua.dk>
parents: 61738
diff changeset
1525 (when ido-everywhere
083f920d9c86 (ido-everywhere): Save and restore old read-buffer-function
Kim F. Storm <storm@cua.dk>
parents: 61738
diff changeset
1526 (when (memq ido-mode '(both file))
61919
cdaec25dce2c (ido-everywhere): Fix last change.
Kim F. Storm <storm@cua.dk>
parents: 61808
diff changeset
1527 (put 'ido-everywhere 'file (cons read-file-name-function nil))
61808
083f920d9c86 (ido-everywhere): Save and restore old read-buffer-function
Kim F. Storm <storm@cua.dk>
parents: 61738
diff changeset
1528 (setq read-file-name-function 'ido-read-file-name))
083f920d9c86 (ido-everywhere): Save and restore old read-buffer-function
Kim F. Storm <storm@cua.dk>
parents: 61738
diff changeset
1529 (when (memq ido-mode '(both buffer))
61919
cdaec25dce2c (ido-everywhere): Fix last change.
Kim F. Storm <storm@cua.dk>
parents: 61808
diff changeset
1530 (put 'ido-everywhere 'buffer (cons read-buffer-function nil))
61808
083f920d9c86 (ido-everywhere): Save and restore old read-buffer-function
Kim F. Storm <storm@cua.dk>
parents: 61738
diff changeset
1531 (setq read-buffer-function 'ido-read-buffer))))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1532
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1533
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
1534 ;;; IDO KEYMAP
67362
ca155a6d12ad (ido-completion-map): Renamed from ido-mode-map.
Kim F. Storm <storm@cua.dk>
parents: 67141
diff changeset
1535 (defun ido-init-completion-maps ()
ca155a6d12ad (ido-completion-map): Renamed from ido-mode-map.
Kim F. Storm <storm@cua.dk>
parents: 67141
diff changeset
1536 "Set up the completion keymaps used by `ido'."
67141
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1537
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1538 ;; Common map
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1539 (let ((map (make-sparse-keymap)))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1540 (define-key map "\C-a" 'ido-toggle-ignore)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1541 (define-key map "\C-c" 'ido-toggle-case)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1542 (define-key map "\C-e" 'ido-edit-input)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1543 (define-key map "\t" 'ido-complete)
46231
794e46e1c313 (ido-set-matches1): Use regexp-quote instead of identity.
Kim F. Storm <storm@cua.dk>
parents: 46225
diff changeset
1544 (define-key map " " 'ido-complete-space)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1545 (define-key map "\C-j" 'ido-select-text)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1546 (define-key map "\C-m" 'ido-exit-minibuffer)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1547 (define-key map "\C-p" 'ido-toggle-prefix)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1548 (define-key map "\C-r" 'ido-prev-match)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1549 (define-key map "\C-s" 'ido-next-match)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1550 (define-key map "\C-t" 'ido-toggle-regexp)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1551 (define-key map "\C-z" 'ido-undo-merge-work-directory)
64336
8b29b8961758 (ido-define-mode-map): Move ido-next-work-file to C-M-o.
Kim F. Storm <storm@cua.dk>
parents: 64168
diff changeset
1552 (define-key map [(control ?\s)] 'ido-restrict-to-matches)
71269
851a15a8f318 (ido-take-first-match, ido-push-dir-first): New commands.
Kim F. Storm <storm@cua.dk>
parents: 71240
diff changeset
1553 (define-key map [(meta ?\s)] 'ido-take-first-match)
47977
01727f34cb9d (ido-restrict-to-matches): New command.
Kim F. Storm <storm@cua.dk>
parents: 47203
diff changeset
1554 (define-key map [(control ?@)] 'ido-restrict-to-matches)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1555 (define-key map [right] 'ido-next-match)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1556 (define-key map [left] 'ido-prev-match)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1557 (define-key map "?" 'ido-completion-help)
62378
4d270efed583 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 62089
diff changeset
1558 ;; Magic commands.
4d270efed583 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 62089
diff changeset
1559 (define-key map "\C-b" 'ido-magic-backward-char)
4d270efed583 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 62089
diff changeset
1560 (define-key map "\C-f" 'ido-magic-forward-char)
4d270efed583 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 62089
diff changeset
1561 (define-key map "\C-d" 'ido-magic-delete-char)
67141
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1562 (set-keymap-parent map minibuffer-local-map)
67362
ca155a6d12ad (ido-completion-map): Renamed from ido-mode-map.
Kim F. Storm <storm@cua.dk>
parents: 67141
diff changeset
1563 (setq ido-common-completion-map map))
67141
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1564
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1565 ;; File and directory map
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1566 (let ((map (make-sparse-keymap)))
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1567 (define-key map "\C-x\C-b" 'ido-enter-switch-buffer)
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1568 (define-key map "\C-x\C-f" 'ido-fallback-command)
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1569 (define-key map "\C-x\C-d" 'ido-enter-dired)
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1570 (define-key map [down] 'ido-next-match-dir)
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1571 (define-key map [up] 'ido-prev-match-dir)
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1572 (define-key map [(meta up)] 'ido-prev-work-directory)
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1573 (define-key map [(meta down)] 'ido-next-work-directory)
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1574 (define-key map [backspace] 'ido-delete-backward-updir)
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1575 (define-key map "\d" 'ido-delete-backward-updir)
76489
a5db78ff7104 (ido-init-completion-maps): Remap delete-backward-char.
Chong Yidong <cyd@stupidchicken.com>
parents: 76148
diff changeset
1576 (define-key map [remap delete-backward-char] 'ido-delete-backward-updir) ; BS
74584
3043e9ec901c (ido-init-completion-maps): Remap backward-kill-word
Kim F. Storm <storm@cua.dk>
parents: 74337
diff changeset
1577 (define-key map [remap backward-kill-word] 'ido-delete-backward-word-updir) ; M-DEL
3043e9ec901c (ido-init-completion-maps): Remap backward-kill-word
Kim F. Storm <storm@cua.dk>
parents: 74337
diff changeset
1578
67141
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1579 (define-key map [(control backspace)] 'ido-up-directory)
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1580 (define-key map "\C-l" 'ido-reread-directory)
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1581 (define-key map [(meta ?d)] 'ido-wide-find-dir-or-delete-dir)
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1582 (define-key map [(meta ?b)] 'ido-push-dir)
71269
851a15a8f318 (ido-take-first-match, ido-push-dir-first): New commands.
Kim F. Storm <storm@cua.dk>
parents: 71240
diff changeset
1583 (define-key map [(meta ?v)] 'ido-push-dir-first)
67141
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1584 (define-key map [(meta ?f)] 'ido-wide-find-file-or-pop-dir)
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1585 (define-key map [(meta ?k)] 'ido-forget-work-directory)
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1586 (define-key map [(meta ?m)] 'ido-make-directory)
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1587 (define-key map [(meta ?n)] 'ido-next-work-directory)
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1588 (define-key map [(meta ?o)] 'ido-prev-work-file)
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1589 (define-key map [(meta control ?o)] 'ido-next-work-file)
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1590 (define-key map [(meta ?p)] 'ido-prev-work-directory)
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1591 (define-key map [(meta ?s)] 'ido-merge-work-directories)
67362
ca155a6d12ad (ido-completion-map): Renamed from ido-mode-map.
Kim F. Storm <storm@cua.dk>
parents: 67141
diff changeset
1592 (set-keymap-parent map ido-common-completion-map)
ca155a6d12ad (ido-completion-map): Renamed from ido-mode-map.
Kim F. Storm <storm@cua.dk>
parents: 67141
diff changeset
1593 (setq ido-file-dir-completion-map map))
67141
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1594
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1595 ;; File only map
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1596 (let ((map (make-sparse-keymap)))
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1597 (define-key map "\C-k" 'ido-delete-file-at-head)
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1598 (define-key map "\C-o" 'ido-copy-current-word)
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1599 (define-key map "\C-w" 'ido-copy-current-file-name)
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1600 (define-key map [(meta ?l)] 'ido-toggle-literal)
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1601 (define-key map "\C-v" 'ido-toggle-vc)
67362
ca155a6d12ad (ido-completion-map): Renamed from ido-mode-map.
Kim F. Storm <storm@cua.dk>
parents: 67141
diff changeset
1602 (set-keymap-parent map ido-file-dir-completion-map)
ca155a6d12ad (ido-completion-map): Renamed from ido-mode-map.
Kim F. Storm <storm@cua.dk>
parents: 67141
diff changeset
1603 (setq ido-file-completion-map map))
67141
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1604
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1605 ;; Buffer map
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1606 (let ((map (make-sparse-keymap)))
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1607 (define-key map "\C-x\C-f" 'ido-enter-find-file)
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1608 (define-key map "\C-x\C-b" 'ido-fallback-command)
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1609 (define-key map "\C-k" 'ido-kill-buffer-at-head)
67362
ca155a6d12ad (ido-completion-map): Renamed from ido-mode-map.
Kim F. Storm <storm@cua.dk>
parents: 67141
diff changeset
1610 (set-keymap-parent map ido-common-completion-map)
ca155a6d12ad (ido-completion-map): Renamed from ido-mode-map.
Kim F. Storm <storm@cua.dk>
parents: 67141
diff changeset
1611 (setq ido-buffer-completion-map map)))
ca155a6d12ad (ido-completion-map): Renamed from ido-mode-map.
Kim F. Storm <storm@cua.dk>
parents: 67141
diff changeset
1612
ca155a6d12ad (ido-completion-map): Renamed from ido-mode-map.
Kim F. Storm <storm@cua.dk>
parents: 67141
diff changeset
1613
ca155a6d12ad (ido-completion-map): Renamed from ido-mode-map.
Kim F. Storm <storm@cua.dk>
parents: 67141
diff changeset
1614 (defun ido-setup-completion-map ()
67141
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1615 "Set up the keymap for `ido'."
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1616
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1617 ;; generated every time so that it can inherit new functions.
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1618 (let ((map (make-sparse-keymap))
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1619 (viper-p (if (boundp 'viper-mode) viper-mode)))
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1620
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1621 (when viper-p
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1622 (define-key map [remap viper-intercept-ESC-key] 'ignore))
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1623
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1624 (cond
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1625 ((memq ido-cur-item '(file dir))
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1626 (when ido-context-switch-command
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1627 (define-key map "\C-x\C-b" ido-context-switch-command)
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1628 (define-key map "\C-x\C-d" 'ignore))
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1629 (when viper-p
49614
1da4c425c852 (ido-define-mode-map):
Kim F. Storm <storm@cua.dk>
parents: 49611
diff changeset
1630 (define-key map [remap viper-backward-char] 'ido-delete-backward-updir)
1da4c425c852 (ido-define-mode-map):
Kim F. Storm <storm@cua.dk>
parents: 49611
diff changeset
1631 (define-key map [remap viper-del-backward-char-in-insert] 'ido-delete-backward-updir)
67141
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1632 (define-key map [remap viper-delete-backward-word] 'ido-delete-backward-word-updir))
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1633 (set-keymap-parent map
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1634 (if (eq ido-cur-item 'file)
67362
ca155a6d12ad (ido-completion-map): Renamed from ido-mode-map.
Kim F. Storm <storm@cua.dk>
parents: 67141
diff changeset
1635 ido-file-completion-map
ca155a6d12ad (ido-completion-map): Renamed from ido-mode-map.
Kim F. Storm <storm@cua.dk>
parents: 67141
diff changeset
1636 ido-file-dir-completion-map)))
67141
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1637
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1638 ((eq ido-cur-item 'buffer)
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1639 (when ido-context-switch-command
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1640 (define-key map "\C-x\C-f" ido-context-switch-command))
67362
ca155a6d12ad (ido-completion-map): Renamed from ido-mode-map.
Kim F. Storm <storm@cua.dk>
parents: 67141
diff changeset
1641 (set-keymap-parent map ido-buffer-completion-map))
67141
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1642
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
1643 (t
67362
ca155a6d12ad (ido-completion-map): Renamed from ido-mode-map.
Kim F. Storm <storm@cua.dk>
parents: 67141
diff changeset
1644 (set-keymap-parent map ido-common-completion-map)))
ca155a6d12ad (ido-completion-map): Renamed from ido-mode-map.
Kim F. Storm <storm@cua.dk>
parents: 67141
diff changeset
1645
ca155a6d12ad (ido-completion-map): Renamed from ido-mode-map.
Kim F. Storm <storm@cua.dk>
parents: 67141
diff changeset
1646 (setq ido-completion-map map)))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1647
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1648 (defun ido-final-slash (dir &optional fix-it)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1649 ;; return DIR if DIR has final slash.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1650 ;; else if FIX-IT is non-nil, return DIR/
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1651 ;; else return nil.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1652 (setq dir (ido-name dir))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1653 (cond
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1654 ((string-match "/\\'" dir) dir)
49180
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
1655 ((ido-is-tramp-root dir) dir)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1656 (fix-it (concat dir "/"))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1657 (t nil)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1658
53166
77088b91def1 * ido.el (ido-use-filename-at-point, ido-use-url-at-point):
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
1659 (defun ido-no-final-slash (s)
77088b91def1 * ido.el (ido-use-filename-at-point, ido-use-url-at-point):
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
1660 ;; Remove optional final slash from string S
77088b91def1 * ido.el (ido-use-filename-at-point, ido-use-url-at-point):
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
1661 (let ((l (1- (length s))))
77088b91def1 * ido.el (ido-use-filename-at-point, ido-use-url-at-point):
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
1662 (if (and (> l 0) (eq (aref s l) ?/))
77088b91def1 * ido.el (ido-use-filename-at-point, ido-use-url-at-point):
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
1663 (substring s 0 l)
77088b91def1 * ido.el (ido-use-filename-at-point, ido-use-url-at-point):
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
1664 s)))
77088b91def1 * ido.el (ido-use-filename-at-point, ido-use-url-at-point):
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
1665
53459
4b85f31aef7c (ido-nonreadable-directory-p): New defun to check for
Kim F. Storm <storm@cua.dk>
parents: 53323
diff changeset
1666 (defun ido-nonreadable-directory-p (dir)
4b85f31aef7c (ido-nonreadable-directory-p): New defun to check for
Kim F. Storm <storm@cua.dk>
parents: 53323
diff changeset
1667 ;; Return t if dir is a directory, but not readable
4b85f31aef7c (ido-nonreadable-directory-p): New defun to check for
Kim F. Storm <storm@cua.dk>
parents: 53323
diff changeset
1668 ;; Do not check for non-readable directories via tramp, as this causes a premature
4b85f31aef7c (ido-nonreadable-directory-p): New defun to check for
Kim F. Storm <storm@cua.dk>
parents: 53323
diff changeset
1669 ;; connect on incomplete tramp paths (after entring just method:).
4b85f31aef7c (ido-nonreadable-directory-p): New defun to check for
Kim F. Storm <storm@cua.dk>
parents: 53323
diff changeset
1670 (let ((ido-enable-tramp-completion nil))
4b85f31aef7c (ido-nonreadable-directory-p): New defun to check for
Kim F. Storm <storm@cua.dk>
parents: 53323
diff changeset
1671 (and (ido-final-slash dir)
69542
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
1672 (not (ido-is-unc-host dir))
53459
4b85f31aef7c (ido-nonreadable-directory-p): New defun to check for
Kim F. Storm <storm@cua.dk>
parents: 53323
diff changeset
1673 (file-directory-p dir)
4b85f31aef7c (ido-nonreadable-directory-p): New defun to check for
Kim F. Storm <storm@cua.dk>
parents: 53323
diff changeset
1674 (not (file-readable-p dir)))))
4b85f31aef7c (ido-nonreadable-directory-p): New defun to check for
Kim F. Storm <storm@cua.dk>
parents: 53323
diff changeset
1675
57211
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
1676 (defun ido-directory-too-big-p (dir)
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
1677 ;; Return t if dir is a directory, but too big to show
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
1678 ;; Do not check for non-readable directories via tramp, as this causes a premature
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
1679 ;; connect on incomplete tramp paths (after entring just method:).
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
1680 (let ((ido-enable-tramp-completion nil))
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
1681 (and (numberp ido-max-directory-size)
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
1682 (ido-final-slash dir)
69542
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
1683 (not (ido-is-unc-host dir))
57211
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
1684 (file-directory-p dir)
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
1685 (> (nth 7 (file-attributes dir)) ido-max-directory-size))))
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
1686
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1687 (defun ido-set-current-directory (dir &optional subdir no-merge)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1688 ;; Set ido's current directory to DIR or DIR/SUBDIR
66212
3a5f2ee9f30b (ido-is-tramp-root): Simplify regexp matching tramp root.
Kim F. Storm <storm@cua.dk>
parents: 65802
diff changeset
1689 (unless (and ido-enable-tramp-completion
3a5f2ee9f30b (ido-is-tramp-root): Simplify regexp matching tramp root.
Kim F. Storm <storm@cua.dk>
parents: 65802
diff changeset
1690 (string-match "\\`/[^/]*@\\'" dir))
3a5f2ee9f30b (ido-is-tramp-root): Simplify regexp matching tramp root.
Kim F. Storm <storm@cua.dk>
parents: 65802
diff changeset
1691 (setq dir (ido-final-slash dir t)))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1692 (setq ido-use-merged-list nil
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1693 ido-try-merged-list (not no-merge))
66212
3a5f2ee9f30b (ido-is-tramp-root): Simplify regexp matching tramp root.
Kim F. Storm <storm@cua.dk>
parents: 65802
diff changeset
1694 (when subdir
3a5f2ee9f30b (ido-is-tramp-root): Simplify regexp matching tramp root.
Kim F. Storm <storm@cua.dk>
parents: 65802
diff changeset
1695 (setq dir (concat dir subdir))
3a5f2ee9f30b (ido-is-tramp-root): Simplify regexp matching tramp root.
Kim F. Storm <storm@cua.dk>
parents: 65802
diff changeset
1696 (unless (and ido-enable-tramp-completion
3a5f2ee9f30b (ido-is-tramp-root): Simplify regexp matching tramp root.
Kim F. Storm <storm@cua.dk>
parents: 65802
diff changeset
1697 (string-match "\\`/[^/]*@\\'" dir))
3a5f2ee9f30b (ido-is-tramp-root): Simplify regexp matching tramp root.
Kim F. Storm <storm@cua.dk>
parents: 65802
diff changeset
1698 (setq dir (ido-final-slash dir t))))
69542
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
1699 (if (get-buffer ido-completion-buffer)
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
1700 (kill-buffer ido-completion-buffer))
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
1701 (cond
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
1702 ((equal dir ido-current-directory)
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
1703 nil)
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
1704 ((ido-is-unc-root dir)
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
1705 (ido-trace "unc" dir)
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
1706 (setq ido-current-directory dir)
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
1707 (setq ido-directory-nonreadable nil)
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
1708 (setq ido-directory-too-big nil)
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
1709 t)
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
1710 (t
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1711 (ido-trace "cd" dir)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1712 (setq ido-current-directory dir)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1713 (if (get-buffer ido-completion-buffer)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1714 (kill-buffer ido-completion-buffer))
53459
4b85f31aef7c (ido-nonreadable-directory-p): New defun to check for
Kim F. Storm <storm@cua.dk>
parents: 53323
diff changeset
1715 (setq ido-directory-nonreadable (ido-nonreadable-directory-p dir))
57211
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
1716 (setq ido-directory-too-big (and (not ido-directory-nonreadable)
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
1717 (ido-directory-too-big-p dir)))
69542
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
1718 t)))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1719
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1720 (defun ido-set-current-home (&optional dir)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1721 ;; Set ido's current directory to user's home directory
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1722 (ido-set-current-directory (expand-file-name (or dir "~/"))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1723
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1724 (defun ido-record-command (command arg)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1725 ;; Add (command arg) to command-history if ido-record-commands is t
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1726 (if ido-record-commands
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1727 (let ((cmd (list command arg)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1728 (if (or (not command-history)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1729 (not (equal cmd (car command-history))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1730 (setq command-history (cons cmd command-history))))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1731
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1732 (defun ido-make-prompt (item prompt)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1733 ;; Make the prompt for ido-read-internal
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1734 (cond
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1735 ((and (memq item '(file dir)) ido-current-directory)
49208
5a945cb7d742 (ido-ignore-directories-merge): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 49180
diff changeset
1736 (let ((dirname (abbreviate-file-name ido-current-directory))
49211
93a6625a2ef3 Rename ido-max-prompt-width to ido-max-file-prompt-width for consistency.
Kim F. Storm <storm@cua.dk>
parents: 49208
diff changeset
1737 (max-width (if (and ido-max-file-prompt-width (floatp ido-max-file-prompt-width))
93a6625a2ef3 Rename ido-max-prompt-width to ido-max-file-prompt-width for consistency.
Kim F. Storm <storm@cua.dk>
parents: 49208
diff changeset
1738 (floor (* (frame-width) ido-max-file-prompt-width))
93a6625a2ef3 Rename ido-max-prompt-width to ido-max-file-prompt-width for consistency.
Kim F. Storm <storm@cua.dk>
parents: 49208
diff changeset
1739 ido-max-file-prompt-width))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1740 (literal (and (boundp 'ido-find-literal) ido-find-literal "(literal) "))
53166
77088b91def1 * ido.el (ido-use-filename-at-point, ido-use-url-at-point):
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
1741 (vc-off (and ido-saved-vc-hb (not vc-handled-backends) "[-VC] "))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1742 (prefix nil)
49208
5a945cb7d742 (ido-ignore-directories-merge): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 49180
diff changeset
1743 (rule ido-rewrite-file-prompt-rules))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1744 (let ((case-fold-search nil))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1745 (while rule
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1746 (if (and (consp (car rule))
49208
5a945cb7d742 (ido-ignore-directories-merge): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 49180
diff changeset
1747 (string-match (car (car rule)) dirname))
5a945cb7d742 (ido-ignore-directories-merge): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 49180
diff changeset
1748 (setq dirname
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1749 (if (stringp (cdr (car rule)))
49208
5a945cb7d742 (ido-ignore-directories-merge): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 49180
diff changeset
1750 (replace-match (cdr (car rule)) t nil dirname)
5a945cb7d742 (ido-ignore-directories-merge): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 49180
diff changeset
1751 (funcall (cdr (car rule)) dirname))))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1752 (setq rule (cdr rule))))
49208
5a945cb7d742 (ido-ignore-directories-merge): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 49180
diff changeset
1753 (run-hooks 'ido-rewrite-file-prompt-functions)
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
1754 (concat prompt
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1755 ; (if ido-process-ignore-lists "" "&")
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1756 (or literal "")
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1757 (or vc-off "")
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1758 (or prefix "")
49208
5a945cb7d742 (ido-ignore-directories-merge): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 49180
diff changeset
1759 (let ((l (length dirname)))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1760 (if (and max-width (> max-width 0) (> l max-width))
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
1761 (let* ((s (substring dirname (- max-width)))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1762 (i (string-match "/" s)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1763 (concat "..." (if i (substring s i) s)))
49208
5a945cb7d742 (ido-ignore-directories-merge): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 49180
diff changeset
1764 dirname)))))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1765 (t prompt)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1766
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1767 ;; Here is very briefly how ido-find-file works:
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1768 ;;
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1769 ;; (ido-find-file)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1770 ;; (ido-file-internal method)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1771 ;; set ido-current-directory
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1772 ;; (ido-read-internal 'file ...)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1773 ;; (while ...
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1774 ;; (ido-make-item-list ...)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1775 ;; (ido-set-matches)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1776 ;; (completing-read ... ido-text-init ...)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1777 ;;
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1778 ;; ... here user is allowed to type characters and commands
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1779 ;; a command may set ido-exit and call (exit-minibuffer)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1780 ;; to make ido-read-internal do advanced tasks (or return)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1781 ;;
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1782 ;; ... ido-tidy and ido-exhibit are pre- and post-hooks
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1783 ;; which are run before and after each user command.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1784 ;;
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1785 ;; return value from completing-read is stored in ido-final-text
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1786 ;; - ido-exit may cause further actions to be taken:
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1787 ;; 'refresh - repeat loop (make-item-list, set-matches)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1788 ;; 'edit - edit the prompt string, then repeat loop
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1789 ;; 'keep - repeat loop but don't (re)make-item-list
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1790 ;; 'updir - go up one directory, repeat loop
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1791 ;; else set ido-selected based on ido-final-text,
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1792 ;; optionally update ido-current-directory and repeat loop, or
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1793 ;; exit with the return value of ido-selected (file name)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1794 ;; selected file name is returned from ido-read-internal,
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1795 ;; ido-exit and method determines what action is taken
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1796 ;; e.g. the file name may be ignored or joined with ido-current-directory, and
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1797 ;; the relevant function is called (find-file, write-file, etc).
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1798
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1799 (defun ido-read-internal (item prompt history &optional default require-match initial)
69738
0bfe57fe99ed (ido-report-no-match, ido-switch-buffer,
Juanma Barranquero <lekktu@gmail.com>
parents: 69733
diff changeset
1800 "Perform the `ido-read-buffer' and `ido-read-file-name' functions.
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
1801 Return the name of a buffer or file selected.
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1802 PROMPT is the prompt to give to the user.
70690
8fd6ecfbe6ea (ido-read-internal): Use only nondirectory part of default item.
Kim F. Storm <storm@cua.dk>
parents: 69817
diff changeset
1803 DEFAULT if given is the default item to start with.
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1804 If REQUIRE-MATCH is non-nil, an existing file must be selected.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1805 If INITIAL is non-nil, it specifies the initial input string."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1806 (let
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1807 ((ido-cur-item item)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1808 (ido-entry-buffer (current-buffer))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1809 (ido-process-ignore-lists t)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1810 (ido-process-ignore-lists-inhibit nil)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1811 (ido-set-default-item t)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1812 ido-default-item
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1813 ido-selected
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1814 ido-final-text
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1815 (done nil)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1816 (icomplete-mode nil) ;; prevent icomplete starting up
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1817 ;; Exported dynamic variables:
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1818 ido-cur-list
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1819 ido-ignored-list
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1820 (ido-rotate-temp nil)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1821 (ido-keep-item-list nil)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1822 (ido-use-merged-list nil)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1823 (ido-try-merged-list t)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1824 (ido-pre-merge-state nil)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1825 (ido-case-fold ido-case-fold)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1826 (ido-enable-prefix ido-enable-prefix)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1827 (ido-enable-regexp ido-enable-regexp)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1828 )
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1829
67362
ca155a6d12ad (ido-completion-map): Renamed from ido-mode-map.
Kim F. Storm <storm@cua.dk>
parents: 67141
diff changeset
1830 (ido-setup-completion-map)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1831 (setq ido-text-init initial)
62089
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
1832 (setq ido-input-stack nil)
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
1833
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
1834 (run-hooks 'ido-setup-hook)
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
1835
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1836 (while (not done)
49180
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
1837 (ido-trace "\n_LOOP_" ido-text-init)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1838 (setq ido-exit nil)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1839 (setq ido-rescan t)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1840 (setq ido-rotate nil)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1841 (setq ido-text "")
47203
d7ff55da60cd (ido-ignore-item-temp-list): New variable.
Kim F. Storm <storm@cua.dk>
parents: 46631
diff changeset
1842 (when ido-set-default-item
d7ff55da60cd (ido-ignore-item-temp-list): New variable.
Kim F. Storm <storm@cua.dk>
parents: 46631
diff changeset
1843 (setq ido-default-item
d7ff55da60cd (ido-ignore-item-temp-list): New variable.
Kim F. Storm <storm@cua.dk>
parents: 46631
diff changeset
1844 (cond
d7ff55da60cd (ido-ignore-item-temp-list): New variable.
Kim F. Storm <storm@cua.dk>
parents: 46631
diff changeset
1845 ((eq item 'buffer)
d7ff55da60cd (ido-ignore-item-temp-list): New variable.
Kim F. Storm <storm@cua.dk>
parents: 46631
diff changeset
1846 (if (bufferp default) (buffer-name default) default))
70690
8fd6ecfbe6ea (ido-read-internal): Use only nondirectory part of default item.
Kim F. Storm <storm@cua.dk>
parents: 69817
diff changeset
1847 ((stringp default)
8fd6ecfbe6ea (ido-read-internal): Use only nondirectory part of default item.
Kim F. Storm <storm@cua.dk>
parents: 69817
diff changeset
1848 (if (memq item '(file dir))
8fd6ecfbe6ea (ido-read-internal): Use only nondirectory part of default item.
Kim F. Storm <storm@cua.dk>
parents: 69817
diff changeset
1849 (file-name-nondirectory default)
8fd6ecfbe6ea (ido-read-internal): Use only nondirectory part of default item.
Kim F. Storm <storm@cua.dk>
parents: 69817
diff changeset
1850 default))
47203
d7ff55da60cd (ido-ignore-item-temp-list): New variable.
Kim F. Storm <storm@cua.dk>
parents: 46631
diff changeset
1851 ((eq item 'file)
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
1852 (and ido-enable-last-directory-history
47203
d7ff55da60cd (ido-ignore-item-temp-list): New variable.
Kim F. Storm <storm@cua.dk>
parents: 46631
diff changeset
1853 (let ((d (assoc ido-current-directory ido-last-directory-list)))
d7ff55da60cd (ido-ignore-item-temp-list): New variable.
Kim F. Storm <storm@cua.dk>
parents: 46631
diff changeset
1854 (and d (cdr d)))))))
d7ff55da60cd (ido-ignore-item-temp-list): New variable.
Kim F. Storm <storm@cua.dk>
parents: 46631
diff changeset
1855 (if (member ido-default-item ido-ignore-item-temp-list)
d7ff55da60cd (ido-ignore-item-temp-list): New variable.
Kim F. Storm <storm@cua.dk>
parents: 46631
diff changeset
1856 (setq ido-default-item nil))
72488
a1eb31579f05 (ido-set-matches-1): Fix full matching for subdirs.
Kim F. Storm <storm@cua.dk>
parents: 71803
diff changeset
1857 (ido-trace "new default" ido-default-item)
75391
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
1858 (if ido-default-item
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
1859 (setq ido-initial-position 0))
47203
d7ff55da60cd (ido-ignore-item-temp-list): New variable.
Kim F. Storm <storm@cua.dk>
parents: 46631
diff changeset
1860 (setq ido-set-default-item nil))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1861
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1862 (if ido-process-ignore-lists-inhibit
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1863 (setq ido-process-ignore-lists nil))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1864
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1865 (if (and ido-use-merged-list (memq ido-try-merged-list '(t wide)) (not ido-keep-item-list))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1866 (let ((olist ido-cur-list)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1867 (oign ido-ignored-list)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1868 (omat ido-matches)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1869 (l (ido-make-merged-file-list ido-text-init
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1870 (eq ido-use-merged-list 'auto)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1871 (eq ido-try-merged-list 'wide))))
62985
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
1872 (ido-trace "merged" l)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1873 (cond
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1874 ((not l)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1875 (if (eq ido-try-merged-list 'wide)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1876 (setq ido-pre-merge-state
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1877 (list "" ido-current-directory olist oign omat)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1878 ido-cur-list nil
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1879 ido-ignored-list nil
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1880 ido-matches nil
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1881 ido-keep-item-list t
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1882 ido-try-merged-list (if (eq ido-use-merged-list 'auto) 'auto nil)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1883 ido-use-merged-list nil)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1884 (setq ido-cur-list olist
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1885 ido-ignored-list oign
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1886 ido-matches omat
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1887 ido-keep-item-list t
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1888 ido-try-merged-list (if (eq ido-use-merged-list 'auto) 'auto nil)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1889 ido-use-merged-list nil)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1890 ((eq l t)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1891 (setq ido-use-merged-list nil))
62985
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
1892 ((eq l 'input-pending-p)
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
1893 (setq ido-try-merged-list t
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
1894 ido-use-merged-list nil))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1895 (t
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1896 (setq ido-pre-merge-state
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1897 (list ido-text-init ido-current-directory olist oign omat))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1898 (ido-set-current-directory (car (cdr (car l))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1899 (if (ido-final-slash ido-text-init)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1900 (setq ido-text-init ""))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1901 (setq ido-cur-list l
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1902 ido-ignored-list nil
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1903 ido-matches l
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1904 ido-rescan nil
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1905 ido-keep-item-list t
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1906 ido-use-merged-list t)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1907 (ido-trace "Merged" t)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1908 ))))
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
1909
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1910 (cond
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1911 (ido-keep-item-list
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1912 (setq ido-keep-item-list nil
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1913 ido-rescan nil))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1914 ((eq ido-cur-item 'file)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1915 (setq ido-ignored-list nil
57211
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
1916 ido-cur-list (and (not ido-directory-nonreadable)
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
1917 (not ido-directory-too-big)
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
1918 (ido-make-file-list ido-default-item))))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1919 ((eq ido-cur-item 'dir)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1920 (setq ido-ignored-list nil
57211
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
1921 ido-cur-list (and (not ido-directory-nonreadable)
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
1922 (not ido-directory-too-big)
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
1923 (ido-make-dir-list ido-default-item))))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1924 ((eq ido-cur-item 'buffer)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1925 (setq ido-ignored-list nil
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1926 ido-cur-list (ido-make-buffer-list ido-default-item)))
57191
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
1927 ((eq ido-cur-item 'list)
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
1928 (setq ido-ignored-list nil
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
1929 ido-cur-list (ido-make-choice-list ido-default-item)))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1930 (t nil))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1931 (setq ido-rotate-temp nil)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1932
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1933 (if ido-process-ignore-lists-inhibit
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1934 (setq ido-process-ignore-lists t
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1935 ido-process-ignore-lists-inhibit nil))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1936
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1937 (ido-set-matches)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1938 (if (and ido-matches (eq ido-try-merged-list 'auto))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1939 (setq ido-try-merged-list t))
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
1940 (let
76795
bcf68ba23417 (ido-read-internal): When reading file or dir, only override
Kim F. Storm <storm@cua.dk>
parents: 76489
diff changeset
1941 ((minibuffer-local-completion-map
bcf68ba23417 (ido-read-internal): When reading file or dir, only override
Kim F. Storm <storm@cua.dk>
parents: 76489
diff changeset
1942 (if (memq ido-cur-item '(file dir))
bcf68ba23417 (ido-read-internal): When reading file or dir, only override
Kim F. Storm <storm@cua.dk>
parents: 76489
diff changeset
1943 minibuffer-local-completion-map
bcf68ba23417 (ido-read-internal): When reading file or dir, only override
Kim F. Storm <storm@cua.dk>
parents: 76489
diff changeset
1944 ido-completion-map))
bcf68ba23417 (ido-read-internal): When reading file or dir, only override
Kim F. Storm <storm@cua.dk>
parents: 76489
diff changeset
1945 (minibuffer-local-filename-completion-map
bcf68ba23417 (ido-read-internal): When reading file or dir, only override
Kim F. Storm <storm@cua.dk>
parents: 76489
diff changeset
1946 (if (memq ido-cur-item '(file dir))
bcf68ba23417 (ido-read-internal): When reading file or dir, only override
Kim F. Storm <storm@cua.dk>
parents: 76489
diff changeset
1947 ido-completion-map
bcf68ba23417 (ido-read-internal): When reading file or dir, only override
Kim F. Storm <storm@cua.dk>
parents: 76489
diff changeset
1948 minibuffer-local-filename-completion-map))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1949 (max-mini-window-height (or ido-max-window-height
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1950 (and (boundp 'max-mini-window-height) max-mini-window-height)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1951 (ido-completing-read t)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1952 (ido-require-match require-match)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1953 (ido-use-mycompletion-depth (1+ (minibuffer-depth)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1954 (show-paren-mode nil))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1955 ;; prompt the user for the file name
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1956 (setq ido-exit nil)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1957 (setq ido-final-text
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1958 (catch 'ido
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
1959 (completing-read
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1960 (ido-make-prompt item prompt)
46256
88bc5ce0674c (ido-find-common-substring): Return substring instead of t.
Kim F. Storm <storm@cua.dk>
parents: 46231
diff changeset
1961 '(("dummy" . 1)) nil nil ; table predicate require-match
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1962 (prog1 ido-text-init (setq ido-text-init nil)) ;initial-contents
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1963 history))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1964 (ido-trace "completing-read" ido-final-text)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1965 (if (get-buffer ido-completion-buffer)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1966 (kill-buffer ido-completion-buffer))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1967
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1968 (ido-trace "\n_EXIT_" ido-exit)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1969
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1970 (cond
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1971 ((eq ido-exit 'refresh)
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
1972 (if (and (eq ido-use-merged-list 'auto)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1973 (or (input-pending-p)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1974 (setq ido-use-merged-list nil
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1975 ido-keep-item-list t))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1976 nil)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1977
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1978 ((eq ido-exit 'done)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1979 (setq done t
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1980 ido-selected ido-text
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1981 ido-exit nil))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1982
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1983 ((memq ido-exit '(edit chdir))
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
1984 (cond
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1985 ((memq ido-cur-item '(file dir))
55359
fa5273a32653 (ido-read-internal): Fix call to read-file-name for edit.
Kim F. Storm <storm@cua.dk>
parents: 54776
diff changeset
1986 (let* ((read-file-name-function nil)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1987 (edit (eq ido-exit 'edit))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1988 (d ido-current-directory)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1989 (f ido-text-init)
49235
beca89eeabb3 (ido-read-internal, ido-file-internal)
Kim F. Storm <storm@cua.dk>
parents: 49233
diff changeset
1990 (new t))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1991 (setq ido-text-init "")
49235
beca89eeabb3 (ido-read-internal, ido-file-internal)
Kim F. Storm <storm@cua.dk>
parents: 49233
diff changeset
1992 (while new
beca89eeabb3 (ido-read-internal, ido-file-internal)
Kim F. Storm <storm@cua.dk>
parents: 49233
diff changeset
1993 (setq new (if edit
62089
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
1994 (condition-case nil
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
1995 (read-file-name (concat prompt "[EDIT] ")
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
1996 (expand-file-name d)
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
1997 (concat d f) nil f)
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
1998 (quit (concat d f)))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
1999 f)
49235
beca89eeabb3 (ido-read-internal, ido-file-internal)
Kim F. Storm <storm@cua.dk>
parents: 49233
diff changeset
2000 d (or (file-name-directory new) "/")
beca89eeabb3 (ido-read-internal, ido-file-internal)
Kim F. Storm <storm@cua.dk>
parents: 49233
diff changeset
2001 f (file-name-nondirectory new)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2002 edit t)
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
2003 (if (or
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2004 (file-directory-p d)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2005 (and (yes-or-no-p (format "Create directory %s? " d))
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
2006 (condition-case nil
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2007 (progn (make-directory d t) t)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2008 (error
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2009 (message "Could not create directory")
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2010 (sit-for 1)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2011 nil))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2012 (progn
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2013 (ido-set-current-directory d nil (eq ido-exit 'chdir))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2014 (setq ido-text-init f
49235
beca89eeabb3 (ido-read-internal, ido-file-internal)
Kim F. Storm <storm@cua.dk>
parents: 49233
diff changeset
2015 new nil))))))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2016 (t
62089
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2017 (setq ido-text-init
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2018 (condition-case nil
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2019 (read-string (concat prompt "[EDIT] ") ido-final-text)
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2020 (quit ido-final-text)))))
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2021
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2022 nil)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2023
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2024 ((eq ido-exit 'keep)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2025 (setq ido-keep-item-list t))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2026
57191
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
2027 ((memq ido-exit '(dired fallback find-file switch-to-buffer insert-buffer insert-file))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2028 (setq done t))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2029
62089
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2030 ((memq ido-exit '(updir push))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2031 ;; cannot go up if already at the root-dir (Unix) or at the
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2032 ;; root-dir of a certain drive (Windows or MS-DOS).
49180
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
2033 (if (ido-is-tramp-root)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
2034 (when (string-match "\\`\\(/\\([^/]+[:@]\\)*\\)\\([^/]+\\)[:@]\\'" ido-current-directory)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
2035 (setq ido-text-init (match-string 3 ido-current-directory))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
2036 (ido-set-current-directory (match-string 1 ido-current-directory))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
2037 (setq ido-set-default-item t))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
2038 (unless (ido-is-root-directory)
62089
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2039 (when (eq ido-exit 'push)
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2040 (setq ido-input-stack (cons (cons ido-cur-item ido-text) ido-input-stack))
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2041 (setq ido-cur-item 'dir)
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2042 (setq ido-text-init (file-name-nondirectory (substring ido-current-directory 0 -1)))
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2043 (ido-trace "push" ido-input-stack))
49180
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
2044 (ido-set-current-directory (file-name-directory (substring ido-current-directory 0 -1)))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
2045 (setq ido-set-default-item t))))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2046
62089
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2047 ((eq ido-exit 'pop)
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2048 (ido-trace "pop" ido-input-stack)
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2049 (let ((elt (car ido-input-stack)))
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2050 (setq ido-input-stack (cdr ido-input-stack))
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2051 (ido-set-current-directory (concat ido-current-directory ido-text))
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2052 (setq ido-cur-item (car elt))
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2053 (setq ido-text-init (cdr elt))))
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2054
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2055 ((eq ido-exit 'pop-all)
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2056 (ido-trace "pop-all" ido-input-stack)
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2057 (while ido-input-stack
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2058 (let ((elt (car ido-input-stack)))
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2059 (setq ido-input-stack (cdr ido-input-stack))
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2060 (ido-set-current-directory (concat ido-current-directory ido-text))
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2061 (setq ido-cur-item (car elt))
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2062 (setq ido-text-init (cdr elt)))))
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2063
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2064 ;; Handling the require-match must be done in a better way.
58458
1708184cc8da (ido-read-internal): Fix require-match check when
Kim F. Storm <storm@cua.dk>
parents: 57805
diff changeset
2065 ((and require-match
1708184cc8da (ido-read-internal): Fix require-match check when
Kim F. Storm <storm@cua.dk>
parents: 57805
diff changeset
2066 (not (if ido-directory-too-big
1708184cc8da (ido-read-internal): Fix require-match check when
Kim F. Storm <storm@cua.dk>
parents: 57805
diff changeset
2067 (file-exists-p (concat ido-current-directory ido-final-text))
1708184cc8da (ido-read-internal): Fix require-match check when
Kim F. Storm <storm@cua.dk>
parents: 57805
diff changeset
2068 (ido-existing-item-p))))
73825
36f23fcd07f8 (ido-ignore-extensions, ido-show-dot-for-dired, ido-max-dir-file-cache,
Juanma Barranquero <lekktu@gmail.com>
parents: 73388
diff changeset
2069 (error "Must specify valid item"))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2070
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2071 (t
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2072 (setq ido-selected
47203
d7ff55da60cd (ido-ignore-item-temp-list): New variable.
Kim F. Storm <storm@cua.dk>
parents: 46631
diff changeset
2073 (if (or (eq ido-exit 'takeprompt)
d7ff55da60cd (ido-ignore-item-temp-list): New variable.
Kim F. Storm <storm@cua.dk>
parents: 46631
diff changeset
2074 (null ido-matches))
d7ff55da60cd (ido-ignore-item-temp-list): New variable.
Kim F. Storm <storm@cua.dk>
parents: 46631
diff changeset
2075 ido-final-text
d7ff55da60cd (ido-ignore-item-temp-list): New variable.
Kim F. Storm <storm@cua.dk>
parents: 46631
diff changeset
2076 ;; else take head of list
d7ff55da60cd (ido-ignore-item-temp-list): New variable.
Kim F. Storm <storm@cua.dk>
parents: 46631
diff changeset
2077 (ido-name (car ido-matches))))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2078
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2079 (cond
61738
31b357591bb4 (ido-read-internal): Fix `list' completion.
Kim F. Storm <storm@cua.dk>
parents: 61394
diff changeset
2080 ((memq item '(buffer list))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2081 (setq done t))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2082
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2083 ((string-equal "./" ido-selected)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2084 nil)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2085
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2086 ((string-equal "../" ido-selected)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2087 ;; cannot go up if already at the root-dir (Unix) or at the
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2088 ;; root-dir of a certain drive (Windows or MS-DOS).
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2089 (or (ido-is-root-directory)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2090 (ido-set-current-directory (file-name-directory (substring ido-current-directory 0 -1))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2091 (setq ido-set-default-item t))
49180
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
2092
74337
ee9b338cccea 2006-11-30 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents: 74020
diff changeset
2093 ((and (string-match (if ido-enable-tramp-completion ".[:@]\\'" ".:\\'") ido-selected)
ee9b338cccea 2006-11-30 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents: 74020
diff changeset
2094 (ido-is-root-directory) ;; Ange-ftp or Tramp
ee9b338cccea 2006-11-30 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents: 74020
diff changeset
2095 (not (ido-local-file-exists-p ido-selected)))
49180
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
2096 (ido-set-current-directory ido-current-directory ido-selected)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
2097 (ido-trace "tramp prefix" ido-selected)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2098 (if (ido-is-slow-ftp-host)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2099 (setq ido-exit 'fallback
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2100 done t)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2101 (setq ido-set-default-item t)))
69542
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
2102
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2103 ((or (string-match "[/\\][^/\\]" ido-selected)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2104 (and (memq system-type '(windows-nt ms-dos))
74337
ee9b338cccea 2006-11-30 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents: 74020
diff changeset
2105 (string-match "\\`[a-zA-Z]:" ido-selected)))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2106 (ido-set-current-directory (file-name-directory ido-selected))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2107 (setq ido-set-default-item t))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2108
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2109 ((string-match "\\`~" ido-selected)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2110 (ido-set-current-home ido-selected))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2111
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2112 ((ido-final-slash ido-selected)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2113 (if ido-enable-last-directory-history
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2114 (let ((x (assoc ido-current-directory ido-last-directory-list)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2115 (if x
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2116 (setcdr x ido-selected)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2117 (setq ido-last-directory-list
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2118 (cons (cons ido-current-directory ido-selected) ido-last-directory-list)))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2119 (ido-set-current-directory ido-current-directory ido-selected)
62089
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2120 (if ido-input-stack
71275
aa026ce4fcef (ido-read-internal): Only pop stack elements automatically if they
Kim F. Storm <storm@cua.dk>
parents: 71273
diff changeset
2121 ; automatically pop stack elements which match existing files or directories
aa026ce4fcef (ido-read-internal): Only pop stack elements automatically if they
Kim F. Storm <storm@cua.dk>
parents: 71273
diff changeset
2122 (let (elt)
aa026ce4fcef (ido-read-internal): Only pop stack elements automatically if they
Kim F. Storm <storm@cua.dk>
parents: 71273
diff changeset
2123 (while (and (setq elt (car ido-input-stack))
aa026ce4fcef (ido-read-internal): Only pop stack elements automatically if they
Kim F. Storm <storm@cua.dk>
parents: 71273
diff changeset
2124 (file-exists-p (concat ido-current-directory (cdr elt))))
62089
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2125 (if (setq ido-input-stack (cdr ido-input-stack))
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2126 (ido-set-current-directory ido-current-directory (cdr elt))
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2127 (setq ido-text-init (cdr elt)))
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2128 (setq ido-cur-item (car elt))))
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2129 (setq ido-set-default-item t)))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2130
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2131 (t
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2132 (setq done t))))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2133 ido-selected))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2134
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2135 (defun ido-edit-input ()
75391
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
2136 "Edit absolute file name entered so far with ido; terminate by RET.
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
2137 If cursor is not at the end of the user input, move to end of input."
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2138 (interactive)
75391
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
2139 (if (not (eobp))
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
2140 (end-of-line)
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
2141 (setq ido-text-init (if ido-matches (ido-name (car ido-matches)) ido-text))
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
2142 (setq ido-exit 'edit)
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
2143 (exit-minibuffer)))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2144
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2145 ;;; MAIN FUNCTIONS
57191
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
2146 (defun ido-buffer-internal (method &optional fallback prompt default initial switch-cmd)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2147 ;; Internal function for ido-switch-buffer and friends
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2148 (if (not ido-mode)
64166
fad9662db4a9 (ido-before-fallback-functions): New hook.
Kim F. Storm <storm@cua.dk>
parents: 64091
diff changeset
2149 (progn
fad9662db4a9 (ido-before-fallback-functions): New hook.
Kim F. Storm <storm@cua.dk>
parents: 64091
diff changeset
2150 (run-hook-with-args 'ido-before-fallback-functions
fad9662db4a9 (ido-before-fallback-functions): New hook.
Kim F. Storm <storm@cua.dk>
parents: 64091
diff changeset
2151 (or fallback 'switch-to-buffer))
fad9662db4a9 (ido-before-fallback-functions): New hook.
Kim F. Storm <storm@cua.dk>
parents: 64091
diff changeset
2152 (call-interactively (or fallback 'switch-to-buffer)))
57191
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
2153 (let* ((ido-context-switch-command switch-cmd)
57211
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
2154 (ido-current-directory nil)
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
2155 (ido-directory-nonreadable nil)
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
2156 (ido-directory-too-big nil)
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
2157 (buf (ido-read-internal 'buffer (or prompt "Buffer: ") 'ido-buffer-history default nil initial)))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2158
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2159 ;; Choose the buffer name: either the text typed in, or the head
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2160 ;; of the list of matches
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2161
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
2162 (cond
57191
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
2163 ((eq ido-exit 'find-file)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2164 (ido-file-internal ido-default-file-method nil nil nil nil ido-text))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2165
57191
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
2166 ((eq ido-exit 'insert-file)
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
2167 (ido-file-internal 'insert 'insert-file nil "Insert file: " nil ido-text 'ido-enter-insert-buffer))
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
2168
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2169 ((eq ido-exit 'fallback)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2170 (let ((read-buffer-function nil))
76148
d38be8d45087 (ido-buffer-internal): Set this-command to fallback command.
Kim F. Storm <storm@cua.dk>
parents: 75686
diff changeset
2171 (setq this-command (or fallback 'switch-to-buffer))
d38be8d45087 (ido-buffer-internal): Set this-command to fallback command.
Kim F. Storm <storm@cua.dk>
parents: 75686
diff changeset
2172 (run-hook-with-args 'ido-before-fallback-functions this-command)
d38be8d45087 (ido-buffer-internal): Set this-command to fallback command.
Kim F. Storm <storm@cua.dk>
parents: 75686
diff changeset
2173 (call-interactively this-command)))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2174
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2175 ;; Check buf is non-nil.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2176 ((not buf) nil)
47203
d7ff55da60cd (ido-ignore-item-temp-list): New variable.
Kim F. Storm <storm@cua.dk>
parents: 46631
diff changeset
2177 ((= (length buf) 0) nil)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2178
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2179 ;; View buffer if it exists
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2180 ((get-buffer buf)
76148
d38be8d45087 (ido-buffer-internal): Set this-command to fallback command.
Kim F. Storm <storm@cua.dk>
parents: 75686
diff changeset
2181 (add-to-history 'buffer-name-history buf)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2182 (if (eq method 'insert)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2183 (progn
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2184 (ido-record-command 'insert-buffer buf)
68804
4ac434def21f (ido-buffer-internal): Set mark for ido-insert-buffer.
Kim F. Storm <storm@cua.dk>
parents: 68651
diff changeset
2185 (push-mark
4ac434def21f (ido-buffer-internal): Set mark for ido-insert-buffer.
Kim F. Storm <storm@cua.dk>
parents: 68651
diff changeset
2186 (save-excursion
4ac434def21f (ido-buffer-internal): Set mark for ido-insert-buffer.
Kim F. Storm <storm@cua.dk>
parents: 68651
diff changeset
2187 (insert-buffer-substring (get-buffer buf))
4ac434def21f (ido-buffer-internal): Set mark for ido-insert-buffer.
Kim F. Storm <storm@cua.dk>
parents: 68651
diff changeset
2188 (point))))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2189 (ido-visit-buffer buf method t)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2190
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2191 ;; buffer doesn't exist
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2192 ((eq ido-create-new-buffer 'never)
73825
36f23fcd07f8 (ido-ignore-extensions, ido-show-dot-for-dired, ido-max-dir-file-cache,
Juanma Barranquero <lekktu@gmail.com>
parents: 73388
diff changeset
2193 (message "No buffer matching `%s'" buf))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2194
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2195 ((and (eq ido-create-new-buffer 'prompt)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2196 (not (y-or-n-p (format "No buffer matching `%s', create one? " buf))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2197 nil)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2198
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2199 ;; create a new buffer
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2200 (t
76148
d38be8d45087 (ido-buffer-internal): Set this-command to fallback command.
Kim F. Storm <storm@cua.dk>
parents: 75686
diff changeset
2201 (add-to-history 'buffer-name-history buf)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2202 (setq buf (get-buffer-create buf))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2203 (if (fboundp 'set-buffer-major-mode)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2204 (set-buffer-major-mode buf))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2205 (ido-visit-buffer buf method t))))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2206
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2207 (defun ido-record-work-directory (&optional dir)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2208 (when (and (numberp ido-max-work-directory-list) (> ido-max-work-directory-list 0))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2209 (if (and (setq dir (or dir ido-current-directory)) (> (length dir) 0))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2210 (let ((items ido-work-directory-list-ignore-regexps)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2211 (case-fold-search nil))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2212 (while (and items dir)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2213 (if (string-match (car items) dir)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2214 (setq dir nil))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2215 (setq items (cdr items)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2216 (if dir
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2217 (setq ido-work-directory-list (cons dir (delete dir ido-work-directory-list))))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2218 (if (> (length ido-work-directory-list) ido-max-work-directory-list)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2219 (setcdr (nthcdr (1- ido-max-work-directory-list) ido-work-directory-list) nil))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2220
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2221 (defun ido-forget-work-directory ()
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2222 (interactive)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2223 (when (and ido-current-directory ido-work-directory-list)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2224 (setq ido-work-directory-list (delete ido-current-directory ido-work-directory-list))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2225 (when ido-use-merged-list
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2226 (ido-undo-merge-work-directory)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2227 (setq ido-exit 'refresh
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2228 ido-try-merged-list t
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2229 ido-use-merged-list t
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2230 ido-text-init ido-text
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2231 ido-rotate-temp t)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2232 (exit-minibuffer))))
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
2233
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2234 (defun ido-record-work-file (name)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2235 ;; Save NAME in ido-work-file-list
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2236 (when (and (numberp ido-max-work-file-list) (> ido-max-work-file-list 0))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2237 (or
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2238 (and ido-work-file-list (equal (car ido-work-file-list) name))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2239 (setq ido-work-file-list (cons name (delete name ido-work-file-list))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2240 (if (> (length ido-work-file-list) ido-max-work-file-list)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2241 (setcdr (nthcdr (1- ido-max-work-file-list) ido-work-file-list) nil))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2242
53323
a053c8c470f3 Handle non-readable directories.
Kim F. Storm <storm@cua.dk>
parents: 53166
diff changeset
2243 (defun ido-expand-directory (dir)
a053c8c470f3 Handle non-readable directories.
Kim F. Storm <storm@cua.dk>
parents: 53166
diff changeset
2244 ;; Expand DIR or use DEFAULT-DIRECTORY if nil.
a053c8c470f3 Handle non-readable directories.
Kim F. Storm <storm@cua.dk>
parents: 53166
diff changeset
2245 ;; Add final slash to result in case it was missing from DEFAULT-DIRECTORY.
a053c8c470f3 Handle non-readable directories.
Kim F. Storm <storm@cua.dk>
parents: 53166
diff changeset
2246 (ido-final-slash (expand-file-name (or dir default-directory)) t))
a053c8c470f3 Handle non-readable directories.
Kim F. Storm <storm@cua.dk>
parents: 53166
diff changeset
2247
57191
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
2248 (defun ido-file-internal (method &optional fallback default prompt item initial switch-cmd)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2249 ;; Internal function for ido-find-file and friends
53166
77088b91def1 * ido.el (ido-use-filename-at-point, ido-use-url-at-point):
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
2250 (unless item
77088b91def1 * ido.el (ido-use-filename-at-point, ido-use-url-at-point):
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
2251 (setq item 'file))
61180
cc04bb9ef8b6 (ido-file-internal): Fall back to non-ido command if
Kim F. Storm <storm@cua.dk>
parents: 60127
diff changeset
2252 (let ((ido-current-directory (ido-expand-directory default))
cc04bb9ef8b6 (ido-file-internal): Fall back to non-ido command if
Kim F. Storm <storm@cua.dk>
parents: 60127
diff changeset
2253 (ido-context-switch-command switch-cmd)
64343
6e19d6e25256 (ido-file-internal, ido-read-file-name, ido-read-directory-name):
Kim F. Storm <storm@cua.dk>
parents: 64341
diff changeset
2254 ido-directory-nonreadable ido-directory-too-big
61180
cc04bb9ef8b6 (ido-file-internal): Fall back to non-ido command if
Kim F. Storm <storm@cua.dk>
parents: 60127
diff changeset
2255 filename)
cc04bb9ef8b6 (ido-file-internal): Fall back to non-ido command if
Kim F. Storm <storm@cua.dk>
parents: 60127
diff changeset
2256
cc04bb9ef8b6 (ido-file-internal): Fall back to non-ido command if
Kim F. Storm <storm@cua.dk>
parents: 60127
diff changeset
2257 (if (or (not ido-mode) (ido-is-slow-ftp-host))
cc04bb9ef8b6 (ido-file-internal): Fall back to non-ido command if
Kim F. Storm <storm@cua.dk>
parents: 60127
diff changeset
2258 (setq filename t
cc04bb9ef8b6 (ido-file-internal): Fall back to non-ido command if
Kim F. Storm <storm@cua.dk>
parents: 60127
diff changeset
2259 ido-exit 'fallback)
cc04bb9ef8b6 (ido-file-internal): Fall back to non-ido command if
Kim F. Storm <storm@cua.dk>
parents: 60127
diff changeset
2260 (setq ido-directory-nonreadable
cc04bb9ef8b6 (ido-file-internal): Fall back to non-ido command if
Kim F. Storm <storm@cua.dk>
parents: 60127
diff changeset
2261 (ido-nonreadable-directory-p ido-current-directory)
cc04bb9ef8b6 (ido-file-internal): Fall back to non-ido command if
Kim F. Storm <storm@cua.dk>
parents: 60127
diff changeset
2262 ido-directory-too-big
cc04bb9ef8b6 (ido-file-internal): Fall back to non-ido command if
Kim F. Storm <storm@cua.dk>
parents: 60127
diff changeset
2263 (and (not ido-directory-nonreadable)
cc04bb9ef8b6 (ido-file-internal): Fall back to non-ido command if
Kim F. Storm <storm@cua.dk>
parents: 60127
diff changeset
2264 (ido-directory-too-big-p ido-current-directory))))
cc04bb9ef8b6 (ido-file-internal): Fall back to non-ido command if
Kim F. Storm <storm@cua.dk>
parents: 60127
diff changeset
2265
cc04bb9ef8b6 (ido-file-internal): Fall back to non-ido command if
Kim F. Storm <storm@cua.dk>
parents: 60127
diff changeset
2266 (when (and (eq item 'file)
53166
77088b91def1 * ido.el (ido-use-filename-at-point, ido-use-url-at-point):
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
2267 (or ido-use-url-at-point ido-use-filename-at-point))
77088b91def1 * ido.el (ido-use-filename-at-point, ido-use-url-at-point):
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
2268 (let (fn d)
77088b91def1 * ido.el (ido-use-filename-at-point, ido-use-url-at-point):
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
2269 (require 'ffap)
96376
c3309dba6542 American English spelling fix.
Glenn Morris <rgm@gnu.org>
parents: 95057
diff changeset
2270 ;; Duplicate code from ffap-guesser as we want different behavior for files and URLs.
53166
77088b91def1 * ido.el (ido-use-filename-at-point, ido-use-url-at-point):
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
2271 (cond
62089
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2272 ((with-no-warnings
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2273 (and ido-use-url-at-point
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2274 ffap-url-regexp
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2275 (ffap-fixup-url (or (ffap-url-at-point)
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2276 (ffap-gopher-at-point)))))
53166
77088b91def1 * ido.el (ido-use-filename-at-point, ido-use-url-at-point):
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
2277 (setq ido-exit 'ffap
77088b91def1 * ido.el (ido-use-filename-at-point, ido-use-url-at-point):
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
2278 filename t))
77088b91def1 * ido.el (ido-use-filename-at-point, ido-use-url-at-point):
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
2279
77088b91def1 * ido.el (ido-use-filename-at-point, ido-use-url-at-point):
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
2280 ((and ido-use-filename-at-point
86234
860a7a8e779e * progmodes/octave-mod.el (inferior-octave-send-list-and-digest):
Dan Nicolaescu <dann@ics.uci.edu>
parents: 85998
diff changeset
2281 (setq fn (with-no-warnings
860a7a8e779e * progmodes/octave-mod.el (inferior-octave-send-list-and-digest):
Dan Nicolaescu <dann@ics.uci.edu>
parents: 85998
diff changeset
2282 (if (eq ido-use-filename-at-point 'guess)
860a7a8e779e * progmodes/octave-mod.el (inferior-octave-send-list-and-digest):
Dan Nicolaescu <dann@ics.uci.edu>
parents: 85998
diff changeset
2283 (ffap-guesser)
860a7a8e779e * progmodes/octave-mod.el (inferior-octave-send-list-and-digest):
Dan Nicolaescu <dann@ics.uci.edu>
parents: 85998
diff changeset
2284 (ffap-string-at-point))))
54776
ae50ef10fab5 (ido-confirm-unique-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 53459
diff changeset
2285 (not (string-match "^http:/" fn))
53166
77088b91def1 * ido.el (ido-use-filename-at-point, ido-use-url-at-point):
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
2286 (setq d (file-name-directory fn))
77088b91def1 * ido.el (ido-use-filename-at-point, ido-use-url-at-point):
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
2287 (file-directory-p d))
77088b91def1 * ido.el (ido-use-filename-at-point, ido-use-url-at-point):
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
2288 (setq ido-current-directory d)
61180
cc04bb9ef8b6 (ido-file-internal): Fall back to non-ido command if
Kim F. Storm <storm@cua.dk>
parents: 60127
diff changeset
2289 (setq initial (file-name-nondirectory fn))))))
53166
77088b91def1 * ido.el (ido-use-filename-at-point, ido-use-url-at-point):
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
2290
77088b91def1 * ido.el (ido-use-filename-at-point, ido-use-url-at-point):
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
2291 (let (ido-saved-vc-hb
77088b91def1 * ido.el (ido-use-filename-at-point, ido-use-url-at-point):
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
2292 (vc-handled-backends (and (boundp 'vc-handled-backends) vc-handled-backends))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2293 (ido-work-directory-index -1)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2294 (ido-work-file-index -1)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2295 (ido-find-literal nil))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2296
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2297 (unless filename
53166
77088b91def1 * ido.el (ido-use-filename-at-point, ido-use-url-at-point):
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
2298 (setq ido-saved-vc-hb vc-handled-backends)
73166
7e2d2b8518f4 (ido-file-internal): Only bind minibuffer-completing-file-name
Kim F. Storm <storm@cua.dk>
parents: 72868
diff changeset
2299 (let ((minibuffer-completing-file-name t))
7e2d2b8518f4 (ido-file-internal): Only bind minibuffer-completing-file-name
Kim F. Storm <storm@cua.dk>
parents: 72868
diff changeset
2300 (setq filename (ido-read-internal item
7e2d2b8518f4 (ido-file-internal): Only bind minibuffer-completing-file-name
Kim F. Storm <storm@cua.dk>
parents: 72868
diff changeset
2301 (or prompt "Find file: ")
74020
9843dfd8d011 (ido-file-internal): Use current buffer's file name as default
Kim F. Storm <storm@cua.dk>
parents: 73985
diff changeset
2302 'ido-file-history
9843dfd8d011 (ido-file-internal): Use current buffer's file name as default
Kim F. Storm <storm@cua.dk>
parents: 73985
diff changeset
2303 (and (eq method 'alt-file) buffer-file-name)
9843dfd8d011 (ido-file-internal): Use current buffer's file name as default
Kim F. Storm <storm@cua.dk>
parents: 73985
diff changeset
2304 nil initial))))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2305
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2306 ;; Choose the file name: either the text typed in, or the head
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2307 ;; of the list of matches
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2308
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2309 (cond
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2310 ((eq ido-exit 'fallback)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2311 ;; Need to guard setting of default-directory here, since
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2312 ;; we don't want to change directory of current buffer.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2313 (let ((default-directory ido-current-directory)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2314 (read-file-name-function nil))
76148
d38be8d45087 (ido-buffer-internal): Set this-command to fallback command.
Kim F. Storm <storm@cua.dk>
parents: 75686
diff changeset
2315 (setq this-command (or fallback 'find-file))
d38be8d45087 (ido-buffer-internal): Set this-command to fallback command.
Kim F. Storm <storm@cua.dk>
parents: 75686
diff changeset
2316 (run-hook-with-args 'ido-before-fallback-functions this-command)
d38be8d45087 (ido-buffer-internal): Set this-command to fallback command.
Kim F. Storm <storm@cua.dk>
parents: 75686
diff changeset
2317 (call-interactively this-command)))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2318
57191
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
2319 ((eq ido-exit 'switch-to-buffer)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2320 (ido-buffer-internal ido-default-buffer-method nil nil nil ido-text))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2321
57191
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
2322 ((eq ido-exit 'insert-buffer)
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
2323 (ido-buffer-internal 'insert 'insert-buffer "Insert buffer: " nil ido-text 'ido-enter-insert-file))
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
2324
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2325 ((eq ido-exit 'dired)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2326 (dired (concat ido-current-directory (or ido-text ""))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2327
53166
77088b91def1 * ido.el (ido-use-filename-at-point, ido-use-url-at-point):
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
2328 ((eq ido-exit 'ffap)
77088b91def1 * ido.el (ido-use-filename-at-point, ido-use-url-at-point):
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
2329 (find-file-at-point))
77088b91def1 * ido.el (ido-use-filename-at-point, ido-use-url-at-point):
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
2330
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2331 ((eq method 'alt-file)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2332 (ido-record-work-file filename)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2333 (setq default-directory ido-current-directory)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2334 (ido-record-work-directory)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2335 (find-alternate-file filename))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2336
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2337 ((memq method '(dired list-directory))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2338 (if (equal filename ".")
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2339 (setq filename ""))
49235
beca89eeabb3 (ido-read-internal, ido-file-internal)
Kim F. Storm <storm@cua.dk>
parents: 49233
diff changeset
2340 (let* ((dirname (ido-final-slash (concat ido-current-directory filename) t))
beca89eeabb3 (ido-read-internal, ido-file-internal)
Kim F. Storm <storm@cua.dk>
parents: 49233
diff changeset
2341 (file (substring dirname 0 -1)))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2342 (cond
49235
beca89eeabb3 (ido-read-internal, ido-file-internal)
Kim F. Storm <storm@cua.dk>
parents: 49233
diff changeset
2343 ((file-directory-p dirname)
beca89eeabb3 (ido-read-internal, ido-file-internal)
Kim F. Storm <storm@cua.dk>
parents: 49233
diff changeset
2344 (ido-record-command method dirname)
beca89eeabb3 (ido-read-internal, ido-file-internal)
Kim F. Storm <storm@cua.dk>
parents: 49233
diff changeset
2345 (ido-record-work-directory dirname)
beca89eeabb3 (ido-read-internal, ido-file-internal)
Kim F. Storm <storm@cua.dk>
parents: 49233
diff changeset
2346 (funcall method dirname))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2347 ((file-directory-p ido-current-directory)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2348 (cond
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2349 ((file-exists-p file)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2350 (ido-record-command method ido-current-directory)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2351 (ido-record-work-directory)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2352 (funcall method ido-current-directory)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2353 (if (eq method 'dired)
62089
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2354 (with-no-warnings
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2355 (dired-goto-file (expand-file-name file)))))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2356 ((string-match "[[*?]" filename)
49235
beca89eeabb3 (ido-read-internal, ido-file-internal)
Kim F. Storm <storm@cua.dk>
parents: 49233
diff changeset
2357 (setq dirname (concat ido-current-directory filename))
beca89eeabb3 (ido-read-internal, ido-file-internal)
Kim F. Storm <storm@cua.dk>
parents: 49233
diff changeset
2358 (ido-record-command method dirname)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2359 (ido-record-work-directory)
49235
beca89eeabb3 (ido-read-internal, ido-file-internal)
Kim F. Storm <storm@cua.dk>
parents: 49233
diff changeset
2360 (funcall method dirname))
65689
96187e7edd1b 2005-09-25 Romain Francoise <romain@orebokech.com>
Romain Francoise <romain@orebokech.com>
parents: 65292
diff changeset
2361 ((y-or-n-p (format "Directory %s does not exist. Create it? " filename))
49235
beca89eeabb3 (ido-read-internal, ido-file-internal)
Kim F. Storm <storm@cua.dk>
parents: 49233
diff changeset
2362 (ido-record-command method dirname)
beca89eeabb3 (ido-read-internal, ido-file-internal)
Kim F. Storm <storm@cua.dk>
parents: 49233
diff changeset
2363 (ido-record-work-directory dirname)
beca89eeabb3 (ido-read-internal, ido-file-internal)
Kim F. Storm <storm@cua.dk>
parents: 49233
diff changeset
2364 (make-directory-internal dirname)
beca89eeabb3 (ido-read-internal, ido-file-internal)
Kim F. Storm <storm@cua.dk>
parents: 49233
diff changeset
2365 (funcall method dirname))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2366 (t
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2367 ;; put make-directory command on history
49235
beca89eeabb3 (ido-read-internal, ido-file-internal)
Kim F. Storm <storm@cua.dk>
parents: 49233
diff changeset
2368 (ido-record-command 'make-directory dirname))))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2369 (t (error "No such directory")))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2370
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2371 ((eq method 'write)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2372 (ido-record-work-file filename)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2373 (setq default-directory ido-current-directory)
76148
d38be8d45087 (ido-buffer-internal): Set this-command to fallback command.
Kim F. Storm <storm@cua.dk>
parents: 75686
diff changeset
2374 (setq filename (concat ido-current-directory filename))
d38be8d45087 (ido-buffer-internal): Set this-command to fallback command.
Kim F. Storm <storm@cua.dk>
parents: 75686
diff changeset
2375 (ido-record-command 'write-file filename)
d38be8d45087 (ido-buffer-internal): Set this-command to fallback command.
Kim F. Storm <storm@cua.dk>
parents: 75686
diff changeset
2376 (add-to-history 'file-name-history filename)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2377 (ido-record-work-directory)
76148
d38be8d45087 (ido-buffer-internal): Set this-command to fallback command.
Kim F. Storm <storm@cua.dk>
parents: 75686
diff changeset
2378 (write-file filename))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2379
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2380 ((eq method 'read-only)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2381 (ido-record-work-file filename)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2382 (setq filename (concat ido-current-directory filename))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2383 (ido-record-command fallback filename)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2384 (ido-record-work-directory)
64166
fad9662db4a9 (ido-before-fallback-functions): New hook.
Kim F. Storm <storm@cua.dk>
parents: 64091
diff changeset
2385 (run-hook-with-args 'ido-before-fallback-functions fallback)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2386 (funcall fallback filename))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2387
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2388 ((eq method 'insert)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2389 (ido-record-work-file filename)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2390 (setq filename (concat ido-current-directory filename))
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
2391 (ido-record-command
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2392 (if ido-find-literal 'insert-file-literally 'insert-file)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2393 filename)
76148
d38be8d45087 (ido-buffer-internal): Set this-command to fallback command.
Kim F. Storm <storm@cua.dk>
parents: 75686
diff changeset
2394 (add-to-history 'file-name-history filename)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2395 (ido-record-work-directory)
68804
4ac434def21f (ido-buffer-internal): Set mark for ido-insert-buffer.
Kim F. Storm <storm@cua.dk>
parents: 68651
diff changeset
2396 (insert-file-1 filename
4ac434def21f (ido-buffer-internal): Set mark for ido-insert-buffer.
Kim F. Storm <storm@cua.dk>
parents: 68651
diff changeset
2397 (if ido-find-literal
4ac434def21f (ido-buffer-internal): Set mark for ido-insert-buffer.
Kim F. Storm <storm@cua.dk>
parents: 68651
diff changeset
2398 #'insert-file-contents-literally
4ac434def21f (ido-buffer-internal): Set mark for ido-insert-buffer.
Kim F. Storm <storm@cua.dk>
parents: 68651
diff changeset
2399 #'insert-file-contents)))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2400
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2401 (filename
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2402 (ido-record-work-file filename)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2403 (setq filename (concat ido-current-directory filename))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2404 (ido-record-command 'find-file filename)
76148
d38be8d45087 (ido-buffer-internal): Set this-command to fallback command.
Kim F. Storm <storm@cua.dk>
parents: 75686
diff changeset
2405 (add-to-history 'file-name-history filename)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2406 (ido-record-work-directory)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2407 (ido-visit-buffer (find-file-noselect filename nil ido-find-literal) method))))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2408
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2409 (defun ido-existing-item-p ()
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2410 ;; Return non-nil if there is a matching item
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2411 (not (null ido-matches)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2412
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2413 ;;; COMPLETION CODE
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2414
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2415 (defun ido-set-common-completion ()
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2416 ;; Find common completion of `ido-text' in `ido-matches'
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2417 ;; The result is stored in `ido-common-match-string'
75573
8ddc4d84085e (ido-set-common-completion): Use `let', not `let*'.
Juanma Barranquero <lekktu@gmail.com>
parents: 75391
diff changeset
2418 (let (val)
8ddc4d84085e (ido-set-common-completion): Use `let', not `let*'.
Juanma Barranquero <lekktu@gmail.com>
parents: 75391
diff changeset
2419 (setq ido-common-match-string nil)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2420 (if (and ido-matches
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2421 (not ido-enable-regexp) ;; testing
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2422 (stringp ido-text)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2423 (> (length ido-text) 0))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2424 (if (setq val (ido-find-common-substring ido-matches ido-text))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2425 (setq ido-common-match-string val)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2426 val))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2427
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2428 (defun ido-complete ()
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2429 "Try and complete the current pattern amongst the file names."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2430 (interactive)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2431 (let (res)
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
2432 (cond
63476
a02cb15bf34c 2005-06-15 Matt Hodges <MPHodges@member.fsf.org>
Kim F. Storm <storm@cua.dk>
parents: 63430
diff changeset
2433 (ido-incomplete-regexp
a02cb15bf34c 2005-06-15 Matt Hodges <MPHodges@member.fsf.org>
Kim F. Storm <storm@cua.dk>
parents: 63430
diff changeset
2434 ;; Do nothing
a02cb15bf34c 2005-06-15 Matt Hodges <MPHodges@member.fsf.org>
Kim F. Storm <storm@cua.dk>
parents: 63430
diff changeset
2435 )
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2436 ((and (memq ido-cur-item '(file dir))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2437 (string-match "[$]" ido-text))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2438 (let ((evar (substitute-in-file-name (concat ido-current-directory ido-text))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2439 (if (not (file-exists-p (file-name-directory evar)))
49438
389e078f2b48 Many doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 49412
diff changeset
2440 (message "Expansion generates non-existing directory name")
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2441 (if (file-directory-p evar)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2442 (ido-set-current-directory evar)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2443 (let ((d (or (file-name-directory evar) "/"))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2444 (f (file-name-nondirectory evar)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2445 (when (file-directory-p d)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2446 (ido-set-current-directory d)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2447 (setq ido-text-init f))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2448 (setq ido-exit 'refresh)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2449 (exit-minibuffer))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2450
57211
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
2451 (ido-directory-too-big
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
2452 (setq ido-directory-too-big nil)
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
2453 (setq ido-text-init ido-text)
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
2454 (setq ido-exit 'refresh)
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
2455 (exit-minibuffer))
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
2456
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2457 ((not ido-matches)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2458 (when ido-completion-buffer
48030
4086fbc6ad65 (ido-cannot-complete-command): New defcustom, default to
Kim F. Storm <storm@cua.dk>
parents: 47977
diff changeset
2459 (call-interactively (setq this-command ido-cannot-complete-command))))
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
2460
49180
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
2461 ((and (= 1 (length ido-matches))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
2462 (not (and ido-enable-tramp-completion
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
2463 (string-equal ido-current-directory "/")
74337
ee9b338cccea 2006-11-30 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents: 74020
diff changeset
2464 (string-match ".[@:]\\'" (ido-name (car ido-matches)))))
ee9b338cccea 2006-11-30 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents: 74020
diff changeset
2465 (not (ido-local-file-exists-p (ido-name (car ido-matches)))))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2466 ;; only one choice, so select it.
54776
ae50ef10fab5 (ido-confirm-unique-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 53459
diff changeset
2467 (if (not ido-confirm-unique-completion)
ae50ef10fab5 (ido-confirm-unique-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 53459
diff changeset
2468 (exit-minibuffer)
ae50ef10fab5 (ido-confirm-unique-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 53459
diff changeset
2469 (setq ido-rescan (not ido-enable-prefix))
ae50ef10fab5 (ido-confirm-unique-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 53459
diff changeset
2470 (delete-region (minibuffer-prompt-end) (point))
72792
e8c7ac0523cb (ido-edit-input, ido-complete, ido-take-first-match)
Kim F. Storm <storm@cua.dk>
parents: 72656
diff changeset
2471 (insert (ido-name (car ido-matches)))))
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
2472
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2473 (t ;; else there could be some completions
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2474 (setq res ido-common-match-string)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2475 (if (and (not (memq res '(t nil)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2476 (not (equal res ido-text)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2477 ;; found something to complete, so put it in the minibuffer.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2478 (progn
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2479 ;; move exact match to front if not in prefix mode
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2480 (setq ido-rescan (not ido-enable-prefix))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2481 (delete-region (minibuffer-prompt-end) (point))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2482 (insert res))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2483 ;; else nothing to complete
48030
4086fbc6ad65 (ido-cannot-complete-command): New defcustom, default to
Kim F. Storm <storm@cua.dk>
parents: 47977
diff changeset
2484 (call-interactively (setq this-command ido-cannot-complete-command))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2485 )))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2486
46231
794e46e1c313 (ido-set-matches1): Use regexp-quote instead of identity.
Kim F. Storm <storm@cua.dk>
parents: 46225
diff changeset
2487 (defun ido-complete-space ()
794e46e1c313 (ido-set-matches1): Use regexp-quote instead of identity.
Kim F. Storm <storm@cua.dk>
parents: 46225
diff changeset
2488 "Try completion unless inserting the space makes sense."
794e46e1c313 (ido-set-matches1): Use regexp-quote instead of identity.
Kim F. Storm <storm@cua.dk>
parents: 46225
diff changeset
2489 (interactive)
794e46e1c313 (ido-set-matches1): Use regexp-quote instead of identity.
Kim F. Storm <storm@cua.dk>
parents: 46225
diff changeset
2490 (if (and (stringp ido-common-match-string)
794e46e1c313 (ido-set-matches1): Use regexp-quote instead of identity.
Kim F. Storm <storm@cua.dk>
parents: 46225
diff changeset
2491 (stringp ido-text)
794e46e1c313 (ido-set-matches1): Use regexp-quote instead of identity.
Kim F. Storm <storm@cua.dk>
parents: 46225
diff changeset
2492 (cond
794e46e1c313 (ido-set-matches1): Use regexp-quote instead of identity.
Kim F. Storm <storm@cua.dk>
parents: 46225
diff changeset
2493 ((> (length ido-common-match-string) (length ido-text))
794e46e1c313 (ido-set-matches1): Use regexp-quote instead of identity.
Kim F. Storm <storm@cua.dk>
parents: 46225
diff changeset
2494 (= (aref ido-common-match-string (length ido-text)) ? ))
794e46e1c313 (ido-set-matches1): Use regexp-quote instead of identity.
Kim F. Storm <storm@cua.dk>
parents: 46225
diff changeset
2495 (ido-matches
794e46e1c313 (ido-set-matches1): Use regexp-quote instead of identity.
Kim F. Storm <storm@cua.dk>
parents: 46225
diff changeset
2496 (let (insert-space
794e46e1c313 (ido-set-matches1): Use regexp-quote instead of identity.
Kim F. Storm <storm@cua.dk>
parents: 46225
diff changeset
2497 (re (concat (regexp-quote ido-text) " "))
794e46e1c313 (ido-set-matches1): Use regexp-quote instead of identity.
Kim F. Storm <storm@cua.dk>
parents: 46225
diff changeset
2498 (comp ido-matches))
794e46e1c313 (ido-set-matches1): Use regexp-quote instead of identity.
Kim F. Storm <storm@cua.dk>
parents: 46225
diff changeset
2499 (while comp
794e46e1c313 (ido-set-matches1): Use regexp-quote instead of identity.
Kim F. Storm <storm@cua.dk>
parents: 46225
diff changeset
2500 (if (string-match re (ido-name (car comp)))
794e46e1c313 (ido-set-matches1): Use regexp-quote instead of identity.
Kim F. Storm <storm@cua.dk>
parents: 46225
diff changeset
2501 (setq comp nil insert-space t)
794e46e1c313 (ido-set-matches1): Use regexp-quote instead of identity.
Kim F. Storm <storm@cua.dk>
parents: 46225
diff changeset
2502 (setq comp (cdr comp))))
794e46e1c313 (ido-set-matches1): Use regexp-quote instead of identity.
Kim F. Storm <storm@cua.dk>
parents: 46225
diff changeset
2503 insert-space))
794e46e1c313 (ido-set-matches1): Use regexp-quote instead of identity.
Kim F. Storm <storm@cua.dk>
parents: 46225
diff changeset
2504 (t nil)))
794e46e1c313 (ido-set-matches1): Use regexp-quote instead of identity.
Kim F. Storm <storm@cua.dk>
parents: 46225
diff changeset
2505 (insert " ")
794e46e1c313 (ido-set-matches1): Use regexp-quote instead of identity.
Kim F. Storm <storm@cua.dk>
parents: 46225
diff changeset
2506 (ido-complete)))
794e46e1c313 (ido-set-matches1): Use regexp-quote instead of identity.
Kim F. Storm <storm@cua.dk>
parents: 46225
diff changeset
2507
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2508 (defun ido-undo-merge-work-directory (&optional text try refresh)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2509 "Undo or redo last ido directory merge operation.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2510 If no merge has yet taken place, toggle automatic merging option."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2511 (interactive)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2512 (cond
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2513 (ido-pre-merge-state
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2514 (ido-set-current-directory (nth 1 ido-pre-merge-state))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2515 (setq ido-text-init (or text (car ido-pre-merge-state))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2516 ido-cur-list (nth 2 ido-pre-merge-state)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2517 ido-ignored-list (nth 3 ido-pre-merge-state)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2518 ido-matches (nth 4 ido-pre-merge-state)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2519 ido-use-merged-list nil
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2520 ido-try-merged-list try
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2521 ido-keep-item-list (not refresh)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2522 ido-rescan nil
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2523 ido-exit 'refresh
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2524 ido-pre-merge-state nil)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2525 (exit-minibuffer))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2526 (text
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2527 nil)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2528 (ido-try-merged-list
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2529 (setq ido-try-merged-list nil))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2530 (ido-matches
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2531 (setq ido-try-merged-list t))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2532 ((not ido-use-merged-list)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2533 (ido-merge-work-directories))))
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
2534
62378
4d270efed583 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 62089
diff changeset
2535 ;;; Magic C-f
4d270efed583 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 62089
diff changeset
2536
91509
ce9d394589c2 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 87566
diff changeset
2537 (defun ido-magic-forward-char (arg)
62378
4d270efed583 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 62089
diff changeset
2538 "Move forward in user input or perform magic action.
63235
ba92543774db (ido-mode, ido-file-extensions-order, ido-default-file-method,
Juanma Barranquero <lekktu@gmail.com>
parents: 63124
diff changeset
2539 If no user input is present, or at end of input, perform magic actions:
62537
43a311177040 (ido-magic-forward-char): Enter ido-find-file at end of input.
Kim F. Storm <storm@cua.dk>
parents: 62378
diff changeset
2540 C-x C-b ... C-f switch to ido-find-file.
43a311177040 (ido-magic-forward-char): Enter ido-find-file at end of input.
Kim F. Storm <storm@cua.dk>
parents: 62378
diff changeset
2541 C-x C-f ... C-f fallback to non-ido find-file.
43a311177040 (ido-magic-forward-char): Enter ido-find-file at end of input.
Kim F. Storm <storm@cua.dk>
parents: 62378
diff changeset
2542 C-x C-d ... C-f fallback to non-ido brief dired.
43a311177040 (ido-magic-forward-char): Enter ido-find-file at end of input.
Kim F. Storm <storm@cua.dk>
parents: 62378
diff changeset
2543 C-x d ... C-f fallback to non-ido dired."
91509
ce9d394589c2 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 87566
diff changeset
2544 (interactive "P")
62378
4d270efed583 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 62089
diff changeset
2545 (cond
91509
ce9d394589c2 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 87566
diff changeset
2546 ((or arg (not (eobp)))
ce9d394589c2 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 87566
diff changeset
2547 (forward-char (min (prefix-numeric-value arg)
ce9d394589c2 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 87566
diff changeset
2548 (- (point-max) (point)))))
62537
43a311177040 (ido-magic-forward-char): Enter ido-find-file at end of input.
Kim F. Storm <storm@cua.dk>
parents: 62378
diff changeset
2549 ((memq ido-cur-item '(file dir))
43a311177040 (ido-magic-forward-char): Enter ido-find-file at end of input.
Kim F. Storm <storm@cua.dk>
parents: 62378
diff changeset
2550 (ido-fallback-command))
43a311177040 (ido-magic-forward-char): Enter ido-find-file at end of input.
Kim F. Storm <storm@cua.dk>
parents: 62378
diff changeset
2551 (ido-context-switch-command
43a311177040 (ido-magic-forward-char): Enter ido-find-file at end of input.
Kim F. Storm <storm@cua.dk>
parents: 62378
diff changeset
2552 (call-interactively ido-context-switch-command))
43a311177040 (ido-magic-forward-char): Enter ido-find-file at end of input.
Kim F. Storm <storm@cua.dk>
parents: 62378
diff changeset
2553 ((eq ido-cur-item 'buffer)
43a311177040 (ido-magic-forward-char): Enter ido-find-file at end of input.
Kim F. Storm <storm@cua.dk>
parents: 62378
diff changeset
2554 (ido-enter-find-file))))
62378
4d270efed583 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 62089
diff changeset
2555
4d270efed583 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 62089
diff changeset
2556 ;;; Magic C-b
4d270efed583 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 62089
diff changeset
2557
91509
ce9d394589c2 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 87566
diff changeset
2558 (defun ido-magic-backward-char (arg)
62378
4d270efed583 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 62089
diff changeset
2559 "Move backward in user input or perform magic action.
62537
43a311177040 (ido-magic-forward-char): Enter ido-find-file at end of input.
Kim F. Storm <storm@cua.dk>
parents: 62378
diff changeset
2560 If no user input is present, or at start of input, perform magic actions:
73825
36f23fcd07f8 (ido-ignore-extensions, ido-show-dot-for-dired, ido-max-dir-file-cache,
Juanma Barranquero <lekktu@gmail.com>
parents: 73388
diff changeset
2561 C-x C-f C-b switch to `ido-switch-buffer'.
36f23fcd07f8 (ido-ignore-extensions, ido-show-dot-for-dired, ido-max-dir-file-cache,
Juanma Barranquero <lekktu@gmail.com>
parents: 73388
diff changeset
2562 C-x C-d C-b switch to `ido-switch-buffer'.
36f23fcd07f8 (ido-ignore-extensions, ido-show-dot-for-dired, ido-max-dir-file-cache,
Juanma Barranquero <lekktu@gmail.com>
parents: 73388
diff changeset
2563 C-x d C-b switch to `ido-switch-buffer'.
36f23fcd07f8 (ido-ignore-extensions, ido-show-dot-for-dired, ido-max-dir-file-cache,
Juanma Barranquero <lekktu@gmail.com>
parents: 73388
diff changeset
2564 C-x C-b C-b fallback to non-ido `switch-to-buffer'."
91509
ce9d394589c2 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 87566
diff changeset
2565 (interactive "P")
62378
4d270efed583 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 62089
diff changeset
2566 (cond
91509
ce9d394589c2 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 87566
diff changeset
2567 ((or arg (> (point) (minibuffer-prompt-end)))
ce9d394589c2 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 87566
diff changeset
2568 (forward-char
ce9d394589c2 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 87566
diff changeset
2569 (- (min (prefix-numeric-value arg)
ce9d394589c2 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 87566
diff changeset
2570 (- (point) (minibuffer-prompt-end))))))
75391
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
2571 ((eq last-command this-command)
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
2572 (when (and (memq ido-cur-item '(file dir))
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
2573 (not (bobp)))
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
2574 (ido-push-dir))) ; else do nothing
62378
4d270efed583 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 62089
diff changeset
2575 ((eq ido-cur-item 'buffer)
62537
43a311177040 (ido-magic-forward-char): Enter ido-find-file at end of input.
Kim F. Storm <storm@cua.dk>
parents: 62378
diff changeset
2576 (ido-fallback-command))
43a311177040 (ido-magic-forward-char): Enter ido-find-file at end of input.
Kim F. Storm <storm@cua.dk>
parents: 62378
diff changeset
2577 (ido-context-switch-command
43a311177040 (ido-magic-forward-char): Enter ido-find-file at end of input.
Kim F. Storm <storm@cua.dk>
parents: 62378
diff changeset
2578 (call-interactively ido-context-switch-command))
43a311177040 (ido-magic-forward-char): Enter ido-find-file at end of input.
Kim F. Storm <storm@cua.dk>
parents: 62378
diff changeset
2579 (t
43a311177040 (ido-magic-forward-char): Enter ido-find-file at end of input.
Kim F. Storm <storm@cua.dk>
parents: 62378
diff changeset
2580 (ido-enter-switch-buffer))))
62378
4d270efed583 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 62089
diff changeset
2581
4d270efed583 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 62089
diff changeset
2582 ;;; Magic C-d
4d270efed583 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 62089
diff changeset
2583
91509
ce9d394589c2 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 87566
diff changeset
2584 (defun ido-magic-delete-char (arg)
62378
4d270efed583 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 62089
diff changeset
2585 "Delete following char in user input or perform magic action.
4d270efed583 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 62089
diff changeset
2586 If at end of user input, perform magic actions:
4d270efed583 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 62089
diff changeset
2587 C-x C-f ... C-d enter dired on current directory."
91509
ce9d394589c2 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 87566
diff changeset
2588 (interactive "P")
62378
4d270efed583 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 62089
diff changeset
2589 (cond
91509
ce9d394589c2 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 87566
diff changeset
2590 ((or arg (not (eobp)))
ce9d394589c2 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 87566
diff changeset
2591 (delete-char (min (prefix-numeric-value arg)
ce9d394589c2 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 87566
diff changeset
2592 (- (point-max) (point)))))
62378
4d270efed583 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 62089
diff changeset
2593 (ido-context-switch-command
4d270efed583 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 62089
diff changeset
2594 nil)
4d270efed583 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 62089
diff changeset
2595 ((memq ido-cur-item '(file dir))
4d270efed583 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 62089
diff changeset
2596 (ido-enter-dired))))
4d270efed583 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 62089
diff changeset
2597
4d270efed583 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 62089
diff changeset
2598
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2599 ;;; TOGGLE FUNCTIONS
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2600
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2601 (defun ido-toggle-case ()
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2602 "Toggle the value of `ido-case-fold'."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2603 (interactive)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2604 (setq ido-case-fold (not ido-case-fold))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2605 ;; ask for list to be regenerated.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2606 (setq ido-rescan t))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2607
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2608 (defun ido-toggle-regexp ()
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2609 "Toggle the value of `ido-enable-regexp'."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2610 (interactive)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2611 (setq ido-enable-regexp (not ido-enable-regexp))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2612 ;; ask for list to be regenerated.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2613 (setq ido-rescan t))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2614
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2615 (defun ido-toggle-prefix ()
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2616 "Toggle the value of `ido-enable-prefix'."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2617 (interactive)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2618 (setq ido-enable-prefix (not ido-enable-prefix))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2619 ;; ask for list to be regenerated.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2620 (setq ido-rescan t))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2621
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2622 (defun ido-toggle-ignore ()
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2623 "Toggle ignoring files specified with `ido-ignore-files'."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2624 (interactive)
75391
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
2625 (if (and (not (eobp)) (> (point) (minibuffer-prompt-end)))
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
2626 (goto-char (minibuffer-prompt-end))
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
2627 (if ido-directory-too-big
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
2628 (progn
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
2629 (message "Reading directory...")
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
2630 (setq ido-directory-too-big nil))
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
2631 (setq ido-process-ignore-lists (not ido-process-ignore-lists)))
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
2632 (setq ido-text-init ido-text)
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
2633 (setq ido-exit 'refresh)
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
2634 (exit-minibuffer)))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2635
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2636 (defun ido-toggle-vc ()
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2637 "Disable version control for this file."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2638 (interactive)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2639 (if (and ido-mode (eq ido-cur-item 'file))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2640 (progn
53166
77088b91def1 * ido.el (ido-use-filename-at-point, ido-use-url-at-point):
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
2641 (setq vc-handled-backends
77088b91def1 * ido.el (ido-use-filename-at-point, ido-use-url-at-point):
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
2642 (if vc-handled-backends nil ido-saved-vc-hb))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2643 (setq ido-text-init ido-text)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2644 (setq ido-exit 'keep)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2645 (exit-minibuffer))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2646
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2647 (defun ido-toggle-literal ()
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2648 "Toggle literal reading of this file."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2649 (interactive)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2650 (if (and ido-mode (eq ido-cur-item 'file))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2651 (progn
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2652 (setq ido-find-literal (not ido-find-literal))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2653 (setq ido-text-init ido-text)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2654 (setq ido-exit 'keep)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2655 (exit-minibuffer))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2656
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2657 (defun ido-reread-directory ()
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2658 "Read current directory again.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2659 May be useful if cached version is no longer valid, but directory
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2660 timestamp has not changed (e.g. with ftp or on Windows)."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2661 (interactive)
73388
98bbab587745 (ido-reread-directory): Work in `dir' mode too.
Kim F. Storm <storm@cua.dk>
parents: 73376
diff changeset
2662 (if (and ido-mode (memq ido-cur-item '(file dir)))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2663 (progn
69809
7dd2c54d4afb (ido-mode): Set after ido-unc-hosts and ido-ignore-unc-host-regexps.
Kim F. Storm <storm@cua.dk>
parents: 69748
diff changeset
2664 (if (ido-is-unc-root)
7dd2c54d4afb (ido-mode): Set after ido-unc-hosts and ido-ignore-unc-host-regexps.
Kim F. Storm <storm@cua.dk>
parents: 69748
diff changeset
2665 (setq ido-unc-hosts-cache t)
7dd2c54d4afb (ido-mode): Set after ido-unc-hosts and ido-ignore-unc-host-regexps.
Kim F. Storm <storm@cua.dk>
parents: 69748
diff changeset
2666 (ido-remove-cached-dir ido-current-directory))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2667 (setq ido-text-init ido-text)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2668 (setq ido-rotate-temp t)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2669 (setq ido-exit 'refresh)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2670 (exit-minibuffer))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2671
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2672 (defun ido-exit-minibuffer ()
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2673 "Exit minibuffer, but make sure we have a match if one is needed."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2674 (interactive)
63476
a02cb15bf34c 2005-06-15 Matt Hodges <MPHodges@member.fsf.org>
Kim F. Storm <storm@cua.dk>
parents: 63430
diff changeset
2675 (if (and (or (not ido-require-match)
a02cb15bf34c 2005-06-15 Matt Hodges <MPHodges@member.fsf.org>
Kim F. Storm <storm@cua.dk>
parents: 63430
diff changeset
2676 (ido-existing-item-p))
a02cb15bf34c 2005-06-15 Matt Hodges <MPHodges@member.fsf.org>
Kim F. Storm <storm@cua.dk>
parents: 63430
diff changeset
2677 (not ido-incomplete-regexp))
62089
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2678 (exit-minibuffer)))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2679
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2680 (defun ido-select-text ()
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2681 "Select the buffer or file named by the prompt.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2682 If no buffer or file exactly matching the prompt exists, maybe create a new one."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2683 (interactive)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2684 (setq ido-exit 'takeprompt)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2685 (exit-minibuffer))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2686
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2687 (defun ido-fallback-command ()
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2688 "Fallback to non-ido version of current command."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2689 (interactive)
60127
283f8f92beaa (ido-fallback-command): Pass user input to fallback command.
Kim F. Storm <storm@cua.dk>
parents: 59996
diff changeset
2690 (let ((i (length ido-text)))
283f8f92beaa (ido-fallback-command): Pass user input to fallback command.
Kim F. Storm <storm@cua.dk>
parents: 59996
diff changeset
2691 (while (> i 0)
283f8f92beaa (ido-fallback-command): Pass user input to fallback command.
Kim F. Storm <storm@cua.dk>
parents: 59996
diff changeset
2692 (push (aref ido-text (setq i (1- i))) unread-command-events)))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2693 (setq ido-exit 'fallback)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2694 (exit-minibuffer))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2695
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2696 (defun ido-enter-find-file ()
63235
ba92543774db (ido-mode, ido-file-extensions-order, ido-default-file-method,
Juanma Barranquero <lekktu@gmail.com>
parents: 63124
diff changeset
2697 "Drop into `find-file' from buffer switching."
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2698 (interactive)
57191
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
2699 (setq ido-exit 'find-file)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2700 (exit-minibuffer))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2701
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2702 (defun ido-enter-switch-buffer ()
63235
ba92543774db (ido-mode, ido-file-extensions-order, ido-default-file-method,
Juanma Barranquero <lekktu@gmail.com>
parents: 63124
diff changeset
2703 "Drop into `ido-switch-buffer' from file switching."
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2704 (interactive)
57191
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
2705 (setq ido-exit 'switch-to-buffer)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2706 (exit-minibuffer))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2707
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2708 (defun ido-enter-dired ()
73825
36f23fcd07f8 (ido-ignore-extensions, ido-show-dot-for-dired, ido-max-dir-file-cache,
Juanma Barranquero <lekktu@gmail.com>
parents: 73388
diff changeset
2709 "Drop into `dired' from file switching."
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2710 (interactive)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2711 (setq ido-exit 'dired)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2712 (exit-minibuffer))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2713
57191
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
2714 (defun ido-enter-insert-buffer ()
73825
36f23fcd07f8 (ido-ignore-extensions, ido-show-dot-for-dired, ido-max-dir-file-cache,
Juanma Barranquero <lekktu@gmail.com>
parents: 73388
diff changeset
2715 "Drop into `insert-buffer' from insert file."
57191
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
2716 (interactive)
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
2717 (setq ido-exit 'insert-buffer)
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
2718 (exit-minibuffer))
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
2719
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
2720 (defun ido-enter-insert-file ()
73825
36f23fcd07f8 (ido-ignore-extensions, ido-show-dot-for-dired, ido-max-dir-file-cache,
Juanma Barranquero <lekktu@gmail.com>
parents: 73388
diff changeset
2721 "Drop into `insert-file' from insert buffer."
57191
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
2722 (interactive)
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
2723 (setq ido-exit 'insert-file)
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
2724 (exit-minibuffer))
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
2725
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2726
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2727 (defun ido-up-directory (&optional clear)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2728 "Go up one directory level."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2729 (interactive "P")
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2730 (setq ido-text-init (if clear nil ido-text))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2731 (setq ido-exit 'updir)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2732 (setq ido-rotate-temp t)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2733 (exit-minibuffer))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2734
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2735 (defun ido-delete-backward-updir (count)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2736 "Delete char backwards, or at beginning of buffer, go up one level."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2737 (interactive "P")
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2738 (cond
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2739 ((= (minibuffer-prompt-end) (point))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2740 (if (not count)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2741 (ido-up-directory t)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2742 ((and ido-pre-merge-state (string-equal (car ido-pre-merge-state) ido-text))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2743 (ido-undo-merge-work-directory (substring ido-text 0 -1) t t))
49579
e19c547c5487 (ido-define-mode-map): Remap viper delete char/word
Kim F. Storm <storm@cua.dk>
parents: 49438
diff changeset
2744 ((eq this-original-command 'viper-backward-char)
e19c547c5487 (ido-define-mode-map): Remap viper delete char/word
Kim F. Storm <storm@cua.dk>
parents: 49438
diff changeset
2745 (funcall this-original-command (prefix-numeric-value count)))
e19c547c5487 (ido-define-mode-map): Remap viper delete char/word
Kim F. Storm <storm@cua.dk>
parents: 49438
diff changeset
2746 ((eq this-original-command 'viper-del-backward-char-in-insert)
e19c547c5487 (ido-define-mode-map): Remap viper delete char/word
Kim F. Storm <storm@cua.dk>
parents: 49438
diff changeset
2747 (funcall this-original-command))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2748 (t
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2749 (delete-backward-char (prefix-numeric-value count)))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2750
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2751 (defun ido-delete-backward-word-updir (count)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2752 "Delete all chars backwards, or at beginning of buffer, go up one level."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2753 (interactive "P")
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2754 (if (= (minibuffer-prompt-end) (point))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2755 (if (not count)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2756 (ido-up-directory t))
49579
e19c547c5487 (ido-define-mode-map): Remap viper delete char/word
Kim F. Storm <storm@cua.dk>
parents: 49438
diff changeset
2757 (if (eq this-original-command 'viper-delete-backward-word)
e19c547c5487 (ido-define-mode-map): Remap viper delete char/word
Kim F. Storm <storm@cua.dk>
parents: 49438
diff changeset
2758 (funcall this-original-command (prefix-numeric-value count))
e19c547c5487 (ido-define-mode-map): Remap viper delete char/word
Kim F. Storm <storm@cua.dk>
parents: 49438
diff changeset
2759 (backward-kill-word (prefix-numeric-value count)))))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2760
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2761 (defun ido-get-work-directory (&optional incr must-match)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2762 (let ((n (length ido-work-directory-list))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2763 (i ido-work-directory-index)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2764 (j 0)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2765 dir)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2766 (if (or (not ido-text) (= (length ido-text) 0))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2767 (setq must-match nil))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2768 (while (< j n)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2769 (setq i (+ i incr)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2770 j (1+ j))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2771 (if (> incr 0)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2772 (if (>= i n) (setq i 0))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2773 (if (< i 0) (setq i (1- n))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2774 (setq dir (nth i ido-work-directory-list))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2775 (if (and dir
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2776 (not (equal dir ido-current-directory))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2777 (file-directory-p dir)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2778 (or (not must-match)
57211
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
2779 ;; TODO. check for nonreadable and too-big.
62985
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
2780 (ido-set-matches-1
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2781 (if (eq ido-cur-item 'file)
62985
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
2782 (ido-make-file-list-1 dir)
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
2783 (ido-make-dir-list-1 dir)))))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2784 (setq j n)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2785 (setq dir nil)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2786 (if dir
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2787 (setq ido-work-directory-index i))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2788 dir))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2789
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2790 (defun ido-prev-work-directory ()
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2791 "Change to next working directory in list."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2792 (interactive)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2793 (let ((dir (ido-get-work-directory 1 ido-work-directory-match-only)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2794 (when dir
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2795 (ido-set-current-directory dir)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2796 (setq ido-exit 'refresh)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2797 (setq ido-text-init ido-text)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2798 (setq ido-rotate-temp t)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2799 (exit-minibuffer))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2800
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2801 (defun ido-next-work-directory ()
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2802 "Change to previous working directory in list."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2803 (interactive)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2804 (let ((dir (ido-get-work-directory -1 ido-work-directory-match-only)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2805 (when dir
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2806 (ido-set-current-directory dir)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2807 (setq ido-exit 'refresh)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2808 (setq ido-text-init ido-text)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2809 (setq ido-rotate-temp t)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2810 (exit-minibuffer))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2811
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2812 (defun ido-merge-work-directories ()
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2813 "Search (and merge) work directories for files matching the current input string."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2814 (interactive)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2815 (setq ido-use-merged-list t ido-try-merged-list t)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2816 (setq ido-exit 'refresh)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2817 (setq ido-text-init ido-text)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2818 (setq ido-rotate-temp t)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2819 (exit-minibuffer))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2820
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2821 (defun ido-wide-find-file (&optional file)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2822 "Prompt for FILE to search for using find, starting from current directory."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2823 (interactive)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2824 (unless file
50260
78ad1c52e368 (ido-mode): Remove unused NOBIND arg. Fix doc string accordingly.
Kim F. Storm <storm@cua.dk>
parents: 49614
diff changeset
2825 (let ((enable-recursive-minibuffers t))
78ad1c52e368 (ido-mode): Remove unused NOBIND arg. Fix doc string accordingly.
Kim F. Storm <storm@cua.dk>
parents: 49614
diff changeset
2826 (setq file
62089
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2827 (condition-case nil
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2828 (read-string (concat "Wide find file: " ido-current-directory) ido-text)
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2829 (quit "")))))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2830 (when (> (length file) 0)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2831 (setq ido-use-merged-list t ido-try-merged-list 'wide)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2832 (setq ido-exit 'refresh)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2833 (setq ido-text-init file)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2834 (setq ido-rotate-temp t)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2835 (exit-minibuffer)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2836
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2837 (defun ido-wide-find-dir (&optional dir)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2838 "Prompt for DIR to search for using find, starting from current directory."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2839 (interactive)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2840 (unless dir
50260
78ad1c52e368 (ido-mode): Remove unused NOBIND arg. Fix doc string accordingly.
Kim F. Storm <storm@cua.dk>
parents: 49614
diff changeset
2841 (let ((enable-recursive-minibuffers t))
78ad1c52e368 (ido-mode): Remove unused NOBIND arg. Fix doc string accordingly.
Kim F. Storm <storm@cua.dk>
parents: 49614
diff changeset
2842 (setq dir
62089
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2843 (condition-case nil
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2844 (read-string (concat "Wide find directory: " ido-current-directory) ido-text)
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2845 (quit "")))))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2846 (when (> (length dir) 0)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2847 (setq ido-use-merged-list t ido-try-merged-list 'wide)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2848 (setq ido-exit 'refresh)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2849 (setq ido-text-init (ido-final-slash dir t))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2850 (setq ido-rotate-temp t)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2851 (exit-minibuffer)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2852
62378
4d270efed583 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 62089
diff changeset
2853 (defun ido-wide-find-dir-or-delete-dir (&optional dir)
4d270efed583 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 62089
diff changeset
2854 "Prompt for DIR to search for using find, starting from current directory.
4d270efed583 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 62089
diff changeset
2855 If input stack is non-empty, delete current directory component."
4d270efed583 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 62089
diff changeset
2856 (interactive)
4d270efed583 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 62089
diff changeset
2857 (if ido-input-stack
4d270efed583 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 62089
diff changeset
2858 (ido-delete-backward-word-updir 1)
4d270efed583 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 62089
diff changeset
2859 (ido-wide-find-dir)))
4d270efed583 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 62089
diff changeset
2860
71269
851a15a8f318 (ido-take-first-match, ido-push-dir-first): New commands.
Kim F. Storm <storm@cua.dk>
parents: 71240
diff changeset
2861 (defun ido-take-first-match ()
851a15a8f318 (ido-take-first-match, ido-push-dir-first): New commands.
Kim F. Storm <storm@cua.dk>
parents: 71240
diff changeset
2862 "Use first matching item as input text."
851a15a8f318 (ido-take-first-match, ido-push-dir-first): New commands.
Kim F. Storm <storm@cua.dk>
parents: 71240
diff changeset
2863 (interactive)
851a15a8f318 (ido-take-first-match, ido-push-dir-first): New commands.
Kim F. Storm <storm@cua.dk>
parents: 71240
diff changeset
2864 (when ido-matches
72792
e8c7ac0523cb (ido-edit-input, ido-complete, ido-take-first-match)
Kim F. Storm <storm@cua.dk>
parents: 72656
diff changeset
2865 (setq ido-text-init (ido-name (car ido-matches)))
71269
851a15a8f318 (ido-take-first-match, ido-push-dir-first): New commands.
Kim F. Storm <storm@cua.dk>
parents: 71240
diff changeset
2866 (setq ido-exit 'refresh)
851a15a8f318 (ido-take-first-match, ido-push-dir-first): New commands.
Kim F. Storm <storm@cua.dk>
parents: 71240
diff changeset
2867 (exit-minibuffer)))
851a15a8f318 (ido-take-first-match, ido-push-dir-first): New commands.
Kim F. Storm <storm@cua.dk>
parents: 71240
diff changeset
2868
62089
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2869 (defun ido-push-dir ()
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2870 "Move to previous directory in file name, push current input on stack."
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2871 (interactive)
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2872 (setq ido-exit 'push)
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2873 (exit-minibuffer))
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2874
71269
851a15a8f318 (ido-take-first-match, ido-push-dir-first): New commands.
Kim F. Storm <storm@cua.dk>
parents: 71240
diff changeset
2875 (defun ido-push-dir-first ()
851a15a8f318 (ido-take-first-match, ido-push-dir-first): New commands.
Kim F. Storm <storm@cua.dk>
parents: 71240
diff changeset
2876 "Move to previous directory in file name, push first match on stack."
851a15a8f318 (ido-take-first-match, ido-push-dir-first): New commands.
Kim F. Storm <storm@cua.dk>
parents: 71240
diff changeset
2877 (interactive)
851a15a8f318 (ido-take-first-match, ido-push-dir-first): New commands.
Kim F. Storm <storm@cua.dk>
parents: 71240
diff changeset
2878 (if ido-matches
72792
e8c7ac0523cb (ido-edit-input, ido-complete, ido-take-first-match)
Kim F. Storm <storm@cua.dk>
parents: 72656
diff changeset
2879 (setq ido-text (ido-name (car ido-matches))))
71269
851a15a8f318 (ido-take-first-match, ido-push-dir-first): New commands.
Kim F. Storm <storm@cua.dk>
parents: 71240
diff changeset
2880 (setq ido-exit 'push)
851a15a8f318 (ido-take-first-match, ido-push-dir-first): New commands.
Kim F. Storm <storm@cua.dk>
parents: 71240
diff changeset
2881 (exit-minibuffer))
851a15a8f318 (ido-take-first-match, ido-push-dir-first): New commands.
Kim F. Storm <storm@cua.dk>
parents: 71240
diff changeset
2882
62089
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2883 (defun ido-pop-dir (arg)
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2884 "Pop directory from input stack back to input.
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2885 With \\[universal-argument], pop all element."
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2886 (interactive "P")
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2887 (when ido-input-stack
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2888 (setq ido-exit (if arg 'pop-all 'pop))
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2889 (exit-minibuffer)))
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2890
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2891 (defun ido-wide-find-file-or-pop-dir (arg)
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2892 (interactive "P")
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2893 (if ido-input-stack
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2894 (ido-pop-dir arg)
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2895 (ido-wide-find-file)))
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
2896
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2897 (defun ido-make-directory (&optional dir)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2898 "Prompt for DIR to create in current directory."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2899 (interactive)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2900 (unless dir
50260
78ad1c52e368 (ido-mode): Remove unused NOBIND arg. Fix doc string accordingly.
Kim F. Storm <storm@cua.dk>
parents: 49614
diff changeset
2901 (let ((enable-recursive-minibuffers t))
78ad1c52e368 (ido-mode): Remove unused NOBIND arg. Fix doc string accordingly.
Kim F. Storm <storm@cua.dk>
parents: 49614
diff changeset
2902 (setq dir
78ad1c52e368 (ido-mode): Remove unused NOBIND arg. Fix doc string accordingly.
Kim F. Storm <storm@cua.dk>
parents: 49614
diff changeset
2903 (read-string (concat "Make directory: " ido-current-directory) ido-text))))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2904 (when (> (length dir) 0)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2905 (setq dir (concat ido-current-directory dir))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2906 (unless (file-exists-p dir)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2907 (make-directory dir t)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2908 (ido-set-current-directory dir)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2909 (setq ido-exit 'refresh)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2910 (setq ido-text-init nil)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2911 (setq ido-rotate-temp t)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2912 (exit-minibuffer))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2913
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2914 (defun ido-get-work-file (incr)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2915 (let ((n (length ido-work-file-list))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2916 (i (+ ido-work-file-index incr))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2917 name)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2918 (if (> incr 0)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2919 (if (>= i n) (setq i 0))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2920 (if (< i 0) (setq i (1- n))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2921 (setq name (nth i ido-work-file-list))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2922 (setq ido-work-file-index i)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2923 name))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2924
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2925 (defun ido-prev-work-file ()
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2926 "Change to next working file name in list."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2927 (interactive)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2928 (let ((name (ido-get-work-file 1)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2929 (when name
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2930 (setq ido-text-init name)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2931 (setq ido-exit 'refresh)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2932 (exit-minibuffer))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2933
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2934 (defun ido-next-work-file ()
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2935 "Change to previous working file name in list."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2936 (interactive)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2937 (let ((name (ido-get-work-file -1)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2938 (when name
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2939 (setq ido-text-init name)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2940 (setq ido-exit 'refresh)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2941 (exit-minibuffer))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2942
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2943 (defun ido-copy-current-file-name (all)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2944 "Insert file name of current buffer.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2945 If repeated, insert text from buffer instead."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2946 (interactive "P")
71803
d35d3efc3d99 (ido-copy-current-file-name): Use buffer-name if buffer-file-name is nil.
Kim F. Storm <storm@cua.dk>
parents: 71275
diff changeset
2947 (let* ((bfname (or (buffer-file-name ido-entry-buffer)
d35d3efc3d99 (ido-copy-current-file-name): Use buffer-name if buffer-file-name is nil.
Kim F. Storm <storm@cua.dk>
parents: 71275
diff changeset
2948 (buffer-name ido-entry-buffer)))
49235
beca89eeabb3 (ido-read-internal, ido-file-internal)
Kim F. Storm <storm@cua.dk>
parents: 49233
diff changeset
2949 (name (and bfname (file-name-nondirectory bfname))))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2950 (when name
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
2951 (setq ido-text-init
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
2952 (if (or all
71271
29fa87029ede (ido-copy-current-file-name): Repeating C-w inserts whole file name.
Kim F. Storm <storm@cua.dk>
parents: 71269
diff changeset
2953 (eq last-command this-command)
49235
beca89eeabb3 (ido-read-internal, ido-file-internal)
Kim F. Storm <storm@cua.dk>
parents: 49233
diff changeset
2954 (not (equal (file-name-directory bfname) ido-current-directory))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2955 (not (string-match "\\.[^.]*\\'" name)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2956 name
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2957 (substring name 0 (1+ (match-beginning 0)))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2958 (setq ido-exit 'refresh
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2959 ido-try-merged-list nil)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2960 (exit-minibuffer))))
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
2961
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2962 (defun ido-copy-current-word (all)
49208
5a945cb7d742 (ido-ignore-directories-merge): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 49180
diff changeset
2963 "Insert current word (file or directory name) from current buffer."
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2964 (interactive "P")
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2965 (let ((word (save-excursion
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2966 (set-buffer ido-entry-buffer)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2967 (let ((p (point)) start-line end-line start-name name)
73985
5783c1198e3b (ido-copy-current-word): C-o copies region if active.
Kim F. Storm <storm@cua.dk>
parents: 73909
diff changeset
2968 (if (and mark-active (/= p (mark)))
5783c1198e3b (ido-copy-current-word): C-o copies region if active.
Kim F. Storm <storm@cua.dk>
parents: 73909
diff changeset
2969 (setq start-name (mark))
5783c1198e3b (ido-copy-current-word): C-o copies region if active.
Kim F. Storm <storm@cua.dk>
parents: 73909
diff changeset
2970 (beginning-of-line)
5783c1198e3b (ido-copy-current-word): C-o copies region if active.
Kim F. Storm <storm@cua.dk>
parents: 73909
diff changeset
2971 (setq start-line (point))
5783c1198e3b (ido-copy-current-word): C-o copies region if active.
Kim F. Storm <storm@cua.dk>
parents: 73909
diff changeset
2972 (end-of-line)
5783c1198e3b (ido-copy-current-word): C-o copies region if active.
Kim F. Storm <storm@cua.dk>
parents: 73909
diff changeset
2973 (setq end-line (point))
5783c1198e3b (ido-copy-current-word): C-o copies region if active.
Kim F. Storm <storm@cua.dk>
parents: 73909
diff changeset
2974 (goto-char p)
5783c1198e3b (ido-copy-current-word): C-o copies region if active.
Kim F. Storm <storm@cua.dk>
parents: 73909
diff changeset
2975 (if (re-search-backward "[^-_a-zA-Z0-9:./\\~@]" start-line 1)
5783c1198e3b (ido-copy-current-word): C-o copies region if active.
Kim F. Storm <storm@cua.dk>
parents: 73909
diff changeset
2976 (forward-char 1))
5783c1198e3b (ido-copy-current-word): C-o copies region if active.
Kim F. Storm <storm@cua.dk>
parents: 73909
diff changeset
2977 (setq start-name (point))
5783c1198e3b (ido-copy-current-word): C-o copies region if active.
Kim F. Storm <storm@cua.dk>
parents: 73909
diff changeset
2978 (re-search-forward "[-_a-zA-Z0-9:./\\~@]*" end-line 1)
5783c1198e3b (ido-copy-current-word): C-o copies region if active.
Kim F. Storm <storm@cua.dk>
parents: 73909
diff changeset
2979 (if (= start-name (point))
5783c1198e3b (ido-copy-current-word): C-o copies region if active.
Kim F. Storm <storm@cua.dk>
parents: 73909
diff changeset
2980 (setq start-name nil)))
5783c1198e3b (ido-copy-current-word): C-o copies region if active.
Kim F. Storm <storm@cua.dk>
parents: 73909
diff changeset
2981 (and start-name
5783c1198e3b (ido-copy-current-word): C-o copies region if active.
Kim F. Storm <storm@cua.dk>
parents: 73909
diff changeset
2982 (buffer-substring-no-properties start-name (point)))))))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2983 (if (cond
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2984 ((not word) nil)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2985 ((string-match "\\`[~/]" word)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2986 (setq ido-text-init word
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2987 ido-try-merged-list nil
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2988 ido-exit 'chdir))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2989 ((string-match "/" word)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2990 (setq ido-text-init (concat ido-current-directory word)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2991 ido-try-merged-list nil
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2992 ido-exit 'chdir))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2993 (t
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2994 (setq ido-text-init word
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2995 ido-try-merged-list nil
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2996 ido-exit 'refresh)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2997 (exit-minibuffer))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
2998
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
2999 (defun ido-next-match ()
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3000 "Put first element of `ido-matches' at the end of the list."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3001 (interactive)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3002 (if ido-matches
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3003 (let ((next (cadr ido-matches)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3004 (setq ido-cur-list (ido-chop ido-cur-list next))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3005 (setq ido-rescan t)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3006 (setq ido-rotate t))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3007
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
3008 (defun ido-prev-match ()
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3009 "Put last element of `ido-matches' at the front of the list."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3010 (interactive)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3011 (if ido-matches
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3012 (let ((prev (car (last ido-matches))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3013 (setq ido-cur-list (ido-chop ido-cur-list prev))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3014 (setq ido-rescan t)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3015 (setq ido-rotate t))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3016
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
3017 (defun ido-next-match-dir ()
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3018 "Find next directory in match list.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3019 If work directories have been merged, cycle through directories for
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3020 first matching file."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3021 (interactive)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3022 (if ido-use-merged-list
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3023 (if ido-matches
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3024 (let* ((elt (car ido-matches))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3025 (dirs (cdr elt)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3026 (when (> (length dirs) 1)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3027 (setcdr elt (ido-chop dirs (cadr dirs))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3028 (setq ido-rescan nil)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3029 (let ((cnt (length ido-matches))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3030 (i 1))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3031 (while (and (< i cnt) (not (ido-final-slash (nth i ido-matches))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3032 (setq i (1+ i)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3033 (if (< i cnt)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3034 (setq ido-cur-list (ido-chop ido-cur-list (nth i ido-matches)))))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3035
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
3036 (defun ido-prev-match-dir ()
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3037 "Find previous directory in match list.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3038 If work directories have been merged, cycle through directories
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3039 for first matching file."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3040 (interactive)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3041 (if ido-use-merged-list
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3042 (if ido-matches
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3043 (let* ((elt (car ido-matches))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3044 (dirs (cdr elt)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3045 (when (> (length dirs) 1)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3046 (setcdr elt (ido-chop dirs (car (last dirs)))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3047 (setq ido-rescan nil)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3048 (let* ((cnt (length ido-matches))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3049 (i (1- cnt)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3050 (while (and (> i 0) (not (ido-final-slash (nth i ido-matches))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3051 (setq i (1- i)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3052 (if (> i 0)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3053 (setq ido-cur-list (ido-chop ido-cur-list (nth i ido-matches)))))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3054
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
3055 (defun ido-restrict-to-matches ()
47977
01727f34cb9d (ido-restrict-to-matches): New command.
Kim F. Storm <storm@cua.dk>
parents: 47203
diff changeset
3056 "Set current item list to the currently matched items."
01727f34cb9d (ido-restrict-to-matches): New command.
Kim F. Storm <storm@cua.dk>
parents: 47203
diff changeset
3057 (interactive)
01727f34cb9d (ido-restrict-to-matches): New command.
Kim F. Storm <storm@cua.dk>
parents: 47203
diff changeset
3058 (when ido-matches
01727f34cb9d (ido-restrict-to-matches): New command.
Kim F. Storm <storm@cua.dk>
parents: 47203
diff changeset
3059 (setq ido-cur-list ido-matches
01727f34cb9d (ido-restrict-to-matches): New command.
Kim F. Storm <storm@cua.dk>
parents: 47203
diff changeset
3060 ido-text-init ""
01727f34cb9d (ido-restrict-to-matches): New command.
Kim F. Storm <storm@cua.dk>
parents: 47203
diff changeset
3061 ido-rescan nil
01727f34cb9d (ido-restrict-to-matches): New command.
Kim F. Storm <storm@cua.dk>
parents: 47203
diff changeset
3062 ido-exit 'keep)
01727f34cb9d (ido-restrict-to-matches): New command.
Kim F. Storm <storm@cua.dk>
parents: 47203
diff changeset
3063 (exit-minibuffer)))
01727f34cb9d (ido-restrict-to-matches): New command.
Kim F. Storm <storm@cua.dk>
parents: 47203
diff changeset
3064
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3065 (defun ido-chop (items elem)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3066 "Remove all elements before ELEM and put them at the end of ITEMS."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3067 (let ((ret nil)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3068 (next nil)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3069 (sofar nil))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3070 (while (not ret)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3071 (setq next (car items))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3072 (if (equal next elem)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3073 (setq ret (append items (nreverse sofar)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3074 ;; else
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3075 (progn
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3076 (setq items (cdr items))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3077 (setq sofar (cons next sofar)))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3078 ret))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3079
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3080 (defun ido-name (item)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3081 ;; Return file name for current item, whether in a normal list
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3082 ;; or a merged work directory list.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3083 (if (consp item) (car item) item))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3084
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3085
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3086 ;;; CREATE LIST OF ALL CURRENT FILES
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3087
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3088 (defun ido-all-completions ()
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3089 ;; Return unsorted list of all competions.
57211
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
3090 (let ((ido-process-ignore-lists nil)
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
3091 (ido-directory-too-big nil))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3092 (cond
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3093 ((eq ido-cur-item 'file)
62985
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3094 (ido-make-file-list-1 ido-current-directory))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3095 ((eq ido-cur-item 'dir)
62985
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3096 (ido-make-dir-list-1 ido-current-directory))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3097 ((eq ido-cur-item 'buffer)
62985
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3098 (ido-make-buffer-list-1))
57191
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
3099 ((eq ido-cur-item 'list)
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
3100 ido-choice-list)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3101 (t nil))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3102
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3103
59995
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3104 ;; File list sorting
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3105
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3106 (defun ido-file-lessp (a b)
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3107 ;; Simple compare two file names.
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3108 (string-lessp (ido-no-final-slash a) (ido-no-final-slash b)))
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3109
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3110
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3111 (defun ido-file-extension-lessp (a b)
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3112 ;; Compare file names according to ido-file-extensions-order list.
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3113 (let ((n (compare-strings a 0 nil b 0 nil nil))
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3114 lessp p)
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3115 (if (eq n t)
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3116 nil
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3117 (if (< n 0)
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3118 (setq n (1- (- n))
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3119 p a a b b p
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3120 lessp t)
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3121 (setq n (1- n)))
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3122 (cond
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3123 ((= n 0)
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3124 lessp)
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3125 ((= (aref a n) ?.)
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3126 (ido-file-extension-aux a b n lessp))
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3127 (t
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3128 (while (and (> n 2) (/= (aref a n) ?.))
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3129 (setq n (1- n)))
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3130 (if (> n 1)
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3131 (ido-file-extension-aux a b n lessp)
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3132 lessp))))))
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3133
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3134 (defun ido-file-extension-aux (a b n lessp)
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3135 (let ((oa (ido-file-extension-order a n))
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3136 (ob (ido-file-extension-order b n)))
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3137 (cond
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3138 ((and oa ob)
73266
acb35bee2828 (ido-file-extension-aux): Fix comparison.
Kim F. Storm <storm@cua.dk>
parents: 73260
diff changeset
3139 (cond
acb35bee2828 (ido-file-extension-aux): Fix comparison.
Kim F. Storm <storm@cua.dk>
parents: 73260
diff changeset
3140 ((= oa ob)
acb35bee2828 (ido-file-extension-aux): Fix comparison.
Kim F. Storm <storm@cua.dk>
parents: 73260
diff changeset
3141 lessp)
acb35bee2828 (ido-file-extension-aux): Fix comparison.
Kim F. Storm <storm@cua.dk>
parents: 73260
diff changeset
3142 (lessp
acb35bee2828 (ido-file-extension-aux): Fix comparison.
Kim F. Storm <storm@cua.dk>
parents: 73260
diff changeset
3143 (> oa ob))
acb35bee2828 (ido-file-extension-aux): Fix comparison.
Kim F. Storm <storm@cua.dk>
parents: 73260
diff changeset
3144 (t
acb35bee2828 (ido-file-extension-aux): Fix comparison.
Kim F. Storm <storm@cua.dk>
parents: 73260
diff changeset
3145 (< oa ob))))
59995
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3146 (oa
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3147 (not lessp))
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3148 (ob
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3149 lessp)
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3150 (t
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3151 lessp))))
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3152
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3153 (defun ido-file-extension-order (s n)
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3154 (let ((l ido-file-extensions-order)
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3155 (i 0) o do)
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3156 (while l
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3157 (cond
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3158 ((eq (car l) t)
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3159 (setq do i
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3160 l (cdr l)))
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3161 ((eq (compare-strings s n nil (car l) 0 nil nil) t)
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3162 (setq o i
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3163 l nil))
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3164 (t
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3165 (setq l (cdr l))))
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3166 (setq i (1+ i)))
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3167 (or o do)))
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3168
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3169
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3170 (defun ido-sort-merged-list (items promote)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3171 ;; Input is list of ("file" . "dir") cons cells.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3172 ;; Output is sorted list of ("file "dir" ...) lists
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3173 (let ((l (sort items (lambda (a b) (string-lessp (car b) (car a)))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3174 res a cur dirs)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3175 (while l
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3176 (setq a (car l)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3177 l (cdr l))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3178 (if (and res (string-equal (car (car res)) (car a)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3179 (progn
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3180 (setcdr (car (if cur (cdr res) res)) (cons (cdr a) (cdr (car res))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3181 (if (and promote (string-equal ido-current-directory (cdr a)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3182 (setq cur t)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3183 (setq res (cons (list (car a) (cdr a)) res)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3184 cur nil)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3185 res))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3186
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3187 (defun ido-wide-find-dirs-or-files (dir file &optional prefix finddir)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3188 ;; As ido-run-find-command, but returns a list of cons pairs ("file" . "dir")
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
3189 (let ((filenames
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
3190 (split-string
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3191 (shell-command-to-string
73260
4dce8f520712 (ido-wide-find-dirs-or-files): Use shell-quote-argument.
Kim F. Storm <storm@cua.dk>
parents: 73166
diff changeset
3192 (concat "find "
4dce8f520712 (ido-wide-find-dirs-or-files): Use shell-quote-argument.
Kim F. Storm <storm@cua.dk>
parents: 73166
diff changeset
3193 (shell-quote-argument dir)
4dce8f520712 (ido-wide-find-dirs-or-files): Use shell-quote-argument.
Kim F. Storm <storm@cua.dk>
parents: 73166
diff changeset
3194 " -name "
4dce8f520712 (ido-wide-find-dirs-or-files): Use shell-quote-argument.
Kim F. Storm <storm@cua.dk>
parents: 73166
diff changeset
3195 (shell-quote-argument
4dce8f520712 (ido-wide-find-dirs-or-files): Use shell-quote-argument.
Kim F. Storm <storm@cua.dk>
parents: 73166
diff changeset
3196 (concat (if prefix "" "*") file "*"))
4dce8f520712 (ido-wide-find-dirs-or-files): Use shell-quote-argument.
Kim F. Storm <storm@cua.dk>
parents: 73166
diff changeset
3197 " -type " (if finddir "d" "f") " -print"))))
49235
beca89eeabb3 (ido-read-internal, ido-file-internal)
Kim F. Storm <storm@cua.dk>
parents: 49233
diff changeset
3198 filename d f
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3199 res)
49235
beca89eeabb3 (ido-read-internal, ido-file-internal)
Kim F. Storm <storm@cua.dk>
parents: 49233
diff changeset
3200 (while filenames
beca89eeabb3 (ido-read-internal, ido-file-internal)
Kim F. Storm <storm@cua.dk>
parents: 49233
diff changeset
3201 (setq filename (car filenames)
beca89eeabb3 (ido-read-internal, ido-file-internal)
Kim F. Storm <storm@cua.dk>
parents: 49233
diff changeset
3202 filenames (cdr filenames))
beca89eeabb3 (ido-read-internal, ido-file-internal)
Kim F. Storm <storm@cua.dk>
parents: 49233
diff changeset
3203 (if (and (string-match "^/" filename)
beca89eeabb3 (ido-read-internal, ido-file-internal)
Kim F. Storm <storm@cua.dk>
parents: 49233
diff changeset
3204 (file-exists-p filename))
beca89eeabb3 (ido-read-internal, ido-file-internal)
Kim F. Storm <storm@cua.dk>
parents: 49233
diff changeset
3205 (setq d (file-name-directory filename)
beca89eeabb3 (ido-read-internal, ido-file-internal)
Kim F. Storm <storm@cua.dk>
parents: 49233
diff changeset
3206 f (file-name-nondirectory filename)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3207 res (cons (cons (if finddir (ido-final-slash f t) f) d) res))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3208 res))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3209
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3210 (defun ido-flatten-merged-list (items)
49208
5a945cb7d742 (ido-ignore-directories-merge): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 49180
diff changeset
3211 ;; Create a list of directory names based on a merged directory list.
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3212 (let (res)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3213 (while items
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3214 (let* ((item (car items))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3215 (file (car item))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3216 (dirs (cdr item)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3217 (while dirs
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3218 (setq res (cons (concat (car dirs) file) res)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3219 dirs (cdr dirs))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3220 (setq items (cdr items)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3221 res))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3222
62985
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3223
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3224 (defun ido-make-merged-file-list-1 (text auto wide)
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3225 (let (res)
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3226 (if (and (ido-final-slash text) ido-dir-file-cache)
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3227 (if wide
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3228 (setq res (ido-wide-find-dirs-or-files
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3229 ido-current-directory (substring text 0 -1) ido-enable-prefix t))
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3230 ;; Use list of cached directories
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3231 (let ((re (concat (regexp-quote (substring text 0 -1)) "[^/:]*/\\'"))
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3232 (dirs ido-dir-file-cache)
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3233 dir b d f)
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3234 (if nil ;; simple
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3235 (while dirs
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3236 (setq dir (car (car dirs))
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3237 dirs (cdr dirs))
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3238 (when (and (string-match re dir)
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3239 (not (ido-ignore-item-p dir ido-ignore-directories-merge))
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3240 (file-directory-p dir))
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3241 (setq b (substring dir 0 -1)
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3242 f (concat (file-name-nondirectory b) "/")
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3243 d (file-name-directory b)
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3244 res (cons (cons f d) res))))
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3245 (while dirs
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3246 (setq dir (car dirs)
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3247 d (car dir)
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3248 dirs (cdr dirs))
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3249 (when (not (ido-ignore-item-p d ido-ignore-directories-merge))
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3250 (setq dir (cdr (cdr dir)))
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3251 (while dir
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3252 (setq f (car dir)
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3253 dir (cdr dir))
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3254 (if (and (string-match re f)
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3255 (not (ido-ignore-item-p f ido-ignore-directories)))
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3256 (setq res (cons (cons f d) res)))))
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3257 (if (and auto (input-pending-p))
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3258 (setq dirs nil
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3259 res t))))))
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3260 (if wide
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3261 (setq res (ido-wide-find-dirs-or-files
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3262 ido-current-directory text ido-enable-prefix nil))
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3263 (let ((ido-text text)
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3264 (dirs ido-work-directory-list)
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3265 (must-match (and text (> (length text) 0)))
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3266 dir fl)
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3267 (if (and auto (not (member ido-current-directory dirs)))
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3268 (setq dirs (cons ido-current-directory dirs)))
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3269 (while dirs
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3270 (setq dir (car dirs)
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3271 dirs (cdr dirs))
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3272 (when (and dir (stringp dir)
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3273 (or ido-merge-ftp-work-directories
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3274 (not (ido-is-ftp-directory dir)))
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3275 (file-directory-p dir)
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3276 ;; TODO. check for nonreadable and too-big.
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3277 (setq fl (if (eq ido-cur-item 'file)
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3278 (ido-make-file-list-1 dir t)
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3279 (ido-make-dir-list-1 dir t))))
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3280 (if must-match
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3281 (setq fl (ido-set-matches-1 fl)))
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3282 (if fl
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3283 (setq res (nconc fl res))))
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3284 (if (and auto (input-pending-p))
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3285 (setq dirs nil
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3286 res t))))))
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3287 res))
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3288
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3289 (defun ido-make-merged-file-list (text auto wide)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3290 (let (res)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3291 (message "Searching for `%s'...." text)
62089
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
3292 (condition-case nil
64983
1a1aa1eae3b3 (ido-buffer-internal): Use with-no-warnings.
Kim F. Storm <storm@cua.dk>
parents: 64762
diff changeset
3293 (if (eq t (setq res
1a1aa1eae3b3 (ido-buffer-internal): Use with-no-warnings.
Kim F. Storm <storm@cua.dk>
parents: 64762
diff changeset
3294 (while-no-input
1a1aa1eae3b3 (ido-buffer-internal): Use with-no-warnings.
Kim F. Storm <storm@cua.dk>
parents: 64762
diff changeset
3295 (ido-make-merged-file-list-1 text auto wide))))
1a1aa1eae3b3 (ido-buffer-internal): Use with-no-warnings.
Kim F. Storm <storm@cua.dk>
parents: 64762
diff changeset
3296 (setq res 'input-pending-p))
62985
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3297 (quit
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3298 (setq res t
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3299 ido-try-merged-list nil
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3300 ido-use-merged-list nil)))
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3301 (when (and res (listp res))
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3302 (setq res (ido-sort-merged-list res auto)))
46257
66e7966b0b91 (ido-make-merged-file-list): Move fully matching item to head of list.
Kim F. Storm <storm@cua.dk>
parents: 46256
diff changeset
3303 (when (and (or ido-rotate-temp ido-rotate-file-list-default)
46292
712d0161e499 (ido-make-merged-file-list): Fix last change again.
Kim F. Storm <storm@cua.dk>
parents: 46280
diff changeset
3304 (listp res)
46257
66e7966b0b91 (ido-make-merged-file-list): Move fully matching item to head of list.
Kim F. Storm <storm@cua.dk>
parents: 46256
diff changeset
3305 (> (length text) 0))
66e7966b0b91 (ido-make-merged-file-list): Move fully matching item to head of list.
Kim F. Storm <storm@cua.dk>
parents: 46256
diff changeset
3306 (let ((elt (assoc text res)))
46270
c64c46b334d7 (ido-make-merged-file-list): Fix last change.
Kim F. Storm <storm@cua.dk>
parents: 46257
diff changeset
3307 (when (and elt (not (eq elt (car res))))
46257
66e7966b0b91 (ido-make-merged-file-list): Move fully matching item to head of list.
Kim F. Storm <storm@cua.dk>
parents: 46256
diff changeset
3308 (setq res (delq elt res))
66e7966b0b91 (ido-make-merged-file-list): Move fully matching item to head of list.
Kim F. Storm <storm@cua.dk>
parents: 46256
diff changeset
3309 (setq res (cons elt res)))))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3310 (message nil)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3311 res))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3312
62985
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3313 (defun ido-make-buffer-list-1 (&optional frame visible)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3314 ;; Return list of non-ignored buffer names
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
3315 (delq nil
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3316 (mapcar
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3317 (lambda (x)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3318 (let ((name (buffer-name x)))
47203
d7ff55da60cd (ido-ignore-item-temp-list): New variable.
Kim F. Storm <storm@cua.dk>
parents: 46631
diff changeset
3319 (if (not (or (ido-ignore-item-p name ido-ignore-buffers) (member name visible)))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3320 name)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3321 (buffer-list frame))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3322
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3323 (defun ido-make-buffer-list (default)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3324 ;; Return the current list of buffers.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3325 ;; Currently visible buffers are put at the end of the list.
63235
ba92543774db (ido-mode, ido-file-extensions-order, ido-default-file-method,
Juanma Barranquero <lekktu@gmail.com>
parents: 63124
diff changeset
3326 ;; The hook `ido-make-buffer-list-hook' is run after the list has been
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3327 ;; created to allow the user to further modify the order of the buffer names
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3328 ;; in this list. If DEFAULT is non-nil, and corresponds to an existing buffer,
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3329 ;; it is put to the start of the list.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3330 (let* ((ido-current-buffers (ido-get-buffers-in-frames 'current))
62985
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3331 (ido-temp-list (ido-make-buffer-list-1 (selected-frame) ido-current-buffers)))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3332 (if ido-temp-list
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3333 (nconc ido-temp-list ido-current-buffers)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3334 (setq ido-temp-list ido-current-buffers))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3335 (if default
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3336 (progn
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
3337 (setq ido-temp-list
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3338 (delete default ido-temp-list))
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
3339 (setq ido-temp-list
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3340 (cons default ido-temp-list))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3341 (run-hooks 'ido-make-buffer-list-hook)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3342 ido-temp-list))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3343
57191
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
3344 (defun ido-make-choice-list (default)
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
3345 ;; Return the current list of choices.
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
3346 ;; If DEFAULT is non-nil, and corresponds to an element of choices,
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
3347 ;; it is put to the start of the list.
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
3348 (let ((ido-temp-list ido-choice-list))
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
3349 (if default
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
3350 (progn
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
3351 (setq ido-temp-list
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
3352 (delete default ido-temp-list))
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
3353 (setq ido-temp-list
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
3354 (cons default ido-temp-list))))
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
3355 ; (run-hooks 'ido-make-choice-list-hook)
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
3356 ido-temp-list))
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
3357
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3358 (defun ido-to-end (items)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3359 ;; Move the elements from ITEMS to the end of `ido-temp-list'
84873
c62cc793efc7 (ido-to-end, ido-set-matches-1): Use `mapc' rather than `mapcar'.
Juanma Barranquero <lekktu@gmail.com>
parents: 78492
diff changeset
3360 (mapc
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
3361 (lambda (elem)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3362 (setq ido-temp-list (delq elem ido-temp-list)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3363 items)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3364 (if ido-temp-list
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3365 (nconc ido-temp-list items)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3366 (setq ido-temp-list items)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3367
87110
aad891ae9148 Remove directory part from filenames in function declarations.
Glenn Morris <rgm@gnu.org>
parents: 87046
diff changeset
3368 (declare-function tramp-tramp-file-p "tramp" (name))
86234
860a7a8e779e * progmodes/octave-mod.el (inferior-octave-send-list-and-digest):
Dan Nicolaescu <dann@ics.uci.edu>
parents: 85998
diff changeset
3369
62985
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3370 (defun ido-file-name-all-completions-1 (dir)
53323
a053c8c470f3 Handle non-readable directories.
Kim F. Storm <storm@cua.dk>
parents: 53166
diff changeset
3371 (cond
53459
4b85f31aef7c (ido-nonreadable-directory-p): New defun to check for
Kim F. Storm <storm@cua.dk>
parents: 53323
diff changeset
3372 ((ido-nonreadable-directory-p dir) '())
57211
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
3373 ;; do not check (ido-directory-too-big-p dir) here.
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
3374 ;; Caller must have done that if necessary.
66212
3a5f2ee9f30b (ido-is-tramp-root): Simplify regexp matching tramp root.
Kim F. Storm <storm@cua.dk>
parents: 65802
diff changeset
3375
53323
a053c8c470f3 Handle non-readable directories.
Kim F. Storm <storm@cua.dk>
parents: 53166
diff changeset
3376 ((and ido-enable-tramp-completion
86406
22b18b2eec8e * ido.el (ido-file-name-all-completions-1): Check for fboundp of
Michael Albinus <michael.albinus@gmx.de>
parents: 86234
diff changeset
3377 (or (fboundp 'tramp-completion-mode-p)
66212
3a5f2ee9f30b (ido-is-tramp-root): Simplify regexp matching tramp root.
Kim F. Storm <storm@cua.dk>
parents: 65802
diff changeset
3378 (require 'tramp nil t))
3a5f2ee9f30b (ido-is-tramp-root): Simplify regexp matching tramp root.
Kim F. Storm <storm@cua.dk>
parents: 65802
diff changeset
3379 (string-match "\\`/[^/]+[:@]\\'" dir))
3a5f2ee9f30b (ido-is-tramp-root): Simplify regexp matching tramp root.
Kim F. Storm <storm@cua.dk>
parents: 65802
diff changeset
3380 ;; Strip method:user@host: part of tramp completions.
3a5f2ee9f30b (ido-is-tramp-root): Simplify regexp matching tramp root.
Kim F. Storm <storm@cua.dk>
parents: 65802
diff changeset
3381 ;; Tramp completions do not include leading slash.
86406
22b18b2eec8e * ido.el (ido-file-name-all-completions-1): Check for fboundp of
Michael Albinus <michael.albinus@gmx.de>
parents: 86234
diff changeset
3382 (let* ((len (1- (length dir)))
22b18b2eec8e * ido.el (ido-file-name-all-completions-1): Check for fboundp of
Michael Albinus <michael.albinus@gmx.de>
parents: 86234
diff changeset
3383 (tramp-completion-mode t)
22b18b2eec8e * ido.el (ido-file-name-all-completions-1): Check for fboundp of
Michael Albinus <michael.albinus@gmx.de>
parents: 86234
diff changeset
3384 (compl
22b18b2eec8e * ido.el (ido-file-name-all-completions-1): Check for fboundp of
Michael Albinus <michael.albinus@gmx.de>
parents: 86234
diff changeset
3385 (or (file-name-all-completions "" dir)
22b18b2eec8e * ido.el (ido-file-name-all-completions-1): Check for fboundp of
Michael Albinus <michael.albinus@gmx.de>
parents: 86234
diff changeset
3386 ;; work around bug in ange-ftp.
22b18b2eec8e * ido.el (ido-file-name-all-completions-1): Check for fboundp of
Michael Albinus <michael.albinus@gmx.de>
parents: 86234
diff changeset
3387 ;; /ftp:user@host: => nil
22b18b2eec8e * ido.el (ido-file-name-all-completions-1): Check for fboundp of
Michael Albinus <michael.albinus@gmx.de>
parents: 86234
diff changeset
3388 ;; /ftp:user@host:./ => ok
22b18b2eec8e * ido.el (ido-file-name-all-completions-1): Check for fboundp of
Michael Albinus <michael.albinus@gmx.de>
parents: 86234
diff changeset
3389 (and
22b18b2eec8e * ido.el (ido-file-name-all-completions-1): Check for fboundp of
Michael Albinus <michael.albinus@gmx.de>
parents: 86234
diff changeset
3390 (not (string= "/ftp:" dir))
22b18b2eec8e * ido.el (ido-file-name-all-completions-1): Check for fboundp of
Michael Albinus <michael.albinus@gmx.de>
parents: 86234
diff changeset
3391 (tramp-tramp-file-p dir)
22b18b2eec8e * ido.el (ido-file-name-all-completions-1): Check for fboundp of
Michael Albinus <michael.albinus@gmx.de>
parents: 86234
diff changeset
3392 (fboundp 'tramp-ftp-file-name-p)
22b18b2eec8e * ido.el (ido-file-name-all-completions-1): Check for fboundp of
Michael Albinus <michael.albinus@gmx.de>
parents: 86234
diff changeset
3393 (funcall 'tramp-ftp-file-name-p dir)
22b18b2eec8e * ido.el (ido-file-name-all-completions-1): Check for fboundp of
Michael Albinus <michael.albinus@gmx.de>
parents: 86234
diff changeset
3394 (string-match ":\\'" dir)
22b18b2eec8e * ido.el (ido-file-name-all-completions-1): Check for fboundp of
Michael Albinus <michael.albinus@gmx.de>
parents: 86234
diff changeset
3395 (file-name-all-completions "" (concat dir "./"))))))
66212
3a5f2ee9f30b (ido-is-tramp-root): Simplify regexp matching tramp root.
Kim F. Storm <storm@cua.dk>
parents: 65802
diff changeset
3396 (if (and compl
3a5f2ee9f30b (ido-is-tramp-root): Simplify regexp matching tramp root.
Kim F. Storm <storm@cua.dk>
parents: 65802
diff changeset
3397 (> (length (car compl)) len)
3a5f2ee9f30b (ido-is-tramp-root): Simplify regexp matching tramp root.
Kim F. Storm <storm@cua.dk>
parents: 65802
diff changeset
3398 (string= (substring (car compl) 0 len) (substring dir 1)))
53323
a053c8c470f3 Handle non-readable directories.
Kim F. Storm <storm@cua.dk>
parents: 53166
diff changeset
3399 (mapcar (lambda (c) (substring c len)) compl)
a053c8c470f3 Handle non-readable directories.
Kim F. Storm <storm@cua.dk>
parents: 53166
diff changeset
3400 compl)))
a053c8c470f3 Handle non-readable directories.
Kim F. Storm <storm@cua.dk>
parents: 53166
diff changeset
3401 (t
a053c8c470f3 Handle non-readable directories.
Kim F. Storm <storm@cua.dk>
parents: 53166
diff changeset
3402 (file-name-all-completions "" dir))))
49180
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
3403
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3404 (defun ido-file-name-all-completions (dir)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3405 ;; Return name of all files in DIR
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3406 ;; Uses and updates ido-dir-file-cache
69542
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
3407 (cond
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
3408 ((ido-is-unc-root dir)
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
3409 (mapcar
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
3410 (lambda (host)
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
3411 (if (string-match "/\\'" host) host (concat host "/")))
69748
e44b79389d65 (ido-unc-hosts-cache): New defvar.
Kim F. Storm <storm@cua.dk>
parents: 69738
diff changeset
3412 (ido-unc-hosts t)))
69542
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
3413 ((and (numberp ido-max-dir-file-cache) (> ido-max-dir-file-cache 0)
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
3414 (stringp dir) (> (length dir) 0)
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
3415 (ido-may-cache-directory dir))
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
3416 (let* ((cached (assoc dir ido-dir-file-cache))
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
3417 (ctime (nth 1 cached))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3418 (ftp (ido-is-ftp-directory dir))
69542
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
3419 (unc (ido-is-unc-host dir))
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
3420 (attr (if (or ftp unc) nil (file-attributes dir)))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3421 (mtime (nth 5 attr))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3422 valid)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3423 (when cached ; should we use the cached entry ?
69542
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
3424 (cond
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
3425 (ftp
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
3426 (setq valid (and (eq (car ctime) 'ftp)
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
3427 (ido-cache-ftp-valid (cdr ctime)))))
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
3428 (unc
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
3429 (setq valid (and (eq (car ctime) 'unc)
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
3430 (ido-cache-unc-valid (cdr ctime)))))
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
3431 (t
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3432 (if attr
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3433 (setq valid (and (= (car ctime) (car mtime))
69542
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
3434 (= (car (cdr ctime)) (car (cdr mtime))))))))
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
3435 (unless valid
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
3436 (setq ido-dir-file-cache (delq cached ido-dir-file-cache)
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
3437 cached nil)))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3438 (unless cached
69542
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
3439 (cond
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
3440 (unc
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
3441 (setq mtime (cons 'unc (ido-time-stamp))))
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
3442 ((and ftp (file-readable-p dir))
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
3443 (setq mtime (cons 'ftp (ido-time-stamp)))))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3444 (if mtime
62985
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3445 (setq cached (cons dir (cons mtime (ido-file-name-all-completions-1 dir)))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3446 ido-dir-file-cache (cons cached ido-dir-file-cache)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3447 (if (> (length ido-dir-file-cache) ido-max-dir-file-cache)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3448 (setcdr (nthcdr (1- ido-max-dir-file-cache) ido-dir-file-cache) nil)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3449 (and cached
69542
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
3450 (cdr (cdr cached)))))
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
3451 (t
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
3452 (ido-file-name-all-completions-1 dir))))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3453
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3454 (defun ido-remove-cached-dir (dir)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3455 ;; Remove dir from ido-dir-file-cache
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3456 (if (and ido-dir-file-cache
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3457 (stringp dir) (> (length dir) 0))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3458 (let ((cached (assoc dir ido-dir-file-cache)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3459 (if cached
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3460 (setq ido-dir-file-cache (delq cached ido-dir-file-cache))))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3461
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3462
62985
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3463 (defun ido-make-file-list-1 (dir &optional merged)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3464 ;; Return list of non-ignored files in DIR
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3465 ;; If MERGED is non-nil, each file is cons'ed with DIR
69542
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
3466 (and (or (ido-is-tramp-root dir) (ido-is-unc-root dir)
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
3467 (file-directory-p dir))
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
3468 (delq nil
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3469 (mapcar
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3470 (lambda (name)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3471 (if (not (ido-ignore-item-p name ido-ignore-files t))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3472 (if merged (cons name dir) name)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3473 (ido-file-name-all-completions dir)))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3474
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3475 (defun ido-make-file-list (default)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3476 ;; Return the current list of files.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3477 ;; Currently visible files are put at the end of the list.
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
3478 ;; The hook `ido-make-file-list-hook' is run after the list has been
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3479 ;; created to allow the user to further modify the order of the file names
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3480 ;; in this list.
62985
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3481 (let ((ido-temp-list (ido-make-file-list-1 ido-current-directory)))
59995
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3482 (setq ido-temp-list (sort ido-temp-list
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3483 (if ido-file-extensions-order
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3484 #'ido-file-extension-lessp
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3485 #'ido-file-lessp)))
66212
3a5f2ee9f30b (ido-is-tramp-root): Simplify regexp matching tramp root.
Kim F. Storm <storm@cua.dk>
parents: 65802
diff changeset
3486 (unless (ido-is-tramp-root ido-current-directory)
3a5f2ee9f30b (ido-is-tramp-root): Simplify regexp matching tramp root.
Kim F. Storm <storm@cua.dk>
parents: 65802
diff changeset
3487 (let ((default-directory ido-current-directory))
3a5f2ee9f30b (ido-is-tramp-root): Simplify regexp matching tramp root.
Kim F. Storm <storm@cua.dk>
parents: 65802
diff changeset
3488 (ido-to-end ;; move ftp hosts and visited files to end
3a5f2ee9f30b (ido-is-tramp-root): Simplify regexp matching tramp root.
Kim F. Storm <storm@cua.dk>
parents: 65802
diff changeset
3489 (delq nil (mapcar
74337
ee9b338cccea 2006-11-30 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents: 74020
diff changeset
3490 (lambda (x) (if (or (and (string-match ".:\\'" x)
ee9b338cccea 2006-11-30 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents: 74020
diff changeset
3491 (not (ido-local-file-exists-p x)))
66212
3a5f2ee9f30b (ido-is-tramp-root): Simplify regexp matching tramp root.
Kim F. Storm <storm@cua.dk>
parents: 65802
diff changeset
3492 (and (not (ido-final-slash x))
74337
ee9b338cccea 2006-11-30 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents: 74020
diff changeset
3493 (let (file-name-handler-alist)
ee9b338cccea 2006-11-30 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents: 74020
diff changeset
3494 (get-file-buffer x)))) x))
66212
3a5f2ee9f30b (ido-is-tramp-root): Simplify regexp matching tramp root.
Kim F. Storm <storm@cua.dk>
parents: 65802
diff changeset
3495 ido-temp-list)))))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3496 (ido-to-end ;; move . files to end
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
3497 (delq nil (mapcar
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3498 (lambda (x) (if (string-equal (substring x 0 1) ".") x))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3499 ido-temp-list)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3500 (if (and default (member default ido-temp-list))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3501 (if (or ido-rotate-temp ido-rotate-file-list-default)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3502 (unless (equal default (car ido-temp-list))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3503 (let ((l ido-temp-list) k)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3504 (while (and l (cdr l) (not (equal default (car (cdr l)))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3505 (setq l (cdr l)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3506 (setq k (cdr l))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3507 (setcdr l nil)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3508 (nconc k ido-temp-list)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3509 (setq ido-temp-list k)))
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
3510 (setq ido-temp-list
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3511 (delete default ido-temp-list))
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
3512 (setq ido-temp-list
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3513 (cons default ido-temp-list))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3514 (when ido-show-dot-for-dired
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3515 (setq ido-temp-list (delete "." ido-temp-list))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3516 (setq ido-temp-list (cons "." ido-temp-list)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3517 (run-hooks 'ido-make-file-list-hook)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3518 ido-temp-list))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3519
62985
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3520 (defun ido-make-dir-list-1 (dir &optional merged)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3521 ;; Return list of non-ignored subdirs in DIR
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3522 ;; If MERGED is non-nil, each subdir is cons'ed with DIR
49180
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
3523 (and (or (ido-is-tramp-root dir) (file-directory-p dir))
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
3524 (delq nil
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3525 (mapcar
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3526 (lambda (name)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3527 (and (ido-final-slash name) (not (ido-ignore-item-p name ido-ignore-directories))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3528 (if merged (cons name dir) name)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3529 (ido-file-name-all-completions dir)))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3530
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3531 (defun ido-make-dir-list (default)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3532 ;; Return the current list of directories.
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
3533 ;; The hook `ido-make-dir-list-hook' is run after the list has been
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3534 ;; created to allow the user to further modify the order of the
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3535 ;; directory names in this list.
62985
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3536 (let ((ido-temp-list (ido-make-dir-list-1 ido-current-directory)))
59995
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3537 (setq ido-temp-list (sort ido-temp-list #'ido-file-lessp))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3538 (ido-to-end ;; move . files to end
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
3539 (delq nil (mapcar
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3540 (lambda (x) (if (string-equal (substring x 0 1) ".") x))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3541 ido-temp-list)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3542 (if (and default (member default ido-temp-list))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3543 (if (or ido-rotate-temp ido-rotate-file-list-default)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3544 (unless (equal default (car ido-temp-list))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3545 (let ((l ido-temp-list) k)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3546 (while (and l (cdr l) (not (equal default (car (cdr l)))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3547 (setq l (cdr l)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3548 (setq k (cdr l))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3549 (setcdr l nil)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3550 (nconc k ido-temp-list)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3551 (setq ido-temp-list k)))
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
3552 (setq ido-temp-list
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3553 (delete default ido-temp-list))
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
3554 (setq ido-temp-list
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3555 (cons default ido-temp-list))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3556 (setq ido-temp-list (delete "." ido-temp-list))
62089
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
3557 (unless ido-input-stack
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
3558 (setq ido-temp-list (cons "." ido-temp-list)))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3559 (run-hooks 'ido-make-dir-list-hook)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3560 ido-temp-list))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3561
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3562 ;; List of the files visible in the current frame.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3563 (defvar ido-bufs-in-frame)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3564
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3565 (defun ido-get-buffers-in-frames (&optional current)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3566 ;; Return the list of buffers that are visible in the current frame.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3567 ;; If optional argument `current' is given, restrict searching to the
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3568 ;; current frame, rather than all frames, regardless of value of
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3569 ;; `ido-all-frames'.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3570 (let ((ido-bufs-in-frame nil))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3571 (walk-windows 'ido-get-bufname nil
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
3572 (if current
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3573 nil
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3574 ido-all-frames))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3575 ido-bufs-in-frame))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3576
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3577 (defun ido-get-bufname (win)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3578 ;; Used by `ido-get-buffers-in-frames' to walk through all windows
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3579 (let ((buf (buffer-name (window-buffer win))))
47203
d7ff55da60cd (ido-ignore-item-temp-list): New variable.
Kim F. Storm <storm@cua.dk>
parents: 46631
diff changeset
3580 (unless (or (member buf ido-bufs-in-frame)
d7ff55da60cd (ido-ignore-item-temp-list): New variable.
Kim F. Storm <storm@cua.dk>
parents: 46631
diff changeset
3581 (member buf ido-ignore-item-temp-list))
d7ff55da60cd (ido-ignore-item-temp-list): New variable.
Kim F. Storm <storm@cua.dk>
parents: 46631
diff changeset
3582 ;; Only add buf if it is not already in list.
d7ff55da60cd (ido-ignore-item-temp-list): New variable.
Kim F. Storm <storm@cua.dk>
parents: 46631
diff changeset
3583 ;; This prevents same buf in two different windows being
d7ff55da60cd (ido-ignore-item-temp-list): New variable.
Kim F. Storm <storm@cua.dk>
parents: 46631
diff changeset
3584 ;; put into the list twice.
d7ff55da60cd (ido-ignore-item-temp-list): New variable.
Kim F. Storm <storm@cua.dk>
parents: 46631
diff changeset
3585 (setq ido-bufs-in-frame
d7ff55da60cd (ido-ignore-item-temp-list): New variable.
Kim F. Storm <storm@cua.dk>
parents: 46631
diff changeset
3586 (cons buf ido-bufs-in-frame)))))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3587
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3588 ;;; FIND MATCHING ITEMS
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3589
62985
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3590 (defun ido-set-matches-1 (items &optional do-full)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3591 ;; Return list of matches in items
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3592 (let* ((case-fold-search ido-case-fold)
49180
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
3593 (slash (and (not ido-enable-prefix) (ido-final-slash ido-text)))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
3594 (text (if slash (substring ido-text 0 -1) ido-text))
72488
a1eb31579f05 (ido-set-matches-1): Fix full matching for subdirs.
Kim F. Storm <storm@cua.dk>
parents: 71803
diff changeset
3595 (rex0 (if ido-enable-regexp text (regexp-quote text)))
a1eb31579f05 (ido-set-matches-1): Fix full matching for subdirs.
Kim F. Storm <storm@cua.dk>
parents: 71803
diff changeset
3596 (rexq (concat rex0 (if slash ".*/" "")))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3597 (re (if ido-enable-prefix (concat "\\`" rexq) rexq))
72488
a1eb31579f05 (ido-set-matches-1): Fix full matching for subdirs.
Kim F. Storm <storm@cua.dk>
parents: 71803
diff changeset
3598 (full-re (and do-full (not ido-enable-regexp) (not (string-match "\$\\'" rex0))
a1eb31579f05 (ido-set-matches-1): Fix full matching for subdirs.
Kim F. Storm <storm@cua.dk>
parents: 71803
diff changeset
3599 (concat "\\`" rex0 (if slash "/" "") "\\'")))
a1eb31579f05 (ido-set-matches-1): Fix full matching for subdirs.
Kim F. Storm <storm@cua.dk>
parents: 71803
diff changeset
3600 (suffix-re (and do-full slash
a1eb31579f05 (ido-set-matches-1): Fix full matching for subdirs.
Kim F. Storm <storm@cua.dk>
parents: 71803
diff changeset
3601 (not ido-enable-regexp) (not (string-match "\$\\'" rex0))
a1eb31579f05 (ido-set-matches-1): Fix full matching for subdirs.
Kim F. Storm <storm@cua.dk>
parents: 71803
diff changeset
3602 (concat rex0 "/\\'")))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3603 (prefix-re (and full-re (not ido-enable-prefix)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3604 (concat "\\`" rexq)))
57065
4bf76a50a989 (ido-enable-dot-prefix): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 56754
diff changeset
3605 (non-prefix-dot (or (not ido-enable-dot-prefix)
4bf76a50a989 (ido-enable-dot-prefix): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 56754
diff changeset
3606 (not ido-process-ignore-lists)
4bf76a50a989 (ido-enable-dot-prefix): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 56754
diff changeset
3607 ido-enable-prefix
4bf76a50a989 (ido-enable-dot-prefix): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 56754
diff changeset
3608 (= (length ido-text) 0)))
72488
a1eb31579f05 (ido-set-matches-1): Fix full matching for subdirs.
Kim F. Storm <storm@cua.dk>
parents: 71803
diff changeset
3609 full-matches suffix-matches prefix-matches matches)
63476
a02cb15bf34c 2005-06-15 Matt Hodges <MPHodges@member.fsf.org>
Kim F. Storm <storm@cua.dk>
parents: 63430
diff changeset
3610 (setq ido-incomplete-regexp nil)
a02cb15bf34c 2005-06-15 Matt Hodges <MPHodges@member.fsf.org>
Kim F. Storm <storm@cua.dk>
parents: 63430
diff changeset
3611 (condition-case error
84873
c62cc793efc7 (ido-to-end, ido-set-matches-1): Use `mapc' rather than `mapcar'.
Juanma Barranquero <lekktu@gmail.com>
parents: 78492
diff changeset
3612 (mapc
63476
a02cb15bf34c 2005-06-15 Matt Hodges <MPHodges@member.fsf.org>
Kim F. Storm <storm@cua.dk>
parents: 63430
diff changeset
3613 (lambda (item)
a02cb15bf34c 2005-06-15 Matt Hodges <MPHodges@member.fsf.org>
Kim F. Storm <storm@cua.dk>
parents: 63430
diff changeset
3614 (let ((name (ido-name item)))
72488
a1eb31579f05 (ido-set-matches-1): Fix full matching for subdirs.
Kim F. Storm <storm@cua.dk>
parents: 71803
diff changeset
3615 (if (and (or non-prefix-dot
a1eb31579f05 (ido-set-matches-1): Fix full matching for subdirs.
Kim F. Storm <storm@cua.dk>
parents: 71803
diff changeset
3616 (if (= (aref ido-text 0) ?.)
a1eb31579f05 (ido-set-matches-1): Fix full matching for subdirs.
Kim F. Storm <storm@cua.dk>
parents: 71803
diff changeset
3617 (= (aref name 0) ?.)
a1eb31579f05 (ido-set-matches-1): Fix full matching for subdirs.
Kim F. Storm <storm@cua.dk>
parents: 71803
diff changeset
3618 (/= (aref name 0) ?.)))
a1eb31579f05 (ido-set-matches-1): Fix full matching for subdirs.
Kim F. Storm <storm@cua.dk>
parents: 71803
diff changeset
3619 (string-match re name))
a1eb31579f05 (ido-set-matches-1): Fix full matching for subdirs.
Kim F. Storm <storm@cua.dk>
parents: 71803
diff changeset
3620 (cond
74926
d2cfe143b802 (ido-set-matches-1): Never put current buffer first if
Kim F. Storm <storm@cua.dk>
parents: 74654
diff changeset
3621 ((and (eq ido-cur-item 'buffer)
74930
2de62cd68677 (ido-set-matches-1): Fix last change. If default item is
Kim F. Storm <storm@cua.dk>
parents: 74926
diff changeset
3622 (or (not (stringp ido-default-item))
2de62cd68677 (ido-set-matches-1): Fix last change. If default item is
Kim F. Storm <storm@cua.dk>
parents: 74926
diff changeset
3623 (not (string= name ido-default-item)))
74926
d2cfe143b802 (ido-set-matches-1): Never put current buffer first if
Kim F. Storm <storm@cua.dk>
parents: 74654
diff changeset
3624 (string= name (buffer-name ido-entry-buffer)))
d2cfe143b802 (ido-set-matches-1): Never put current buffer first if
Kim F. Storm <storm@cua.dk>
parents: 74654
diff changeset
3625 (setq matches (cons item matches)))
72488
a1eb31579f05 (ido-set-matches-1): Fix full matching for subdirs.
Kim F. Storm <storm@cua.dk>
parents: 71803
diff changeset
3626 ((and full-re (string-match full-re name))
a1eb31579f05 (ido-set-matches-1): Fix full matching for subdirs.
Kim F. Storm <storm@cua.dk>
parents: 71803
diff changeset
3627 (setq full-matches (cons item full-matches)))
a1eb31579f05 (ido-set-matches-1): Fix full matching for subdirs.
Kim F. Storm <storm@cua.dk>
parents: 71803
diff changeset
3628 ((and suffix-re (string-match suffix-re name))
a1eb31579f05 (ido-set-matches-1): Fix full matching for subdirs.
Kim F. Storm <storm@cua.dk>
parents: 71803
diff changeset
3629 (setq suffix-matches (cons item suffix-matches)))
a1eb31579f05 (ido-set-matches-1): Fix full matching for subdirs.
Kim F. Storm <storm@cua.dk>
parents: 71803
diff changeset
3630 ((and prefix-re (string-match prefix-re name))
a1eb31579f05 (ido-set-matches-1): Fix full matching for subdirs.
Kim F. Storm <storm@cua.dk>
parents: 71803
diff changeset
3631 (setq prefix-matches (cons item prefix-matches)))
a1eb31579f05 (ido-set-matches-1): Fix full matching for subdirs.
Kim F. Storm <storm@cua.dk>
parents: 71803
diff changeset
3632 (t (setq matches (cons item matches))))))
a1eb31579f05 (ido-set-matches-1): Fix full matching for subdirs.
Kim F. Storm <storm@cua.dk>
parents: 71803
diff changeset
3633 t)
63476
a02cb15bf34c 2005-06-15 Matt Hodges <MPHodges@member.fsf.org>
Kim F. Storm <storm@cua.dk>
parents: 63430
diff changeset
3634 items)
a02cb15bf34c 2005-06-15 Matt Hodges <MPHodges@member.fsf.org>
Kim F. Storm <storm@cua.dk>
parents: 63430
diff changeset
3635 (invalid-regexp
a02cb15bf34c 2005-06-15 Matt Hodges <MPHodges@member.fsf.org>
Kim F. Storm <storm@cua.dk>
parents: 63430
diff changeset
3636 (setq ido-incomplete-regexp t
a02cb15bf34c 2005-06-15 Matt Hodges <MPHodges@member.fsf.org>
Kim F. Storm <storm@cua.dk>
parents: 63430
diff changeset
3637 ;; Consider the invalid regexp message internally as a
a02cb15bf34c 2005-06-15 Matt Hodges <MPHodges@member.fsf.org>
Kim F. Storm <storm@cua.dk>
parents: 63430
diff changeset
3638 ;; special-case single match, and handle appropriately
a02cb15bf34c 2005-06-15 Matt Hodges <MPHodges@member.fsf.org>
Kim F. Storm <storm@cua.dk>
parents: 63430
diff changeset
3639 ;; elsewhere.
a02cb15bf34c 2005-06-15 Matt Hodges <MPHodges@member.fsf.org>
Kim F. Storm <storm@cua.dk>
parents: 63430
diff changeset
3640 matches (cdr error))))
72488
a1eb31579f05 (ido-set-matches-1): Fix full matching for subdirs.
Kim F. Storm <storm@cua.dk>
parents: 71803
diff changeset
3641 (when prefix-matches
a1eb31579f05 (ido-set-matches-1): Fix full matching for subdirs.
Kim F. Storm <storm@cua.dk>
parents: 71803
diff changeset
3642 (ido-trace "prefix match" prefix-matches)
a1eb31579f05 (ido-set-matches-1): Fix full matching for subdirs.
Kim F. Storm <storm@cua.dk>
parents: 71803
diff changeset
3643 (setq matches (nconc prefix-matches matches)))
a1eb31579f05 (ido-set-matches-1): Fix full matching for subdirs.
Kim F. Storm <storm@cua.dk>
parents: 71803
diff changeset
3644 (when suffix-matches
a1eb31579f05 (ido-set-matches-1): Fix full matching for subdirs.
Kim F. Storm <storm@cua.dk>
parents: 71803
diff changeset
3645 (ido-trace "suffix match" (list text suffix-re suffix-matches))
a1eb31579f05 (ido-set-matches-1): Fix full matching for subdirs.
Kim F. Storm <storm@cua.dk>
parents: 71803
diff changeset
3646 (setq matches (nconc suffix-matches matches)))
a1eb31579f05 (ido-set-matches-1): Fix full matching for subdirs.
Kim F. Storm <storm@cua.dk>
parents: 71803
diff changeset
3647 (when full-matches
a1eb31579f05 (ido-set-matches-1): Fix full matching for subdirs.
Kim F. Storm <storm@cua.dk>
parents: 71803
diff changeset
3648 (ido-trace "full match" (list text full-re full-matches))
a1eb31579f05 (ido-set-matches-1): Fix full matching for subdirs.
Kim F. Storm <storm@cua.dk>
parents: 71803
diff changeset
3649 (setq matches (nconc full-matches matches)))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3650 (when (and (null matches)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3651 ido-enable-flex-matching
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3652 (> (length ido-text) 1)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3653 (not ido-enable-regexp))
46256
88bc5ce0674c (ido-find-common-substring): Return substring instead of t.
Kim F. Storm <storm@cua.dk>
parents: 46231
diff changeset
3654 (setq re (mapconcat #'regexp-quote (split-string ido-text "") ".*"))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3655 (if ido-enable-prefix
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3656 (setq re (concat "\\`" re)))
84873
c62cc793efc7 (ido-to-end, ido-set-matches-1): Use `mapc' rather than `mapcar'.
Juanma Barranquero <lekktu@gmail.com>
parents: 78492
diff changeset
3657 (mapc
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3658 (lambda (item)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3659 (let ((name (ido-name item)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3660 (if (string-match re name)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3661 (setq matches (cons item matches)))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3662 items))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3663 matches))
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
3664
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3665
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3666 (defun ido-set-matches ()
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3667 ;; Set `ido-matches' to the list of items matching prompt
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3668 (when ido-rescan
62985
d1cbfe7309c1 (ido-make-merged-file-list-1): New defun split from
Kim F. Storm <storm@cua.dk>
parents: 62537
diff changeset
3669 (setq ido-matches (ido-set-matches-1 (reverse ido-cur-list) (not ido-rotate))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3670 ido-rotate nil)))
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
3671
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3672 (defun ido-ignore-item-p (name re-list &optional ignore-ext)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3673 ;; Return t if the buffer or file NAME should be ignored.
47203
d7ff55da60cd (ido-ignore-item-temp-list): New variable.
Kim F. Storm <storm@cua.dk>
parents: 46631
diff changeset
3674 (or (member name ido-ignore-item-temp-list)
d7ff55da60cd (ido-ignore-item-temp-list): New variable.
Kim F. Storm <storm@cua.dk>
parents: 46631
diff changeset
3675 (and
d7ff55da60cd (ido-ignore-item-temp-list): New variable.
Kim F. Storm <storm@cua.dk>
parents: 46631
diff changeset
3676 ido-process-ignore-lists re-list
65064
ae16fdfb41ab (ido-ignore-item-p): Use save-match-data.
Kim F. Storm <storm@cua.dk>
parents: 65026
diff changeset
3677 (save-match-data
ae16fdfb41ab (ido-ignore-item-p): Use save-match-data.
Kim F. Storm <storm@cua.dk>
parents: 65026
diff changeset
3678 (let ((ext-list (and ignore-ext ido-ignore-extensions
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3679 completion-ignored-extensions))
65064
ae16fdfb41ab (ido-ignore-item-p): Use save-match-data.
Kim F. Storm <storm@cua.dk>
parents: 65026
diff changeset
3680 (case-fold-search ido-case-fold)
ae16fdfb41ab (ido-ignore-item-p): Use save-match-data.
Kim F. Storm <storm@cua.dk>
parents: 65026
diff changeset
3681 ignorep nextstr
ae16fdfb41ab (ido-ignore-item-p): Use save-match-data.
Kim F. Storm <storm@cua.dk>
parents: 65026
diff changeset
3682 (flen (length name)) slen)
ae16fdfb41ab (ido-ignore-item-p): Use save-match-data.
Kim F. Storm <storm@cua.dk>
parents: 65026
diff changeset
3683 (while ext-list
ae16fdfb41ab (ido-ignore-item-p): Use save-match-data.
Kim F. Storm <storm@cua.dk>
parents: 65026
diff changeset
3684 (setq nextstr (car ext-list))
ae16fdfb41ab (ido-ignore-item-p): Use save-match-data.
Kim F. Storm <storm@cua.dk>
parents: 65026
diff changeset
3685 (if (cond
ae16fdfb41ab (ido-ignore-item-p): Use save-match-data.
Kim F. Storm <storm@cua.dk>
parents: 65026
diff changeset
3686 ((stringp nextstr)
ae16fdfb41ab (ido-ignore-item-p): Use save-match-data.
Kim F. Storm <storm@cua.dk>
parents: 65026
diff changeset
3687 (and (>= flen (setq slen (length nextstr)))
ae16fdfb41ab (ido-ignore-item-p): Use save-match-data.
Kim F. Storm <storm@cua.dk>
parents: 65026
diff changeset
3688 (string-equal (substring name (- flen slen)) nextstr)))
72868
299c5f25649b (ido-ignore-item-p): Allow any kind of functions in ignore lists.
Kim F. Storm <storm@cua.dk>
parents: 72792
diff changeset
3689 ((functionp nextstr) (funcall nextstr name))
65064
ae16fdfb41ab (ido-ignore-item-p): Use save-match-data.
Kim F. Storm <storm@cua.dk>
parents: 65026
diff changeset
3690 (t nil))
ae16fdfb41ab (ido-ignore-item-p): Use save-match-data.
Kim F. Storm <storm@cua.dk>
parents: 65026
diff changeset
3691 (setq ignorep t
ae16fdfb41ab (ido-ignore-item-p): Use save-match-data.
Kim F. Storm <storm@cua.dk>
parents: 65026
diff changeset
3692 ext-list nil
ae16fdfb41ab (ido-ignore-item-p): Use save-match-data.
Kim F. Storm <storm@cua.dk>
parents: 65026
diff changeset
3693 re-list nil)
ae16fdfb41ab (ido-ignore-item-p): Use save-match-data.
Kim F. Storm <storm@cua.dk>
parents: 65026
diff changeset
3694 (setq ext-list (cdr ext-list))))
ae16fdfb41ab (ido-ignore-item-p): Use save-match-data.
Kim F. Storm <storm@cua.dk>
parents: 65026
diff changeset
3695 (while re-list
ae16fdfb41ab (ido-ignore-item-p): Use save-match-data.
Kim F. Storm <storm@cua.dk>
parents: 65026
diff changeset
3696 (setq nextstr (car re-list))
ae16fdfb41ab (ido-ignore-item-p): Use save-match-data.
Kim F. Storm <storm@cua.dk>
parents: 65026
diff changeset
3697 (if (cond
ae16fdfb41ab (ido-ignore-item-p): Use save-match-data.
Kim F. Storm <storm@cua.dk>
parents: 65026
diff changeset
3698 ((stringp nextstr) (string-match nextstr name))
72868
299c5f25649b (ido-ignore-item-p): Allow any kind of functions in ignore lists.
Kim F. Storm <storm@cua.dk>
parents: 72792
diff changeset
3699 ((functionp nextstr) (funcall nextstr name))
65064
ae16fdfb41ab (ido-ignore-item-p): Use save-match-data.
Kim F. Storm <storm@cua.dk>
parents: 65026
diff changeset
3700 (t nil))
ae16fdfb41ab (ido-ignore-item-p): Use save-match-data.
Kim F. Storm <storm@cua.dk>
parents: 65026
diff changeset
3701 (setq ignorep t
ae16fdfb41ab (ido-ignore-item-p): Use save-match-data.
Kim F. Storm <storm@cua.dk>
parents: 65026
diff changeset
3702 re-list nil)
ae16fdfb41ab (ido-ignore-item-p): Use save-match-data.
Kim F. Storm <storm@cua.dk>
parents: 65026
diff changeset
3703 (setq re-list (cdr re-list))))
ae16fdfb41ab (ido-ignore-item-p): Use save-match-data.
Kim F. Storm <storm@cua.dk>
parents: 65026
diff changeset
3704 ;; return the result
ae16fdfb41ab (ido-ignore-item-p): Use save-match-data.
Kim F. Storm <storm@cua.dk>
parents: 65026
diff changeset
3705 (if ignorep
ae16fdfb41ab (ido-ignore-item-p): Use save-match-data.
Kim F. Storm <storm@cua.dk>
parents: 65026
diff changeset
3706 (setq ido-ignored-list (cons name ido-ignored-list)))
ae16fdfb41ab (ido-ignore-item-p): Use save-match-data.
Kim F. Storm <storm@cua.dk>
parents: 65026
diff changeset
3707 ignorep)))))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3708
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3709 ;; Private variable used by `ido-word-matching-substring'.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3710 (defvar ido-change-word-sub)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3711
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3712 (defun ido-find-common-substring (items subs)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3713 ;; Return common string following SUBS in each element of ITEMS.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3714 (let (res
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3715 alist
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3716 ido-change-word-sub)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3717 (setq ido-change-word-sub
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3718 (if ido-enable-regexp
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3719 subs
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3720 (regexp-quote subs)))
46256
88bc5ce0674c (ido-find-common-substring): Return substring instead of t.
Kim F. Storm <storm@cua.dk>
parents: 46231
diff changeset
3721 (setq res (mapcar #'ido-word-matching-substring items))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3722 (setq res (delq nil res)) ;; remove any nil elements (shouldn't happen)
46256
88bc5ce0674c (ido-find-common-substring): Return substring instead of t.
Kim F. Storm <storm@cua.dk>
parents: 46231
diff changeset
3723 (setq alist (mapcar #'ido-makealist res)) ;; could use an OBARRAY
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3724
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3725 ;; try-completion returns t if there is an exact match.
46256
88bc5ce0674c (ido-find-common-substring): Return substring instead of t.
Kim F. Storm <storm@cua.dk>
parents: 46231
diff changeset
3726 (let* ((completion-ignore-case ido-case-fold)
88bc5ce0674c (ido-find-common-substring): Return substring instead of t.
Kim F. Storm <storm@cua.dk>
parents: 46231
diff changeset
3727 (comp (try-completion subs alist)))
88bc5ce0674c (ido-find-common-substring): Return substring instead of t.
Kim F. Storm <storm@cua.dk>
parents: 46231
diff changeset
3728 (if (eq comp t)
88bc5ce0674c (ido-find-common-substring): Return substring instead of t.
Kim F. Storm <storm@cua.dk>
parents: 46231
diff changeset
3729 subs
88bc5ce0674c (ido-find-common-substring): Return substring instead of t.
Kim F. Storm <storm@cua.dk>
parents: 46231
diff changeset
3730 comp))))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3731
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3732 (defun ido-word-matching-substring (word)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3733 ;; Return part of WORD before 1st match to `ido-change-word-sub'.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3734 ;; If `ido-change-word-sub' cannot be found in WORD, return nil.
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
3735 (let ((case-fold-search ido-case-fold))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3736 (let ((m (string-match ido-change-word-sub (ido-name word))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3737 (if m
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3738 (substring (ido-name word) m)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3739 ;; else no match
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3740 nil))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3741
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3742 (defun ido-makealist (res)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3743 ;; Return dotted pair (RES . 1).
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3744 (cons res 1))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3745
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3746 (defun ido-choose-completion-string (choice buffer mini-p base-size)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3747 (when (ido-active)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3748 ;; Insert the completion into the buffer where completion was requested.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3749 (if (get-buffer ido-completion-buffer)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3750 (kill-buffer ido-completion-buffer))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3751 (cond
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3752 ((ido-active t) ;; ido-use-merged-list
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3753 (setq ido-current-directory ""
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3754 ido-text choice
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3755 ido-exit 'done))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3756 ((not (ido-final-slash choice))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3757 (setq ido-text choice
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3758 ido-exit 'done))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3759 (t
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3760 (ido-set-current-directory ido-current-directory choice)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3761 (setq ido-exit 'refresh)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3762 (exit-minibuffer)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3763 t))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3764
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3765 (defun ido-completion-help ()
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3766 "Show possible completions in a *File Completions* buffer."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3767 (interactive)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3768 (setq ido-rescan nil)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3769 (let ((temp-buf (get-buffer ido-completion-buffer))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3770 display-it full-list)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3771 (if (and (eq last-command this-command) temp-buf)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3772 ;; scroll buffer
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3773 (let (win (buf (current-buffer)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3774 (display-buffer temp-buf nil nil)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3775 (set-buffer temp-buf)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3776 (setq win (get-buffer-window temp-buf))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3777 (if (pos-visible-in-window-p (point-max) win)
74652
ffe7cd324841 (ido-completion-help): Build ido-cur-list and ido-matches
Kim F. Storm <storm@cua.dk>
parents: 74584
diff changeset
3778 (if (or ido-completion-buffer-all-completions
ffe7cd324841 (ido-completion-help): Build ido-cur-list and ido-matches
Kim F. Storm <storm@cua.dk>
parents: 74584
diff changeset
3779 (boundp 'ido-completion-buffer-full))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3780 (set-window-start win (point-min))
62089
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
3781 (with-no-warnings
e002770fe3ac (ido-setup-hook): New hook.
Kim F. Storm <storm@cua.dk>
parents: 62051
diff changeset
3782 (set (make-local-variable 'ido-completion-buffer-full) t))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3783 (setq full-list t
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3784 display-it t))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3785 (scroll-other-window))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3786 (set-buffer buf))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3787 (setq display-it t))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3788 (if display-it
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3789 (with-output-to-temp-buffer ido-completion-buffer
59995
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3790 (let ((completion-list (sort
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3791 (cond
74652
ffe7cd324841 (ido-completion-help): Build ido-cur-list and ido-matches
Kim F. Storm <storm@cua.dk>
parents: 74584
diff changeset
3792 (ido-directory-too-big
74654
a82d50e19590 (ido-toggle-ignore, ido-completion-help): Print message while
Kim F. Storm <storm@cua.dk>
parents: 74652
diff changeset
3793 (message "Reading directory...")
74652
ffe7cd324841 (ido-completion-help): Build ido-cur-list and ido-matches
Kim F. Storm <storm@cua.dk>
parents: 74584
diff changeset
3794 (setq ido-directory-too-big nil
ffe7cd324841 (ido-completion-help): Build ido-cur-list and ido-matches
Kim F. Storm <storm@cua.dk>
parents: 74584
diff changeset
3795 ido-ignored-list nil
ffe7cd324841 (ido-completion-help): Build ido-cur-list and ido-matches
Kim F. Storm <storm@cua.dk>
parents: 74584
diff changeset
3796 ido-cur-list (ido-all-completions)
ffe7cd324841 (ido-completion-help): Build ido-cur-list and ido-matches
Kim F. Storm <storm@cua.dk>
parents: 74584
diff changeset
3797 ido-rescan t)
ffe7cd324841 (ido-completion-help): Build ido-cur-list and ido-matches
Kim F. Storm <storm@cua.dk>
parents: 74584
diff changeset
3798 (ido-set-matches)
ffe7cd324841 (ido-completion-help): Build ido-cur-list and ido-matches
Kim F. Storm <storm@cua.dk>
parents: 74584
diff changeset
3799 (or ido-matches ido-cur-list))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3800 (ido-use-merged-list
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3801 (ido-flatten-merged-list (or ido-matches ido-cur-list)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3802 ((or full-list ido-completion-buffer-all-completions)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3803 (ido-all-completions))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3804 (t
59995
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3805 (copy-sequence (or ido-matches ido-cur-list))))
8f4938738427 (ido-file-extensions-order): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 58458
diff changeset
3806 #'ido-file-lessp)))
48559
f694cedb78e4 (ido-xemacs): Remove defvar. All uses changed to
Kim F. Storm <storm@cua.dk>
parents: 48108
diff changeset
3807 (if (featurep 'xemacs)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3808 ;; XEmacs extents are put on by default, doesn't seem to be
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3809 ;; any way of switching them off.
46333
a86a0859521a Comment change.
Richard M. Stallman <rms@gnu.org>
parents: 46292
diff changeset
3810 ;; This obscure code avoids a byte compiler warning in Emacs.
46225
172a10dd044b Changed xemacs specific code to avoid byte compiler warning in GNU
Kim F. Storm <storm@cua.dk>
parents: 46118
diff changeset
3811 (let ((f 'display-completion-list))
172a10dd044b Changed xemacs specific code to avoid byte compiler warning in GNU
Kim F. Storm <storm@cua.dk>
parents: 46118
diff changeset
3812 (funcall f completion-list
172a10dd044b Changed xemacs specific code to avoid byte compiler warning in GNU
Kim F. Storm <storm@cua.dk>
parents: 46118
diff changeset
3813 :help-string "ido "
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
3814 :activate-callback
73825
36f23fcd07f8 (ido-ignore-extensions, ido-show-dot-for-dired, ido-max-dir-file-cache,
Juanma Barranquero <lekktu@gmail.com>
parents: 73388
diff changeset
3815 '(lambda (x y z) (message "Doesn't work yet, sorry!"))))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3816 ;; else running Emacs
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3817 ;;(add-hook 'completion-setup-hook 'completion-setup-function)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3818 (display-completion-list completion-list)))))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3819
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3820 ;;; KILL CURRENT BUFFER
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3821 (defun ido-kill-buffer-at-head ()
75391
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
3822 "Kill the buffer at the head of `ido-matches'.
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
3823 If cursor is not at the end of the user input, delete to end of input."
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3824 (interactive)
75391
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
3825 (if (not (eobp))
77400
ba8b19b89247 (ido-kill-buffer-at-head, ido-delete-file-at-head):
Kim F. Storm <storm@cua.dk>
parents: 76795
diff changeset
3826 (delete-region (point) (line-end-position))
75391
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
3827 (let ((enable-recursive-minibuffers t)
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
3828 (buf (ido-name (car ido-matches))))
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
3829 (when buf
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
3830 (kill-buffer buf)
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
3831 ;; Check if buffer still exists.
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
3832 (if (get-buffer buf)
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
3833 ;; buffer couldn't be killed.
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
3834 (setq ido-rescan t)
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
3835 ;; else buffer was killed so remove name from list.
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
3836 (setq ido-cur-list (delq buf ido-cur-list)))))))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3837
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3838 ;;; DELETE CURRENT FILE
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3839 (defun ido-delete-file-at-head ()
75391
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
3840 "Delete the file at the head of `ido-matches'.
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
3841 If cursor is not at the end of the user input, delete to end of input."
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3842 (interactive)
75391
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
3843 (if (not (eobp))
77400
ba8b19b89247 (ido-kill-buffer-at-head, ido-delete-file-at-head):
Kim F. Storm <storm@cua.dk>
parents: 76795
diff changeset
3844 (delete-region (point) (line-end-position))
75391
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
3845 (let ((enable-recursive-minibuffers t)
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
3846 (file (ido-name (car ido-matches))))
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
3847 (if file
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
3848 (setq file (concat ido-current-directory file)))
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
3849 (when (and file
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
3850 (file-exists-p file)
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
3851 (not (file-directory-p file))
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
3852 (file-writable-p ido-current-directory)
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
3853 (yes-or-no-p (concat "Delete " file "? ")))
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
3854 (delete-file file)
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
3855 ;; Check if file still exists.
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
3856 (if (file-exists-p file)
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
3857 ;; file could not be deleted
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
3858 (setq ido-rescan t)
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
3859 ;; else file was killed so remove name from list.
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
3860 (setq ido-cur-list (delq (car ido-matches) ido-cur-list)))))))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3861
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3862
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3863 ;;; VISIT CHOSEN BUFFER
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3864 (defun ido-visit-buffer (buffer method &optional record)
71240
0b7ea03b3bcd (ido-default-file-method, ido-default-buffer-method):
Kim F. Storm <storm@cua.dk>
parents: 70797
diff changeset
3865 "Switch to BUFFER according to METHOD.
63235
ba92543774db (ido-mode, ido-file-extensions-order, ido-default-file-method,
Juanma Barranquero <lekktu@gmail.com>
parents: 63124
diff changeset
3866 Record command in `command-history' if optional RECORD is non-nil."
72656
5d8f8bf05df4 (ido-visit-buffer): Use buffer name if buffer arg is a buffer.
Kim F. Storm <storm@cua.dk>
parents: 72488
diff changeset
3867 (if (bufferp buffer)
5d8f8bf05df4 (ido-visit-buffer): Use buffer name if buffer arg is a buffer.
Kim F. Storm <storm@cua.dk>
parents: 72488
diff changeset
3868 (setq buffer (buffer-name buffer)))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3869 (let (win newframe)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3870 (cond
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3871 ((eq method 'kill)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3872 (if record
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3873 (ido-record-command 'kill-buffer buffer))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3874 (kill-buffer buffer))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3875
71240
0b7ea03b3bcd (ido-default-file-method, ido-default-buffer-method):
Kim F. Storm <storm@cua.dk>
parents: 70797
diff changeset
3876 ((eq method 'other-window)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3877 (if record
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3878 (ido-record-command 'switch-to-buffer buffer))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3879 (switch-to-buffer-other-window buffer))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3880
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3881 ((eq method 'display)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3882 (display-buffer buffer))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3883
71240
0b7ea03b3bcd (ido-default-file-method, ido-default-buffer-method):
Kim F. Storm <storm@cua.dk>
parents: 70797
diff changeset
3884 ((eq method 'other-frame)
48559
f694cedb78e4 (ido-xemacs): Remove defvar. All uses changed to
Kim F. Storm <storm@cua.dk>
parents: 48108
diff changeset
3885 (switch-to-buffer-other-frame buffer)
71240
0b7ea03b3bcd (ido-default-file-method, ido-default-buffer-method):
Kim F. Storm <storm@cua.dk>
parents: 70797
diff changeset
3886 (select-frame-set-input-focus (selected-frame)))
0b7ea03b3bcd (ido-default-file-method, ido-default-buffer-method):
Kim F. Storm <storm@cua.dk>
parents: 70797
diff changeset
3887
0b7ea03b3bcd (ido-default-file-method, ido-default-buffer-method):
Kim F. Storm <storm@cua.dk>
parents: 70797
diff changeset
3888 ((and (memq method '(raise-frame maybe-frame))
0b7ea03b3bcd (ido-default-file-method, ido-default-buffer-method):
Kim F. Storm <storm@cua.dk>
parents: 70797
diff changeset
3889 window-system
0b7ea03b3bcd (ido-default-file-method, ido-default-buffer-method):
Kim F. Storm <storm@cua.dk>
parents: 70797
diff changeset
3890 (setq win (ido-buffer-window-other-frame buffer))
0b7ea03b3bcd (ido-default-file-method, ido-default-buffer-method):
Kim F. Storm <storm@cua.dk>
parents: 70797
diff changeset
3891 (or (eq method 'raise-frame)
0b7ea03b3bcd (ido-default-file-method, ido-default-buffer-method):
Kim F. Storm <storm@cua.dk>
parents: 70797
diff changeset
3892 (y-or-n-p "Jump to frame? ")))
0b7ea03b3bcd (ido-default-file-method, ido-default-buffer-method):
Kim F. Storm <storm@cua.dk>
parents: 70797
diff changeset
3893 (setq newframe (window-frame win))
0b7ea03b3bcd (ido-default-file-method, ido-default-buffer-method):
Kim F. Storm <storm@cua.dk>
parents: 70797
diff changeset
3894 (select-frame-set-input-focus newframe)
0b7ea03b3bcd (ido-default-file-method, ido-default-buffer-method):
Kim F. Storm <storm@cua.dk>
parents: 70797
diff changeset
3895 (select-window win))
0b7ea03b3bcd (ido-default-file-method, ido-default-buffer-method):
Kim F. Storm <storm@cua.dk>
parents: 70797
diff changeset
3896
0b7ea03b3bcd (ido-default-file-method, ido-default-buffer-method):
Kim F. Storm <storm@cua.dk>
parents: 70797
diff changeset
3897 ;; (eq method 'selected-window)
0b7ea03b3bcd (ido-default-file-method, ido-default-buffer-method):
Kim F. Storm <storm@cua.dk>
parents: 70797
diff changeset
3898 (t
0b7ea03b3bcd (ido-default-file-method, ido-default-buffer-method):
Kim F. Storm <storm@cua.dk>
parents: 70797
diff changeset
3899 ;; No buffer in other frames...
0b7ea03b3bcd (ido-default-file-method, ido-default-buffer-method):
Kim F. Storm <storm@cua.dk>
parents: 70797
diff changeset
3900 (if record
0b7ea03b3bcd (ido-default-file-method, ido-default-buffer-method):
Kim F. Storm <storm@cua.dk>
parents: 70797
diff changeset
3901 (ido-record-command 'switch-to-buffer buffer))
0b7ea03b3bcd (ido-default-file-method, ido-default-buffer-method):
Kim F. Storm <storm@cua.dk>
parents: 70797
diff changeset
3902 (switch-to-buffer buffer)
48559
f694cedb78e4 (ido-xemacs): Remove defvar. All uses changed to
Kim F. Storm <storm@cua.dk>
parents: 48108
diff changeset
3903 ))))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3904
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3905
71240
0b7ea03b3bcd (ido-default-file-method, ido-default-buffer-method):
Kim F. Storm <storm@cua.dk>
parents: 70797
diff changeset
3906 (defun ido-buffer-window-other-frame (buffer)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3907 ;; Return window pointer if BUFFER is visible in another frame.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3908 ;; If BUFFER is visible in the current frame, return nil.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3909 (let ((blist (ido-get-buffers-in-frames 'current)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3910 ;;If the buffer is visible in current frame, return nil
47203
d7ff55da60cd (ido-ignore-item-temp-list): New variable.
Kim F. Storm <storm@cua.dk>
parents: 46631
diff changeset
3911 (if (member buffer blist)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3912 nil
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3913 ;; maybe in other frame or icon
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3914 (get-buffer-window buffer 0) ; better than 'visible
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3915 )))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3916
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3917
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3918 ;;; ----------- IDONIZED FUNCTIONS ------------
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3919
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3920 ;;;###autoload
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3921 (defun ido-switch-buffer ()
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3922 "Switch to another buffer.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3923 The buffer is displayed according to `ido-default-buffer-method' -- the
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3924 default is to show it in the same window, unless it is already visible
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3925 in another frame.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3926
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3927 As you type in a string, all of the buffers matching the string are
69733
156c18d0fca4 (ido-cache-unc-host-shares-time, ido-max-work-file-list, ido-switch-buffer):
Juanma Barranquero <lekktu@gmail.com>
parents: 69542
diff changeset
3928 displayed if substring-matching is used \(default). Look at
63235
ba92543774db (ido-mode, ido-file-extensions-order, ido-default-file-method,
Juanma Barranquero <lekktu@gmail.com>
parents: 63124
diff changeset
3929 `ido-enable-prefix' and `ido-toggle-prefix'. When you have found the
ba92543774db (ido-mode, ido-file-extensions-order, ido-default-file-method,
Juanma Barranquero <lekktu@gmail.com>
parents: 63124
diff changeset
3930 buffer you want, it can then be selected. As you type, most keys have
67362
ca155a6d12ad (ido-completion-map): Renamed from ido-mode-map.
Kim F. Storm <storm@cua.dk>
parents: 67141
diff changeset
3931 their normal keybindings, except for the following: \\<ido-buffer-completion-map>
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3932
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3933 RET Select the buffer at the front of the list of matches. If the
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3934 list is empty, possibly prompt to create new buffer.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3935
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3936 \\[ido-select-text] Select the current prompt as the buffer.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3937 If no buffer is found, prompt for a new one.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3938
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3939 \\[ido-next-match] Put the first element at the end of the list.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3940 \\[ido-prev-match] Put the last element at the start of the list.
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
3941 \\[ido-complete] Complete a common suffix to the current string that
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3942 matches all buffers. If there is only one match, select that buffer.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3943 If there is no common suffix, show a list of all matching buffers
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3944 in a separate window.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3945 \\[ido-edit-input] Edit input string.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3946 \\[ido-fallback-command] Fallback to non-ido version of current command.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3947 \\[ido-toggle-regexp] Toggle regexp searching.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3948 \\[ido-toggle-prefix] Toggle between substring and prefix matching.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3949 \\[ido-toggle-case] Toggle case-sensitive searching of buffer names.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3950 \\[ido-completion-help] Show list of matching buffers in separate window.
69738
0bfe57fe99ed (ido-report-no-match, ido-switch-buffer,
Juanma Barranquero <lekktu@gmail.com>
parents: 69733
diff changeset
3951 \\[ido-enter-find-file] Drop into `ido-find-file'.
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3952 \\[ido-kill-buffer-at-head] Kill buffer at head of buffer list.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3953 \\[ido-toggle-ignore] Toggle ignoring buffers listed in `ido-ignore-buffers'."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3954 (interactive)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3955 (ido-buffer-internal ido-default-buffer-method))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3956
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3957 ;;;###autoload
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3958 (defun ido-switch-buffer-other-window ()
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3959 "Switch to another buffer and show it in another window.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3960 The buffer name is selected interactively by typing a substring.
75686
514805720b93 Doc fixes.
Kim F. Storm <storm@cua.dk>
parents: 75573
diff changeset
3961 For details of keybindings, see `ido-switch-buffer'."
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3962 (interactive)
71240
0b7ea03b3bcd (ido-default-file-method, ido-default-buffer-method):
Kim F. Storm <storm@cua.dk>
parents: 70797
diff changeset
3963 (ido-buffer-internal 'other-window 'switch-to-buffer-other-window))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3964
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3965 ;;;###autoload
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3966 (defun ido-display-buffer ()
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3967 "Display a buffer in another window but don't select it.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3968 The buffer name is selected interactively by typing a substring.
75686
514805720b93 Doc fixes.
Kim F. Storm <storm@cua.dk>
parents: 75573
diff changeset
3969 For details of keybindings, see `ido-switch-buffer'."
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3970 (interactive)
57191
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
3971 (ido-buffer-internal 'display 'display-buffer nil nil nil 'ignore))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3972
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3973 ;;;###autoload
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3974 (defun ido-kill-buffer ()
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3975 "Kill a buffer.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3976 The buffer name is selected interactively by typing a substring.
75686
514805720b93 Doc fixes.
Kim F. Storm <storm@cua.dk>
parents: 75573
diff changeset
3977 For details of keybindings, see `ido-switch-buffer'."
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3978 (interactive)
57191
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
3979 (ido-buffer-internal 'kill 'kill-buffer "Kill buffer: " (buffer-name (current-buffer)) nil 'ignore))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3980
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3981 ;;;###autoload
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3982 (defun ido-insert-buffer ()
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3983 "Insert contents of a buffer in current buffer after point.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3984 The buffer name is selected interactively by typing a substring.
75686
514805720b93 Doc fixes.
Kim F. Storm <storm@cua.dk>
parents: 75573
diff changeset
3985 For details of keybindings, see `ido-switch-buffer'."
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3986 (interactive)
57191
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
3987 (ido-buffer-internal 'insert 'insert-buffer "Insert buffer: " nil nil 'ido-enter-insert-file))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3988
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3989 ;;;###autoload
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3990 (defun ido-switch-buffer-other-frame ()
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3991 "Switch to another buffer and show it in another frame.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3992 The buffer name is selected interactively by typing a substring.
75686
514805720b93 Doc fixes.
Kim F. Storm <storm@cua.dk>
parents: 75573
diff changeset
3993 For details of keybindings, see `ido-switch-buffer'."
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3994 (interactive)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3995 (if ido-mode
71240
0b7ea03b3bcd (ido-default-file-method, ido-default-buffer-method):
Kim F. Storm <storm@cua.dk>
parents: 70797
diff changeset
3996 (ido-buffer-internal 'other-frame)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3997 (call-interactively 'switch-to-buffer-other-frame)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3998
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
3999 ;;;###autoload
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4000 (defun ido-find-file-in-dir (dir)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4001 "Switch to another file starting from DIR."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4002 (interactive "DDir: ")
78030
109ec6cd33be (ido-find-file-in-dir): Don't signal an error for empty directories.
Juanma Barranquero <lekktu@gmail.com>
parents: 77400
diff changeset
4003 (setq dir (file-name-as-directory dir))
57191
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4004 (ido-file-internal ido-default-file-method nil dir nil nil nil 'ignore))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4005
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4006 ;;;###autoload
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4007 (defun ido-find-file ()
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4008 "Edit file with name obtained via minibuffer.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4009 The file is displayed according to `ido-default-file-method' -- the
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4010 default is to show it in the same window, unless it is already
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4011 visible in another frame.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4012
63235
ba92543774db (ido-mode, ido-file-extensions-order, ido-default-file-method,
Juanma Barranquero <lekktu@gmail.com>
parents: 63124
diff changeset
4013 The file name is selected interactively by typing a substring. As you
ba92543774db (ido-mode, ido-file-extensions-order, ido-default-file-method,
Juanma Barranquero <lekktu@gmail.com>
parents: 63124
diff changeset
4014 type in a string, all of the filenames matching the string are displayed
ba92543774db (ido-mode, ido-file-extensions-order, ido-default-file-method,
Juanma Barranquero <lekktu@gmail.com>
parents: 63124
diff changeset
4015 if substring-matching is used \(default). Look at `ido-enable-prefix' and
ba92543774db (ido-mode, ido-file-extensions-order, ido-default-file-method,
Juanma Barranquero <lekktu@gmail.com>
parents: 63124
diff changeset
4016 `ido-toggle-prefix'. When you have found the filename you want, it can
ba92543774db (ido-mode, ido-file-extensions-order, ido-default-file-method,
Juanma Barranquero <lekktu@gmail.com>
parents: 63124
diff changeset
4017 then be selected. As you type, most keys have their normal keybindings,
67362
ca155a6d12ad (ido-completion-map): Renamed from ido-mode-map.
Kim F. Storm <storm@cua.dk>
parents: 67141
diff changeset
4018 except for the following: \\<ido-file-completion-map>
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4019
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4020 RET Select the file at the front of the list of matches. If the
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4021 list is empty, possibly prompt to create new file.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4022
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4023 \\[ido-select-text] Select the current prompt as the buffer or file.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4024 If no buffer or file is found, prompt for a new one.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4025
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4026 \\[ido-next-match] Put the first element at the end of the list.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4027 \\[ido-prev-match] Put the last element at the start of the list.
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
4028 \\[ido-complete] Complete a common suffix to the current string that
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4029 matches all files. If there is only one match, select that file.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4030 If there is no common suffix, show a list of all matching files
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4031 in a separate window.
49208
5a945cb7d742 (ido-ignore-directories-merge): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 49180
diff changeset
4032 \\[ido-edit-input] Edit input string (including directory).
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4033 \\[ido-prev-work-directory] or \\[ido-next-work-directory] go to previous/next directory in work directory history.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4034 \\[ido-merge-work-directories] search for file in the work directory history.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4035 \\[ido-forget-work-directory] removes current directory from the work directory history.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4036 \\[ido-prev-work-file] or \\[ido-next-work-file] cycle through the work file history.
67141
bb428fcd0e86 (ido-mode-map): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 66212
diff changeset
4037 \\[ido-wide-find-file-or-pop-dir] and \\[ido-wide-find-dir-or-delete-dir] prompts and uses find to locate files or directories.
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4038 \\[ido-make-directory] prompts for a directory to create in current directory.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4039 \\[ido-fallback-command] Fallback to non-ido version of current command.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4040 \\[ido-toggle-regexp] Toggle regexp searching.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4041 \\[ido-toggle-prefix] Toggle between substring and prefix matching.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4042 \\[ido-toggle-case] Toggle case-sensitive searching of file names.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4043 \\[ido-toggle-vc] Toggle version control for this file.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4044 \\[ido-toggle-literal] Toggle literal reading of this file.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4045 \\[ido-completion-help] Show list of matching files in separate window.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4046 \\[ido-toggle-ignore] Toggle ignoring files listed in `ido-ignore-files'."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4047
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4048 (interactive)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4049 (ido-file-internal ido-default-file-method))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4050
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4051 ;;;###autoload
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4052 (defun ido-find-file-other-window ()
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4053 "Switch to another file and show it in another window.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4054 The file name is selected interactively by typing a substring.
75686
514805720b93 Doc fixes.
Kim F. Storm <storm@cua.dk>
parents: 75573
diff changeset
4055 For details of keybindings, see `ido-find-file'."
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4056 (interactive)
71240
0b7ea03b3bcd (ido-default-file-method, ido-default-buffer-method):
Kim F. Storm <storm@cua.dk>
parents: 70797
diff changeset
4057 (ido-file-internal 'other-window 'find-file-other-window))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4058
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4059 ;;;###autoload
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4060 (defun ido-find-alternate-file ()
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4061 "Switch to another file and show it in another window.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4062 The file name is selected interactively by typing a substring.
75686
514805720b93 Doc fixes.
Kim F. Storm <storm@cua.dk>
parents: 75573
diff changeset
4063 For details of keybindings, see `ido-find-file'."
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4064 (interactive)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4065 (ido-file-internal 'alt-file 'find-alternate-file nil "Find alternate file: "))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4066
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4067 ;;;###autoload
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4068 (defun ido-find-file-read-only ()
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4069 "Edit file read-only with name obtained via minibuffer.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4070 The file name is selected interactively by typing a substring.
75686
514805720b93 Doc fixes.
Kim F. Storm <storm@cua.dk>
parents: 75573
diff changeset
4071 For details of keybindings, see `ido-find-file'."
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4072 (interactive)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4073 (ido-file-internal 'read-only 'find-file-read-only nil "Find file read-only: "))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4074
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4075 ;;;###autoload
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4076 (defun ido-find-file-read-only-other-window ()
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4077 "Edit file read-only in other window with name obtained via minibuffer.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4078 The file name is selected interactively by typing a substring.
75686
514805720b93 Doc fixes.
Kim F. Storm <storm@cua.dk>
parents: 75573
diff changeset
4079 For details of keybindings, see `ido-find-file'."
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4080 (interactive)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4081 (ido-file-internal 'read-only 'find-file-read-only-other-window nil "Find file read-only other window: "))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4082
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4083 ;;;###autoload
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4084 (defun ido-find-file-read-only-other-frame ()
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4085 "Edit file read-only in other frame with name obtained via minibuffer.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4086 The file name is selected interactively by typing a substring.
75686
514805720b93 Doc fixes.
Kim F. Storm <storm@cua.dk>
parents: 75573
diff changeset
4087 For details of keybindings, see `ido-find-file'."
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4088 (interactive)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4089 (ido-file-internal 'read-only 'find-file-read-only-other-frame nil "Find file read-only other frame: "))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4090
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4091 ;;;###autoload
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4092 (defun ido-display-file ()
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4093 "Display a file in another window but don't select it.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4094 The file name is selected interactively by typing a substring.
75686
514805720b93 Doc fixes.
Kim F. Storm <storm@cua.dk>
parents: 75573
diff changeset
4095 For details of keybindings, see `ido-find-file'."
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4096 (interactive)
57191
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4097 (ido-file-internal 'display nil nil nil nil nil 'ignore))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4098
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4099 ;;;###autoload
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4100 (defun ido-find-file-other-frame ()
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4101 "Switch to another file and show it in another frame.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4102 The file name is selected interactively by typing a substring.
75686
514805720b93 Doc fixes.
Kim F. Storm <storm@cua.dk>
parents: 75573
diff changeset
4103 For details of keybindings, see `ido-find-file'."
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4104 (interactive)
71240
0b7ea03b3bcd (ido-default-file-method, ido-default-buffer-method):
Kim F. Storm <storm@cua.dk>
parents: 70797
diff changeset
4105 (ido-file-internal 'other-frame 'find-file-other-frame))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4106
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4107 ;;;###autoload
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4108 (defun ido-write-file ()
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4109 "Write current buffer to a file.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4110 The file name is selected interactively by typing a substring.
75686
514805720b93 Doc fixes.
Kim F. Storm <storm@cua.dk>
parents: 75573
diff changeset
4111 For details of keybindings, see `ido-find-file'."
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4112 (interactive)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4113 (let ((ido-process-ignore-lists t)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4114 (ido-work-directory-match-only nil)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4115 (ido-ignore-files (cons "[^/]\\'" ido-ignore-files))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4116 (ido-report-no-match nil)
54776
ae50ef10fab5 (ido-confirm-unique-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 53459
diff changeset
4117 (ido-confirm-unique-completion t)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4118 (ido-auto-merge-work-directories-length -1))
57191
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4119 (ido-file-internal 'write 'write-file nil "Write file: " nil nil 'ignore)))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4120
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4121 ;;;###autoload
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4122 (defun ido-insert-file ()
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4123 "Insert contents of file in current buffer.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4124 The file name is selected interactively by typing a substring.
75686
514805720b93 Doc fixes.
Kim F. Storm <storm@cua.dk>
parents: 75573
diff changeset
4125 For details of keybindings, see `ido-find-file'."
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4126 (interactive)
57191
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4127 (ido-file-internal 'insert 'insert-file nil "Insert file: " nil nil 'ido-enter-insert-buffer))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4128
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4129 ;;;###autoload
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4130 (defun ido-dired ()
73825
36f23fcd07f8 (ido-ignore-extensions, ido-show-dot-for-dired, ido-max-dir-file-cache,
Juanma Barranquero <lekktu@gmail.com>
parents: 73388
diff changeset
4131 "Call `dired' the ido way.
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4132 The directory is selected interactively by typing a substring.
75686
514805720b93 Doc fixes.
Kim F. Storm <storm@cua.dk>
parents: 75573
diff changeset
4133 For details of keybindings, see `ido-find-file'."
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4134 (interactive)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4135 (let ((ido-report-no-match nil)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4136 (ido-auto-merge-work-directories-length -1))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4137 (ido-file-internal 'dired 'dired nil "Dired: " 'dir)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4138
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4139 (defun ido-list-directory ()
73825
36f23fcd07f8 (ido-ignore-extensions, ido-show-dot-for-dired, ido-max-dir-file-cache,
Juanma Barranquero <lekktu@gmail.com>
parents: 73388
diff changeset
4140 "Call `list-directory' the ido way.
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4141 The directory is selected interactively by typing a substring.
75686
514805720b93 Doc fixes.
Kim F. Storm <storm@cua.dk>
parents: 75573
diff changeset
4142 For details of keybindings, see `ido-find-file'."
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4143 (interactive)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4144 (let ((ido-report-no-match nil)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4145 (ido-auto-merge-work-directories-length -1))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4146 (ido-file-internal 'list-directory 'list-directory nil "List directory: " 'dir)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4147
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4148 ;;; XEmacs hack for showing default buffer
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4149
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4150 ;; The first time we enter the minibuffer, Emacs puts up the default
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4151 ;; buffer to switch to, but XEmacs doesn't -- presumably there is a
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4152 ;; subtle difference in the two versions of post-command-hook. The
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4153 ;; default is shown for both whenever we delete all of our text
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4154 ;; though, indicating its just a problem the first time we enter the
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4155 ;; function. To solve this, we use another entry hook for emacs to
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4156 ;; show the default the first time we enter the minibuffer.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4157
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4158
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4159 ;;; ICOMPLETE TYPE CODE
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4160
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4161 (defun ido-initiate-auto-merge (buffer)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4162 (ido-trace "\n*merge timeout*" buffer)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4163 (setq ido-auto-merge-timer nil)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4164 (when (and (buffer-live-p buffer)
75381
3e93f595966f (ido-active): Add xemacs test from ido-minibuffer-setup.
Kim F. Storm <storm@cua.dk>
parents: 75347
diff changeset
4165 (ido-active)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4166 (boundp 'ido-eoinput) ido-eoinput)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4167 (let ((contents (buffer-substring-no-properties (minibuffer-prompt-end) ido-eoinput)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4168 (ido-trace "request merge")
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4169 (setq ido-use-merged-list 'auto
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4170 ido-text-init contents
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4171 ido-rotate-temp t
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4172 ido-exit 'refresh)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4173 (save-excursion
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4174 (set-buffer buffer)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4175 (ido-tidy))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4176 (throw 'ido contents))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4177
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4178 (defun ido-exhibit ()
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4179 "Post command hook for `ido'."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4180 ;; Find matching files and display a list in the minibuffer.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4181 ;; Copied from `icomplete-exhibit' with two changes:
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4182 ;; 1. It prints a default file name when there is no text yet entered.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4183 ;; 2. It calls my completion routine rather than the standard completion.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4184
75381
3e93f595966f (ido-active): Add xemacs test from ido-minibuffer-setup.
Kim F. Storm <storm@cua.dk>
parents: 75347
diff changeset
4185 (when (ido-active)
49180
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4186 (let ((contents (buffer-substring-no-properties (minibuffer-prompt-end) (point-max)))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4187 (buffer-undo-list t)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4188 try-single-dir-match
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4189 refresh)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4190
72488
a1eb31579f05 (ido-set-matches-1): Fix full matching for subdirs.
Kim F. Storm <storm@cua.dk>
parents: 71803
diff changeset
4191 (when ido-trace-enable
a1eb31579f05 (ido-set-matches-1): Fix full matching for subdirs.
Kim F. Storm <storm@cua.dk>
parents: 71803
diff changeset
4192 (ido-trace "\nexhibit" this-command)
a1eb31579f05 (ido-set-matches-1): Fix full matching for subdirs.
Kim F. Storm <storm@cua.dk>
parents: 71803
diff changeset
4193 (ido-trace "dir" ido-current-directory)
a1eb31579f05 (ido-set-matches-1): Fix full matching for subdirs.
Kim F. Storm <storm@cua.dk>
parents: 71803
diff changeset
4194 (ido-trace "contents" contents)
a1eb31579f05 (ido-set-matches-1): Fix full matching for subdirs.
Kim F. Storm <storm@cua.dk>
parents: 71803
diff changeset
4195 (ido-trace "list" ido-cur-list)
a1eb31579f05 (ido-set-matches-1): Fix full matching for subdirs.
Kim F. Storm <storm@cua.dk>
parents: 71803
diff changeset
4196 (ido-trace "matches" ido-matches)
a1eb31579f05 (ido-set-matches-1): Fix full matching for subdirs.
Kim F. Storm <storm@cua.dk>
parents: 71803
diff changeset
4197 (ido-trace "rescan" ido-rescan))
49180
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4198
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4199 (save-excursion
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4200 (goto-char (point-max))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4201 ;; Register the end of input, so we know where the extra stuff (match-status info) begins:
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4202 (unless (boundp 'ido-eoinput)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4203 ;; In case it got wiped out by major mode business:
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4204 (make-local-variable 'ido-eoinput))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4205 (setq ido-eoinput (point))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4206
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4207 ;; Handle explicit directory changes
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4208 (cond
57191
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4209 ((memq ido-cur-item '(buffer list))
49180
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4210 )
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4211
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4212 ((= (length contents) 0)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4213 )
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4214
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4215 ((= (length contents) 1)
69542
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
4216 (cond
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
4217 ((and (ido-is-tramp-root) (string-equal contents "/"))
49180
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4218 (ido-set-current-directory ido-current-directory contents)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4219 (setq refresh t))
69748
e44b79389d65 (ido-unc-hosts-cache): New defvar.
Kim F. Storm <storm@cua.dk>
parents: 69738
diff changeset
4220 ((and (ido-unc-hosts) (string-equal contents "/")
69542
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
4221 (let ((ido-enable-tramp-completion nil))
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
4222 (ido-is-root-directory)))
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
4223 (ido-set-current-directory "//")
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
4224 (setq refresh t))
4a6d7cd41a8f (ido-cache-ftp-work-directory-time): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 69524
diff changeset
4225 ))
49180
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4226
74337
ee9b338cccea 2006-11-30 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents: 74020
diff changeset
4227 ((and (string-match (if ido-enable-tramp-completion ".[:@]\\'" ".:\\'") contents)
ee9b338cccea 2006-11-30 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents: 74020
diff changeset
4228 (ido-is-root-directory) ;; Ange-ftp or tramp
ee9b338cccea 2006-11-30 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents: 74020
diff changeset
4229 (not (ido-local-file-exists-p contents)))
49180
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4230 (ido-set-current-directory ido-current-directory contents)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4231 (when (ido-is-slow-ftp-host)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4232 (setq ido-exit 'fallback)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4233 (exit-minibuffer))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4234 (setq refresh t))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4235
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4236 ((ido-final-slash contents) ;; xxx/
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4237 (ido-trace "final slash" contents)
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
4238 (cond
49180
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4239 ((string-equal contents "~/")
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4240 (ido-set-current-home)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4241 (setq refresh t))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4242 ((string-equal contents "../")
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4243 (ido-up-directory t)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4244 (setq refresh t))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4245 ((string-equal contents "./")
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4246 (setq refresh t))
73376
22f24dad9952 2006-10-15 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents: 73266
diff changeset
4247 ((string-match "\\`~[-_a-zA-Z0-9]+[$]?/\\'" contents)
49180
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4248 (ido-trace "new home" contents)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4249 (ido-set-current-home contents)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4250 (setq refresh t))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4251 ((string-match "[$][A-Za-z0-9_]+/\\'" contents)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4252 (let ((exp (condition-case ()
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4253 (expand-file-name
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4254 (substitute-in-file-name (substring contents 0 -1))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4255 ido-current-directory)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4256 (error nil))))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4257 (ido-trace contents exp)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4258 (when (and exp (file-directory-p exp))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4259 (ido-set-current-directory (file-name-directory exp))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4260 (setq ido-text-init (file-name-nondirectory exp))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4261 (setq refresh t))))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4262 ((and (memq system-type '(windows-nt ms-dos))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4263 (string-equal (substring contents 1) ":/"))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4264 (ido-set-current-directory (file-name-directory contents))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4265 (setq refresh t))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4266 ((string-equal (substring contents -2 -1) "/")
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
4267 (ido-set-current-directory
49180
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4268 (if (memq system-type '(windows-nt ms-dos))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4269 (expand-file-name "/" ido-current-directory)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4270 "/"))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4271 (setq refresh t))
57211
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
4272 ((and (or ido-directory-nonreadable ido-directory-too-big)
53323
a053c8c470f3 Handle non-readable directories.
Kim F. Storm <storm@cua.dk>
parents: 53166
diff changeset
4273 (file-directory-p (concat ido-current-directory (file-name-directory contents))))
54776
ae50ef10fab5 (ido-confirm-unique-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 53459
diff changeset
4274 (ido-set-current-directory
53323
a053c8c470f3 Handle non-readable directories.
Kim F. Storm <storm@cua.dk>
parents: 53166
diff changeset
4275 (concat ido-current-directory (file-name-directory contents)))
a053c8c470f3 Handle non-readable directories.
Kim F. Storm <storm@cua.dk>
parents: 53166
diff changeset
4276 (setq refresh t))
49180
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4277 (t
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4278 (ido-trace "try single dir")
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4279 (setq try-single-dir-match t))))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4280
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4281 ((and (string-equal (substring contents -2 -1) "/")
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4282 (not (string-match "[$]" contents)))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4283 (ido-set-current-directory
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4284 (cond
49180
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4285 ((= (length contents) 2)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4286 "/")
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4287 (ido-matches
72792
e8c7ac0523cb (ido-edit-input, ido-complete, ido-take-first-match)
Kim F. Storm <storm@cua.dk>
parents: 72656
diff changeset
4288 (concat ido-current-directory (ido-name (car ido-matches))))
49180
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4289 (t
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4290 (concat ido-current-directory (substring contents 0 -1)))))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4291 (setq ido-text-init (substring contents -1))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4292 (setq refresh t))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4293
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4294 ((and (not ido-use-merged-list)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4295 (not (ido-final-slash contents))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4296 (eq ido-try-merged-list t)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4297 (numberp ido-auto-merge-work-directories-length)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4298 (> ido-auto-merge-work-directories-length 0)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4299 (= (length contents) ido-auto-merge-work-directories-length)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4300 (not (and ido-auto-merge-inhibit-characters-regexp
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4301 (string-match ido-auto-merge-inhibit-characters-regexp contents)))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4302 (not (input-pending-p)))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4303 (setq ido-use-merged-list 'auto
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4304 ido-text-init contents
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4305 ido-rotate-temp t)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4306 (setq refresh t))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4307
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4308 (t nil))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4309
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4310 (when refresh
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4311 (ido-trace "refresh on /" ido-text-init)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4312 (setq ido-exit 'refresh)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4313 (exit-minibuffer))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4314
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4315 ;; Update the list of matches
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4316 (setq ido-text contents)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4317 (ido-set-matches)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4318 (ido-trace "new " ido-matches)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4319
65012
70976e57cb56 (ido-enter-matching-directory): Rename from
Kim F. Storm <storm@cua.dk>
parents: 64983
diff changeset
4320 (when (and ido-enter-matching-directory
49180
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4321 ido-matches
65012
70976e57cb56 (ido-enter-matching-directory): Rename from
Kim F. Storm <storm@cua.dk>
parents: 64983
diff changeset
4322 (or (eq ido-enter-matching-directory 'first)
70976e57cb56 (ido-enter-matching-directory): Rename from
Kim F. Storm <storm@cua.dk>
parents: 64983
diff changeset
4323 (null (cdr ido-matches)))
72792
e8c7ac0523cb (ido-edit-input, ido-complete, ido-take-first-match)
Kim F. Storm <storm@cua.dk>
parents: 72656
diff changeset
4324 (ido-final-slash (ido-name (car ido-matches)))
49180
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4325 (or try-single-dir-match
65012
70976e57cb56 (ido-enter-matching-directory): Rename from
Kim F. Storm <storm@cua.dk>
parents: 64983
diff changeset
4326 (eq ido-enter-matching-directory t)))
49180
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4327 (ido-trace "single match" (car ido-matches))
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
4328 (ido-set-current-directory
72792
e8c7ac0523cb (ido-edit-input, ido-complete, ido-take-first-match)
Kim F. Storm <storm@cua.dk>
parents: 72656
diff changeset
4329 (concat ido-current-directory (ido-name (car ido-matches))))
49180
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4330 (setq ido-exit 'refresh)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4331 (exit-minibuffer))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4332
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4333 (when (and (not ido-matches)
53323
a053c8c470f3 Handle non-readable directories.
Kim F. Storm <storm@cua.dk>
parents: 53166
diff changeset
4334 (not ido-directory-nonreadable)
57211
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
4335 (not ido-directory-too-big)
49180
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4336 ;; ido-rescan ?
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4337 ido-process-ignore-lists
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4338 ido-ignored-list)
49180
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4339 (let ((ido-process-ignore-lists nil)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4340 (ido-rotate ido-rotate)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4341 (ido-cur-list ido-ignored-list))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4342 (ido-trace "try all" ido-ignored-list)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4343 (ido-set-matches))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4344 (when ido-matches
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4345 (ido-trace "found " ido-matches)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4346 (setq ido-rescan t)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4347 (setq ido-process-ignore-lists-inhibit t)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4348 (setq ido-text-init ido-text)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4349 (setq ido-exit 'refresh)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4350 (exit-minibuffer)))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4351
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4352 (when (and
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4353 ido-rescan
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4354 (not ido-matches)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4355 (memq ido-cur-item '(file dir))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4356 (not (ido-is-root-directory))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4357 (> (length contents) 1)
53323
a053c8c470f3 Handle non-readable directories.
Kim F. Storm <storm@cua.dk>
parents: 53166
diff changeset
4358 (not (string-match "[$]" contents))
57211
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
4359 (not ido-directory-nonreadable)
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
4360 (not ido-directory-too-big))
49180
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4361 (ido-trace "merge?")
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4362 (if ido-use-merged-list
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4363 (ido-undo-merge-work-directory contents nil)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4364 (when (and (eq ido-try-merged-list t)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4365 (numberp ido-auto-merge-work-directories-length)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4366 (= ido-auto-merge-work-directories-length 0)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4367 (not (and ido-auto-merge-inhibit-characters-regexp
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4368 (string-match ido-auto-merge-inhibit-characters-regexp contents)))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4369 (not (input-pending-p)))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4370 (ido-trace "\n*start timer*")
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4371 (setq ido-auto-merge-timer
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4372 (run-with-timer ido-auto-merge-delay-time nil 'ido-initiate-auto-merge (current-buffer))))))
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
4373
49180
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4374 (setq ido-rescan t)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4375
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
4376 (if (and ido-use-merged-list
49180
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4377 ido-matches
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4378 (not (string-equal (car (cdr (car ido-matches))) ido-current-directory)))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4379 (progn
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4380 (ido-set-current-directory (car (cdr (car ido-matches))))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4381 (setq ido-use-merged-list t
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4382 ido-exit 'keep
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4383 ido-text-init ido-text)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4384 (exit-minibuffer)))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4385
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4386 ;; Insert the match-status information:
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4387 (ido-set-common-completion)
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
4388 (let ((inf (ido-completions
49180
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4389 contents
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4390 minibuffer-completion-table
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4391 minibuffer-completion-predicate
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4392 (not minibuffer-completion-confirm))))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4393 (ido-trace "inf" inf)
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4394 (insert inf))
b76c3354f4e7 (ido-enable-tramp-completion): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 48867
diff changeset
4395 ))))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4396
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4397 (defun ido-completions (name candidates predicate require-match)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4398 ;; Return the string that is displayed after the user's text.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4399 ;; Modified from `icomplete-completions'.
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
4400
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4401 (let* ((comps ido-matches)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4402 (ind (and (consp (car comps)) (> (length (cdr (car comps))) 1)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4403 ido-merged-indicator))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4404 first)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4405
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4406 (if (and ind ido-use-faces)
63066
bf364cb1c987 (ido-first-match, ido-only-match, ido-subdir)
Kim F. Storm <storm@cua.dk>
parents: 62985
diff changeset
4407 (put-text-property 0 1 'face 'ido-indicator ind))
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
4408
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4409 (if (and ido-use-faces comps)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4410 (let* ((fn (ido-name (car comps)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4411 (ln (length fn)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4412 (setq first (format "%s" fn))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4413 (put-text-property 0 ln 'face
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4414 (if (= (length comps) 1)
63476
a02cb15bf34c 2005-06-15 Matt Hodges <MPHodges@member.fsf.org>
Kim F. Storm <storm@cua.dk>
parents: 63430
diff changeset
4415 (if ido-incomplete-regexp
a02cb15bf34c 2005-06-15 Matt Hodges <MPHodges@member.fsf.org>
Kim F. Storm <storm@cua.dk>
parents: 63430
diff changeset
4416 'ido-incomplete-regexp
a02cb15bf34c 2005-06-15 Matt Hodges <MPHodges@member.fsf.org>
Kim F. Storm <storm@cua.dk>
parents: 63430
diff changeset
4417 'ido-only-match)
63066
bf364cb1c987 (ido-first-match, ido-only-match, ido-subdir)
Kim F. Storm <storm@cua.dk>
parents: 62985
diff changeset
4418 'ido-first-match)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4419 first)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4420 (if ind (setq first (concat first ind)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4421 (setq comps (cons first (cdr comps)))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4422
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4423 (cond ((null comps)
53323
a053c8c470f3 Handle non-readable directories.
Kim F. Storm <storm@cua.dk>
parents: 53166
diff changeset
4424 (cond
a053c8c470f3 Handle non-readable directories.
Kim F. Storm <storm@cua.dk>
parents: 53166
diff changeset
4425 (ido-directory-nonreadable
a053c8c470f3 Handle non-readable directories.
Kim F. Storm <storm@cua.dk>
parents: 53166
diff changeset
4426 (or (nth 8 ido-decorations) " [Not readable]"))
57211
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
4427 (ido-directory-too-big
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
4428 (or (nth 9 ido-decorations) " [Too big]"))
53323
a053c8c470f3 Handle non-readable directories.
Kim F. Storm <storm@cua.dk>
parents: 53166
diff changeset
4429 (ido-report-no-match
a053c8c470f3 Handle non-readable directories.
Kim F. Storm <storm@cua.dk>
parents: 53166
diff changeset
4430 (nth 6 ido-decorations)) ;; [No match]
a053c8c470f3 Handle non-readable directories.
Kim F. Storm <storm@cua.dk>
parents: 53166
diff changeset
4431 (t "")))
63476
a02cb15bf34c 2005-06-15 Matt Hodges <MPHodges@member.fsf.org>
Kim F. Storm <storm@cua.dk>
parents: 63430
diff changeset
4432 (ido-incomplete-regexp
a02cb15bf34c 2005-06-15 Matt Hodges <MPHodges@member.fsf.org>
Kim F. Storm <storm@cua.dk>
parents: 63430
diff changeset
4433 (concat " " (car comps)))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4434 ((null (cdr comps)) ;one match
63476
a02cb15bf34c 2005-06-15 Matt Hodges <MPHodges@member.fsf.org>
Kim F. Storm <storm@cua.dk>
parents: 63430
diff changeset
4435 (concat (if (if (not ido-enable-regexp)
a02cb15bf34c 2005-06-15 Matt Hodges <MPHodges@member.fsf.org>
Kim F. Storm <storm@cua.dk>
parents: 63430
diff changeset
4436 (= (length (ido-name (car comps))) (length name))
a02cb15bf34c 2005-06-15 Matt Hodges <MPHodges@member.fsf.org>
Kim F. Storm <storm@cua.dk>
parents: 63430
diff changeset
4437 ;; We can't rely on the length of the input
a02cb15bf34c 2005-06-15 Matt Hodges <MPHodges@member.fsf.org>
Kim F. Storm <storm@cua.dk>
parents: 63430
diff changeset
4438 ;; for regexps, so explicitly check for a
a02cb15bf34c 2005-06-15 Matt Hodges <MPHodges@member.fsf.org>
Kim F. Storm <storm@cua.dk>
parents: 63430
diff changeset
4439 ;; complete match
a02cb15bf34c 2005-06-15 Matt Hodges <MPHodges@member.fsf.org>
Kim F. Storm <storm@cua.dk>
parents: 63430
diff changeset
4440 (string-match name (ido-name (car comps)))
a02cb15bf34c 2005-06-15 Matt Hodges <MPHodges@member.fsf.org>
Kim F. Storm <storm@cua.dk>
parents: 63430
diff changeset
4441 (string-equal (match-string 0 (ido-name (car comps)))
a02cb15bf34c 2005-06-15 Matt Hodges <MPHodges@member.fsf.org>
Kim F. Storm <storm@cua.dk>
parents: 63430
diff changeset
4442 (ido-name (car comps))))
a02cb15bf34c 2005-06-15 Matt Hodges <MPHodges@member.fsf.org>
Kim F. Storm <storm@cua.dk>
parents: 63430
diff changeset
4443 ""
a02cb15bf34c 2005-06-15 Matt Hodges <MPHodges@member.fsf.org>
Kim F. Storm <storm@cua.dk>
parents: 63430
diff changeset
4444 ;; when there is one match, show the matching file name in full
a02cb15bf34c 2005-06-15 Matt Hodges <MPHodges@member.fsf.org>
Kim F. Storm <storm@cua.dk>
parents: 63430
diff changeset
4445 (concat (nth 4 ido-decorations) ;; [ ... ]
a02cb15bf34c 2005-06-15 Matt Hodges <MPHodges@member.fsf.org>
Kim F. Storm <storm@cua.dk>
parents: 63430
diff changeset
4446 (ido-name (car comps))
a02cb15bf34c 2005-06-15 Matt Hodges <MPHodges@member.fsf.org>
Kim F. Storm <storm@cua.dk>
parents: 63430
diff changeset
4447 (nth 5 ido-decorations)))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4448 (if (not ido-use-faces) (nth 7 ido-decorations)))) ;; [Matched]
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4449 (t ;multiple matches
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4450 (let* ((items (if (> ido-max-prospects 0) (1+ ido-max-prospects) 999))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4451 (alternatives
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4452 (apply
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
4453 #'concat
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4454 (cdr (apply
46256
88bc5ce0674c (ido-find-common-substring): Return substring instead of t.
Kim F. Storm <storm@cua.dk>
parents: 46231
diff changeset
4455 #'nconc
88bc5ce0674c (ido-find-common-substring): Return substring instead of t.
Kim F. Storm <storm@cua.dk>
parents: 46231
diff changeset
4456 (mapcar
88bc5ce0674c (ido-find-common-substring): Return substring instead of t.
Kim F. Storm <storm@cua.dk>
parents: 46231
diff changeset
4457 (lambda (com)
88bc5ce0674c (ido-find-common-substring): Return substring instead of t.
Kim F. Storm <storm@cua.dk>
parents: 46231
diff changeset
4458 (setq com (ido-name com))
88bc5ce0674c (ido-find-common-substring): Return substring instead of t.
Kim F. Storm <storm@cua.dk>
parents: 46231
diff changeset
4459 (setq items (1- items))
88bc5ce0674c (ido-find-common-substring): Return substring instead of t.
Kim F. Storm <storm@cua.dk>
parents: 46231
diff changeset
4460 (cond
88bc5ce0674c (ido-find-common-substring): Return substring instead of t.
Kim F. Storm <storm@cua.dk>
parents: 46231
diff changeset
4461 ((< items 0) ())
88bc5ce0674c (ido-find-common-substring): Return substring instead of t.
Kim F. Storm <storm@cua.dk>
parents: 46231
diff changeset
4462 ((= items 0) (list (nth 3 ido-decorations))) ; " | ..."
88bc5ce0674c (ido-find-common-substring): Return substring instead of t.
Kim F. Storm <storm@cua.dk>
parents: 46231
diff changeset
4463 (t
88bc5ce0674c (ido-find-common-substring): Return substring instead of t.
Kim F. Storm <storm@cua.dk>
parents: 46231
diff changeset
4464 (list (or ido-separator (nth 2 ido-decorations)) ; " | "
88bc5ce0674c (ido-find-common-substring): Return substring instead of t.
Kim F. Storm <storm@cua.dk>
parents: 46231
diff changeset
4465 (let ((str (substring com 0)))
88bc5ce0674c (ido-find-common-substring): Return substring instead of t.
Kim F. Storm <storm@cua.dk>
parents: 46231
diff changeset
4466 (if (and ido-use-faces
88bc5ce0674c (ido-find-common-substring): Return substring instead of t.
Kim F. Storm <storm@cua.dk>
parents: 46231
diff changeset
4467 (not (string= str first))
88bc5ce0674c (ido-find-common-substring): Return substring instead of t.
Kim F. Storm <storm@cua.dk>
parents: 46231
diff changeset
4468 (ido-final-slash str))
63066
bf364cb1c987 (ido-first-match, ido-only-match, ido-subdir)
Kim F. Storm <storm@cua.dk>
parents: 62985
diff changeset
4469 (put-text-property 0 (length str) 'face 'ido-subdir str))
46256
88bc5ce0674c (ido-find-common-substring): Return substring instead of t.
Kim F. Storm <storm@cua.dk>
parents: 46231
diff changeset
4470 str)))))
88bc5ce0674c (ido-find-common-substring): Return substring instead of t.
Kim F. Storm <storm@cua.dk>
parents: 46231
diff changeset
4471 comps))))))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4472
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4473 (concat
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4474 ;; put in common completion item -- what you get by pressing tab
46256
88bc5ce0674c (ido-find-common-substring): Return substring instead of t.
Kim F. Storm <storm@cua.dk>
parents: 46231
diff changeset
4475 (if (and (stringp ido-common-match-string)
88bc5ce0674c (ido-find-common-substring): Return substring instead of t.
Kim F. Storm <storm@cua.dk>
parents: 46231
diff changeset
4476 (> (length ido-common-match-string) (length name)))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4477 (concat (nth 4 ido-decorations) ;; [ ... ]
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4478 (substring ido-common-match-string (length name))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4479 (nth 5 ido-decorations)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4480 ;; list all alternatives
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4481 (nth 0 ido-decorations) ;; { ... }
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4482 alternatives
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4483 (nth 1 ido-decorations)))))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4484
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4485 (defun ido-minibuffer-setup ()
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4486 "Minibuffer setup hook for `ido'."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4487 ;; Copied from `icomplete-minibuffer-setup-hook'.
75381
3e93f595966f (ido-active): Add xemacs test from ido-minibuffer-setup.
Kim F. Storm <storm@cua.dk>
parents: 75347
diff changeset
4488 (when (ido-active)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4489 (add-hook 'pre-command-hook 'ido-tidy nil t)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4490 (add-hook 'post-command-hook 'ido-exhibit nil t)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4491 (setq cua-inhibit-cua-keys t)
48559
f694cedb78e4 (ido-xemacs): Remove defvar. All uses changed to
Kim F. Storm <storm@cua.dk>
parents: 48108
diff changeset
4492 (when (featurep 'xemacs)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4493 (ido-exhibit)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4494 (goto-char (point-min)))
75391
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
4495 (run-hooks 'ido-minibuffer-setup-hook)
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
4496 (when ido-initial-position
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
4497 (goto-char (+ (minibuffer-prompt-end) ido-initial-position))
1859649395ed (ido-initial-position): New variable.
Kim F. Storm <storm@cua.dk>
parents: 75381
diff changeset
4498 (setq ido-initial-position nil))))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4499
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4500 (defun ido-tidy ()
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4501 "Pre command hook for `ido'."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4502 ;; Remove completions display, if any, prior to new user input.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4503 ;; Copied from `icomplete-tidy'."
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4504
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4505 (when ido-auto-merge-timer
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4506 (ido-trace "\n*cancel timer*" this-command)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4507 (cancel-timer ido-auto-merge-timer)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4508 (setq ido-auto-merge-timer nil))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4509
75381
3e93f595966f (ido-active): Add xemacs test from ido-minibuffer-setup.
Kim F. Storm <storm@cua.dk>
parents: 75347
diff changeset
4510 (if (ido-active)
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4511 (if (and (boundp 'ido-eoinput)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4512 ido-eoinput)
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
4513
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4514 (if (> ido-eoinput (point-max))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4515 ;; Oops, got rug pulled out from under us - reinit:
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4516 (setq ido-eoinput (point-max))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4517 (let ((buffer-undo-list t))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4518 (delete-region ido-eoinput (point-max))))
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
4519
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4520 ;; Reestablish the local variable 'cause minibuffer-setup is weird:
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4521 (make-local-variable 'ido-eoinput)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4522 (setq ido-eoinput 1))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4523
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4524 (defun ido-summary-buffers-to-end ()
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4525 ;; Move the summaries to the end of the buffer list.
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4526 ;; This is an example function which can be hooked on to
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4527 ;; `ido-make-buffer-list-hook'. Any buffer matching the regexps
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4528 ;; `Summary' or `output\*$'are put to the end of the list.
49588
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
4529 (let ((summaries (delq nil (mapcar
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
4530 (lambda (x)
37645a051842 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 49579
diff changeset
4531 (if (or
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4532 (string-match "Summary" x)
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4533 (string-match "output\\*\\'" x))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4534 x))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4535 ido-temp-list))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4536 (ido-to-end summaries)))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4537
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4538 ;;; Helper functions for other programs
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4539
55361
c1239eb451dc (ido-read-file-name): If command has ido property, don't use ido
Kim F. Storm <storm@cua.dk>
parents: 55359
diff changeset
4540 (put 'dired-do-rename 'ido 'ignore)
62378
4d270efed583 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 62089
diff changeset
4541 (put 'ibuffer-find-file 'ido 'find-file)
64409
2b7f6da0c696 (dired-other-window): Put ido property on dired-other-window.
Kim F. Storm <storm@cua.dk>
parents: 64343
diff changeset
4542 (put 'dired-other-window 'ido 'dir)
55361
c1239eb451dc (ido-read-file-name): If command has ido property, don't use ido
Kim F. Storm <storm@cua.dk>
parents: 55359
diff changeset
4543
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4544 ;;;###autoload
57211
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
4545 (defun ido-read-buffer (prompt &optional default require-match)
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
4546 "Ido replacement for the built-in `read-buffer'.
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
4547 Return the name of a buffer selected.
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
4548 PROMPT is the prompt to give to the user. DEFAULT if given is the default
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
4549 buffer to be selected, which will go to the front of the list.
63235
ba92543774db (ido-mode, ido-file-extensions-order, ido-default-file-method,
Juanma Barranquero <lekktu@gmail.com>
parents: 63124
diff changeset
4550 If REQUIRE-MATCH is non-nil, an existing buffer must be selected."
57211
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
4551 (let* ((ido-current-directory nil)
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
4552 (ido-directory-nonreadable nil)
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
4553 (ido-directory-too-big nil)
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
4554 (ido-context-switch-command 'ignore)
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
4555 (buf (ido-read-internal 'buffer prompt 'ido-buffer-history default require-match)))
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
4556 (if (eq ido-exit 'fallback)
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
4557 (let ((read-buffer-function nil))
64166
fad9662db4a9 (ido-before-fallback-functions): New hook.
Kim F. Storm <storm@cua.dk>
parents: 64091
diff changeset
4558 (run-hook-with-args 'ido-before-fallback-functions 'read-buffer)
57211
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
4559 (read-buffer prompt default require-match))
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
4560 buf)))
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
4561
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
4562 ;;;###autoload
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4563 (defun ido-read-file-name (prompt &optional dir default-filename mustmatch initial predicate)
57211
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
4564 "Ido replacement for the built-in `read-file-name'.
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
4565 Read file name, prompting with PROMPT and completing in directory DIR.
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4566 See `read-file-name' for additional parameters."
57191
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4567 (let (filename)
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4568 (cond
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4569 ((or (eq predicate 'file-directory-p)
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4570 (eq (get this-command 'ido) 'dir)
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4571 (memq this-command ido-read-file-name-as-directory-commands))
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4572 (setq filename
63124
37a47a1de226 (ido-read-file-name): Fallback to read-file-name on C-f
Kim F. Storm <storm@cua.dk>
parents: 63066
diff changeset
4573 (ido-read-directory-name prompt dir default-filename mustmatch initial))
37a47a1de226 (ido-read-file-name): Fallback to read-file-name on C-f
Kim F. Storm <storm@cua.dk>
parents: 63066
diff changeset
4574 (if (eq ido-exit 'fallback)
37a47a1de226 (ido-read-file-name): Fallback to read-file-name on C-f
Kim F. Storm <storm@cua.dk>
parents: 63066
diff changeset
4575 (setq filename 'fallback)))
57191
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4576 ((and (not (eq (get this-command 'ido) 'ignore))
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4577 (not (memq this-command ido-read-file-name-non-ido))
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4578 (or (null predicate) (eq predicate 'file-exists-p)))
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4579 (let* (ido-saved-vc-hb
62378
4d270efed583 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 62089
diff changeset
4580 (ido-context-switch-command
4d270efed583 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 62089
diff changeset
4581 (if (eq (get this-command 'ido) 'find-file) nil 'ignore))
57191
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4582 (vc-handled-backends (and (boundp 'vc-handled-backends) vc-handled-backends))
64343
6e19d6e25256 (ido-file-internal, ido-read-file-name, ido-read-directory-name):
Kim F. Storm <storm@cua.dk>
parents: 64341
diff changeset
4583 (minibuffer-completing-file-name t)
57191
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4584 (ido-current-directory (ido-expand-directory dir))
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4585 (ido-directory-nonreadable (not (file-readable-p ido-current-directory)))
57211
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
4586 (ido-directory-too-big (and (not ido-directory-nonreadable)
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
4587 (ido-directory-too-big-p ido-current-directory)))
57191
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4588 (ido-work-directory-index -1)
70797
4429856755f0 (ido-read-file-name): Bind ido-show-dot-for-dired to nil
Kim F. Storm <storm@cua.dk>
parents: 70690
diff changeset
4589 (ido-show-dot-for-dired (and ido-show-dot-for-dired
4429856755f0 (ido-read-file-name): Bind ido-show-dot-for-dired to nil
Kim F. Storm <storm@cua.dk>
parents: 70690
diff changeset
4590 (not default-filename)))
57191
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4591 (ido-work-file-index -1)
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4592 (ido-find-literal nil))
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4593 (setq ido-exit nil)
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4594 (setq filename
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4595 (ido-read-internal 'file prompt 'ido-file-history default-filename mustmatch initial))
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4596 (cond
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4597 ((eq ido-exit 'fallback)
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4598 (setq filename 'fallback))
62378
4d270efed583 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 62089
diff changeset
4599 ((eq ido-exit 'dired)
4d270efed583 (ido-magic-forward-char, ido-magic-backward-char)
Kim F. Storm <storm@cua.dk>
parents: 62089
diff changeset
4600 (setq filename ido-current-directory))
57191
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4601 (filename
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4602 (setq filename
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4603 (concat ido-current-directory filename))))))
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4604 (t
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4605 (setq filename 'fallback)))
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4606 (if (eq filename 'fallback)
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4607 (let ((read-file-name-function nil))
64166
fad9662db4a9 (ido-before-fallback-functions): New hook.
Kim F. Storm <storm@cua.dk>
parents: 64091
diff changeset
4608 (run-hook-with-args 'ido-before-fallback-functions 'read-file-name)
57191
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4609 (read-file-name prompt dir default-filename mustmatch initial predicate))
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4610 filename)))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4611
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4612 ;;;###autoload
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4613 (defun ido-read-directory-name (prompt &optional dir default-dirname mustmatch initial)
57211
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
4614 "Ido replacement for the built-in `read-directory-name'.
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
4615 Read directory name, prompting with PROMPT and completing in directory DIR.
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
4616 See `read-directory-name' for additional parameters."
53323
a053c8c470f3 Handle non-readable directories.
Kim F. Storm <storm@cua.dk>
parents: 53166
diff changeset
4617 (let* (filename
64343
6e19d6e25256 (ido-file-internal, ido-read-file-name, ido-read-directory-name):
Kim F. Storm <storm@cua.dk>
parents: 64341
diff changeset
4618 (minibuffer-completing-file-name t)
57191
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4619 (ido-context-switch-command 'ignore)
53323
a053c8c470f3 Handle non-readable directories.
Kim F. Storm <storm@cua.dk>
parents: 53166
diff changeset
4620 ido-saved-vc-hb
a053c8c470f3 Handle non-readable directories.
Kim F. Storm <storm@cua.dk>
parents: 53166
diff changeset
4621 (ido-current-directory (ido-expand-directory dir))
a053c8c470f3 Handle non-readable directories.
Kim F. Storm <storm@cua.dk>
parents: 53166
diff changeset
4622 (ido-directory-nonreadable (not (file-readable-p ido-current-directory)))
57211
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
4623 (ido-directory-too-big (and (not ido-directory-nonreadable)
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
4624 (ido-directory-too-big-p ido-current-directory)))
53323
a053c8c470f3 Handle non-readable directories.
Kim F. Storm <storm@cua.dk>
parents: 53166
diff changeset
4625 (ido-work-directory-index -1)
a053c8c470f3 Handle non-readable directories.
Kim F. Storm <storm@cua.dk>
parents: 53166
diff changeset
4626 (ido-work-file-index -1))
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4627 (setq filename
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4628 (ido-read-internal 'dir prompt 'ido-file-history default-dirname mustmatch initial))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4629 (if filename
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4630 (if (and (stringp filename) (string-equal filename "."))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4631 ido-current-directory
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4632 (concat ido-current-directory filename)))))
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4633
57191
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4634 ;;;###autoload
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4635 (defun ido-completing-read (prompt choices &optional predicate require-match initial-input hist def)
57211
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
4636 "Ido replacement for the built-in `completing-read'.
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
4637 Read a string in the minibuffer with ido-style completion.
57191
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4638 PROMPT is a string to prompt with; normally it ends in a colon and a space.
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4639 CHOICES is a list of strings which are the possible completions.
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4640 PREDICATE is currently ignored; it is included to be compatible
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4641 with `completing-read'.
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4642 If REQUIRE-MATCH is non-nil, the user is not allowed to exit unless
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4643 the input is (or completes to) an element of CHOICES or is null.
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4644 If the input is null, `ido-completing-read' returns DEF, or an empty
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4645 string if DEF is nil, regardless of the value of REQUIRE-MATCH.
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4646 If INITIAL-INPUT is non-nil, insert it in the minibuffer initially,
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4647 with point positioned at the end.
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4648 HIST, if non-nil, specifies a history list.
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4649 DEF, if non-nil, is the default value."
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4650 (let ((ido-current-directory nil)
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4651 (ido-directory-nonreadable nil)
57211
98f763c22ee4 (ido-max-directory-size): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 57191
diff changeset
4652 (ido-directory-too-big nil)
57191
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4653 (ido-context-switch-command 'ignore)
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4654 (ido-choice-list choices))
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4655 (ido-read-internal 'list prompt hist def require-match initial-input)))
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4656
bd5d1158ebcf (ido-choice-list): New dynamic var for `list' context.
Kim F. Storm <storm@cua.dk>
parents: 57065
diff changeset
4657
87566
0c4a74c24677 * progmodes/ada-xref.el (ada-prj-find-prj-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 87110
diff changeset
4658 ;; arch-tag: b63a3500-1735-41bd-8a01-05373f0864da
46068
5769eed50ff7 New file.
Kim F. Storm <storm@cua.dk>
parents:
diff changeset
4659 ;;; ido.el ends here