;;; @(#) ada-prj.el --- Easy editing of project files for the ada-mode
-;; Copyright (C) 1998, 1999 Ada Core Technologies, Inc
+;; Copyright (C) 1998,1999 Free Software Foundation, Inc.
;; Author: Emmanuel Briot <briot@gnat.com>
;; Ada Core Technologies's version: $Revision: 1.30 $
;; ------ Functions -------------------------------------------------------
(defun ada-prj-add-ada-menu ()
- "Add a new submenu to the Ada menu"
+ "Add a new submenu to the Ada menu."
(interactive)
(if ada-xemacs
))
(defun ada-prj-add-keymap ()
- "Add new keybindings for ada-prj"
+ "Add new keybindings for ada-prj."
(define-key ada-mode-map "\C-cu" 'ada-customize))
(defun ada-customize (&optional new-file)
- "Edit the project file associated with the current buffer, or
-a new one if none is found"
+ "Edit the project file associated with the current buffer.
+If there is none or NEW-FILE is non-nil, make a new one."
(interactive)
(if new-file
(progn
(ada-prj-customize)))
(defun ada-prj-save ()
- "save the edited project file"
+ "Save the currently edited project file."
(interactive)
(let ((file-name (widget-value ada-prj-widget-prj-dir))
value output)
)
(defun ada-prj-customize ()
- "Edit the project file whose name is given by prj-file."
+ "Edit the project file associated with the current Ada buffer."
(let* ((old-name (buffer-file-name))
prj-file)
(mapcar 'delete-overlay (car all))
(mapcar 'delete-overlay (cdr all))))
- (use-local-map widget-keymap)
+ (use-local-map (copy-keymap custom-mode-map))
(local-set-key "\C-x\C-s" 'ada-prj-save)
(widget-insert "
----------------------------------------------------------------
--- Customize your emacs ada mode for the current application --
+-- Customize your Emacs Ada mode for the current application --
----------------------------------------------------------------
This buffer will allow you to create easily a project file for your application.
-This file will tell emacs where to find the ada sources, the cross-referencing
+This file will tell Emacs where to find the ada sources, the cross-referencing
informations, how to compile and run your application, ...
Please use the RETURN key, or middle mouse button to activate the fields.\n\n")
(setq ada-prj-widget-src-dir
(ada-prj-list 'ada-prj-widget-src-dir prj-file "src_dir"
(get 'ada-prj-default 'src_dir)
- "\nYou should enter below all the directories where emacs
+ "\nYou should enter below all the directories where Emacs
will find your ada sources for the current application\n"))
(setq ada-prj-widget-obj-dir
(get 'ada-prj-default 'obj_dir)
"\nBelow are the directories where the object files generated
by the compiler will be found. This files are required for the cross-referencing
-capabilities of the emacs ada-mode.\n"))
+capabilities of the Emacs' Ada-mode.\n"))
(setq ada-prj-widget-comp-opt
(ada-prj-new 'ada-prj-widget-comp-opt prj-file "comp_opt"
;; ---------------- Utilities --------------------------------
(defun ada-prj-new (variable prj-file text default message)
- "Create a buffer-local text variable, whose value is either read in
-the prj-file or default
-Then adds a text field (with MESSAGE), and returns the created widget"
+ "Create a buffer-local variable with name VARIABLE.
+If PRJ-FILE exists, read its value from that file, otherwise set it to
+DEFAULT.
+It also creates a widget in the current buffer to edit this variable,
+which MESSAGE explaning what the variable is supposed to do.
+TEXT is put just before the editable field, and should display the name
+of the variable."
;; create local variable
(make-local-variable variable)
(defun ada-prj-list (variable prj-file text default message)
- "Create a buffer-local list variable, whose value is either read in
-the prj-file or default
-Then adds a list widget (with MESSAGE), and returns the created widget"
+ "Create a buffer-local list variable with name VARIABLE.
+If PRJ-FILE exists, read its value from that file, otherwise set it to
+DEFAULT.
+It also creates a widget in the current buffer to edit this variable,
+which MESSAGE explaning what the variable is supposed to do.
+TEXT is put just before the editable field, and should display the name
+of the variable."
;; create local variable
(make-local-variable variable)
:value variable
(list 'editable-field :keymap widget-keymap)))
-(defun ada-prj-set-list (string ada-dir-list)
- "Creates a single string of blank-separated directory names"
+(defsubst ada-prj-set-list (string ada-dir-list)
+ "Join the strings in ADA-DIR-LIST into a single string. Each name is put
+on a separate line that begins with STRING."
(mapconcat (lambda (x)
- (concat string "="
- x
- (unless (string=
- (substring x -1)
- "/")
+ (concat string "=" x
+ (unless (string= (substring x -1) "/")
"/")))
ada-dir-list "\n"))
(defun ada-prj-get-prj-dir (&optional ada-file)
- "returns a string which is the directory/name of the prj file.
-If no-standard-prj is t, do not use the default algorithm, just
-use a default name"
+ "Returns the directory/name of the project file for ADA-FILE.
+If ADA-FILE is nil, returns the project file for the current buffer."
(unless ada-file
(setq ada-file (buffer-file-name)))
;; @(#) ada-xref.el --- use Gnat for lookup and completion in Ada mode
-;; Copyright (C) 1994-1999 Free Software Foundation, Inc.
+;; Copyright (C) 1994, 1995--1998, 1999 Free Software Foundation, Inc.
;; Author: Markus Heritsch <Markus.Heritsch@studbox.uni-stuttgart.de>
;; Rolf Ebert <ebert@inf.enst.fr>
;; frame to show the declaration
;;; - `ada-compile-application': recompile your whole application, provided
;;; that a project file exists in your directory
-;;; - `ada-run-application': run your application directly from emacs
-;;; - `ada-reread-prj-file': force emacs to read your project file again.
-;;; Otherwise, this file is only read the first time emacs needs some
+;;; - `ada-run-application': run your application directly from Emacs
+;;; - `ada-reread-prj-file': force Emacs to read your project file again.
+;;; Otherwise, this file is only read the first time Emacs needs some
;;; informations, which are then kept in memory
;;; - `ada-change-prj': change the prj file associated with a buffer
;;; - `ada-change-default-prj': change the default project file used for
;; ------ Use variables
(defcustom ada-xref-other-buffer t
- "*if non-nil then either use a buffer in the same frame or another frame.
-If Nil, always jump to the declaration in the same buffer"
+ "*If nil, always display the cross-references in the same buffer.
+Otherwise create either a new buffer or a new frame."
:type 'boolean :group 'ada)
(defcustom ada-xref-create-ali t
- "*if non-nil, run gcc whenever it is needed
-if nil, the cross-reference mode will never run gcc"
+ "*If non-nil, run gcc whenever the cross-references are not up-to-date.
+If nil, the cross-reference mode will never run gcc."
:type 'boolean :group 'ada)
(defcustom ada-xref-confirm-compile nil
- "*if non-nil, ask for command confirmation before compiling or
-running the application"
+ "*If non-nil, always ask for user confirmation before compiling or running
+the application."
:type 'boolean :group 'ada)
(defcustom ada-krunch-args "0"
- "*Maximum number of characters for filename create by gnatkr
-Set to 0, if you don't use crunched filenames."
+ "*Maximum number of characters for filenames created by gnatkr.
+Set to 0, if you don't use crunched filenames. This should be a string."
:type 'string :group 'ada)
-(defcustom ada-prj-default-comp-cmd "${cross_prefix}gcc -c -g -gnatq ${comp_opt} -I${src_dir}"
+(defcustom ada-prj-default-comp-cmd
+ "${cross_prefix}gcc -c -g -gnatq ${comp_opt} -I${src_dir}"
"*Default command to be used to compile a single file.
Emacs will add the filename at the end of this command.
This is the same syntax as in the project file."
:type 'string :group 'ada)
(defcustom ada-prj-default-project-file ""
- "*Non nil means always use this project file, no matter what the
-directory is. Emacs will not try to use the standard algorithm to
-find the project file.
-Note: you can use M-<TAB> in the customization buffer for completion"
+ "*Name of the project file to use for every Ada file.
+Emacs will not try to use the standard algorithm to find the project file if
+this string is not empty."
:type '(file :must-match t) :group 'ada)
(defcustom ada-gnatstub-opts "-q -I${src_dir}"
- "*List of the options to pass to gnatsub when generating the body from
-a spec file. This has the same syntax as in the project file (with
-variable substitution"
+ "*List of the options to pass to gnatsub to generate the body of a package.
+This has the same syntax as in the project file (with variable substitution)."
:type 'string :group 'ada)
(defcustom ada-always-ask-project nil
- "*Non-nil means ask for the name of a project file to use when none is
-found by the standard algorithm.
-Nil means use default values when no project file was found")
+ "*If nil, use default values when no project file was found.
+Otherwise, ask the user for the name of the project file to use.")
;; ------- Nothing to be modified by the user below this
(defvar ada-last-prj-file ""
- "Name of the last project file entered by the user, when the
-default algorithm did not find any possible project file")
+ "Name of the last project file entered by the user.")
(defvar ada-check-switch " -gnats "
- "Switch added to the command line to check the current file")
+ "Switch added to the command line to check the current file.")
(defvar ada-project-file-extension ".adp"
- "The extension used for project files")
+ "The extension used for project files.")
(defconst is-windows (memq system-type (quote (windows-nt)))
- "true if we are running on windows NT or windows 95")
+ "True if we are running on windows NT or windows 95.")
(defvar ada-xref-pos-ring '()
- "This is the list of all the positions we went to with the
-cross-references features. This is used to go back to these positions.")
+ "List of positions selected by the cross-references functions.
+Used to go back to these positions.")
(defconst ada-xref-pos-ring-max 16
- "Number of positions kept in the list ada-xref-pos-ring")
+ "Number of positions kept in the list ada-xref-pos-ring.")
(defvar ada-operator-re
"\\+\\|-\\|/\\|\\*\\|=\\|mod\\|and\\|not\\|or\\|xor\\|<=\\|<\\|>=\\|>"
- "Regexp to match for operators")
+ "Regexp to match for operators.")
(defvar ada-xref-default-prj-file nil
- "name of the default prj file, per directory.
-Every directory is potentially associated with a default project file
+ "Name of the default prj file, per directory.
+Every directory is potentially associated with a default project file.
If it is nil, then the first prj file loaded will be the default for this
-emacs session")
+Emacs session.")
;; These variables will be overwritted by buffer-local variables
(defvar ada-prj-prj-file nil
- "Name of the project file for the current ada buffer")
+ "Name of the project file for the current ada buffer.")
(defvar ada-prj-src-dir nil
- "List of directories to look into for ada sources")
+ "List of directories to look into for ada sources.")
(defvar ada-prj-obj-dir nil
- "List of directories to look into for object and .ali files")
+ "List of directories to look into for object and .ali files.")
(defvar ada-prj-comp-opt nil
- "Switches to use on the command line for the default compile
-command (gcc)")
+ "Switches to use on the command line for the default compile command.")
(defvar ada-prj-bind-opt nil
- "Switches to use on the command line for the default bind
-command (gnatbind)")
+ "Switches to use on the command line for the default bind command.")
(defvar ada-prj-link-opt nil
- "Switches to use on the command line for the default link
-command (gnatlink)")
+ "Switches to use on the command line for the default link command.")
(defvar ada-prj-comp-cmd nil
- "Command to use to compile the current file only")
+ "Command to use to compile the current file only.")
(defvar ada-prj-make-cmd nil
- "Command to use to compile the whole current application")
+ "Command to use to compile the whole current application.")
(defvar ada-prj-run-cmd nil
- "Command to use to run the current application")
+ "Command to use to run the current application.")
(defvar ada-prj-debug-cmd nil
- "Command to use to run the debugger")
+ "Command to use to run the debugger.")
(defvar ada-prj-main nil
- "Name of the main programm of the current application")
+ "Name of the main programm of the current application.")
(defvar ada-prj-remote-machine nil
- "Name of the machine to log on before a compilation")
+ "Name of the machine to log on before a compilation.")
(defvar ada-prj-cross-prefix nil
"Prefix to be added to the gnatmake, gcc, ... commands when
using a cross-compilation environment.
A '-' is automatically added at the end if not already present.
-For instance, the compiler is called `ada-prj-cross-prefix'gnatmake")
+For instance, the compiler is called `ada-prj-cross-prefix'gnatmake.")
;; ----- Keybindings ------------------------------------------------------
(defun ada-add-keymap ()
- "Add new key bindings when using ada-xrel.el"
+ "Add new key bindings when using `ada-xrel.el'."
(interactive)
(if ada-xemacs
(progn
;; ----- Menus --------------------------------------------------------------
(defun ada-add-ada-menu ()
- "Add some items to the standard Ada mode menu (the menu defined in
-ada-mode.el)"
+ "Add some items to the standard Ada mode menu."
(interactive)
(if ada-xemacs
(progn
(add-menu-button '("Ada") ["Check file" ada-check-current t] "Goto")
- (add-menu-button '("Ada") ["Compile file" ada-compile-current t] "Goto")
+ (add-menu-button '("Ada") ["Compile file" ada-compile-current t]
+ "Goto")
(add-menu-button '("Ada") ["Build" ada-compile-application t] "Goto")
(add-menu-button '("Ada") ["Run" ada-run-application t] "Goto")
(add-menu-button '("Ada") ["Debug" ada-gdb-application t] "Goto")
"Goto")
(add-menu-button '("Ada" "Goto") ["Goto Parent Unit" ada-goto-parent t]
"Next compilation error")
- (add-menu-button '("Ada" "Goto") ["Goto References to any entity" ada-find-any-references t]
+ (add-menu-button '("Ada" "Goto") ["Goto References to any entity"
+ ada-find-any-references t]
"Next compilation error")
- (add-menu-button '("Ada" "Goto") ["List References" ada-find-references t]
+ (add-menu-button '("Ada" "Goto") ["List References"
+ ada-find-references t]
"Next compilation error")
(add-menu-button '("Ada" "Goto") ["Goto Declaration Other Frame"
ada-goto-declaration-other-frame t]
"Next compilation error")
- (add-menu-button '("Ada" "Goto") ["Goto Declaration/Body" ada-goto-declaration t]
+ (add-menu-button '("Ada" "Goto") ["Goto Declaration/Body"
+ ada-goto-declaration t]
"Next compilation error")
- (add-menu-button '("Ada" "Goto") ["Goto Previous Reference" ada-xref-goto-previous-reference t]
+ (add-menu-button '("Ada" "Goto") ["Goto Previous Reference"
+ ada-xref-goto-previous-reference t]
"Next compilation error")
(add-menu-button '("Ada" "Goto") ["--" nil t]
"Next compilation error")
- (add-menu-button '("Ada" "Edit") ["Complete Identifier" ada-complete-identifier t]
+ (add-menu-button '("Ada" "Edit") ["Complete Identifier"
+ ada-complete-identifier t]
"Indent Line")
(add-menu-button '("Ada" "Edit") ["--------" nil t]
"Indent Line")
(define-key help-submenu [Gcc]
'("Gcc Documentation" . (lambda() (interactive) (info "gcc"))))
(define-key help-submenu [gdb]
- '("Ada Aware Gdb Documentation" . (lambda() (interactive) (info "gdb"))))
+ '("Ada Aware Gdb Documentation" .
+ (lambda() (interactive) (info "gdb"))))
(define-key goto-submenu [rem] '("----" . nil))
- (define-key goto-submenu [Parent] '("Goto Parent Unit" . ada-goto-parent))
+ (define-key goto-submenu [Parent]
+ '("Goto Parent Unit" . ada-goto-parent))
(define-key goto-submenu [References-any]
'("Goto References to any entity" . ada-find-any-references))
(define-key goto-submenu [References]
;; ----- Utilities -------------------------------------------------
(defun ada-require-project-file ()
- "If no project file is assigned to this buffer, load one"
+ "If no project file is assigned to this buffer, load one."
(if (not ( my-local-variable-if-set-p 'ada-prj-src-dir (current-buffer)))
(ada-parse-prj-file (ada-prj-find-prj-file))))
(defun my-local-variable-if-set-p (variable &optional buffer)
+ "Returns t if VARIABLE is local in BUFFER and is non-nil."
(and (local-variable-p variable buffer)
(save-excursion
(set-buffer buffer)
(symbol-value variable))))
(defun ada-xref-push-pos (filename position)
- "Push (FILENAME, POSITION) on the position ring for cross-references"
+ "Push (FILENAME, POSITION) on the position ring for cross-references."
(setq ada-xref-pos-ring (cons (list position filename) ada-xref-pos-ring))
(if (> (length ada-xref-pos-ring) ada-xref-pos-ring-max)
(setcdr (nthcdr (1- ada-xref-pos-ring-max) ada-xref-pos-ring) nil)))
(defun ada-xref-goto-previous-reference ()
- "Go to the previous cross-reference we were on"
+ "Go to the previous cross-reference we were on."
(interactive)
(if ada-xref-pos-ring
- (progn
- (let ((pos (car ada-xref-pos-ring)))
- (setq ada-xref-pos-ring (cdr ada-xref-pos-ring))
- (find-file (car (cdr pos)))
- (goto-char (car pos))))))
+ (let ((pos (car ada-xref-pos-ring)))
+ (setq ada-xref-pos-ring (cdr ada-xref-pos-ring))
+ (find-file (car (cdr pos)))
+ (goto-char (car pos)))))
(defun ada-convert-file-name (name)
- "Function to convert from the buffer file name to the name given in
-argument to the ada-compile-current function. This function is
-overridden on VMS to convert from VMS filename to Unix filenames"
+ "Converts from NAME to a name that can be used by the compilation commands.
+This is overriden on VMS to convert from VMS filenames to Unix filenames."
name)
(defun ada-set-default-project-file (name)
- (interactive "fName of project file:")
+ "Set the file whose name is NAME as the default project file."
+ (interactive "fProject file:")
(set 'ada-prj-default-project-file name)
(ada-reread-prj-file t)
)
-;; ------ Handling the project file -----------------------------
-
(defun ada-replace-substring (cmd-string search-for replace-with)
- "Replace all instances of SEARCH-FOR with REPLACE-WITH in
-string CMD-STRING"
+ "Replace all instances of SEARCH-FOR with REPLACE-WITH in CMD-STRING."
(while (string-match search-for cmd-string)
(setq cmd-string (replace-match replace-with t t cmd-string)))
cmd-string)
(defun ada-treat-cmd-string (cmd-string)
- "Replace meta-sequences like ${...} with the appropriate value in CMD-STRING.
-The current buffer must be the one where all local variable are definied (that
+ "Replace meta-sequences like ${...} in CMD-STRING with the appropriate value.
+The current buffer must be the one where all local variable are defined (that
is the ada source)"
-
(if ( my-local-variable-if-set-p 'ada-prj-src-dir (current-buffer))
(if (string-match "\\(-[^-\$I]*I\\)\${src_dir}" cmd-string)
(progn
(defun ada-prj-find-prj-file (&optional no-user-question)
- "Find the prj file associated with the current buffer
+ "Find the prj file associated with the current buffer.
The rules are the following ones :
- If the buffer is already associated with a prj file, use this one
- else if there's a default prj file for the same directory use it
- else if a prj file with the same filename exists, use it
- else if there's only one prj file in the directory, use it
- else if there are more than one prj file, ask the user
-- else if there is no prj file and no-user-question is nil, ask the user
+- else if there is no prj file and NO-USER-QUESTION is nil, ask the user
for the project file to use."
(let* ((current-file (buffer-file-name))
(first-choice (concat
(defun ada-parse-prj-file (prj-file)
- "Reads and parses the PRJ-FILE file if it was found.
+ "Reads and parses the project file PRJ-FILE.
+Does nothing if PRJ-FILE was not found.
The current buffer should be the ada-file buffer"
(let ((tmp-src-dir nil)
(defun ada-find-references (&optional pos)
- "Find every references to the entity under POS
-Calls gnatfind to find every references"
+ "Find all references to the entity under POS.
+Calls gnatfind to find the references."
(interactive "")
(unless pos
(set 'pos (point)))
)
(defun ada-find-any-references (entity &optional file line column)
- "Search for references to any entity"
+ "Search for references to any entity whose name is ENTITY.
+ENTITY was first found the location given by FILE, LINE and COLUMN."
(interactive "sEntity name: ")
(ada-require-project-file)
(if (my-local-variable-if-set-p 'ada-prj-prj-file (current-buffer))
(setq command (concat command " -p" ada-prj-prj-file)))
- (compile-internal command
- "No more references"
- "gnatfind")
+ (compile-internal command "No more references" "gnatfind")
;; Hide the "Compilation" menu
(save-excursion
)
(defun ada-buffer-list ()
- "Display a buffer with all the ada-mode buffers and their associated prj file"
+ "Display a buffer with all the Ada buffers and their associated project."
(interactive)
(save-excursion
(set-buffer (get-buffer-create "*Buffer List*"))
)
(defun ada-change-prj (filename)
- "Change the project file associated with the current buffer"
+ "Set FILENAME to be the project file for current buffer."
(interactive "fproject file:")
;; make sure we are using an Ada file
;; ask the user for the new file name
(setq ada-prj-prj-file filename)
- ;; force emacs to reread the prj file next-time
+ ;; force Emacs to reread the prj file next-time
(ada-reread-prj-file)
)
(defun ada-change-default-prj (filename)
- "Change the default project file used for all ada files from the
-current directory"
+ "Set FILENAME to be the default project file for the current directory."
(interactive "ffile name:")
(let ((dir (file-name-directory (buffer-file-name)))
(prj (expand-file-name filename)))
- ;; If the directory is already associated with a project file
+ ;; Associate the directory with a project file
(if (assoc dir ada-xref-default-prj-file)
-
(setcdr (assoc dir ada-xref-default-prj-file) prj)
- ;; Else create a new element in the list
(add-to-list 'ada-xref-default-prj-file (list dir prj)))
;; Reparse the project file
;; ----- Identifier Completion --------------------------------------------
(defun ada-complete-identifier (pos)
"Tries to complete the identifier around POS.
-The feature is only available if the files where compiled not using the -gnatx
-option"
+The feature is only available if the files where not compiled using the -gnatx
+option."
(interactive "d")
(ada-require-project-file)
(ada-goto-declaration (point)))
(defun ada-goto-declaration (pos)
- "Displays the declaration of the identifier around POS.
-The declaration is shown in another buffer if `ada-xref-other-buffer' is non-nil"
+ "Display the declaration of the identifier around POS.
+The declaration is shown in another buffer if `ada-xref-other-buffer' is
+non-nil."
(interactive "d")
(ada-require-project-file)
(push-mark pos)
(ada-find-in-ali (ada-read-identifier pos)))
(defun ada-goto-declaration-other-frame (pos)
- "Displays the declaration of the identifier around point.
-The declation is shown in another frame if `ada-xref-other-buffer' is non-nil"
+ "Display the declaration of the identifier around POS.
+The declation is shown in another frame if `ada-xref-other-buffer' is non-nil."
(interactive "d")
(ada-require-project-file)
(push-mark pos)
(ada-find-in-ali (ada-read-identifier pos) t))
(defun ada-compile (command)
- "Start a compilation, on the machine specified in the project file,
-using command COMMAND"
-
+ "Start COMMAND on the machine specified in the project file."
(if (and (my-local-variable-if-set-p 'ada-prj-remote-machine (current-buffer))
(not (string= ada-prj-remote-machine "")))
(set 'command
(compile command))
(defun ada-compile-application ()
- "Compiles the whole application, using the command find in the gnat.prj file"
+ "Compiles the application, using the command found in the project file."
(interactive)
(ada-require-project-file)
)
(defun ada-compile-current ()
- "Recompile the current file"
+ "Recompile the current file."
(interactive)
(ada-require-project-file)
)
(defun ada-check-current ()
- "Recompile the current file"
+ "Recompile the current file."
(interactive)
(ada-require-project-file)
(defun ada-run-application ()
- "Run the application"
+ "Run the application."
(interactive)
(ada-require-project-file)
(defun ada-gdb-application ()
- "Run the application"
+ "Start the debugger on the application."
(interactive)
(require 'gud)
(defun ada-reread-prj-file (&optional for-all-buffer)
- "Forces emacs to read the project file again.
+ "Forces Emacs to read the project file again.
Otherwise, this file is only read once, and never read again
-If `for-all-buffer' is non-nil, or the function was called with \C-u prefix,
-then do this for every opened buffer"
+If FOR-ALL-BUFFER is non-nil, or the function was called with \C-u prefix,
+then do this for every opened buffer."
(interactive "P")
(if for-all-buffer
;; ------ Private routines
(defun ada-xref-current (file &optional ali-file-name)
- "Creates a new ali file from the FILE source file,
-assuming the ali file will be called ALI-FILE-NAME.
-Uses the function `compile' to execute the commands
-defined in the project file."
+ "Update the cross-references for FILE.
+This in fact recompiles FILE to create ALI-FILE-NAME."
;; kill old buffer
(if (and ali-file-name
(get-file-buffer ali-file-name))
)
(defun ada-first-non-nil (list)
- "Returns the first non-nil element of the list"
+ "Returns the first non-nil element of the LIST"
(cond
((not list) nil)
((car list) (car list))
(defun ada-find-ali-file-in-dir (file)
- "Search for FILE in obj_dir
-The current buffer must be the Ada file"
+ "Search for FILE in obj_dir.
+The current buffer must be the Ada file."
(ada-first-non-nil
(mapcar (lambda (x)
(if (file-exists-p (concat (file-name-directory x)
)
(defun ada-get-ali-file-name (file)
- "create the ali file name for the ada-file FILE
-The file is searched for in every directory shown in the
-obj_dir lines of the project file"
+ "Create the ali file name for the ada-file FILE.
+The file is searched for in every directory shown in the obj_dir lines of
+the project file."
;; This function has to handle the special case of non-standard
;; file names (i.e. not .adb or .ads)
))
(defun ada-get-ada-file-name (file original-file)
- "Create the complete file name (+directory) for FILE
-The original file (where the user was) is ORIGINAL-FILE.
-Search in project file for possible paths"
+ "Create the complete file name (+directory) for FILE.
+The original file (where the user was) is ORIGINAL-FILE. Search in project
+file for possible paths."
(save-excursion
(set-buffer (get-file-buffer original-file))
)))
(defun ada-find-file-number-in-ali (file)
- "Returns the file number for FILE in the associated ali file"
+ "Returns the file number for FILE in the associated ali file."
(set-buffer (ada-get-ali-buffer file))
(goto-char (point-min))
(count-lines begin (point))))
(defun ada-read-identifier (pos)
- "Returns the identlist around POS and switch to the .ali buffer"
+ "Returns the identlist around POS and switch to the .ali buffer."
;; If there's a compilation in progress, it's probably because the
;; .ali file didn't exist. So we should wait...
))
(defun ada-get-all-references (identlist)
- "Completes and returns the identlist with the information extracted
-from the ali file (definition file and places where it is referenced)"
+ "Completes and returns the IDENTLIST with the information extracted
+from the ali file (definition file and places where it is referenced)."
(let ((ali-buffer (ada-get-ali-buffer (ada-file-of identlist)))
declaration-found)
"Find the matching position for IDENTLIST in the current ali buffer.
This function is only called when the file was not up-to-date, so we need
to make some guesses.
-This function is disabled for operators, and only works for identifiers"
+This function is disabled for operators, and only works for identifiers."
(unless (= (string-to-char (ada-name-of identlist)) ?\")
(progn
(defun ada-find-in-ali (identlist &optional other-frame)
- "Look in the .ali file for the definition of the identifier
-if OTHER-FRAME is non nil, and `ada-xref-other-buffer' is non nil,
-opens a new window to show the declaration"
+ "Look in the .ali file for the definition of the identifier in IDENTLIST.
+If OTHER-FRAME is non nil, and `ada-xref-other-buffer' is non nil,
+opens a new window to show the declaration."
(ada-get-all-references identlist)
(let ((ali-line (ada-references-of identlist))
"Select and display FILE, at LINE and COLUMN. The new file is
associated with the same project file as the one for IDENTLIST.
If we do not end on the same identifier as IDENTLIST, find the closest
-match. Kills the .ali buffer at the end"
+match. Kills the .ali buffer at the end.
+If OTHER-FRAME is non-nil, creates a new frame to show the file."
(let (prj-file
declaration-buffer
;; Find the parent library file of the current file
(defun ada-goto-parent ()
- "go to the parent library file"
+ "Go to the parent library file."
(interactive)
(ada-require-project-file)
))
(defun ada-make-filename-from-adaname (adaname)
- "Determine the filename of a package/procedure from its own Ada name."
- ;; this is done simply by calling `gnatkr', when we work with GNAT. It
- ;; must be a more complex function in other compiler environments.
+ "Determine the filename in which ADANAME is found.
+This is a GNAT specific function that uses gnatkrunch."
(let (krunch-buf)
(setq krunch-buf (generate-new-buffer "*gkrunch*"))
(save-excursion