
(autoload-rubric): Don't use any more. * cedet/semantic/fw.el (semantic/loaddefs): * cedet/srecode.el (srecode/loaddefs): * cedet/ede.el (ede/loaddefs): Load rather than require. * lisp/cedet/ede/cpp-root.el: * lisp/cedet/ede/emacs.el: * lisp/cedet/ede/files.el: * lisp/cedet/ede/linux.el: * lisp/cedet/ede/locate.el: * lisp/cedet/ede/make.el: * lisp/cedet/ede/shell.el: * lisp/cedet/ede/speedbar.el: * lisp/cedet/ede/system.el: * lisp/cedet/ede/util.el: * lisp/cedet/semantic/analyze.el: * lisp/cedet/semantic/bovine.el: * lisp/cedet/semantic/complete.el: * lisp/cedet/semantic/ctxt.el: * lisp/cedet/semantic/db-file.el: * lisp/cedet/semantic/db-find.el: * lisp/cedet/semantic/db-global.el: * lisp/cedet/semantic/db-mode.el: * lisp/cedet/semantic/db-typecache.el: * lisp/cedet/semantic/db.el: * lisp/cedet/semantic/debug.el: * lisp/cedet/semantic/dep.el: * lisp/cedet/semantic/doc.el: * lisp/cedet/semantic/edit.el: * lisp/cedet/semantic/find.el: * lisp/cedet/semantic/format.el: * lisp/cedet/semantic/html.el: * lisp/cedet/semantic/ia-sb.el: * lisp/cedet/semantic/ia.el: * lisp/cedet/semantic/idle.el: * lisp/cedet/semantic/lex-spp.el: * lisp/cedet/semantic/lex.el: * lisp/cedet/semantic/mru-bookmark.el: * lisp/cedet/semantic/scope.el: * lisp/cedet/semantic/senator.el: * lisp/cedet/semantic/sort.el: * lisp/cedet/semantic/symref.el: * lisp/cedet/semantic/tag-file.el: * lisp/cedet/semantic/tag-ls.el: * lisp/cedet/semantic/tag-write.el: * lisp/cedet/semantic/tag.el: * lisp/cedet/semantic/util-modes.el: * lisp/cedet/semantic/analyze/complete.el: * lisp/cedet/semantic/analyze/refs.el: * lisp/cedet/semantic/bovine/c.el: * lisp/cedet/semantic/bovine/gcc.el: * lisp/cedet/semantic/bovine/make.el: * lisp/cedet/semantic/bovine/scm.el: * lisp/cedet/semantic/decorate/include.el: * lisp/cedet/semantic/decorate/mode.el: * lisp/cedet/semantic/symref/cscope.el: * lisp/cedet/semantic/symref/global.el: * lisp/cedet/semantic/symref/grep.el: * lisp/cedet/semantic/symref/idutils.el: * lisp/cedet/semantic/symref/list.el: * lisp/cedet/semantic/wisent/java-tags.el: * lisp/cedet/semantic/wisent/javascript.el: * lisp/cedet/srecode/compile.el: * lisp/cedet/srecode/cpp.el: * lisp/cedet/srecode/document.el: * lisp/cedet/srecode/el.el: * lisp/cedet/srecode/expandproto.el: * lisp/cedet/srecode/getset.el: * lisp/cedet/srecode/insert.el: * lisp/cedet/srecode/java.el: * lisp/cedet/srecode/map.el: * lisp/cedet/srecode/mode.el: * lisp/cedet/srecode/template.el: * lisp/cedet/srecode/texi.el: Remove the file-local setting of generated-autoload-feature.
237 lines
7.4 KiB
EmacsLisp
237 lines
7.4 KiB
EmacsLisp
;;; ede/linux.el --- Special project for Linux
|
|
|
|
;; Copyright (C) 2008, 2009 Free Software Foundation, Inc.
|
|
|
|
;; Author: Eric M. Ludlam <eric@siege-engine.com>
|
|
|
|
;; This file is part of GNU Emacs.
|
|
|
|
;; GNU Emacs is free software: you can redistribute it and/or modify
|
|
;; it under the terms of the GNU General Public License as published by
|
|
;; the Free Software Foundation, either version 3 of the License, or
|
|
;; (at your option) any later version.
|
|
|
|
;; GNU Emacs is distributed in the hope that it will be useful,
|
|
;; but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
;; GNU General Public License for more details.
|
|
|
|
;; You should have received a copy of the GNU General Public License
|
|
;; along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
;;; Commentary:
|
|
;;
|
|
;; Provide a special project type just for Linux, cause Linux is special.
|
|
;;
|
|
;; Identifies a Linux project automatically.
|
|
;; Speedy ede-expand-filename based on extension.
|
|
;; Pre-populates the preprocessor map from lisp.h
|
|
;;
|
|
;; ToDo :
|
|
;; * Add "build" options.
|
|
;; * Add texinfo lookup options.
|
|
;; * Add website
|
|
|
|
(require 'ede)
|
|
(declare-function semanticdb-file-table-object "semantic/db")
|
|
(declare-function semanticdb-needs-refresh-p "semantic/db")
|
|
(declare-function semanticdb-refresh-table "semantic/db")
|
|
|
|
;;; Code:
|
|
(defvar ede-linux-project-list nil
|
|
"List of projects created by option `ede-linux-project'.")
|
|
|
|
(defun ede-linux-file-existing (dir)
|
|
"Find a Linux project in the list of Linux projects.
|
|
DIR is the directory to search from."
|
|
(let ((projs ede-linux-project-list)
|
|
(ans nil))
|
|
(while (and projs (not ans))
|
|
(let ((root (ede-project-root-directory (car projs))))
|
|
(when (string-match (concat "^" (regexp-quote root)) dir)
|
|
(setq ans (car projs))))
|
|
(setq projs (cdr projs)))
|
|
ans))
|
|
|
|
;;;###autoload
|
|
(defun ede-linux-project-root (&optional dir)
|
|
"Get the root directory for DIR."
|
|
(when (not dir) (setq dir default-directory))
|
|
(let ((case-fold-search t)
|
|
(proj (ede-linux-file-existing dir)))
|
|
(if proj
|
|
(ede-up-directory (file-name-directory
|
|
(oref proj :file)))
|
|
;; No pre-existing project. Lets take a wild-guess if we have
|
|
;; an Linux project here.
|
|
(when (string-match "linux[^/]*" dir)
|
|
(let ((base (substring dir 0 (match-end 0))))
|
|
(when (file-exists-p (expand-file-name "scripts/ver_linux" base))
|
|
base))))))
|
|
|
|
(defun ede-linux-version (dir)
|
|
"Find the Linux version for the Linux src in DIR."
|
|
(let ((buff (get-buffer-create " *linux-query*")))
|
|
(with-current-buffer buff
|
|
(erase-buffer)
|
|
(setq default-directory (file-name-as-directory dir))
|
|
(insert-file-contents "Makefile" nil 0 512)
|
|
(goto-char (point-min))
|
|
(let (major minor sub)
|
|
(re-search-forward "^VERSION *= *\\([0-9.]+\\)")
|
|
(setq major (match-string 1))
|
|
(re-search-forward "^PATCHLEVEL *= *\\([0-9.]+\\)")
|
|
(setq minor (match-string 1))
|
|
(re-search-forward "^SUBLEVEL *= *\\([0-9.]+\\)")
|
|
(setq sub (match-string 1))
|
|
(prog1
|
|
(concat major "." minor "." sub)
|
|
(kill-buffer buff)
|
|
)))))
|
|
|
|
(defclass ede-linux-project (ede-project eieio-instance-tracker)
|
|
((tracking-symbol :initform 'ede-linux-project-list)
|
|
)
|
|
"Project Type for the Linux source code."
|
|
:method-invocation-order :depth-first)
|
|
|
|
(defun ede-linux-load (dir &optional rootproj)
|
|
"Return an Linux Project object if there is a match.
|
|
Return nil if there isn't one.
|
|
Argument DIR is the directory it is created for.
|
|
ROOTPROJ is nil, since there is only one project."
|
|
(or (ede-linux-file-existing dir)
|
|
;; Doesn't already exist, so lets make one.
|
|
(ede-linux-project "Linux"
|
|
:name "Linux"
|
|
:version (ede-linux-version dir)
|
|
:directory (file-name-as-directory dir)
|
|
:file (expand-file-name "scripts/ver_linux"
|
|
dir))
|
|
(ede-add-project-to-global-list this)
|
|
)
|
|
)
|
|
|
|
(defclass ede-linux-target-c (ede-target)
|
|
()
|
|
"EDE Linux Project target for C code.
|
|
All directories need at least one target.")
|
|
|
|
(defclass ede-linux-target-misc (ede-target)
|
|
()
|
|
"EDE Linux Project target for Misc files.
|
|
All directories need at least one target.")
|
|
|
|
(defmethod initialize-instance ((this ede-linux-project)
|
|
&rest fields)
|
|
"Make sure the :file is fully expanded."
|
|
(call-next-method)
|
|
(unless (slot-boundp this 'targets)
|
|
(oset this :targets nil)))
|
|
|
|
;;; File Stuff
|
|
;;
|
|
(defmethod ede-project-root-directory ((this ede-linux-project)
|
|
&optional file)
|
|
"Return the root for THIS Linux project with file."
|
|
(ede-up-directory (file-name-directory (oref this file))))
|
|
|
|
(defmethod ede-project-root ((this ede-linux-project))
|
|
"Return my root."
|
|
this)
|
|
|
|
(defmethod ede-find-subproject-for-directory ((proj ede-linux-project)
|
|
dir)
|
|
"Return PROJ, for handling all subdirs below DIR."
|
|
proj)
|
|
|
|
;;; TARGET MANAGEMENT
|
|
;;
|
|
(defun ede-linux-find-matching-target (class dir targets)
|
|
"Find a target that is a CLASS and is in DIR in the list of TARGETS."
|
|
(let ((match nil))
|
|
(dolist (T targets)
|
|
(when (and (object-of-class-p T class)
|
|
(string= (oref T :path) dir))
|
|
(setq match T)
|
|
))
|
|
match))
|
|
|
|
(defmethod ede-find-target ((proj ede-linux-project) buffer)
|
|
"Find an EDE target in PROJ for BUFFER.
|
|
If one doesn't exist, create a new one for this directory."
|
|
(let* ((ext (file-name-extension (buffer-file-name buffer)))
|
|
(cls (cond ((not ext)
|
|
'ede-linux-target-misc)
|
|
((string-match "c\\|h" ext)
|
|
'ede-linux-target-c)
|
|
(t 'ede-linux-target-misc)))
|
|
(targets (oref proj targets))
|
|
(dir default-directory)
|
|
(ans (ede-linux-find-matching-target cls dir targets))
|
|
)
|
|
(when (not ans)
|
|
(setq ans (make-instance
|
|
cls
|
|
:name (file-name-nondirectory
|
|
(directory-file-name dir))
|
|
:path dir
|
|
:source nil))
|
|
(object-add-to-list proj :targets ans)
|
|
)
|
|
ans))
|
|
|
|
;;; UTILITIES SUPPORT.
|
|
;;
|
|
(defmethod ede-preprocessor-map ((this ede-linux-target-c))
|
|
"Get the pre-processor map for Linux C code.
|
|
All files need the macros from lisp.h!"
|
|
(require 'semantic/db)
|
|
(let* ((proj (ede-target-parent this))
|
|
(root (ede-project-root proj))
|
|
(versionfile (ede-expand-filename root "include/linux/version.h"))
|
|
(table (when (and versionfile (file-exists-p versionfile))
|
|
(semanticdb-file-table-object versionfile)))
|
|
(filemap '( ("__KERNEL__" . "")
|
|
))
|
|
)
|
|
(when table
|
|
(when (semanticdb-needs-refresh-p table)
|
|
(semanticdb-refresh-table table))
|
|
(setq filemap (append filemap (oref table lexical-table)))
|
|
)
|
|
filemap
|
|
))
|
|
|
|
(defun ede-linux-file-exists-name (name root subdir)
|
|
"Return a file name if NAME exists under ROOT with SUBDIR in between."
|
|
(let ((F (expand-file-name name (expand-file-name subdir root))))
|
|
(when (file-exists-p F) F)))
|
|
|
|
(defmethod ede-expand-filename-impl ((proj ede-linux-project) name)
|
|
"Within this project PROJ, find the file NAME.
|
|
Knows about how the Linux source tree is organized."
|
|
(let* ((ext (file-name-extension name))
|
|
(root (ede-project-root proj))
|
|
(dir (ede-project-root-directory root))
|
|
(F (cond
|
|
((not ext) nil)
|
|
((string-match "h" ext)
|
|
(or (ede-linux-file-exists-name name dir "")
|
|
(ede-linux-file-exists-name name dir "include"))
|
|
)
|
|
((string-match "txt" ext)
|
|
(ede-linux-file-exists-name name dir "Documentation"))
|
|
(t nil)))
|
|
)
|
|
(or F (call-next-method))))
|
|
|
|
(provide 'ede/linux)
|
|
|
|
;; Local variables:
|
|
;; generated-autoload-file: "loaddefs.el"
|
|
;; generated-autoload-load-name: "ede/linux"
|
|
;; End:
|
|
|
|
;; arch-tag: 41f310c8-b169-4259-8a2d-0ff4bd0a736d
|
|
;;; ede/linux.el ends here
|