1 ;;; pcmpl-gnu.el --- completions for GNU project tools -*- lexical-binding: t -*-
3 ;; Copyright (C) 1999-2012 Free Software Foundation, Inc.
7 ;; This file is part of GNU Emacs.
9 ;; GNU Emacs is free software: you can redistribute it and/or modify
10 ;; it under the terms of the GNU General Public License as published by
11 ;; the Free Software Foundation, either version 3 of the License, or
12 ;; (at your option) any later version.
14 ;; GNU Emacs is distributed in the hope that it will be useful,
15 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
16 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 ;; GNU General Public License for more details.
19 ;; You should have received a copy of the GNU General Public License
20 ;; along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>.
31 (defgroup pcmpl-gnu nil
32 "Completions for GNU project tools."
37 (defcustom pcmpl-gnu-makefile-regexps
38 '("\\`GNUmakefile" "\\`[Mm]akefile" "\\.ma?k\\'")
39 "A list of regexps that will match Makefile names."
40 :type
'(repeat regexp
)
46 (defun pcomplete/gzip
()
47 "Completion for `gzip'."
48 (let ((pcomplete-help "(gzip)"))
49 (pcomplete-opt "cdfhlLnNqrStvV123456789")
50 (while (pcomplete-here
51 (pcmpl-gnu-zipped-files
53 (let ((args pcomplete-args
))
55 (if (string-match "\\`-.*[dt]" (car args
))
56 (throw 'has-d-flag t
))
57 (setq args
(cdr args
))))))))))
59 (defun pcmpl-gnu-zipped-files (unzip-p)
60 "Find all zipped or unzipped files: the inverse of UNZIP-P."
65 (when (and (file-readable-p entry
)
66 (file-regular-p entry
))
67 (let ((zipped (string-match "\\.\\(t?gz\\|\\(ta\\)?Z\\)\\'"
69 (or (and unzip-p zipped
)
70 (and (not unzip-p
) (not zipped
)))))))))
73 (defun pcomplete/bzip2
()
74 "Completion for `bzip2'."
75 (pcomplete-opt "hdzkftcqvLVs123456789")
76 (while (pcomplete-here
77 (pcmpl-gnu-bzipped-files
79 (let ((args pcomplete-args
))
81 (if (string-match "\\`-.*[dt]" (car args
))
82 (throw 'has-d-flag t
))
83 (setq args
(cdr args
)))))))))
85 (defun pcmpl-gnu-bzipped-files (unzip-p)
86 "Find all zipped or unzipped files: the inverse of UNZIP-P."
91 (when (and (file-readable-p entry
)
92 (file-regular-p entry
))
93 (let ((zipped (string-match "\\.\\(t?z2\\|bz2\\)\\'" entry
)))
94 (or (and unzip-p zipped
)
95 (and (not unzip-p
) (not zipped
)))))))))
98 (defun pcomplete/make
()
99 "Completion for GNU `make'."
100 (let ((pcomplete-help "(make)Top"))
101 (pcomplete-opt "bmC/def(pcmpl-gnu-makefile-names)hiI/j?kl?no.pqrsStvwW.")
102 (while (pcomplete-here (completion-table-in-turn
103 (pcmpl-gnu-make-rule-names)
107 (defun pcmpl-gnu-makefile-names ()
108 "Return a list of possible makefile names."
109 (pcomplete-entries (mapconcat 'identity pcmpl-gnu-makefile-regexps
"\\|")))
111 (defun pcmpl-gnu-make-rule-names ()
112 "Return a list of possible make rule names in MAKEFILE."
113 (let* ((minus-f (member "-f" pcomplete-args
))
114 (makefile (or (cadr minus-f
)
116 ((file-exists-p "GNUmakefile") "GNUmakefile")
117 ((file-exists-p "makefile") "makefile")
120 (if (not (file-readable-p makefile
))
121 (unless minus-f
(list "-f"))
123 (ignore-errors ;Could be a directory or something.
124 (insert-file-contents makefile
))
125 (while (re-search-forward
126 (concat "^\\s-*\\([^\n#%.$][^:=\n]*\\)\\s-*:[^=]") nil t
)
127 (setq rules
(append (split-string (match-string 1)) rules
))))
128 (pcomplete-uniqify-list rules
))))
130 (defcustom pcmpl-gnu-tarfile-regexp
131 "\\.t\\(ar\\(\\.\\(gz\\|bz2\\|Z\\|xz\\)\\)?\\|gz\\|a[zZ]\\|z2\\)\\'"
132 "A regexp which matches any tar archive."
133 :version
"24.3" ; added xz
137 ;; Only used in tar-mode buffers.
138 (defvar tar-parse-info
)
139 (declare-function tar-header-name
"tar-mode" t t
)
141 (defmacro pcmpl-gnu-with-file-buffer
(file &rest body
)
142 "Run BODY inside a buffer visiting FILE."
143 (declare (debug t
) (indent 1))
144 (let ((exist (make-symbol "exist"))
145 (filesym (make-symbol "file"))
146 (buf (make-symbol "buf")))
147 `(let* ((,filesym
,file
)
148 (,exist
(find-buffer-visiting ,filesym
))
149 (,buf
(or ,exist
(find-file-noselect ,filesym
))))
151 (with-current-buffer ,buf
153 (when (and (not ,exist
) (buffer-live-p ,buf
))
154 (kill-buffer ,buf
))))))
157 (defun pcomplete/tar
()
158 "Completion for the GNU tar utility."
159 ;; options that end in an equal sign will want further completion...
160 (let (saw-option complete-within
)
161 (let ((pcomplete-suffix-list (cons ?
= pcomplete-suffix-list
)))
162 (while (pcomplete-match "^-" 0)
164 (if (pcomplete-match "^--" 0)
165 (if (pcomplete-match "^--\\([^= \t\n\f]*\\)\\'" 0)
166 ;; FIXME: Extract this list from "tar --help".
196 "--ignore-failed-read"
204 "--listed-incremental"
206 "--modification-time"
208 "--new-volume-script="
221 "--preserve-permissions"
222 "--read-full-records"
240 "--use-compress-program="
245 (pcomplete-opt "01234567ABCFGKLMNOPRSTUVWXZbcdfghiklmoprstuvwxz"))
247 ((pcomplete-match "\\`-\\'" 0)
249 ((pcomplete-match "\\`--after-date=" 0)
251 ((pcomplete-match "\\`--backup=" 0)
253 ((pcomplete-match "\\`--blocking-factor=" 0)
255 ((pcomplete-match "\\`--directory=\\(.*\\)" 0)
256 (pcomplete-here* (pcomplete-dirs)
257 (pcomplete-match-string 1 0)))
258 ((pcomplete-match "\\`--exclude-from=\\(.*\\)" 0)
259 (pcomplete-here* (pcomplete-entries)
260 (pcomplete-match-string 1 0)))
261 ((pcomplete-match "\\`--exclude=" 0)
263 ((pcomplete-match "\\`--\\(extract\\|list\\)\\'" 0)
264 (setq complete-within t
))
265 ((pcomplete-match "\\`--file=\\(.*\\)" 0)
266 (pcomplete-here* (pcomplete-dirs-or-entries pcmpl-gnu-tarfile-regexp
)
267 (pcomplete-match-string 1 0)))
268 ((pcomplete-match "\\`--files-from=\\(.*\\)" 0)
269 (pcomplete-here* (pcomplete-entries)
270 (pcomplete-match-string 1 0)))
271 ((pcomplete-match "\\`--group=\\(.*\\)" 0)
272 (pcomplete-here* (pcmpl-unix-group-names)
273 (pcomplete-match-string 1 0)))
274 ((pcomplete-match "\\`--info-script=\\(.*\\)" 0)
275 (pcomplete-here* (pcomplete-entries)
276 (pcomplete-match-string 1 0)))
277 ((pcomplete-match "\\`--label=" 0)
279 ((pcomplete-match "\\`--mode=" 0)
281 ((pcomplete-match "\\`--new-volume-script=\\(.*\\)" 0)
282 (pcomplete-here* (pcomplete-entries)
283 (pcomplete-match-string 1 0)))
284 ((pcomplete-match "\\`--newer=" 0)
286 ((pcomplete-match "\\`--owner=\\(.*\\)" 0)
287 (pcomplete-here* (pcmpl-unix-user-names)
288 (pcomplete-match-string 1 0)))
289 ((pcomplete-match "\\`--record-size=" 0)
291 ((pcomplete-match "\\`--rsh-command=\\(.*\\)" 0)
292 (pcomplete-here* (funcall pcomplete-command-completion-function
)
293 (pcomplete-match-string 1 0)))
294 ((pcomplete-match "\\`--starting-file=\\(.*\\)" 0)
295 (pcomplete-here* (pcomplete-entries)
296 (pcomplete-match-string 1 0)))
297 ((pcomplete-match "\\`--suffix=" 0)
299 ((pcomplete-match "\\`--tape-length=" 0)
301 ((pcomplete-match "\\`--use-compress-program=\\(.*\\)" 0)
302 (pcomplete-here* (funcall pcomplete-command-completion-function
)
303 (pcomplete-match-string 1 0)))
304 ((pcomplete-match "\\`--volno-file=\\(.*\\)" 0)
305 (pcomplete-here* (pcomplete-entries)
306 (pcomplete-match-string 1 0))))))
309 (mapcar 'char-to-string
311 "01234567ABCFGIKLMNOPRSTUVWXZbcdfghiklmoprstuvwxz")))
312 (if (pcomplete-match "[xt]" 'first
1)
313 (setq complete-within t
)))
314 (pcomplete-here (pcomplete-dirs-or-entries pcmpl-gnu-tarfile-regexp
))
315 (while (pcomplete-here
316 (if (and complete-within
317 (let* ((fa (file-attributes (pcomplete-arg 1)))
320 (or (null large-file-warning-threshold
)
321 (< size large-file-warning-threshold
)))))
322 (let ((file (pcomplete-arg 1)))
323 (completion-table-dynamic
325 (pcmpl-gnu-with-file-buffer file
326 (mapcar #'tar-header-name tar-parse-info
)))))
331 (defalias 'pcomplete
/gdb
'pcomplete
/xargs
)
333 ;;; pcmpl-gnu.el ends here