123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687 |
- (eval-when-compile (require 'cl))
- (require 'easymenu)
- (require 'dired)
- (require 'ede)
- (defvar ede-dired-keymap
- (let ((map (make-sparse-keymap)))
- (define-key map ".a" 'ede-dired-add-to-target)
- (define-key map ".t" 'ede-new-target)
- (define-key map ".s" 'ede-speedbar)
- (define-key map ".C" 'ede-compile-project)
- (define-key map ".d" 'ede-make-dist)
- (easy-menu-define
- ede-dired-menu map "EDE Dired Minor Mode Menu"
- '("Project"
- [ "Add files to target" ede-dired-add-to-target (ede-current-project) ]
- ( "Build" :filter ede-build-forms-menu)
- "-"
- [ "Create Project" ede-new (not (ede-current-project)) ]
- [ "Create Target" ede-new-target (ede-current-project) ]
- "-"
- ( "Customize Project" :filter ede-customize-forms-menu )
- [ "View Project Tree" ede-speedbar (ede-current-project) ]
- ))
- map)
- "Keymap used for ede dired minor mode.")
- (define-minor-mode ede-dired-minor-mode
- "A minor mode that should only be activated in DIRED buffers.
- If ARG is nil or a positive number, force on, if
- negative, force off."
- :lighter " EDE" :keymap ede-dired-keymap
- (unless (derived-mode-p 'dired-mode)
- (setq ede-dired-minor-mode nil)
- (error "Not in DIRED mode"))
- (unless (or (ede-directory-project-p default-directory)
- (interactive-p))
- (setq ede-dired-minor-mode nil)))
- (defun ede-dired-add-to-target (target)
- "Add a file, or all marked files into a TARGET."
- (interactive (list
- (let ((ede-object (ede-current-project)))
- (ede-invoke-method 'project-interactive-select-target
- "Add files to Target: "))))
- (dolist (file (dired-get-marked-files t))
- (project-add-file target file)
-
- (if (get-file-buffer file)
- (with-current-buffer (get-file-buffer file)
- (setq ede-object nil)
- (setq ede-object (ede-buffer-object (current-buffer)))))))
- (provide 'ede/dired)
|