* emacs-lisp/byte-run.el (defmacro): Use same argument parsing as
[bpt/emacs.git] / lisp / cedet / ede / dired.el
CommitLineData
acc33231
CY
1;;; ede/dired.el --- EDE extensions to dired.
2
acaf905b 3;; Copyright (C) 1998-2000, 2003, 2009-2012 Free Software Foundation, Inc.
acc33231
CY
4
5;; Author: Eric M. Ludlam <zappo@gnu.org>
6;; Version: 0.4
7;; Keywords: project, make
8
9;; This file is part of GNU Emacs.
10
11;; GNU Emacs is free software: you can redistribute it and/or modify
12;; it under the terms of the GNU General Public License as published by
13;; the Free Software Foundation, either version 3 of the License, or
14;; (at your option) any later version.
15
16;; GNU Emacs is distributed in the hope that it will be useful,
17;; but WITHOUT ANY WARRANTY; without even the implied warranty of
18;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
19;; GNU General Public License for more details.
20
21;; You should have received a copy of the GNU General Public License
22;; along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>.
23
24;;; Commentary:
25;;
26;; This provides a dired interface to EDE, allowing users to modify
27;; their project file by adding files (or whatever) directly from a
28;; dired buffer.
cb7f3653 29(eval-when-compile (require 'cl))
acc33231
CY
30(require 'easymenu)
31(require 'dired)
32(require 'ede)
33
34;;; Code:
cb7f3653
SM
35(defvar ede-dired-keymap
36 (let ((map (make-sparse-keymap)))
37 (define-key map ".a" 'ede-dired-add-to-target)
38 (define-key map ".t" 'ede-new-target)
39 (define-key map ".s" 'ede-speedbar)
40 (define-key map ".C" 'ede-compile-project)
41 (define-key map ".d" 'ede-make-dist)
42
43 (easy-menu-define
44 ede-dired-menu map "EDE Dired Minor Mode Menu"
45 '("Project"
46 [ "Add files to target" ede-dired-add-to-target (ede-current-project) ]
47 ( "Build" :filter ede-build-forms-menu)
48 "-"
49 [ "Create Project" ede-new (not (ede-current-project)) ]
50 [ "Create Target" ede-new-target (ede-current-project) ]
51 "-"
52 ( "Customize Project" :filter ede-customize-forms-menu )
53 [ "View Project Tree" ede-speedbar (ede-current-project) ]
54 ))
55 map)
acc33231
CY
56 "Keymap used for ede dired minor mode.")
57
cb7f3653 58(define-minor-mode ede-dired-minor-mode
acc33231 59 "A minor mode that should only be activated in DIRED buffers.
cb7f3653 60If ARG is nil or a positive number, force on, if
acc33231 61negative, force off."
cb7f3653
SM
62 :lighter " EDE" :keymap ede-dired-keymap
63 (unless (derived-mode-p 'dired-mode)
64 (setq ede-dired-minor-mode nil)
65 (error "Not in DIRED mode"))
66 (unless (or (ede-directory-project-p default-directory)
62a81506 67 (called-interactively-p 'any))
cb7f3653 68 (setq ede-dired-minor-mode nil)))
acc33231
CY
69
70(defun ede-dired-add-to-target (target)
71 "Add a file, or all marked files into a TARGET."
72 (interactive (list
73 (let ((ede-object (ede-current-project)))
74 (ede-invoke-method 'project-interactive-select-target
75 "Add files to Target: "))))
cb7f3653
SM
76 (dolist (file (dired-get-marked-files t))
77 (project-add-file target file)
266a86bd 78 ;; Find the buffer for this files, and set its ede-object
cb7f3653 79 (if (get-file-buffer file)
266a86bd
CY
80 (with-current-buffer (get-file-buffer file)
81 (setq ede-object nil)
82 (setq ede-object (ede-buffer-object (current-buffer)))))))
acc33231
CY
83
84(provide 'ede/dired)
85
86;;; ede/dired.el ends here