mirror of
git://git.sv.gnu.org/emacs.git
synced 2025-12-30 09:00:31 -08:00
* lisp/auth-source.el (auth-source-backend-parse-parameters) (auth-source-search-collection) (auth-source-secrets-listify-pattern) (auth-source--decode-octal-string, auth-source-plstore-search): * lisp/registry.el (registry-lookup) (registry-lookup-breaks-before-lexbind) (registry-lookup-secondary, registry-lookup-secondary-value) (registry-search, registry-delete, registry-size, registry-full) (registry-insert, registry-reindex, registry-prune) (registry-collect-prune-candidates): * lisp/subr.el (nbutlast, process-live-p): * lisp/tab-bar.el (tab-bar-list): * lisp/cedet/ede/linux.el (ede-linux--get-archs) (ede-linux--include-path, ede-linux-load): * lisp/erc/erc-log.el (erc-log-all-but-server-buffers): * lisp/erc/erc-pcomplete.el (pcomplete-erc-commands) (pcomplete-erc-ops, pcomplete-erc-not-ops, pcomplete-erc-nicks) (pcomplete-erc-all-nicks, pcomplete-erc-channels) (pcomplete-erc-command-name, pcomplete-erc-parse-arguments): * lisp/eshell/em-term.el (eshell-visual-command-p): * lisp/gnus/gnus-cache.el (gnus-cache-fully-p): * lisp/gnus/nnmail.el (nnmail-get-active) (nnmail-fancy-expiry-target): * lisp/mail/mail-utils.el (mail-string-delete): * lisp/mail/supercite.el (sc-hdr, sc-valid-index-p): * lisp/net/ange-ftp.el (ange-ftp-use-smart-gateway-p): * lisp/net/nsm.el (nsm-save-fingerprint-maybe) (nsm-network-same-subnet, nsm-should-check): * lisp/net/rcirc.el (rcirc-looking-at-input): * lisp/net/tramp-cache.el (tramp-get-hash-table): * lisp/net/tramp-compat.el (tramp-compat-process-running-p): * lisp/net/tramp-smb.el (tramp-smb-get-share) (tramp-smb-get-localname, tramp-smb-read-file-entry) (tramp-smb-get-cifs-capabilities, tramp-smb-get-stat-capability): * lisp/net/zeroconf.el (zeroconf-list-service-names) (zeroconf-list-service-types, zeroconf-list-services) (zeroconf-get-host, zeroconf-get-domain) (zeroconf-get-host-domain): * lisp/nxml/rng-xsd.el (rng-xsd-compile) (rng-xsd-make-date-time-regexp, rng-xsd-convert-date-time): * lisp/obsolete/erc-hecomplete.el (erc-hecomplete) (erc-command-list, erc-complete-at-prompt): * lisp/org/ob-scheme.el (org-babel-scheme-get-buffer-impl): * lisp/org/ob-shell.el (org-babel--variable-assignments:sh-generic) (org-babel--variable-assignments:bash_array) (org-babel--variable-assignments:bash_assoc) (org-babel--variable-assignments:bash): * lisp/org/org-clock.el (org-day-of-week): * lisp/progmodes/cperl-mode.el (cperl-char-ends-sub-keyword-p): * lisp/progmodes/gud.el (gud-find-c-expr, gud-innermost-expr) (gud-prev-expr, gud-next-expr): * lisp/textmodes/table.el (table--at-cell-p, table--probe-cell) (table--get-cell-justify-property) (table--get-cell-valign-property) (table--put-cell-justify-property) (table--put-cell-valign-property): Fix typos. * lisp/so-long.el (fboundp): Doc fix. (so-long-mode-line-info, so-long-mode) (so-long--check-header-modes): Fix typos. * lisp/emulation/viper-mous.el (viper-surrounding-word) (viper-mouse-click-get-word): Fix typos. (viper-mouse-click-search-word): Doc fix. * lisp/erc/erc-backend.el (erc-forward-word, erc-word-at-arg-p) (erc-bounds-of-word-at-point): Fix typos. (erc-decode-string-from-target, define-erc-response-handler): Refill docstring. * lisp/erc/erc-dcc.el (pcomplete/erc-mode/DCC): Fix typo. (erc-dcc-get-host, erc-dcc-auto-mask-p, erc-dcc-get-file): Doc fixes. * lisp/erc/erc-networks.el (erc-network-name): Fix typo. (erc-determine-network): Refill docstring. * lisp/net/dbus.el (dbus-list-hash-table) (dbus-string-to-byte-array, dbus-byte-array-to-string) (dbus-check-event): Fix typos. (dbus-introspect-get-property): Doc fix. * lisp/net/tramp-adb.el (tramp-adb-file-name-handler): Rename ARGS to ARGUMENTS. Doc fix. (tramp-adb-sh-fix-ls-output, tramp-adb-execute-adb-command) (tramp-adb-find-test-command): Fix typos. * lisp/net/tramp.el (tramp-set-completion-function) (tramp-get-completion-function) (tramp-completion-dissect-file-name) (tramp-completion-dissect-file-name1) (tramp-get-completion-methods, tramp-get-completion-user-host) (tramp-get-inode, tramp-get-device, tramp-mode-string-to-int) (tramp-call-process, tramp-call-process-region) (tramp-process-lines): Fix typos. (tramp-interrupt-process): Doc fix. * lisp/org/ob-core.el (org-babel-named-src-block-regexp-for-name) (org-babel-named-data-regexp-for-name): Doc fix. (org-babel-src-block-names, org-babel-result-names): Fix typos. * lisp/progmodes/inf-lisp.el (lisp-input-filter): Doc fix. (lisp-fn-called-at-pt): Fix typo. * lisp/progmodes/xref.el (xref-backend-identifier-at-point): Doc fix. (xref-backend-identifier-completion-table): Fix typo.
396 lines
13 KiB
EmacsLisp
396 lines
13 KiB
EmacsLisp
;;; ede/linux.el --- Special project for Linux
|
|
|
|
;; Copyright (C) 2008-2019 Free Software Foundation, Inc.
|
|
|
|
;; Author: Eric M. Ludlam <zappo@gnu.org>
|
|
|
|
;; 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 <https://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)
|
|
(require 'ede/make)
|
|
(require 'semantic/db)
|
|
(eval-when-compile (require 'cl-lib))
|
|
|
|
;;; Code:
|
|
(defgroup project-linux nil
|
|
"File and tag browser frame."
|
|
:group 'tools
|
|
:group 'ede
|
|
:version "24.3")
|
|
|
|
(defcustom project-linux-build-directory-default 'ask
|
|
"Build directory."
|
|
:version "24.4"
|
|
:group 'project-linux
|
|
:type '(choice (const :tag "Same as source directory" same)
|
|
(const :tag "Ask the user" ask)))
|
|
|
|
(defcustom project-linux-architecture-default 'ask
|
|
"Target architecture to assume when not auto-detected."
|
|
:version "24.4"
|
|
:group 'project-linux
|
|
:type '(choice (string :tag "Architecture name")
|
|
(const :tag "Ask the user" ask)))
|
|
|
|
|
|
(defcustom project-linux-compile-target-command (concat ede-make-command " -k -C %s SUBDIRS=%s")
|
|
"Default command used to compile a target."
|
|
:group 'project-linux
|
|
:type 'string)
|
|
|
|
(defcustom project-linux-compile-project-command (concat ede-make-command " -k -C %s")
|
|
"Default command used to compile a project."
|
|
:group 'project-linux
|
|
:type 'string)
|
|
|
|
(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)
|
|
((build-directory :initarg :build-directory
|
|
:type string
|
|
:documentation "Build directory.")
|
|
(architecture :initarg :architecture
|
|
:type string
|
|
:documentation "Target architecture.")
|
|
(include-path :initarg :include-path
|
|
:type list
|
|
:documentation "Include directories.
|
|
Contains both common and target architecture-specific directories."))
|
|
"Project Type for the Linux source code."
|
|
:method-invocation-order :depth-first)
|
|
|
|
|
|
(defun ede-linux--get-build-directory (dir)
|
|
"Detect build directory for sources in DIR.
|
|
If DIR has not been used as a build directory, fall back to
|
|
`project-linux-build-directory-default'."
|
|
(or
|
|
;; detected build on source directory
|
|
(and (file-exists-p (expand-file-name ".config" dir)) dir)
|
|
;; use configuration
|
|
(cl-case project-linux-build-directory-default
|
|
(same dir)
|
|
(ask (read-directory-name "Select Linux' build directory: " dir)))))
|
|
|
|
|
|
(defun ede-linux--get-archs (dir)
|
|
"Return a list of architecture names found in DIR."
|
|
(let ((archs-dir (expand-file-name "arch" dir))
|
|
archs)
|
|
(when (file-directory-p archs-dir)
|
|
(mapc (lambda (elem)
|
|
(when (and
|
|
(not (string= elem "."))
|
|
(not (string= elem ".."))
|
|
(not (string= elem "x86_64")) ; has no separate sources
|
|
(file-directory-p
|
|
(expand-file-name elem archs-dir)))
|
|
(add-to-list 'archs elem t)))
|
|
(directory-files archs-dir)))
|
|
archs))
|
|
|
|
|
|
(defun ede-linux--detect-architecture (dir)
|
|
"Try to auto-detect the architecture as configured in DIR.
|
|
DIR is Linux' build directory. If it cannot be auto-detected,
|
|
returns `project-linux-architecture-default'."
|
|
(let ((archs-dir (expand-file-name "arch" dir))
|
|
(archs (ede-linux--get-archs dir))
|
|
arch found)
|
|
(or (and
|
|
archs
|
|
;; Look for /arch/<arch>/include/generated
|
|
(progn
|
|
(while (and archs (not found))
|
|
(setq arch (car archs))
|
|
(when (file-directory-p
|
|
(expand-file-name (concat arch "/include/generated")
|
|
archs-dir))
|
|
(setq found arch))
|
|
(setq archs (cdr archs)))
|
|
found))
|
|
project-linux-architecture-default)))
|
|
|
|
(defun ede-linux--get-architecture (dir bdir)
|
|
"Try to auto-detect the architecture as configured in BDIR.
|
|
Uses `ede-linux--detect-architecture' for the auto-detection.
|
|
If the result is `ask', let the user choose from architectures
|
|
found in DIR."
|
|
(let ((arch (ede-linux--detect-architecture bdir)))
|
|
(cl-case arch
|
|
(ask
|
|
(completing-read "Select target architecture: "
|
|
(ede-linux--get-archs dir)))
|
|
(t arch))))
|
|
|
|
|
|
(defun ede-linux--include-path (dir bdir arch)
|
|
"Return a list with include directories.
|
|
Returned directories might not exist, since they are not created
|
|
until Linux is built for the first time."
|
|
(cl-map 'list
|
|
(lambda (elem) (format (concat (car elem) "/" (cdr elem)) arch))
|
|
;; XXX: taken from the output of "make V=1"
|
|
(list (cons dir "arch/%s/include")
|
|
(cons bdir "arch/%s/include/generated")
|
|
(cons dir "include")
|
|
(cons bdir "include")
|
|
(cons dir "arch/%s/include/uapi")
|
|
(cons bdir "arch/%s/include/generated/uapi")
|
|
(cons dir "include/uapi")
|
|
(cons bdir "include/generated/uapi"))))
|
|
|
|
;;;###autoload
|
|
(defun ede-linux-load (dir &optional _rootproj)
|
|
"Return a 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."
|
|
;; Doesn't already exist, so let's make one.
|
|
(let* ((bdir (ede-linux--get-build-directory dir))
|
|
(arch (ede-linux--get-architecture dir bdir))
|
|
(include-path (ede-linux--include-path dir bdir arch)))
|
|
(make-instance 'ede-linux-project
|
|
:name "Linux"
|
|
:version (ede-linux-version dir)
|
|
:directory (file-name-as-directory dir)
|
|
:file (expand-file-name "scripts/ver_linux"
|
|
dir)
|
|
:build-directory bdir
|
|
:architecture arch
|
|
:include-path include-path)))
|
|
|
|
;;;###autoload
|
|
(ede-add-project-autoload
|
|
(make-instance 'ede-project-autoload
|
|
:name "LINUX ROOT"
|
|
:file 'ede/linux
|
|
:proj-file "scripts/ver_linux"
|
|
:load-type 'ede-linux-load
|
|
:class-sym 'ede-linux-project
|
|
:new-p nil
|
|
:safe-p t)
|
|
'unique)
|
|
|
|
(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.")
|
|
|
|
(cl-defmethod initialize-instance ((this ede-linux-project)
|
|
&rest _fields)
|
|
"Make sure the targets slot is bound."
|
|
(cl-call-next-method)
|
|
(unless (slot-boundp this 'targets)
|
|
(oset this :targets nil)))
|
|
|
|
;;; File Stuff
|
|
;;
|
|
(cl-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))))
|
|
|
|
(cl-defmethod ede-project-root ((this ede-linux-project))
|
|
"Return my root."
|
|
this)
|
|
|
|
(cl-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))
|
|
|
|
(cl-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.
|
|
;;
|
|
(cl-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)))
|
|
|
|
(cl-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))
|
|
(bdir (oref proj build-directory))
|
|
(F (cond
|
|
((not ext) nil)
|
|
((string-match "h" ext)
|
|
(let ((dirs (oref proj include-path))
|
|
found)
|
|
(while (and dirs (not found))
|
|
(setq found
|
|
(or (ede-linux-file-exists-name name bdir (car dirs))
|
|
(ede-linux-file-exists-name name dir (car dirs))))
|
|
(setq dirs (cdr dirs)))
|
|
found))
|
|
((string-match "txt" ext)
|
|
(ede-linux-file-exists-name name dir "Documentation"))
|
|
(t nil))))
|
|
(or F (cl-call-next-method))))
|
|
|
|
;;; Command Support
|
|
;;
|
|
(cl-defmethod project-compile-project ((proj ede-linux-project)
|
|
&optional command)
|
|
"Compile the entire current project.
|
|
Argument COMMAND is the command to use when compiling."
|
|
(let* ((dir (ede-project-root-directory proj)))
|
|
|
|
(require 'compile)
|
|
(if (not project-linux-compile-project-command)
|
|
(setq project-linux-compile-project-command compile-command))
|
|
(if (not command)
|
|
(setq command
|
|
(format
|
|
project-linux-compile-project-command
|
|
dir)))
|
|
|
|
(compile command)))
|
|
|
|
(cl-defmethod project-compile-target ((obj ede-linux-target-c) &optional command)
|
|
"Compile the current target.
|
|
Argument COMMAND is the command to use for compiling the target."
|
|
(let* ((proj (ede-target-parent obj))
|
|
(root (ede-project-root proj))
|
|
(dir (ede-project-root-directory root))
|
|
(subdir (oref obj path)))
|
|
|
|
(require 'compile)
|
|
(if (not project-linux-compile-project-command)
|
|
(setq project-linux-compile-project-command compile-command))
|
|
(if (not command)
|
|
(setq command
|
|
(format
|
|
project-linux-compile-target-command
|
|
dir subdir)))
|
|
|
|
(compile command)))
|
|
|
|
(cl-defmethod project-rescan ((this ede-linux-project))
|
|
"Rescan this Linux project from the sources."
|
|
(let* ((dir (ede-project-root-directory this))
|
|
(bdir (ede-linux--get-build-directory dir))
|
|
(arch (ede-linux--get-architecture dir bdir))
|
|
(inc (ede-linux--include-path dir bdir arch))
|
|
(ver (ede-linux-version dir)))
|
|
(oset this version ver)
|
|
(oset this :build-directory bdir)
|
|
(oset this :architecture arch)
|
|
(oset this :include-path inc)
|
|
))
|
|
|
|
(provide 'ede/linux)
|
|
|
|
;; Local variables:
|
|
;; generated-autoload-file: "loaddefs.el"
|
|
;; generated-autoload-load-name: "ede/linux"
|
|
;; End:
|
|
|
|
;;; ede/linux.el ends here
|