aboutsummaryrefslogtreecommitdiff
path: root/old_ada/doc
diff options
context:
space:
mode:
Diffstat (limited to 'old_ada/doc')
-rw-r--r--old_ada/doc/ada-mode.html2288
-rw-r--r--old_ada/doc/ada-mode.info1983
-rw-r--r--old_ada/doc/ada-mode.pdfbin303898 -> 0 bytes
-rw-r--r--old_ada/doc/ada-mode.texi1526
-rwxr-xr-xold_ada/doc/build.sh3
-rwxr-xr-xold_ada/doc/clean.sh2
-rw-r--r--old_ada/doc/doclicense.texi505
-rw-r--r--old_ada/doc/docstyle.texi19
8 files changed, 0 insertions, 6326 deletions
diff --git a/old_ada/doc/ada-mode.html b/old_ada/doc/ada-mode.html
deleted file mode 100644
index 6788acb..0000000
--- a/old_ada/doc/ada-mode.html
+++ /dev/null
@@ -1,2288 +0,0 @@
-<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
-<html>
-<!-- Created by GNU Texinfo 6.8, https://www.gnu.org/software/texinfo/ -->
-<head>
-<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
-<!-- Copyright (C) 1999-2019 Free Software Foundation, Inc.
-
-Permission is granted to copy, distribute and/or modify this document
-under the terms of the GNU Free Documentation License, Version 1.3 or
-any later version published by the Free Software Foundation; with no
-Invariant Sections, with the Front-Cover Texts being "A GNU Manual",
-and with the Back-Cover Texts as in (a) below. A copy of the license
-is included in the section entitled "GNU Free Documentation License".
-
-(a) The FSF's Back-Cover Text is: "You have the freedom to copy and
-modify this GNU manual." -->
-<title>Ada Mode</title>
-
-<meta name="description" content="Ada Mode">
-<meta name="keywords" content="Ada Mode">
-<meta name="resource-type" content="document">
-<meta name="distribution" content="global">
-<meta name="Generator" content="texi2any">
-<meta name="viewport" content="width=device-width,initial-scale=1">
-
-<link href="#Top" rel="start" title="Top">
-<link href="#Index" rel="index" title="Index">
-<link href="#SEC_Contents" rel="contents" title="Table of Contents">
-<link href="#Overview" rel="next" title="Overview">
-<style type="text/css">
-<!--
-a.copiable-anchor {visibility: hidden; text-decoration: none; line-height: 0em}
-a.summary-letter {text-decoration: none}
-blockquote.indentedblock {margin-right: 0em}
-div.display {margin-left: 3.2em}
-div.example {margin-left: 3.2em}
-kbd {font-style: oblique}
-pre.display {font-family: inherit}
-pre.format {font-family: inherit}
-pre.menu-comment {font-family: serif}
-pre.menu-preformatted {font-family: serif}
-span.nolinebreak {white-space: nowrap}
-span.roman {font-family: initial; font-weight: normal}
-span.sansserif {font-family: sans-serif; font-weight: normal}
-span:hover a.copiable-anchor {visibility: visible}
-ul.no-bullet {list-style: none}
--->
-</style>
-
-
-</head>
-
-<body lang="en">
-<h1 class="settitle" align="center">Ada Mode</h1>
-
-
-
-
-
-<div class="top" id="Top">
-<div class="header">
-<p>
-Next: <a href="#Overview" accesskey="n" rel="next">Overview</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#Index" title="Index" rel="index">Index</a>]</p>
-</div>
-<span id="Ada-Mode"></span><h1 class="top">Ada Mode</h1>
-
-<p>Copyright &copy; 1999&ndash;2019 Free Software Foundation, Inc.
-</p>
-<blockquote>
-<p>Permission is granted to copy, distribute and/or modify this document
-under the terms of the GNU Free Documentation License, Version 1.3 or
-any later version published by the Free Software Foundation; with no
-Invariant Sections, with the Front-Cover Texts being &ldquo;A GNU Manual&rdquo;,
-and with the Back-Cover Texts as in (a) below. A copy of the license
-is included in the section entitled &ldquo;GNU Free Documentation License&rdquo;.
-</p>
-<p>(a) The FSF&rsquo;s Back-Cover Text is: &ldquo;You have the freedom to copy and
-modify this GNU manual.&rdquo;
-</p></blockquote>
-
-
-
-<div class="Contents_element" id="SEC_Contents">
-<h2 class="contents-heading">Table of Contents</h2>
-
-<div class="contents">
-
-<ul class="no-bullet">
- <li><a id="toc-Overview-1" href="#Overview">1 Overview</a></li>
- <li><a id="toc-Installation-1" href="#Installation">2 Installation</a></li>
- <li><a id="toc-Customizing-Ada-mode" href="#Customization">3 Customizing Ada mode</a>
- <ul class="no-bullet">
- <li><a id="toc-Non_002dstandard-file-names-1" href="#Non_002dstandard-file-names">3.1 Non-standard file names</a></li>
- <li><a id="toc-Other-compiler-1" href="#Other-compiler">3.2 Other compiler</a></li>
- <li><a id="toc-Other-customization-1" href="#Other-customization">3.3 Other customization</a></li>
- </ul></li>
- <li><a id="toc-Compiling-Executing-1" href="#Compiling-Executing">4 Compiling Executing</a>
- <ul class="no-bullet">
- <li><a id="toc-Compile-commands-1" href="#Compile-commands">4.1 Compile commands</a></li>
- <li><a id="toc-Compiler-errors-1" href="#Compiler-errors">4.2 Compiler errors</a></li>
- </ul></li>
- <li><a id="toc-Project-files-1" href="#Project-files">5 Project files</a>
- <ul class="no-bullet">
- <li><a id="toc-Project-File-Overview-1" href="#Project-File-Overview">5.1 Project File Overview</a></li>
- <li><a id="toc-GUI-Editor-1" href="#GUI-Editor">5.2 GUI Editor</a></li>
- <li><a id="toc-Project-file-variables-1" href="#Project-file-variables">5.3 Project file variables</a></li>
- </ul></li>
- <li><a id="toc-Compiling-Examples-1" href="#Compiling-Examples">6 Compiling Examples</a>
- <ul class="no-bullet">
- <li><a id="toc-No-project-files-1" href="#No-project-files">6.1 No project files</a></li>
- <li><a id="toc-Set-compiler-options-1" href="#Set-compiler-options">6.2 Set compiler options</a></li>
- <li><a id="toc-Set-source-search-path-1" href="#Set-source-search-path">6.3 Set source search path</a></li>
- <li><a id="toc-Use-GNAT-project-file-1" href="#Use-GNAT-project-file">6.4 Use GNAT project file</a></li>
- <li><a id="toc-Use-multiple-GNAT-project-files-1" href="#Use-multiple-GNAT-project-files">6.5 Use multiple GNAT project files</a></li>
- </ul></li>
- <li><a id="toc-Moving-Through-Ada-Code-1" href="#Moving-Through-Ada-Code">7 Moving Through Ada Code</a></li>
- <li><a id="toc-Identifier-completion-1" href="#Identifier-completion">8 Identifier completion</a></li>
- <li><a id="toc-Automatic-Smart-Indentation-1" href="#Automatic-Smart-Indentation">9 Automatic Smart Indentation</a></li>
- <li><a id="toc-Formatting-Parameter-Lists-1" href="#Formatting-Parameter-Lists">10 Formatting Parameter Lists</a></li>
- <li><a id="toc-Automatic-Casing-1" href="#Automatic-Casing">11 Automatic Casing</a></li>
- <li><a id="toc-Statement-Templates-1" href="#Statement-Templates">12 Statement Templates</a></li>
- <li><a id="toc-Comment-Handling-1" href="#Comment-Handling">13 Comment Handling</a></li>
- <li><a id="toc-GNU-Free-Documentation-License-1" href="#GNU-Free-Documentation-License">Appendix A GNU Free Documentation License</a></li>
- <li><a id="toc-Index-1" href="#Index" rel="index">Index</a></li>
-</ul>
-</div>
-</div>
-<hr>
-<div class="chapter" id="Overview">
-<div class="header">
-<p>
-Next: <a href="#Installation" accesskey="n" rel="next">Installation</a>, Previous: <a href="#Top" accesskey="p" rel="prev">Ada Mode</a>, Up: <a href="#Top" accesskey="u" rel="up">Ada Mode</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#Index" title="Index" rel="index">Index</a>]</p>
-</div>
-<span id="Overview-1"></span><h2 class="chapter">1 Overview</h2>
-
-<p>The Emacs mode for programming in Ada helps the user in understanding
-existing code and facilitates writing new code.
-</p>
-<p>When the GNU Ada compiler GNAT is used, the cross-reference
-information output by the compiler is used to provide powerful code
-navigation (jump to definition, find all uses, etc.).
-</p>
-<p>When you open a file with a file extension of <samp>.ads</samp> or
-<samp>.adb</samp>, Emacs will automatically load and activate Ada mode.
-</p>
-<p>Ada mode works without any customization, if you are using the GNAT
-compiler (<a href="https://libre2.adacore.com/">https://libre2.adacore.com/</a>) and the GNAT default
-naming convention.
-</p>
-<p>You must customize a few things if you are using a different compiler
-or file naming convention; See <a href="#Other-compiler">Other compiler</a>, See <a href="#Non_002dstandard-file-names">Non-standard file names</a>.
-</p>
-<p>In addition, you may want to customize the indentation,
-capitalization, and other things; See <a href="#Other-customization">Other customization</a>.
-</p>
-<p>Finally, for large Ada projects, you will want to set up an Emacs
-Ada mode project file for each project; See <a href="#Project-files">Project files</a>. Note
-that these are different from the GNAT project files used by gnatmake
-and other GNAT commands.
-</p>
-<p>See the Emacs info manual, section &rsquo;Running Debuggers Under Emacs&rsquo;,
-for general information on debugging.
-</p>
-<hr>
-</div>
-<div class="chapter" id="Installation">
-<div class="header">
-<p>
-Next: <a href="#Customization" accesskey="n" rel="next">Customizing Ada mode</a>, Previous: <a href="#Overview" accesskey="p" rel="prev">Overview</a>, Up: <a href="#Top" accesskey="u" rel="up">Ada Mode</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#Index" title="Index" rel="index">Index</a>]</p>
-</div>
-<span id="Installation-1"></span><h2 class="chapter">2 Installation</h2>
-
-<p>Ada mode is part of the standard Emacs distribution; if you use that,
-no files need to be installed.
-</p>
-<p>Ada mode is also available as a separate distribution, from the Emacs
-Ada mode website
-<a href="http://stephe-leake.org/emacs/ada-mode/emacs-ada-mode.html">http://stephe-leake.org/emacs/ada-mode/emacs-ada-mode.html</a>. The
-separate distribution may be more recent.
-</p>
-<p>For installing the separate distribution, see the <samp>README</samp> file
-in the distribution.
-</p>
-<p>To see what version of Ada mode you have installed, do <kbd>M-x
-ada-mode-version</kbd>.
-</p>
-<p>The following files are provided with the Ada mode distribution:
-</p>
-<ul>
-<li> <samp>ada-mode.el</samp>: The main file for Ada mode, providing indentation,
-formatting of parameter lists, moving through code, comment handling
-and automatic casing.
-
-</li><li> <samp>ada-prj.el</samp>: GUI editing of Ada mode project files, using Emacs
-widgets.
-
-</li><li> <samp>ada-stmt.el</samp>: Ada statement templates.
-
-</li><li> <samp>ada-xref.el</samp>: GNAT cross-references, completion of identifiers,
-and compilation. Also provides project files (which are not
-GNAT-specific).
-
-</li></ul>
-
-<hr>
-</div>
-<div class="chapter" id="Customization">
-<div class="header">
-<p>
-Next: <a href="#Compiling-Executing" accesskey="n" rel="next">Compiling Executing</a>, Previous: <a href="#Installation" accesskey="p" rel="prev">Installation</a>, Up: <a href="#Top" accesskey="u" rel="up">Ada Mode</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#Index" title="Index" rel="index">Index</a>]</p>
-</div>
-<span id="Customizing-Ada-mode"></span><h2 class="chapter">3 Customizing Ada mode</h2>
-
-<p>Here we assume you are familiar with setting variables in Emacs,
-either thru &rsquo;customize&rsquo; or in elisp (in your <samp>.emacs</samp> file). For
-a basic introduction to customize, elisp, and Emacs in general, see
-the tutorial in
-<cite>The GNU Emacs Manual</cite>.
-</p>
-<p>These global Emacs settings are strongly recommended (put them in your
-.emacs):
-</p>
-<div class="example">
-<pre class="example">(global-font-lock-mode t)
-(transient-mark-mode t)
-</pre></div>
-
-<p>&lsquo;<samp>(global-font-lock-mode t)</samp>&rsquo; turns on syntax
-highlighting for all buffers (it is off by default because it may be
-too slow for some machines).
-</p>
-<p>&lsquo;<samp>(transient-mark-mode t)</samp>&rsquo; highlights selected text.
-</p>
-<p>See the Emacs help for each of these variables for more information.
-</p>
-
-<ul class="section-toc">
-<li><a href="#Non_002dstandard-file-names" accesskey="1">Non-standard file names</a></li>
-<li><a href="#Other-compiler" accesskey="2">Other compiler</a></li>
-<li><a href="#Other-customization" accesskey="3">Other customization</a></li>
-</ul>
-<hr>
-<div class="section" id="Non_002dstandard-file-names">
-<div class="header">
-<p>
-Next: <a href="#Other-compiler" accesskey="n" rel="next">Other compiler</a>, Up: <a href="#Customization" accesskey="u" rel="up">Customizing Ada mode</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#Index" title="Index" rel="index">Index</a>]</p>
-</div>
-<span id="Non_002dstandard-file-names-1"></span><h3 class="section">3.1 Non-standard file names</h3>
-
-<p>By default, Ada mode is configured to use the GNAT file naming
-convention, where file names are a simple modification of the Ada
-names, and the extension for specs and bodies are
-&lsquo;<samp>.ads</samp>&rsquo; and &lsquo;<samp>.adb</samp>&rsquo;, respectively.
-</p>
-<p>Ada mode uses the file extensions to allow moving from a package body
-to the corresponding spec and back.
-</p>
-<p>Ada mode supports a list of alternative file extensions for specs and bodies.
-</p>
-<p>For instance, if your spec and bodies files are called
-<samp><var>unit</var>_s.ada</samp> and <samp><var>unit</var>_b.ada</samp>, respectively, you
-can add the following to your <samp>.emacs</samp> file:
-</p>
-<div class="example">
-<pre class="example">(ada-add-extensions &quot;_s.ada&quot; &quot;_b.ada&quot;)
-</pre></div>
-
-<p>You can define additional extensions:
-</p>
-<div class="example">
-<pre class="example">(ada-add-extensions &quot;.ads&quot; &quot;_b.ada&quot;)
-(ada-add-extensions &quot;.ads&quot; &quot;.body&quot;)
-</pre></div>
-
-<p>This means that whenever Ada mode looks for the body for a file
-whose extension is <samp>.ads</samp>, it will take the first available file
-that ends with either <samp>.adb</samp>, <samp>_b.ada</samp> or
-<samp>.body</samp>.
-</p>
-<p>Similarly, if Ada mode is looking for a spec, it will look for
-<samp>.ads</samp> or <samp>_s.ada</samp>.
-</p>
-<p>If the filename is not derived from the Ada name following the GNAT
-convention, things are a little more complicated. You then need to
-rewrite the function <code>ada-make-filename-from-adaname</code>. Doing that
-is beyond the scope of this manual; see the current definitions in
-<samp>ada-mode.el</samp> and <samp>ada-xref.el</samp> for examples.
-</p>
-<hr>
-</div>
-<div class="section" id="Other-compiler">
-<div class="header">
-<p>
-Next: <a href="#Other-customization" accesskey="n" rel="next">Other customization</a>, Previous: <a href="#Non_002dstandard-file-names" accesskey="p" rel="prev">Non-standard file names</a>, Up: <a href="#Customization" accesskey="u" rel="up">Customizing Ada mode</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#Index" title="Index" rel="index">Index</a>]</p>
-</div>
-<span id="Other-compiler-1"></span><h3 class="section">3.2 Other compiler</h3>
-
-<p>By default, Ada mode is configured to use the GNU Ada compiler GNAT.
-</p>
-<p>To use a different Ada compiler, you must specify the command lines
-used to run that compiler, either in lisp variables or in Emacs
-Ada mode project files. See <a href="#Project-file-variables">Project file variables</a> for the list
-of project variables, and the corresponding lisp variables.
-</p>
-<hr>
-</div>
-<div class="section" id="Other-customization">
-<div class="header">
-<p>
-Previous: <a href="#Other-compiler" accesskey="p" rel="prev">Other compiler</a>, Up: <a href="#Customization" accesskey="u" rel="up">Customizing Ada mode</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#Index" title="Index" rel="index">Index</a>]</p>
-</div>
-<span id="Other-customization-1"></span><h3 class="section">3.3 Other customization</h3>
-
-<p>All user-settable Ada mode variables can be set via the menu
-&lsquo;<samp>Ada | Customize</samp>&rsquo;. Click on the &lsquo;<samp>Help</samp>&rsquo; button there for help
-on using customize.
-</p>
-<p>To modify a specific variable, you can directly call the function
-<code>customize-variable</code>; just type <kbd>M-x customize-variable
-<span class="key">RET</span> <var>variable-name</var> <span class="key">RET</span></kbd>).
-</p>
-<p>Alternately, you can specify variable settings in the Emacs
-configuration file, <samp>.emacs</samp>. This file is coded in Emacs lisp,
-and the syntax to set a variable is the following:
-</p><div class="example">
-<pre class="example">(setq variable-name value)
-</pre></div>
-
-<hr>
-</div>
-</div>
-<div class="chapter" id="Compiling-Executing">
-<div class="header">
-<p>
-Next: <a href="#Project-files" accesskey="n" rel="next">Project files</a>, Previous: <a href="#Customization" accesskey="p" rel="prev">Customizing Ada mode</a>, Up: <a href="#Top" accesskey="u" rel="up">Ada Mode</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#Index" title="Index" rel="index">Index</a>]</p>
-</div>
-<span id="Compiling-Executing-1"></span><h2 class="chapter">4 Compiling Executing</h2>
-
-<p>Ada projects can be compiled, linked, and executed using commands on
-the Ada menu. All of these commands can be customized via a project
-file (see <a href="#Project-files">Project files</a>), but the defaults are sufficient for using
-the GNAT compiler for simple projects (single files, or several files
-in a single directory).
-</p>
-<p>Even when no project file is used, the GUI project editor (menu
-&lsquo;<samp>Ada | Project | Edit</samp>&rsquo;) shows the settings of the various project
-file variables referenced here.
-</p>
-
-<ul class="section-toc">
-<li><a href="#Compile-commands" accesskey="1">Compile commands</a></li>
-<li><a href="#Compiler-errors" accesskey="2">Compiler errors</a></li>
-</ul>
-<hr>
-<div class="section" id="Compile-commands">
-<div class="header">
-<p>
-Next: <a href="#Compiler-errors" accesskey="n" rel="next">Compiler errors</a>, Up: <a href="#Compiling-Executing" accesskey="u" rel="up">Compiling Executing</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#Index" title="Index" rel="index">Index</a>]</p>
-</div>
-<span id="Compile-commands-1"></span><h3 class="section">4.1 Compile commands</h3>
-
-<p>Here are the commands for building and using an Ada project, as
-listed in the Ada menu.
-</p>
-<p>In multi-file projects, there must be one file that is the main
-program. That is given by the <code>main</code> project file variable;
-it defaults to the current file if not yet set, but is also set by the
-&ldquo;set main and build&rdquo; command.
-</p>
-<dl compact="compact">
-<dt><span><code>Check file</code></span></dt>
-<dd><p>Compiles the current file in syntax check mode, by running
-<code>check_cmd</code> defined in the current project file. This typically
-runs faster than full compile mode, speeding up finding and fixing
-compilation errors.
-</p>
-<p>This sets <code>main</code> only if it has not been set yet.
-</p>
-</dd>
-<dt><span><code>Compile file</code></span></dt>
-<dd><p>Compiles the current file, by running <code>comp_cmd</code> from the current
-project file.
-</p>
-<p>This does not set <code>main</code>.
-</p>
-</dd>
-<dt><span><code>Set main and Build</code></span></dt>
-<dd><p>Sets <code>main</code> to the current file, then executes the Build
-command.
-</p>
-</dd>
-<dt><span><code>Show main</code></span></dt>
-<dd><p>Display <code>main</code> in the message buffer.
-</p>
-</dd>
-<dt><span><code>Build</code></span></dt>
-<dd><p>Compiles all obsolete units of the current <code>main</code>, and links
-<code>main</code>, by running <code>make_cmd</code> from the current project.
-</p>
-<p>This sets <code>main</code> only if it has not been set yet.
-</p>
-</dd>
-<dt><span><code>Run</code></span></dt>
-<dd><p>Executes the main program in a shell, displayed in a separate Emacs
-buffer. This runs <code>run_cmd</code> from the current project. The
-execution buffer allows for interactive input/output.
-</p>
-<p>To modify the run command, in particular to provide or change the
-command line arguments, type <kbd>C-u</kbd> before invoking the command.
-</p>
-<p>This command is not available for a cross-compilation toolchain.
-</p>
-</dd>
-</dl>
-<p>It is important when using these commands to understand how
-<code>main</code> is used and changed.
-</p>
-<p>Build runs &rsquo;gnatmake&rsquo; on the main unit. During a typical edit/compile
-session, this is the only command you need to invoke, which is why it
-is bound to <kbd>C-c C-c</kbd>. It will compile all files needed by the
-main unit, and display compilation errors in any of them.
-</p>
-<p>Note that Build can be invoked from any Ada buffer; typically you will
-be fixing errors in files other than the main, but you don&rsquo;t have to
-switch back to the main to invoke the compiler again.
-</p>
-<p>Novices and students typically work on single-file Ada projects. In
-this case, <kbd>C-c C-m</kbd> will normally be the only command needed; it
-will build the current file, rather than the last-built main.
-</p>
-<p>There are three ways to change <code>main</code>:
-</p>
-<ol>
-<li> Invoke &lsquo;<samp>Ada | Set main and Build</samp>&rsquo;, which sets <code>main</code> to
-the current file.
-
-</li><li> Invoke &lsquo;<samp>Ada | Project | Edit</samp>&rsquo;, edit <code>main</code> and
-<code>main</code>, and click &lsquo;<samp>[save]</samp>&rsquo;
-
-</li><li> Invoke &lsquo;<samp>Ada | Project | Load</samp>&rsquo;, and load a project file that specifies <code>main</code>
-
-</li></ol>
-
-<hr>
-</div>
-<div class="section" id="Compiler-errors">
-<div class="header">
-<p>
-Previous: <a href="#Compile-commands" accesskey="p" rel="prev">Compile commands</a>, Up: <a href="#Compiling-Executing" accesskey="u" rel="up">Compiling Executing</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#Index" title="Index" rel="index">Index</a>]</p>
-</div>
-<span id="Compiler-errors-1"></span><h3 class="section">4.2 Compiler errors</h3>
-
-<p>The <code>Check file</code>, <code>Compile file</code>, and <code>Build</code> commands
-all place compilation errors in a separate buffer named
-<samp>*compilation*</samp>.
-</p>
-<p>Each line in this buffer will become active: you can simply click on
-it with the middle button of the mouse, or move point to it and press
-<tt class="key">RET</tt>. Emacs will then display the relevant source file and put
-point on the line and column where the error was found.
-</p>
-<p>You can also press the <kbd>C-x `</kbd> key (<code>next-error</code>), and Emacs
-will jump to the first error. If you press that key again, it will
-move you to the second error, and so on.
-</p>
-<p>Some error messages might also include references to other files. These
-references are also clickable in the same way, or put point after the
-line number and press <tt class="key">RET</tt>.
-</p>
-<hr>
-</div>
-</div>
-<div class="chapter" id="Project-files">
-<div class="header">
-<p>
-Next: <a href="#Compiling-Examples" accesskey="n" rel="next">Compiling Examples</a>, Previous: <a href="#Compiling-Executing" accesskey="p" rel="prev">Compiling Executing</a>, Up: <a href="#Top" accesskey="u" rel="up">Ada Mode</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#Index" title="Index" rel="index">Index</a>]</p>
-</div>
-<span id="Project-files-1"></span><h2 class="chapter">5 Project files</h2>
-
-<p>An Emacs Ada mode project file specifies what directories hold sources
-for your project, and allows you to customize the compilation commands
-and other things on a per-project basis.
-</p>
-<p>Note that Ada mode project files <samp>*.adp</samp> are different than GNAT
-compiler project files <samp>*.gpr</samp>. However, Emacs Ada mode can use a
-GNAT project file to specify the project directories. If no
-other customization is needed, a GNAT project file can be used without
-an Emacs Ada mode project file.
-</p>
-
-<ul class="section-toc">
-<li><a href="#Project-File-Overview" accesskey="1">Project File Overview</a></li>
-<li><a href="#GUI-Editor" accesskey="2">GUI Editor</a></li>
-<li><a href="#Project-file-variables" accesskey="3">Project file variables</a></li>
-</ul>
-<hr>
-<div class="section" id="Project-File-Overview">
-<div class="header">
-<p>
-Next: <a href="#GUI-Editor" accesskey="n" rel="next">GUI Editor</a>, Up: <a href="#Project-files" accesskey="u" rel="up">Project files</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#Index" title="Index" rel="index">Index</a>]</p>
-</div>
-<span id="Project-File-Overview-1"></span><h3 class="section">5.1 Project File Overview</h3>
-
-<p>Project files have a simple syntax; they may be edited directly. Each
-line specifies a project variable name and its value, separated by &ldquo;=&rdquo;:
-</p><div class="example">
-<pre class="example">src_dir=/Projects/my_project/src_1
-src_dir=/Projects/my_project/src_2
-</pre></div>
-
-<p>Some variables (like <code>src_dir</code>) are lists; multiple occurrences
-are concatenated.
-</p>
-<p>There must be no space between the variable name and &ldquo;=&rdquo;, and no
-trailing spaces.
-</p>
-<p>Alternately, a GUI editor for project files is available (see <a href="#GUI-Editor">GUI Editor</a>). It uses Emacs widgets, similar to Emacs customize.
-</p>
-<p>The GUI editor also provides a convenient way to view current project
-settings, if they have been modified using menu commands rather than
-by editing the project file.
-</p>
-<p>After the first Ada mode build command is invoked, there is always a
-current project file, given by the lisp variable
-<code>ada-prj-default-project-file</code>. Currently, the only way to show
-the current project file is to invoke the GUI editor.
-</p>
-<p>To find the project file the first time, Ada mode uses the following
-search algorithm:
-</p>
-<ul>
-<li> If <code>ada-prj-default-project-file</code> is set, use that.
-
-</li><li> Otherwise, search for a file in the current directory with
-the same base name as the Ada file, but extension given by
-<code>ada-prj-file-extension</code> (default <code>&quot;.adp&quot;</code>).
-
-</li><li> If not found, search for <samp>*.adp</samp> in the current directory; if
-several are found, prompt the user to select one.
-
-</li><li> If none are found, use <samp>default.adp</samp> in the current directory (even
-if it does not exist).
-
-</li></ul>
-
-<p>This algorithm always sets <code>ada-prj-default-project-file</code>, even
-when the file does not actually exist.
-</p>
-<p>To change the project file before or after the first one is found,
-invoke &lsquo;<samp>Ada | Project | Load ...</samp>&rsquo;.
-</p>
-<p>Or, in lisp, evaluate <code>(ada-set-default-project-file &quot;/path/file.adp&quot;)</code>.
-This sets <code>ada-prj-default-project-file</code>, and reads the project file.
-</p>
-<p>You can also specify a GNAT project file to &lsquo;<samp>Ada | Project | Load
-...</samp>&rsquo; or <code>ada-set-default-project-file</code>. Emacs Ada mode checks the
-file extension; if it is <code>.gpr</code>, the file is treated as a GNAT
-project file. Any other extension is treated as an Emacs Ada mode
-project file.
-</p>
-<hr>
-</div>
-<div class="section" id="GUI-Editor">
-<div class="header">
-<p>
-Next: <a href="#Project-file-variables" accesskey="n" rel="next">Project file variables</a>, Previous: <a href="#Project-File-Overview" accesskey="p" rel="prev">Project File Overview</a>, Up: <a href="#Project-files" accesskey="u" rel="up">Project files</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#Index" title="Index" rel="index">Index</a>]</p>
-</div>
-<span id="GUI-Editor-1"></span><h3 class="section">5.2 GUI Editor</h3>
-
-<p>The project file editor is invoked with the menu &lsquo;<samp>Ada | Projects
-| Edit</samp>&rsquo;.
-</p>
-<p>Once in the buffer for editing the project file, you can save your
-modification using the &lsquo;<samp>[save]</samp>&rsquo; button at the bottom of the
-buffer, or the <kbd>C-x C-s</kbd> binding. To cancel your modifications,
-kill the buffer or click on the &lsquo;<samp>[cancel]</samp>&rsquo; button.
-</p>
-<hr>
-</div>
-<div class="section" id="Project-file-variables">
-<div class="header">
-<p>
-Previous: <a href="#GUI-Editor" accesskey="p" rel="prev">GUI Editor</a>, Up: <a href="#Project-files" accesskey="u" rel="up">Project files</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#Index" title="Index" rel="index">Index</a>]</p>
-</div>
-<span id="Project-file-variables-1"></span><h3 class="section">5.3 Project file variables</h3>
-
-<p>The following variables can be defined in a project file; some can
-also be defined in lisp variables.
-</p>
-<p>To set a project variable that is a list, specify each element of the
-list on a separate line in the project file.
-</p>
-<p>Any project variable can be referenced in other project variables,
-using a shell-like notation. For instance, if the variable
-<code>comp_cmd</code> contains <code>${comp_opt}</code>, the value of the
-<code>comp_opt</code> variable will be substituted when <code>comp_cmd</code> is
-used.
-</p>
-<p>In addition, process environment variables can be referenced using the
-same syntax, or the normal <code>$var</code> syntax.
-</p>
-<p>Most project variables have defaults that can be changed by setting
-lisp variables; the table below identifies the lisp variable for each
-project variable. Lisp variables corresponding to project variables
-that are lists are lisp lists.
-</p>
-<p>In general, project variables are evaluated when referenced in
-Emacs Ada mode commands. Relative file paths are expanded to
-absolute relative to <code>${build_dir}</code>.
-</p>
-<p>Here is the list of variables. In the default values, the current
-directory <code>&quot;.&quot;</code> is the project file directory.
-</p>
-<dl compact="compact">
-<dt><span><code>ada_project_path_sep</code> [default: <code>&quot;:&quot; or &quot;;&quot;</code>]</span></dt>
-<dd><p>Path separator for <code>ADA_PROJECT_PATH</code>. It defaults to the correct
-value for a native implementation of GNAT for the current operating
-system. The user must override this when using Windows native GNAT
-with Cygwin Emacs, and perhaps in other cases.
-</p>
-<p>Lisp variable: <code>ada-prj-ada-project-path-sep</code>.
-</p>
-</dd>
-<dt><span><code>ada_project_path</code> [default: <code>&quot;&quot;</code>]</span></dt>
-<dd><p>A list of directories to search for GNAT project files.
-</p>
-<p>If set, the <code>ADA_PROJECT_PATH</code> process environment variable is
-set to this value in the Emacs process when the Emacs Ada mode project
-is selected via menu &lsquo;<samp>Ada | Project | Load</samp>&rsquo;.
-</p>
-<p>For <code>ada_project_path</code>, relative file paths are expanded to
-absolute when the Emacs Ada project file is read, rather than when the
-project file is selected.
-</p>
-<p>For example if the project file is in the directory
-<samp>/home/myproject</samp>, the environment variable <code>GDS_ROOT</code> is
-set to <code>/home/shared</code>, and the project file contains:
-</p><div class="example">
-<pre class="example">ada_project_path_sep=:
-ada_project_path=$GDS_ROOT/makerules
-ada_project_path=../opentoken
-</pre></div>
-<p>then as a result the environment variable <code>ADA_PROJECT_PATH</code> will
-be set to <code>&quot;/home/shared/makerules:/home/opentoken/&quot;</code>.
-</p>
-<p>The default value is not the current value of this environment
-variable, because that will typically have been set by another
-project, and will therefore be incorrect for this project.
-</p>
-<p>If you have the environment variable set correctly for all of your
-projects, you do not need to set this project variable.
-</p>
-</dd>
-<dt><span><code>bind_opt</code> [default: <code>&quot;&quot;</code>]</span></dt>
-<dd><p>Holds user binder options; used in the default build commands.
-</p>
-<p>Lisp variable: <code>ada-prj-default-bind-opt</code>.
-</p>
-</dd>
-<dt><span><code>build_dir</code> [default: <code>&quot;.&quot;</code>]</span></dt>
-<dd><p>The compile commands will be issued in this directory.
-</p>
-</dd>
-<dt><span><code>casing</code> [default: <code>(&quot;~/.emacs_case_exceptions&quot;)</code>]</span></dt>
-<dd><p>List of files containing casing exceptions. See the help on
-<code>ada-case-exception-file</code> for more info.
-</p>
-<p>Lisp variable: <code>ada-case-exception-file</code>.
-</p>
-</dd>
-<dt><span><code>check_cmd</code> [default: <code>&quot;${cross_prefix}gnatmake -u -c -gnatc ${gnatmake_opt} ${full_current} -cargs ${comp_opt}&quot;</code>]</span></dt>
-<dd><p>Command used to syntax check a single file.
-The name of the file is substituted for <code>full_current</code>.
-</p>
-<p>Lisp variable: <code>ada-prj-default-check-cmd</code>
-</p>
-</dd>
-<dt><span><code>comp_cmd</code> [default: <code>&quot;${cross_prefix}gnatmake -u -c ${gnatmake_opt} ${full_current} -cargs ${comp_opt}&quot;</code>]</span></dt>
-<dd><p>Command used to compile a single file.
-The name of the file is substituted for <code>full_current</code>.
-</p>
-<p>Lisp variable: <code>ada-prj-default-comp-cmd</code>.
-</p>
-</dd>
-<dt><span><code>comp_opt</code> [default: <code>&quot;-gnatq -gnatQ&quot;</code>]</span></dt>
-<dd><p>Holds user compiler options; used in the default compile commands. The
-default value tells gnatmake to generate library files for
-cross-referencing even when there are errors.
-</p>
-<p>If source code for the project is in multiple directories, the
-appropriate compiler options must be added here. <a href="#Set-source-search-path">Set source search path</a> for examples of this. Alternately, GNAT project files may
-be used; <a href="#Use-GNAT-project-file">Use GNAT project file</a>.
-</p>
-<p>Lisp variable: <code>ada-prj-default-comp-opt</code>.
-</p>
-</dd>
-<dt><span><code>cross_prefix</code> [default: <code>&quot;&quot;</code>]</span></dt>
-<dd><p>Name of target machine in a cross-compilation environment. Used in
-default compile and build commands.
-</p>
-</dd>
-<dt><span><code>debug_cmd</code> [default: <code>&quot;${cross_prefix}gdb ${main}&quot;</code>]</span></dt>
-<dd><p>Command used to debug the application
-</p>
-<p>Lisp variable: <code>ada-prj-default-debugger</code>.
-</p>
-</dd>
-<dt><span><code>debug_post_cmd</code> [default: <code>&quot;&quot;</code>]</span></dt>
-<dd><p>Command executed after <code>debug_cmd</code>.
-</p>
-</dd>
-<dt><span><code>debug_pre_cmd</code> [default: <code>&quot;cd ${build_dir}&quot;</code>]</span></dt>
-<dd><p>Command executed before <code>debug_cmd</code>.
-</p>
-</dd>
-<dt><span><code>gnatfind_opt</code> [default: <code>&quot;-rf&quot;</code>]</span></dt>
-<dd><p>Holds user gnatfind options; used in the default find commands.
-</p>
-<p>Lisp variable: <code>ada-prj-gnatfind-switches</code>.
-</p>
-</dd>
-<dt><span><code>gnatmake_opt</code> [default: <code>&quot;-g&quot;</code>]</span></dt>
-<dd><p>Holds user gnatmake options; used in the default build commands.
-</p>
-<p>Lisp variable: <code>ada-prj-default-gnatmake-opt</code>.
-</p>
-</dd>
-<dt><span><code>gpr_file</code> [default: <code>&quot;&quot;</code>]</span></dt>
-<dd><p>Specify GNAT project file.
-</p>
-<p>If set, the source and object directories specified in the GNAT
-project file are appended to <code>src_dir</code> and <code>obj_dir</code>. This
-allows specifying Ada source directories with a GNAT project file, and
-other source directories with the Emacs project file.
-</p>
-<p>In addition, <code>-P{gpr_file}</code> is added to the project variable
-<code>gnatmake_opt</code> whenever it is referenced. With the default
-project variables, this passes the project file to all gnatmake
-commands.
-</p>
-<p>Lisp variable: <code>ada-prj-default-gpr-file</code>.
-</p>
-
-</dd>
-<dt><span><code>link_opt</code> [default: <code>&quot;&quot;</code>]</span></dt>
-<dd><p>Holds user linker options; used in the default build commands.
-</p>
-<p>Lisp variable: <code>ada-prj-default-link-opt</code>.
-</p>
-</dd>
-<dt><span><code>main</code> [default: current file]</span></dt>
-<dd><p>Specifies the name of the executable file for the project; used in the
-default build commands.
-</p>
-</dd>
-<dt><span><code>make_cmd</code> [default: <code>&quot;${cross_prefix}gnatmake -o ${main} ${main} ${gnatmake_opt} -cargs ${comp_opt} -bargs ${bind_opt} -largs ${link_opt}&quot;</code>]</span></dt>
-<dd><p>Command used to build the application.
-</p>
-<p>Lisp variable: <code>ada-prj-default-make-cmd</code>.
-</p>
-</dd>
-<dt><span><code>obj_dir</code> [default: <code>&quot;.&quot;</code>]</span></dt>
-<dd><p>A list of directories to search for library files. Ada mode searches
-this list for the &lsquo;<samp>.ali</samp>&rsquo; files generated by GNAT that contain
-cross-reference information.
-</p>
-<p>The compiler commands must place the &lsquo;<samp>.ali</samp>&rsquo; files in one of these
-directories; the default commands do that.
-</p>
-</dd>
-<dt><span><code>remote_machine</code> [default: <code>&quot;&quot;</code>]</span></dt>
-<dd><p>Name of the machine to log into before issuing the compile and build
-commands. If this variable is empty, the command will be run on the
-local machine.
-</p>
-</dd>
-<dt><span><code>run_cmd</code> [default: <code>&quot;./${main}&quot;</code>]</span></dt>
-<dd><p>Command used to run the application.
-</p>
-</dd>
-<dt><span><code>src_dir</code> [default: <code>&quot;.&quot;</code>]</span></dt>
-<dd><p>A list of directories to search for source files, both for compile
-commands and source navigation.
-</p>
-</dd>
-</dl>
-
-<hr>
-</div>
-</div>
-<div class="chapter" id="Compiling-Examples">
-<div class="header">
-<p>
-Next: <a href="#Moving-Through-Ada-Code" accesskey="n" rel="next">Moving Through Ada Code</a>, Previous: <a href="#Project-files" accesskey="p" rel="prev">Project files</a>, Up: <a href="#Top" accesskey="u" rel="up">Ada Mode</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#Index" title="Index" rel="index">Index</a>]</p>
-</div>
-<span id="Compiling-Examples-1"></span><h2 class="chapter">6 Compiling Examples</h2>
-
-<p>We present several small projects, and walk thru the process of
-compiling, linking, and running them.
-</p>
-<p>The first example illustrates more Ada mode features than the others;
-you should work thru that example before doing the others.
-</p>
-<p>All of these examples assume you are using GNAT.
-</p>
-<p>The source for these examples is available on the Emacs Ada mode
-website mentioned in See <a href="#Installation">Installation</a>.
-</p>
-
-<ul class="section-toc">
-<li><a href="#No-project-files" accesskey="1">No project files</a></li>
-<li><a href="#Set-compiler-options" accesskey="2">Set compiler options</a></li>
-<li><a href="#Set-source-search-path" accesskey="3">Set source search path</a></li>
-<li><a href="#Use-GNAT-project-file" accesskey="4">Use GNAT project file</a></li>
-<li><a href="#Use-multiple-GNAT-project-files" accesskey="5">Use multiple GNAT project files</a></li>
-</ul>
-<hr>
-<div class="section" id="No-project-files">
-<div class="header">
-<p>
-Next: <a href="#Set-compiler-options" accesskey="n" rel="next">Set compiler options</a>, Up: <a href="#Compiling-Examples" accesskey="u" rel="up">Compiling Examples</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#Index" title="Index" rel="index">Index</a>]</p>
-</div>
-<span id="No-project-files-1"></span><h3 class="section">6.1 No project files</h3>
-<p>This example uses no project files.
-</p>
-<p>First, create a directory <samp>Example_1</samp>, containing:
-</p>
-<p><samp>hello.adb</samp>:
-</p>
-<div class="example">
-<pre class="example">with Ada.Text_IO;
-procedure Hello
-is begin
- Put_Line(&quot;Hello from hello.adb&quot;);
-end Hello;
-</pre></div>
-
-<p>Yes, this is missing &ldquo;use Ada.Text_IO;&rdquo; - we want to demonstrate
-compiler error handling.
-</p>
-<p><samp>hello_2.adb</samp>:
-</p>
-<div class="example">
-<pre class="example">with Hello_Pkg;
-procedure Hello_2
-is begin
- Hello_Pkg.Say_Hello;
-end Hello_2;
-</pre></div>
-
-<p>This file has no errors.
-</p>
-<p><samp>hello_pkg.ads</samp>:
-</p>
-<div class="example">
-<pre class="example">package Hello_Pkg is
- procedure Say_Hello;
-end Hello_Pkg;
-</pre></div>
-
-<p>This file has no errors.
-</p>
-<p><samp>hello_pkg.adb</samp>:
-</p>
-<div class="example">
-<pre class="example">with Ada.Text_IO;
-package Hello_Pkg is
- procedure Say_Hello
- is begin
- Ada.Text_IO.Put_Line (&quot;Hello from hello_pkg.adb&quot;);
- end Say_Hello;
-end Hello_Pkg;
-</pre></div>
-
-<p>Yes, this is missing the keyword <code>body</code>; another compiler error
-example.
-</p>
-<p>In buffer <samp>hello.adb</samp>, invoke &lsquo;<samp>Ada | Check file</samp>&rsquo;. You should
-get a <samp>*compilation*</samp> buffer containing something like (the
-directory paths will be different):
-</p>
-<div class="example">
-<pre class="example">cd c:/Examples/Example_1/
-gnatmake -u -c -gnatc -g c:/Examples/Example_1/hello.adb -cargs -gnatq -gnatQ
-gcc -c -Ic:/Examples/Example_1/ -gnatc -g -gnatq -gnatQ -I- c:/Examples/Example_1/hello.adb
-hello.adb:4:04: &quot;Put_Line&quot; is not visible
-hello.adb:4:04: non-visible declaration at a-textio.ads:264
-hello.adb:4:04: non-visible declaration at a-textio.ads:260
-gnatmake: &quot;c:/Examples/Example_1/hello.adb&quot; compilation error
-</pre></div>
-
-<p>If you have enabled font-lock, the lines with actual errors (starting
-with <samp>hello.adb</samp>) are highlighted, with the file name in red.
-</p>
-<p>Now type <kbd>C-x `</kbd> (on a PC keyboard, <tt class="key">`</tt> is next to <tt class="key">1</tt>).
-Or you can click the middle mouse button on the first error line. The
-compilation buffer scrolls to put the first error on the top line, and
-point is put at the place of the error in the <samp>hello.adb</samp> buffer.
-</p>
-<p>To fix the error, change the line to be
-</p>
-<div class="example">
-<pre class="example"> Ada.Text_IO.Put_Line (&quot;hello from hello.adb&quot;);
-</pre></div>
-
-<p>Now invoke &lsquo;<samp>Ada | Show main</samp>&rsquo;; this displays &lsquo;<samp>Ada mode main: hello</samp>&rsquo;.
-</p>
-<p>Now (in buffer <samp>hello.adb</samp>), invoke &lsquo;<samp>Ada | Build</samp>&rsquo;. You are
-prompted to save the file (if you haven&rsquo;t already). Then the
-compilation buffer is displayed again, containing:
-</p>
-<div class="example">
-<pre class="example">cd c:/Examples/Example_1/
-gnatmake -o hello hello -g -cargs -gnatq -gnatQ -bargs -largs
-gcc -c -g -gnatq -gnatQ hello.adb
-gnatbind -x hello.ali
-gnatlink hello.ali -o hello.exe -g
-</pre></div>
-
-<p>The compilation has succeeded without errors; <samp>hello.exe</samp> now
-exists in the same directory as <samp>hello.adb</samp>.
-</p>
-<p>Now invoke &lsquo;<samp>Ada | Run</samp>&rsquo;. A <samp>*run*</samp> buffer is displayed,
-containing
-</p>
-<div class="example">
-<pre class="example">Hello from hello.adb
-
-Process run finished
-</pre></div>
-
-<p>That completes the first part of this example.
-</p>
-<p>Now we will compile a multi-file project. Open the file
-<samp>hello_2.adb</samp>, and invoke &lsquo;<samp>Ada | Set main and Build</samp>&rsquo;. This
-finds an error in <samp>hello_pkg.adb</samp>:
-</p>
-<div class="example">
-<pre class="example">cd c:/Examples/Example_1/
-gnatmake -o hello_2 hello_2 -g -cargs -gnatq -gnatQ -bargs -largs
-gcc -c -g -gnatq -gnatQ hello_pkg.adb
-hello_pkg.adb:2:08: keyword &quot;body&quot; expected here [see file name]
-gnatmake: &quot;hello_pkg.adb&quot; compilation error
-</pre></div>
-
-<p>This demonstrates that gnatmake finds the files needed by the main
-program. However, it cannot find files in a different directory,
-unless you use an Emacs Ada mode project file to specify the other directories;
-See <a href="#Set-source-search-path">Set source search path</a>, or a GNAT project file; <a href="#Use-GNAT-project-file">Use GNAT project file</a>.
-</p>
-<p>Invoke &lsquo;<samp>Ada | Show main</samp>&rsquo;; this displays <samp>Ada mode main: hello_2</samp>.
-</p>
-<p>Move to the error with <kbd>C-x `</kbd>, and fix the error by adding <code>body</code>:
-</p>
-<div class="example">
-<pre class="example">package body Hello_Pkg is
-</pre></div>
-
-<p>Now, while still in <samp>hello_pkg.adb</samp>, invoke &lsquo;<samp>Ada | Build</samp>&rsquo;.
-gnatmake successfully builds <samp>hello_2</samp>. This demonstrates that
-Emacs has remembered the main file, in the project variable
-<code>main</code>, and used it for the Build command.
-</p>
-<p>Finally, again while in <samp>hello_pkg.adb</samp>, invoke &lsquo;<samp>Ada | Run</samp>&rsquo;.
-The <samp>*run*</samp> buffer displays <code>Hello from hello_pkg.adb</code>.
-</p>
-<p>One final point. If you switch back to buffer <samp>hello.adb</samp>, and
-invoke &lsquo;<samp>Ada | Run</samp>&rsquo;, <samp>hello_2.exe</samp> will be run. That is
-because <code>main</code> is still set to <code>hello_2</code>, as you can
-see when you invoke &lsquo;<samp>Ada | Project | Edit</samp>&rsquo;.
-</p>
-<p>There are three ways to change <code>main</code>:
-</p>
-<ol>
-<li> Invoke &lsquo;<samp>Ada | Set main and Build</samp>&rsquo;, which sets <code>main</code> to
-the current file.
-
-</li><li> Invoke &lsquo;<samp>Ada | Project | Edit</samp>&rsquo;, edit <code>main</code>, and click &lsquo;<samp>[save]</samp>&rsquo;
-
-</li><li> Invoke &lsquo;<samp>Ada | Project | Load</samp>&rsquo;, and load a project file that specifies <code>main</code>
-
-</li></ol>
-
-<hr>
-</div>
-<div class="section" id="Set-compiler-options">
-<div class="header">
-<p>
-Next: <a href="#Set-source-search-path" accesskey="n" rel="next">Set source search path</a>, Previous: <a href="#No-project-files" accesskey="p" rel="prev">No project files</a>, Up: <a href="#Compiling-Examples" accesskey="u" rel="up">Compiling Examples</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#Index" title="Index" rel="index">Index</a>]</p>
-</div>
-<span id="Set-compiler-options-1"></span><h3 class="section">6.2 Set compiler options</h3>
-
-<p>This example illustrates using an Emacs Ada mode project file to set a
-compiler option.
-</p>
-<p>If you have files from <samp>Example_1</samp> open in Emacs, you should
-close them so you don&rsquo;t get confused. Use menu &lsquo;<samp>File | Close
-(current buffer)</samp>&rsquo;.
-</p>
-<p>In directory <samp>Example_2</samp>, create these files:
-</p>
-<p><samp>hello.adb</samp>:
-</p>
-<div class="example">
-<pre class="example">with Ada.Text_IO;
-procedure Hello
-is begin
- Put_Line(&quot;Hello from hello.adb&quot;);
-end Hello;
-</pre></div>
-
-<p>This is the same as <samp>hello.adb</samp> from <samp>Example_1</samp>. It has two
-errors; missing &ldquo;use Ada.Text_IO;&rdquo;, and no space between
-<code>Put_Line</code> and its argument list.
-</p>
-<p><samp>hello.adp</samp>:
-</p>
-<div class="example">
-<pre class="example">comp_opt=-gnatyt
-</pre></div>
-
-<p>This tells the GNAT compiler to check for token spacing; in
-particular, there must be a space preceding a parenthesis.
-</p>
-<p>In buffer <samp>hello.adb</samp>, invoke &lsquo;<samp>Ada | Project | Load...</samp>&rsquo;, and
-select <samp>Example_2/hello.adp</samp>.
-</p>
-<p>Then, again in buffer <samp>hello.adb</samp>, invoke &lsquo;<samp>Ada | Set main and
-Build</samp>&rsquo;. You should get a <samp>*compilation*</samp> buffer containing
-something like (the directory paths will be different):
-</p>
-<div class="example">
-<pre class="example">cd c:/Examples/Example_2/
-gnatmake -o hello hello -g -cargs -gnatyt -bargs -largs
-gcc -c -g -gnatyt hello.adb
-hello.adb:4:04: &quot;Put_Line&quot; is not visible
-hello.adb:4:04: non-visible declaration at a-textio.ads:264
-hello.adb:4:04: non-visible declaration at a-textio.ads:260
-hello.adb:4:12: (style) space required
-gnatmake: &quot;hello.adb&quot; compilation error
-</pre></div>
-
-<p>Compare this to the compiler output in <a href="#No-project-files">No project files</a>; the
-gnatmake option <code>-cargs -gnatq -gnatQ</code> has been replaced by
-<code>-cargs -gnaty</code>, and an additional error is reported in
-<samp>hello.adb</samp> on line 4. This shows that <samp>hello.adp</samp> is being
-used to set the compiler options.
-</p>
-<p>Fixing the error, linking and running the code proceed as in <a href="#No-project-files">No project files</a>.
-</p>
-<hr>
-</div>
-<div class="section" id="Set-source-search-path">
-<div class="header">
-<p>
-Next: <a href="#Use-GNAT-project-file" accesskey="n" rel="next">Use GNAT project file</a>, Previous: <a href="#Set-compiler-options" accesskey="p" rel="prev">Set compiler options</a>, Up: <a href="#Compiling-Examples" accesskey="u" rel="up">Compiling Examples</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#Index" title="Index" rel="index">Index</a>]</p>
-</div>
-<span id="Set-source-search-path-1"></span><h3 class="section">6.3 Set source search path</h3>
-
-<p>In this example, we show how to deal with files in more than one
-directory. We start with the same code as in <a href="#No-project-files">No project files</a>;
-create those files (with the errors present)
-</p>
-<p>Create the directory <samp>Example_3</samp>, containing:
-</p>
-<p><samp>hello_pkg.ads</samp>:
-</p>
-<div class="example">
-<pre class="example">package Hello_Pkg is
- procedure Say_Hello;
-end Hello_Pkg;
-</pre></div>
-
-<p><samp>hello_pkg.adb</samp>:
-</p>
-<div class="example">
-<pre class="example">with Ada.Text_IO;
-package Hello_Pkg is
- procedure Say_Hello
- is begin
- Ada.Text_IO.Put_Line (&quot;Hello from hello_pkg.adb&quot;);
- end Say_Hello;
-end Hello_Pkg;
-</pre></div>
-
-<p>These are the same files from example 1; <samp>hello_pkg.adb</samp> has an
-error on line 2.
-</p>
-<p>In addition, create a directory <samp>Example_3/Other</samp>, containing these files:
-</p>
-<p><samp>Other/hello_3.adb</samp>:
-</p>
-<div class="example">
-<pre class="example">with Hello_Pkg;
-with Ada.Text_IO; use Ada.Text_IO;
-procedure Hello_3
-is begin
- Hello_Pkg.Say_Hello;
- Put_Line (&quot;From hello_3&quot;);
-end Hello_3;
-</pre></div>
-
-<p>There are no errors in this file.
-</p>
-<p><samp>Other/other.adp</samp>:
-</p>
-<div class="example">
-<pre class="example">src_dir=..
-comp_opt=-I..
-</pre></div>
-
-<p>Note that there must be no trailing spaces.
-</p>
-<p>In buffer <samp>hello_3.adb</samp>, invoke &lsquo;<samp>Ada | Project | Load...</samp>&rsquo;, and
-select <samp>Example_3/Other/other.adp</samp>.
-</p>
-<p>Then, again in <samp>hello_3.adb</samp>, invoke &lsquo;<samp>Ada | Set main and
-Build</samp>&rsquo;. You should get a <samp>*compilation*</samp> buffer containing
-something like (the directory paths will be different):
-</p>
-<div class="example">
-<pre class="example">cd c:/Examples/Example_3/Other/
-gnatmake -o hello_3 hello_3 -g -cargs -I.. -bargs -largs
-gcc -c -g -I.. hello_3.adb
-gcc -c -I./ -g -I.. -I- C:\Examples\Example_3\hello_pkg.adb
-hello_pkg.adb:2:08: keyword &quot;body&quot; expected here [see file name]
-gnatmake: &quot;C:\Examples\Example_3\hello_pkg.adb&quot; compilation error
-</pre></div>
-
-<p>Compare the <code>-cargs</code> option to the compiler output in <a href="#Set-compiler-options">Set compiler options</a>; this shows that <samp>other.adp</samp> is being used to
-set the compiler options.
-</p>
-<p>Move to the error with <kbd>C-x `</kbd>. Ada mode searches the list of
-directories given by <code>src_dir</code> for the file mentioned in the
-compiler error message.
-</p>
-<p>Fixing the error, linking and running the code proceed as in <a href="#No-project-files">No project files</a>.
-</p>
-<hr>
-</div>
-<div class="section" id="Use-GNAT-project-file">
-<div class="header">
-<p>
-Next: <a href="#Use-multiple-GNAT-project-files" accesskey="n" rel="next">Use multiple GNAT project files</a>, Previous: <a href="#Set-source-search-path" accesskey="p" rel="prev">Set source search path</a>, Up: <a href="#Compiling-Examples" accesskey="u" rel="up">Compiling Examples</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#Index" title="Index" rel="index">Index</a>]</p>
-</div>
-<span id="Use-GNAT-project-file-1"></span><h3 class="section">6.4 Use GNAT project file</h3>
-
-<p>In this example, we show how to use a GNAT project file, with no Ada
-mode project file.
-</p>
-<p>Create the directory <samp>Example_4</samp>, containing:
-</p>
-<p><samp>hello_pkg.ads</samp>:
-</p>
-<div class="example">
-<pre class="example">package Hello_Pkg is
- procedure Say_Hello;
-end Hello_Pkg;
-</pre></div>
-
-<p><samp>hello_pkg.adb</samp>:
-</p>
-<div class="example">
-<pre class="example">with Ada.Text_IO;
-package Hello_Pkg is
- procedure Say_Hello
- is begin
- Ada.Text_IO.Put_Line (&quot;Hello from hello_pkg.adb&quot;);
- end Say_Hello;
-end Hello_Pkg;
-</pre></div>
-
-<p>These are the same files from example 1; <samp>hello_pkg.adb</samp> has an
-error on line 2.
-</p>
-<p>In addition, create a directory <samp>Example_4/Gnat_Project</samp>,
-containing these files:
-</p>
-<p><samp>Gnat_Project/hello_4.adb</samp>:
-</p>
-<div class="example">
-<pre class="example">with Hello_Pkg;
-with Ada.Text_IO; use Ada.Text_IO;
-procedure Hello_4
-is begin
- Hello_Pkg.Say_Hello;
- Put_Line (&quot;From hello_4&quot;);
-end Hello_4;
-</pre></div>
-
-<p>There are no errors in this file.
-</p>
-<p><samp>Gnat_Project/hello_4.gpr</samp>:
-</p>
-<div class="example">
-<pre class="example">Project Hello_4 is
- for Source_Dirs use (&quot;.&quot;, &quot;..&quot;);
-end Hello_4;
-</pre></div>
-
-<p>In buffer <samp>hello_4.adb</samp>, invoke &lsquo;<samp>Ada | Project | Load...</samp>&rsquo;, and
-select <samp>Example_4/Gnat_Project/hello_4.gpr</samp>.
-</p>
-<p>Then, again in <samp>hello_4.adb</samp>, invoke &lsquo;<samp>Ada | Set main and
-Build</samp>&rsquo;. You should get a <samp>*compilation*</samp> buffer containing
-something like (the directory paths will be different):
-</p>
-<div class="example">
-<pre class="example">cd c:/Examples/Example_4/Gnat_Project/
-gnatmake -o hello_4 hello_4 -Phello_4.gpr -cargs -gnatq -gnatQ -bargs -largs
-gcc -c -g -gnatyt -gnatq -gnatQ -I- -gnatA c:\Examples\Example_4\Gnat_Project\hello_4.adb
-gcc -c -g -gnatyt -gnatq -gnatQ -I- -gnatA c:\Examples\Example_4\hello_pkg.adb
-hello_pkg.adb:2:08: keyword &quot;body&quot; expected here [see file name]
-gnatmake: &quot;c:\examples\example_4\hello_pkg.adb&quot; compilation error
-</pre></div>
-
-<p>Compare the <code>gcc</code> options to the compiler output in <a href="#Set-compiler-options">Set compiler options</a>; this shows that <samp>hello_4.gpr</samp> is being used to
-set the compiler options.
-</p>
-<p>Fixing the error, linking and running the code proceed as in <a href="#No-project-files">No project files</a>.
-</p>
-<hr>
-</div>
-<div class="section" id="Use-multiple-GNAT-project-files">
-<div class="header">
-<p>
-Previous: <a href="#Use-GNAT-project-file" accesskey="p" rel="prev">Use GNAT project file</a>, Up: <a href="#Compiling-Examples" accesskey="u" rel="up">Compiling Examples</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#Index" title="Index" rel="index">Index</a>]</p>
-</div>
-<span id="Use-multiple-GNAT-project-files-1"></span><h3 class="section">6.5 Use multiple GNAT project files</h3>
-
-<p>In this example, we show how to use multiple GNAT project files,
-specifying the GNAT project search path in an Ada mode project file.
-</p>
-<p>Create the directory <samp>Example_4</samp> as specified in <a href="#Use-GNAT-project-file">Use GNAT project file</a>.
-</p>
-<p>Create the directory <samp>Example_5</samp>, containing:
-</p>
-<p><samp>hello_5.adb</samp>:
-</p>
-<div class="example">
-<pre class="example">with Hello_Pkg;
-with Ada.Text_IO; use Ada.Text_IO;
-procedure Hello_5
-is begin
- Hello_Pkg.Say_Hello;
- Put_Line (&quot;From hello_5&quot;);
-end Hello_5;
-</pre></div>
-
-<p>There are no errors in this file.
-</p>
-<p><samp>hello_5.adp</samp>:
-</p>
-<div class="example">
-<pre class="example">ada_project_path=../Example_4/Gnat_Project
-gpr_file=hello_5.gpr
-</pre></div>
-
-<p><samp>hello_5.gpr</samp>:
-</p>
-<div class="example">
-<pre class="example">with &quot;hello_4&quot;;
-Project Hello_5 is
- for Source_Dirs use (&quot;.&quot;);
- package Compiler is
- for Default_Switches (&quot;Ada&quot;) use (&quot;-g&quot;, &quot;-gnatyt&quot;);
- end Compiler;
-end Hello_5;
-</pre></div>
-
-<p>In buffer <samp>hello_5.adb</samp>, invoke &lsquo;<samp>Ada | Project | Load...</samp>&rsquo;, and
-select <samp>Example_5/hello_5.adp</samp>.
-</p>
-<p>Then, again in <samp>hello_5.adb</samp>, invoke &lsquo;<samp>Ada | Set main and
-Build</samp>&rsquo;. You should get a <samp>*compilation*</samp> buffer containing
-something like (the directory paths will be different):
-</p>
-<div class="example">
-<pre class="example">cd c:/Examples/Example_5/
-gnatmake -o hello_5 hello_5 -Phello_5.gpr -g -cargs -gnatq -gnatQ -bargs -largs
-gcc -c -g -gnatyt -g -gnatq -gnatQ -I- -gnatA c:\Examples\Example_5\hello_5.adb
-gcc -c -g -gnatyt -g -gnatq -gnatQ -I- -gnatA c:\Examples\Example_4\hello_pkg.adb
-hello_pkg.adb:2:08: keyword &quot;body&quot; expected here [see file name]
-gnatmake: &quot;c:\examples\example_4\hello_pkg.adb&quot; compilation error
-</pre></div>
-
-<p>Now type <kbd>C-x `</kbd>. <samp>Example_4/hello_pkg.adb</samp> is shown,
-demonstrating that <samp>hello_5.gpr</samp> and <samp>hello_4.gpr</samp> are being
-used to set the compilation search path.
-</p>
-<hr>
-</div>
-</div>
-<div class="chapter" id="Moving-Through-Ada-Code">
-<div class="header">
-<p>
-Next: <a href="#Identifier-completion" accesskey="n" rel="next">Identifier completion</a>, Previous: <a href="#Compiling-Examples" accesskey="p" rel="prev">Compiling Examples</a>, Up: <a href="#Top" accesskey="u" rel="up">Ada Mode</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#Index" title="Index" rel="index">Index</a>]</p>
-</div>
-<span id="Moving-Through-Ada-Code-1"></span><h2 class="chapter">7 Moving Through Ada Code</h2>
-
-<p>There are several easy to use commands to navigate through Ada code. All
-these functions are available through the Ada menu, and you can also
-use the following key bindings or the command names. Some of these
-menu entries are available only if the GNAT compiler is used, since
-the implementation relies on the GNAT cross-referencing information.
-</p>
-<dl compact="compact">
-<dt id='index-ada_002dnext_002dprocedure'><span><kbd>M-C-e</kbd><a href='#index-ada_002dnext_002dprocedure' class='copiable-anchor'> &para;</a></span></dt>
-<dd><p>Move to the next function/procedure/task, which ever comes next
-(<code>ada-next-procedure</code>).
-</p></dd>
-<dt id='index-ada_002dprevious_002dprocedure'><span><kbd>M-C-a</kbd><a href='#index-ada_002dprevious_002dprocedure' class='copiable-anchor'> &para;</a></span></dt>
-<dd><p>Move to previous function/procedure/task
-(<code>ada-previous-procedure</code>).
-</p></dd>
-<dt id='index-ada_002dnext_002dpackage'><span><kbd>M-x ada-next-package</kbd><a href='#index-ada_002dnext_002dpackage' class='copiable-anchor'> &para;</a></span></dt>
-<dd><p>Move to next package.
-</p></dd>
-<dt id='index-ada_002dprevious_002dpackage'><span><kbd>M-x ada-previous-package</kbd><a href='#index-ada_002dprevious_002dpackage' class='copiable-anchor'> &para;</a></span></dt>
-<dd><p>Move to previous package.
-</p></dd>
-<dt id='index-ada_002dmove_002dto_002dstart'><span><kbd>C-c C-a</kbd><a href='#index-ada_002dmove_002dto_002dstart' class='copiable-anchor'> &para;</a></span></dt>
-<dd><p>Move to matching start of <code>end</code> (<code>ada-move-to-start</code>). If
-point is at the end of a subprogram, this command jumps to the
-corresponding <code>begin</code> if the user option
-<code>ada-move-to-declaration</code> is <code>nil</code> (default), otherwise it jumps to
-the subprogram declaration.
-</p></dd>
-<dt id='index-ada_002dmove_002dto_002dend'><span><kbd>C-c C-e</kbd><a href='#index-ada_002dmove_002dto_002dend' class='copiable-anchor'> &para;</a></span></dt>
-<dd><p>Move point to end of current block (<code>ada-move-to-end</code>).
-</p></dd>
-<dt><span><kbd>C-c o</kbd></span></dt>
-<dd><p>Switch between corresponding spec and body file
-(<code>ff-find-other-file</code>). If point is in a subprogram, position
-point on the corresponding declaration or body in the other file.
-</p></dd>
-<dt id='index-ada_002dgoto_002ddeclaration'><span><kbd>C-c c-d</kbd><a href='#index-ada_002dgoto_002ddeclaration' class='copiable-anchor'> &para;</a></span></dt>
-<dd><p>Move from any reference to its declaration, for from a declaration to
-its body (for procedures, tasks, private and incomplete types).
-</p></dd>
-<dt id='index-ada_002dfind_002dreferences'><span><kbd>C-c C-r</kbd><a href='#index-ada_002dfind_002dreferences' class='copiable-anchor'> &para;</a></span></dt>
-<dd><p>Runs the <samp>gnatfind</samp> command to search for all references to the
-identifier surrounding point (<code>ada-find-references</code>). Use
-<kbd>C-x `</kbd> (<code>next-error</code>) to visit each reference (as for
-compilation errors).
-</p></dd>
-</dl>
-
-<p>If the <code>ada-xref-create-ali</code> variable is non-<code>nil</code>, Emacs
-will try to run GNAT for you whenever cross-reference information is
-needed, and is older than the current source file.
-</p>
-<hr>
-</div>
-<div class="chapter" id="Identifier-completion">
-<div class="header">
-<p>
-Next: <a href="#Automatic-Smart-Indentation" accesskey="n" rel="next">Automatic Smart Indentation</a>, Previous: <a href="#Moving-Through-Ada-Code" accesskey="p" rel="prev">Moving Through Ada Code</a>, Up: <a href="#Top" accesskey="u" rel="up">Ada Mode</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#Index" title="Index" rel="index">Index</a>]</p>
-</div>
-<span id="Identifier-completion-1"></span><h2 class="chapter">8 Identifier completion</h2>
-
-<p>Emacs and Ada mode provide two general ways for the completion of
-identifiers. This is an easy way to type faster: you just have to type
-the first few letters of an identifiers, and then loop through all the
-possible completions.
-</p>
-<p>The first method is general for Emacs. It works by parsing all open
-files for possible completions.
-</p>
-<p>For instance, if the words &lsquo;<samp>my_identifier</samp>&rsquo;, &lsquo;<samp>my_subprogram</samp>&rsquo;
-are the only words starting with &lsquo;<samp>my</samp>&rsquo; in any of the opened files,
-then you will have this scenario:
-</p>
-<div class="example">
-<pre class="example">You type: my<kbd>M-/</kbd>
-Emacs inserts: &lsquo;<samp>my_identifier</samp>&rsquo;
-If you press <kbd>M-/</kbd> once again, Emacs replaces &lsquo;<samp>my_identifier</samp>&rsquo; with
-&lsquo;<samp>my_subprogram</samp>&rsquo;.
-Pressing <kbd>M-/</kbd> once more will bring you back to &lsquo;<samp>my_identifier</samp>&rsquo;.
-</pre></div>
-
-<p>This is a very fast way to do completion, and the casing of words will
-also be respected.
-</p>
-<p>The second method (<kbd>C-<span class="key">TAB</span></kbd>) is specific to Ada mode and the GNAT
-compiler. Emacs will search the cross-information for possible
-completions.
-</p>
-<p>The main advantage is that this completion is more accurate: only
-existing identifier will be suggested.
-</p>
-<p>On the other hand, this completion is a little bit slower and requires
-that you have compiled your file at least once since you created that
-identifier.
-</p>
-<dl compact="compact">
-<dt id='index-ada_002dcomplete_002didentifier'><span><kbd>C-<span class="key">TAB</span></kbd><a href='#index-ada_002dcomplete_002didentifier' class='copiable-anchor'> &para;</a></span></dt>
-<dd><p>Complete current identifier using cross-reference information.
-</p></dd>
-<dt><span><kbd>M-/</kbd></span></dt>
-<dd><p>Complete identifier using buffer information (not Ada-specific).
-</p></dd>
-</dl>
-
-<hr>
-</div>
-<div class="chapter" id="Automatic-Smart-Indentation">
-<div class="header">
-<p>
-Next: <a href="#Formatting-Parameter-Lists" accesskey="n" rel="next">Formatting Parameter Lists</a>, Previous: <a href="#Identifier-completion" accesskey="p" rel="prev">Identifier completion</a>, Up: <a href="#Top" accesskey="u" rel="up">Ada Mode</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#Index" title="Index" rel="index">Index</a>]</p>
-</div>
-<span id="Automatic-Smart-Indentation-1"></span><h2 class="chapter">9 Automatic Smart Indentation</h2>
-
-<p>Ada mode comes with a full set of rules for automatic indentation. You
-can also configure the indentation, via the following variables:
-</p>
-<dl compact="compact">
-<dt><span><code>ada-broken-indent</code> (default value: 2)</span></dt>
-<dd><p>Number of columns to indent the continuation of a broken line.
-</p>
-</dd>
-<dt><span><code>ada-indent</code> (default value: 3)</span></dt>
-<dd><p>Number of columns for default indentation.
-</p>
-</dd>
-<dt><span><code>ada-indent-record-rel-type</code> (default value: 3)</span></dt>
-<dd><p>Indentation for <code>record</code> relative to <code>type</code> or <code>use</code>.
-</p>
-</dd>
-<dt><span><code>ada-indent-return</code> (default value: 0)</span></dt>
-<dd><p>Indentation for <code>return</code> relative to <code>function</code> (if
-<code>ada-indent-return</code> is greater than 0), or the open parenthesis
-(if <code>ada-indent-return</code> is negative or 0). Note that in the second
-case, when there is no open parenthesis, the indentation is done
-relative to <code>function</code> with the value of <code>ada-broken-indent</code>.
-</p>
-</dd>
-<dt><span><code>ada-label-indent</code> (default value: -4)</span></dt>
-<dd><p>Number of columns to indent a label.
-</p>
-</dd>
-<dt><span><code>ada-stmt-end-indent</code> (default value: 0)</span></dt>
-<dd><p>Number of columns to indent a statement <code>end</code> keyword on a separate line.
-</p>
-</dd>
-<dt><span><code>ada-when-indent</code> (default value: 3)</span></dt>
-<dd><p>Indentation for <code>when</code> relative to <code>exception</code> or <code>case</code>.
-</p>
-</dd>
-<dt><span><code>ada-indent-is-separate</code> (default value: t)</span></dt>
-<dd><p>Non-<code>nil</code> means indent <code>is separate</code> or <code>is abstract</code> if on a single line.
-</p>
-</dd>
-<dt><span><code>ada-indent-to-open-paren</code> (default value: t)</span></dt>
-<dd><p>Non-<code>nil</code> means indent according to the innermost open parenthesis.
-</p>
-</dd>
-<dt><span><code>ada-indent-after-return</code> (default value: t)</span></dt>
-<dd><p>Non-<code>nil</code> means that the current line will also be re-indented
-before inserting a newline, when you press <tt class="key">RET</tt>.
-</p></dd>
-</dl>
-
-<p>Most of the time, the indentation will be automatic, i.e., when you
-press <tt class="key">RET</tt>, the cursor will move to the correct column on the
-next line.
-</p>
-<p>You can also indent single lines, or the current region, with <tt class="key">TAB</tt>.
-</p>
-<p>Another mode of indentation exists that helps you to set up your
-indentation scheme. If you press <kbd>C-c <span class="key">TAB</span></kbd>, Ada mode will do
-the following:
-</p>
-<ul>
-<li> Reindent the current line, as <tt class="key">TAB</tt> would do.
-</li><li> Temporarily move the cursor to a reference line, i.e., the line that
-was used to calculate the current indentation.
-</li><li> Display in the message window the name of the variable that provided
-the offset for the indentation.
-</li></ul>
-
-<p>The exact indentation of the current line is the same as the one for the
-reference line, plus an offset given by the variable.
-</p>
-<dl compact="compact">
-<dt><span><kbd><span class="key">TAB</span></kbd></span></dt>
-<dd><p>Indent the current line or the current region.
-</p></dd>
-<dt><span><kbd>C-M-\</kbd></span></dt>
-<dd><p>Indent lines in the current region.
-</p></dd>
-<dt><span><kbd>C-c <span class="key">TAB</span></kbd></span></dt>
-<dd><p>Indent the current line and display the name of the variable used for
-indentation.
-</p></dd>
-</dl>
-
-<hr>
-</div>
-<div class="chapter" id="Formatting-Parameter-Lists">
-<div class="header">
-<p>
-Next: <a href="#Automatic-Casing" accesskey="n" rel="next">Automatic Casing</a>, Previous: <a href="#Automatic-Smart-Indentation" accesskey="p" rel="prev">Automatic Smart Indentation</a>, Up: <a href="#Top" accesskey="u" rel="up">Ada Mode</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#Index" title="Index" rel="index">Index</a>]</p>
-</div>
-<span id="Formatting-Parameter-Lists-1"></span><h2 class="chapter">10 Formatting Parameter Lists</h2>
-
-<dl compact="compact">
-<dt id='index-ada_002dformat_002dparamlist'><span><kbd>C-c C-f</kbd><a href='#index-ada_002dformat_002dparamlist' class='copiable-anchor'> &para;</a></span></dt>
-<dd><p>Format the parameter list (<code>ada-format-paramlist</code>).
-</p></dd>
-</dl>
-
-<p>This aligns the declarations on the colon (&lsquo;<samp>:</samp>&rsquo;) separating
-argument names and argument types, and aligns the <code>in</code>,
-<code>out</code> and <code>in out</code> keywords.
-</p>
-<hr>
-</div>
-<div class="chapter" id="Automatic-Casing">
-<div class="header">
-<p>
-Next: <a href="#Statement-Templates" accesskey="n" rel="next">Statement Templates</a>, Previous: <a href="#Formatting-Parameter-Lists" accesskey="p" rel="prev">Formatting Parameter Lists</a>, Up: <a href="#Top" accesskey="u" rel="up">Ada Mode</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#Index" title="Index" rel="index">Index</a>]</p>
-</div>
-<span id="Automatic-Casing-1"></span><h2 class="chapter">11 Automatic Casing</h2>
-
-<p>Casing of identifiers, attributes and keywords is automatically
-performed while typing when the variable <code>ada-auto-case</code> is set.
-Every time you press a word separator, the previous word is
-automatically cased.
-</p>
-<p>You can customize the automatic casing differently for keywords,
-attributes and identifiers. The relevant variables are the following:
-<code>ada-case-keyword</code>, <code>ada-case-attribute</code> and
-<code>ada-case-identifier</code>.
-</p>
-<p>All these variables can have one of the following values:
-</p>
-<dl compact="compact">
-<dt><span><code>downcase-word</code></span></dt>
-<dd><p>The word will be lowercase. For instance <code>My_vARIable</code> is
-converted to <code>my_variable</code>.
-</p>
-</dd>
-<dt><span><code>upcase-word</code></span></dt>
-<dd><p>The word will be uppercase. For instance <code>My_vARIable</code> is
-converted to <code>MY_VARIABLE</code>.
-</p>
-</dd>
-<dt><span><code>ada-capitalize-word</code></span></dt>
-<dd><p>The first letter and each letter following an underscore (&lsquo;<samp>_</samp>&rsquo;)
-are uppercase, others are lowercase. For instance <code>My_vARIable</code>
-is converted to <code>My_Variable</code>.
-</p>
-</dd>
-<dt><span><code>ada-loose-case-word</code></span></dt>
-<dd><p>Characters after an underscore &lsquo;<samp>_</samp>&rsquo; character are uppercase,
-others are not modified. For instance <code>My_vARIable</code> is converted
-to <code>My_VARIable</code>.
-</p></dd>
-</dl>
-
-<p>Ada mode allows you to define exceptions to these rules, in a file
-specified by the variable <code>ada-case-exception-file</code>
-(default <samp>~/.emacs_case_exceptions</samp>). Each line in this file
-specifies the casing of one word or word fragment. Comments may be
-included, separated from the word by a space.
-</p>
-<p>If the word starts with an asterisk (&lsquo;<samp>*</samp>&rsquo;), it defines the casing
-as a word fragment (or &ldquo;substring&rdquo;); part of a word between two
-underscores or word boundary.
-</p>
-<p>For example:
-</p>
-<div class="example">
-<pre class="example">DOD Department of Defense
-*IO
-GNAT The GNAT compiler from Ada Core Technologies
-</pre></div>
-
-<p>The word fragment <code>*IO</code> applies to any word containing &ldquo;_io&rdquo;;
-<code>Text_IO</code>, <code>Hardware_IO</code>, etc.
-</p>
-<span id="index-ada_002dcreate_002dcase_002dexception"></span>
-<p>There are two ways to add new items to this file: you can simply edit
-it as you would edit any text file. Or you can position point on the
-word you want to add, and select menu &lsquo;<samp>Ada | Edit | Create Case
-Exception</samp>&rsquo;, or press <kbd>C-c C-y</kbd> (<code>ada-create-case-exception</code>).
-The word will automatically be added to the current list of exceptions
-and to the file.
-</p>
-<p>To define a word fragment case exception, select the word fragment,
-then select menu &lsquo;<samp>Ada | Edit | Create Case Exception Substring</samp>&rsquo;.
-</p>
-<p>It is sometimes useful to have multiple exception files around (for
-instance, one could be the standard Ada acronyms, the second some
-company specific exceptions, and the last one some project specific
-exceptions). If you set up the variable <code>ada-case-exception-file</code>
-as a list of files, each of them will be parsed and used in your emacs
-session. However, when you save a new exception through the menu, as
-described above, the new exception will be added to the first file in
-the list.
-</p>
-<dl compact="compact">
-<dt id='index-ada_002dadjust_002dcase_002dbuffer'><span><kbd>C-c C-b</kbd><a href='#index-ada_002dadjust_002dcase_002dbuffer' class='copiable-anchor'> &para;</a></span></dt>
-<dd><p>Adjust case in the whole buffer (<code>ada-adjust-case-buffer</code>).
-</p></dd>
-<dt><span><kbd>C-c C-y</kbd></span></dt>
-<dd><p>Create a new entry in the exception dictionary, with the word under
-the cursor (<code>ada-create-case-exception</code>)
-</p></dd>
-<dt id='index-ada_002dcase_002dread_002dexceptions'><span><kbd>C-c C-t</kbd><a href='#index-ada_002dcase_002dread_002dexceptions' class='copiable-anchor'> &para;</a></span></dt>
-<dd><p>Rereads the exception dictionary from the file
-<code>ada-case-exception-file</code> (<code>ada-case-read-exceptions</code>).
-</p></dd>
-</dl>
-
-<hr>
-</div>
-<div class="chapter" id="Statement-Templates">
-<div class="header">
-<p>
-Next: <a href="#Comment-Handling" accesskey="n" rel="next">Comment Handling</a>, Previous: <a href="#Automatic-Casing" accesskey="p" rel="prev">Automatic Casing</a>, Up: <a href="#Top" accesskey="u" rel="up">Ada Mode</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#Index" title="Index" rel="index">Index</a>]</p>
-</div>
-<span id="Statement-Templates-1"></span><h2 class="chapter">12 Statement Templates</h2>
-
-<p>Templates are defined for most Ada statements, using the Emacs
-&ldquo;skeleton&rdquo; package. They can be inserted in the buffer using the
-following commands:
-</p>
-<dl compact="compact">
-<dt id='index-ada_002dexception_002dblock'><span><kbd>C-c t b</kbd><a href='#index-ada_002dexception_002dblock' class='copiable-anchor'> &para;</a></span></dt>
-<dd><p>exception Block (<code>ada-exception-block</code>).
-</p></dd>
-<dt id='index-ada_002dcase'><span><kbd>C-c t c</kbd><a href='#index-ada_002dcase' class='copiable-anchor'> &para;</a></span></dt>
-<dd><p>case (<code>ada-case</code>).
-</p></dd>
-<dt id='index-ada_002ddeclare_002dblock'><span><kbd>C-c t d</kbd><a href='#index-ada_002ddeclare_002dblock' class='copiable-anchor'> &para;</a></span></dt>
-<dd><p>declare Block (<code>ada-declare-block</code>).
-</p></dd>
-<dt id='index-ada_002delse'><span><kbd>C-c t e</kbd><a href='#index-ada_002delse' class='copiable-anchor'> &para;</a></span></dt>
-<dd><p>else (<code>ada-else</code>).
-</p></dd>
-<dt id='index-ada_002dfor_002dloop'><span><kbd>C-c t f</kbd><a href='#index-ada_002dfor_002dloop' class='copiable-anchor'> &para;</a></span></dt>
-<dd><p>for Loop (<code>ada-for-loop</code>).
-</p></dd>
-<dt id='index-ada_002dheader'><span><kbd>C-c t h</kbd><a href='#index-ada_002dheader' class='copiable-anchor'> &para;</a></span></dt>
-<dd><p>Header (<code>ada-header</code>).
-</p></dd>
-<dt id='index-ada_002dif'><span><kbd>C-c t i</kbd><a href='#index-ada_002dif' class='copiable-anchor'> &para;</a></span></dt>
-<dd><p>if (<code>ada-if</code>).
-</p></dd>
-<dt id='index-ada_002dpackage_002dbody'><span><kbd>C-c t k</kbd><a href='#index-ada_002dpackage_002dbody' class='copiable-anchor'> &para;</a></span></dt>
-<dd><p>package Body (<code>ada-package-body</code>).
-</p></dd>
-<dt id='index-ada_002dloop'><span><kbd>C-c t l</kbd><a href='#index-ada_002dloop' class='copiable-anchor'> &para;</a></span></dt>
-<dd><p>loop (<code>ada-loop</code>).
-</p></dd>
-<dt id='index-ada_002dsubprogram_002dbody'><span><kbd>C-c p</kbd><a href='#index-ada_002dsubprogram_002dbody' class='copiable-anchor'> &para;</a></span></dt>
-<dd><p>subprogram body (<code>ada-subprogram-body</code>).
-</p></dd>
-<dt id='index-ada_002dtask_002dbody'><span><kbd>C-c t t</kbd><a href='#index-ada_002dtask_002dbody' class='copiable-anchor'> &para;</a></span></dt>
-<dd><p>task Body (<code>ada-task-body</code>).
-</p></dd>
-<dt id='index-ada_002dwhile'><span><kbd>C-c t w</kbd><a href='#index-ada_002dwhile' class='copiable-anchor'> &para;</a></span></dt>
-<dd><p>while Loop (<code>ada-while</code>).
-</p></dd>
-<dt id='index-ada_002duse'><span><kbd>C-c t u</kbd><a href='#index-ada_002duse' class='copiable-anchor'> &para;</a></span></dt>
-<dd><p>use (<code>ada-use</code>).
-</p></dd>
-<dt id='index-ada_002dexit'><span><kbd>C-c t x</kbd><a href='#index-ada_002dexit' class='copiable-anchor'> &para;</a></span></dt>
-<dd><p>exit (<code>ada-exit</code>).
-</p></dd>
-<dt id='index-ada_002darray'><span><kbd>C-c t C-a</kbd><a href='#index-ada_002darray' class='copiable-anchor'> &para;</a></span></dt>
-<dd><p>array (<code>ada-array</code>).
-</p></dd>
-<dt id='index-ada_002delsif'><span><kbd>C-c t C-e</kbd><a href='#index-ada_002delsif' class='copiable-anchor'> &para;</a></span></dt>
-<dd><p>elsif (<code>ada-elsif</code>).
-</p></dd>
-<dt id='index-ada_002dfunction_002dspec'><span><kbd>C-c t C-f</kbd><a href='#index-ada_002dfunction_002dspec' class='copiable-anchor'> &para;</a></span></dt>
-<dd><p>function Spec (<code>ada-function-spec</code>).
-</p></dd>
-<dt id='index-ada_002dpackage_002dspec'><span><kbd>C-c t C-k</kbd><a href='#index-ada_002dpackage_002dspec' class='copiable-anchor'> &para;</a></span></dt>
-<dd><p>package Spec (<code>ada-package-spec</code>).
-</p></dd>
-<dt id='index-ada_002dprocedure_002dspec'><span><kbd>C-c t C-p</kbd><a href='#index-ada_002dprocedure_002dspec' class='copiable-anchor'> &para;</a></span></dt>
-<dd><p>procedure Spec (<code>ada-package-spec</code>.
-</p></dd>
-<dt id='index-ada_002drecord'><span><kbd>C-c t C-r</kbd><a href='#index-ada_002drecord' class='copiable-anchor'> &para;</a></span></dt>
-<dd><p>record (<code>ada-record</code>).
-</p></dd>
-<dt id='index-ada_002dsubtype'><span><kbd>C-c t C-s</kbd><a href='#index-ada_002dsubtype' class='copiable-anchor'> &para;</a></span></dt>
-<dd><p>subtype (<code>ada-subtype</code>).
-</p></dd>
-<dt id='index-ada_002dtask_002dspec'><span><kbd>C-c t C-t</kbd><a href='#index-ada_002dtask_002dspec' class='copiable-anchor'> &para;</a></span></dt>
-<dd><p>task Spec (<code>ada-task-spec</code>).
-</p></dd>
-<dt id='index-ada_002dwith'><span><kbd>C-c t C-u</kbd><a href='#index-ada_002dwith' class='copiable-anchor'> &para;</a></span></dt>
-<dd><p>with (<code>ada-with</code>).
-</p></dd>
-<dt id='index-ada_002dprivate'><span><kbd>C-c t C-v</kbd><a href='#index-ada_002dprivate' class='copiable-anchor'> &para;</a></span></dt>
-<dd><p>private (<code>ada-private</code>).
-</p></dd>
-<dt id='index-ada_002dwhen'><span><kbd>C-c t C-w</kbd><a href='#index-ada_002dwhen' class='copiable-anchor'> &para;</a></span></dt>
-<dd><p>when (<code>ada-when</code>).
-</p></dd>
-<dt id='index-ada_002dexception'><span><kbd>C-c t C-x</kbd><a href='#index-ada_002dexception' class='copiable-anchor'> &para;</a></span></dt>
-<dd><p>exception (<code>ada-exception</code>).
-</p></dd>
-<dt id='index-ada_002dtype'><span><kbd>C-c t C-y</kbd><a href='#index-ada_002dtype' class='copiable-anchor'> &para;</a></span></dt>
-<dd><p>type (<code>ada-type</code>).
-</p></dd>
-</dl>
-
-<hr>
-</div>
-<div class="chapter" id="Comment-Handling">
-<div class="header">
-<p>
-Next: <a href="#GNU-Free-Documentation-License" accesskey="n" rel="next">GNU Free Documentation License</a>, Previous: <a href="#Statement-Templates" accesskey="p" rel="prev">Statement Templates</a>, Up: <a href="#Top" accesskey="u" rel="up">Ada Mode</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#Index" title="Index" rel="index">Index</a>]</p>
-</div>
-<span id="Comment-Handling-1"></span><h2 class="chapter">13 Comment Handling</h2>
-
-<p>By default, comment lines get indented like Ada code. There are a few
-additional functions to handle comments:
-</p>
-<dl compact="compact">
-<dt><span><kbd>M-;</kbd></span></dt>
-<dd><p>Start a comment in default column.
-</p></dd>
-<dt><span><kbd>M-j</kbd></span></dt>
-<dd><p>Continue comment on next line.
-</p></dd>
-<dt><span><kbd>C-c ;</kbd></span></dt>
-<dd><p>Comment the selected region (add &lsquo;<samp>--</samp>&rsquo; at the beginning of lines).
-</p></dd>
-<dt><span><kbd>C-c :</kbd></span></dt>
-<dd><p>Uncomment the selected region
-</p></dd>
-<dt><span><kbd>M-q</kbd></span></dt>
-<dd><p>autofill the current comment.
-</p></dd>
-</dl>
-
-<hr>
-</div>
-<div class="appendix" id="GNU-Free-Documentation-License">
-<div class="header">
-<p>
-Next: <a href="#Index" accesskey="n" rel="next">Index</a>, Previous: <a href="#Comment-Handling" accesskey="p" rel="prev">Comment Handling</a>, Up: <a href="#Top" accesskey="u" rel="up">Ada Mode</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#Index" title="Index" rel="index">Index</a>]</p>
-</div>
-<span id="GNU-Free-Documentation-License-1"></span><h2 class="appendix">Appendix A GNU Free Documentation License</h2>
-<div align="center">Version 1.3, 3 November 2008
-</div>
-
-<div class="display">
-<pre class="display">Copyright &copy; 2000, 2001, 2002, 2007, 2008 Free Software Foundation, Inc.
-<a href="https://fsf.org/">https://fsf.org/</a>
-
-Everyone is permitted to copy and distribute verbatim copies
-of this license document, but changing it is not allowed.
-</pre></div>
-
-<ol start="0">
-<li> PREAMBLE
-
-<p>The purpose of this License is to make a manual, textbook, or other
-functional and useful document <em>free</em> in the sense of freedom: to
-assure everyone the effective freedom to copy and redistribute it,
-with or without modifying it, either commercially or noncommercially.
-Secondarily, this License preserves for the author and publisher a way
-to get credit for their work, while not being considered responsible
-for modifications made by others.
-</p>
-<p>This License is a kind of &ldquo;copyleft&rdquo;, which means that derivative
-works of the document must themselves be free in the same sense. It
-complements the GNU General Public License, which is a copyleft
-license designed for free software.
-</p>
-<p>We have designed this License in order to use it for manuals for free
-software, because free software needs free documentation: a free
-program should come with manuals providing the same freedoms that the
-software does. But this License is not limited to software manuals;
-it can be used for any textual work, regardless of subject matter or
-whether it is published as a printed book. We recommend this License
-principally for works whose purpose is instruction or reference.
-</p>
-</li><li> APPLICABILITY AND DEFINITIONS
-
-<p>This License applies to any manual or other work, in any medium, that
-contains a notice placed by the copyright holder saying it can be
-distributed under the terms of this License. Such a notice grants a
-world-wide, royalty-free license, unlimited in duration, to use that
-work under the conditions stated herein. The &ldquo;Document&rdquo;, below,
-refers to any such manual or work. Any member of the public is a
-licensee, and is addressed as &ldquo;you&rdquo;. You accept the license if you
-copy, modify or distribute the work in a way requiring permission
-under copyright law.
-</p>
-<p>A &ldquo;Modified Version&rdquo; of the Document means any work containing the
-Document or a portion of it, either copied verbatim, or with
-modifications and/or translated into another language.
-</p>
-<p>A &ldquo;Secondary Section&rdquo; is a named appendix or a front-matter section
-of the Document that deals exclusively with the relationship of the
-publishers or authors of the Document to the Document&rsquo;s overall
-subject (or to related matters) and contains nothing that could fall
-directly within that overall subject. (Thus, if the Document is in
-part a textbook of mathematics, a Secondary Section may not explain
-any mathematics.) The relationship could be a matter of historical
-connection with the subject or with related matters, or of legal,
-commercial, philosophical, ethical or political position regarding
-them.
-</p>
-<p>The &ldquo;Invariant Sections&rdquo; are certain Secondary Sections whose titles
-are designated, as being those of Invariant Sections, in the notice
-that says that the Document is released under this License. If a
-section does not fit the above definition of Secondary then it is not
-allowed to be designated as Invariant. The Document may contain zero
-Invariant Sections. If the Document does not identify any Invariant
-Sections then there are none.
-</p>
-<p>The &ldquo;Cover Texts&rdquo; are certain short passages of text that are listed,
-as Front-Cover Texts or Back-Cover Texts, in the notice that says that
-the Document is released under this License. A Front-Cover Text may
-be at most 5 words, and a Back-Cover Text may be at most 25 words.
-</p>
-<p>A &ldquo;Transparent&rdquo; copy of the Document means a machine-readable copy,
-represented in a format whose specification is available to the
-general public, that is suitable for revising the document
-straightforwardly with generic text editors or (for images composed of
-pixels) generic paint programs or (for drawings) some widely available
-drawing editor, and that is suitable for input to text formatters or
-for automatic translation to a variety of formats suitable for input
-to text formatters. A copy made in an otherwise Transparent file
-format whose markup, or absence of markup, has been arranged to thwart
-or discourage subsequent modification by readers is not Transparent.
-An image format is not Transparent if used for any substantial amount
-of text. A copy that is not &ldquo;Transparent&rdquo; is called &ldquo;Opaque&rdquo;.
-</p>
-<p>Examples of suitable formats for Transparent copies include plain
-ASCII without markup, Texinfo input format, LaTeX input
-format, SGML or XML using a publicly available
-DTD, and standard-conforming simple HTML,
-PostScript or PDF designed for human modification. Examples
-of transparent image formats include PNG, XCF and
-JPG. Opaque formats include proprietary formats that can be
-read and edited only by proprietary word processors, SGML or
-XML for which the DTD and/or processing tools are
-not generally available, and the machine-generated HTML,
-PostScript or PDF produced by some word processors for
-output purposes only.
-</p>
-<p>The &ldquo;Title Page&rdquo; means, for a printed book, the title page itself,
-plus such following pages as are needed to hold, legibly, the material
-this License requires to appear in the title page. For works in
-formats which do not have any title page as such, &ldquo;Title Page&rdquo; means
-the text near the most prominent appearance of the work&rsquo;s title,
-preceding the beginning of the body of the text.
-</p>
-<p>The &ldquo;publisher&rdquo; means any person or entity that distributes copies
-of the Document to the public.
-</p>
-<p>A section &ldquo;Entitled XYZ&rdquo; means a named subunit of the Document whose
-title either is precisely XYZ or contains XYZ in parentheses following
-text that translates XYZ in another language. (Here XYZ stands for a
-specific section name mentioned below, such as &ldquo;Acknowledgements&rdquo;,
-&ldquo;Dedications&rdquo;, &ldquo;Endorsements&rdquo;, or &ldquo;History&rdquo;.) To &ldquo;Preserve the Title&rdquo;
-of such a section when you modify the Document means that it remains a
-section &ldquo;Entitled XYZ&rdquo; according to this definition.
-</p>
-<p>The Document may include Warranty Disclaimers next to the notice which
-states that this License applies to the Document. These Warranty
-Disclaimers are considered to be included by reference in this
-License, but only as regards disclaiming warranties: any other
-implication that these Warranty Disclaimers may have is void and has
-no effect on the meaning of this License.
-</p>
-</li><li> VERBATIM COPYING
-
-<p>You may copy and distribute the Document in any medium, either
-commercially or noncommercially, provided that this License, the
-copyright notices, and the license notice saying this License applies
-to the Document are reproduced in all copies, and that you add no other
-conditions whatsoever to those of this License. You may not use
-technical measures to obstruct or control the reading or further
-copying of the copies you make or distribute. However, you may accept
-compensation in exchange for copies. If you distribute a large enough
-number of copies you must also follow the conditions in section 3.
-</p>
-<p>You may also lend copies, under the same conditions stated above, and
-you may publicly display copies.
-</p>
-</li><li> COPYING IN QUANTITY
-
-<p>If you publish printed copies (or copies in media that commonly have
-printed covers) of the Document, numbering more than 100, and the
-Document&rsquo;s license notice requires Cover Texts, you must enclose the
-copies in covers that carry, clearly and legibly, all these Cover
-Texts: Front-Cover Texts on the front cover, and Back-Cover Texts on
-the back cover. Both covers must also clearly and legibly identify
-you as the publisher of these copies. The front cover must present
-the full title with all words of the title equally prominent and
-visible. You may add other material on the covers in addition.
-Copying with changes limited to the covers, as long as they preserve
-the title of the Document and satisfy these conditions, can be treated
-as verbatim copying in other respects.
-</p>
-<p>If the required texts for either cover are too voluminous to fit
-legibly, you should put the first ones listed (as many as fit
-reasonably) on the actual cover, and continue the rest onto adjacent
-pages.
-</p>
-<p>If you publish or distribute Opaque copies of the Document numbering
-more than 100, you must either include a machine-readable Transparent
-copy along with each Opaque copy, or state in or with each Opaque copy
-a computer-network location from which the general network-using
-public has access to download using public-standard network protocols
-a complete Transparent copy of the Document, free of added material.
-If you use the latter option, you must take reasonably prudent steps,
-when you begin distribution of Opaque copies in quantity, to ensure
-that this Transparent copy will remain thus accessible at the stated
-location until at least one year after the last time you distribute an
-Opaque copy (directly or through your agents or retailers) of that
-edition to the public.
-</p>
-<p>It is requested, but not required, that you contact the authors of the
-Document well before redistributing any large number of copies, to give
-them a chance to provide you with an updated version of the Document.
-</p>
-</li><li> MODIFICATIONS
-
-<p>You may copy and distribute a Modified Version of the Document under
-the conditions of sections 2 and 3 above, provided that you release
-the Modified Version under precisely this License, with the Modified
-Version filling the role of the Document, thus licensing distribution
-and modification of the Modified Version to whoever possesses a copy
-of it. In addition, you must do these things in the Modified Version:
-</p>
-<ol type="A" start="1">
-<li> Use in the Title Page (and on the covers, if any) a title distinct
-from that of the Document, and from those of previous versions
-(which should, if there were any, be listed in the History section
-of the Document). You may use the same title as a previous version
-if the original publisher of that version gives permission.
-
-</li><li> List on the Title Page, as authors, one or more persons or entities
-responsible for authorship of the modifications in the Modified
-Version, together with at least five of the principal authors of the
-Document (all of its principal authors, if it has fewer than five),
-unless they release you from this requirement.
-
-</li><li> State on the Title page the name of the publisher of the
-Modified Version, as the publisher.
-
-</li><li> Preserve all the copyright notices of the Document.
-
-</li><li> Add an appropriate copyright notice for your modifications
-adjacent to the other copyright notices.
-
-</li><li> Include, immediately after the copyright notices, a license notice
-giving the public permission to use the Modified Version under the
-terms of this License, in the form shown in the Addendum below.
-
-</li><li> Preserve in that license notice the full lists of Invariant Sections
-and required Cover Texts given in the Document&rsquo;s license notice.
-
-</li><li> Include an unaltered copy of this License.
-
-</li><li> Preserve the section Entitled &ldquo;History&rdquo;, Preserve its Title, and add
-to it an item stating at least the title, year, new authors, and
-publisher of the Modified Version as given on the Title Page. If
-there is no section Entitled &ldquo;History&rdquo; in the Document, create one
-stating the title, year, authors, and publisher of the Document as
-given on its Title Page, then add an item describing the Modified
-Version as stated in the previous sentence.
-
-</li><li> Preserve the network location, if any, given in the Document for
-public access to a Transparent copy of the Document, and likewise
-the network locations given in the Document for previous versions
-it was based on. These may be placed in the &ldquo;History&rdquo; section.
-You may omit a network location for a work that was published at
-least four years before the Document itself, or if the original
-publisher of the version it refers to gives permission.
-
-</li><li> For any section Entitled &ldquo;Acknowledgements&rdquo; or &ldquo;Dedications&rdquo;, Preserve
-the Title of the section, and preserve in the section all the
-substance and tone of each of the contributor acknowledgements and/or
-dedications given therein.
-
-</li><li> Preserve all the Invariant Sections of the Document,
-unaltered in their text and in their titles. Section numbers
-or the equivalent are not considered part of the section titles.
-
-</li><li> Delete any section Entitled &ldquo;Endorsements&rdquo;. Such a section
-may not be included in the Modified Version.
-
-</li><li> Do not retitle any existing section to be Entitled &ldquo;Endorsements&rdquo; or
-to conflict in title with any Invariant Section.
-
-</li><li> Preserve any Warranty Disclaimers.
-</li></ol>
-
-<p>If the Modified Version includes new front-matter sections or
-appendices that qualify as Secondary Sections and contain no material
-copied from the Document, you may at your option designate some or all
-of these sections as invariant. To do this, add their titles to the
-list of Invariant Sections in the Modified Version&rsquo;s license notice.
-These titles must be distinct from any other section titles.
-</p>
-<p>You may add a section Entitled &ldquo;Endorsements&rdquo;, provided it contains
-nothing but endorsements of your Modified Version by various
-parties&mdash;for example, statements of peer review or that the text has
-been approved by an organization as the authoritative definition of a
-standard.
-</p>
-<p>You may add a passage of up to five words as a Front-Cover Text, and a
-passage of up to 25 words as a Back-Cover Text, to the end of the list
-of Cover Texts in the Modified Version. Only one passage of
-Front-Cover Text and one of Back-Cover Text may be added by (or
-through arrangements made by) any one entity. If the Document already
-includes a cover text for the same cover, previously added by you or
-by arrangement made by the same entity you are acting on behalf of,
-you may not add another; but you may replace the old one, on explicit
-permission from the previous publisher that added the old one.
-</p>
-<p>The author(s) and publisher(s) of the Document do not by this License
-give permission to use their names for publicity for or to assert or
-imply endorsement of any Modified Version.
-</p>
-</li><li> COMBINING DOCUMENTS
-
-<p>You may combine the Document with other documents released under this
-License, under the terms defined in section 4 above for modified
-versions, provided that you include in the combination all of the
-Invariant Sections of all of the original documents, unmodified, and
-list them all as Invariant Sections of your combined work in its
-license notice, and that you preserve all their Warranty Disclaimers.
-</p>
-<p>The combined work need only contain one copy of this License, and
-multiple identical Invariant Sections may be replaced with a single
-copy. If there are multiple Invariant Sections with the same name but
-different contents, make the title of each such section unique by
-adding at the end of it, in parentheses, the name of the original
-author or publisher of that section if known, or else a unique number.
-Make the same adjustment to the section titles in the list of
-Invariant Sections in the license notice of the combined work.
-</p>
-<p>In the combination, you must combine any sections Entitled &ldquo;History&rdquo;
-in the various original documents, forming one section Entitled
-&ldquo;History&rdquo;; likewise combine any sections Entitled &ldquo;Acknowledgements&rdquo;,
-and any sections Entitled &ldquo;Dedications&rdquo;. You must delete all
-sections Entitled &ldquo;Endorsements.&rdquo;
-</p>
-</li><li> COLLECTIONS OF DOCUMENTS
-
-<p>You may make a collection consisting of the Document and other documents
-released under this License, and replace the individual copies of this
-License in the various documents with a single copy that is included in
-the collection, provided that you follow the rules of this License for
-verbatim copying of each of the documents in all other respects.
-</p>
-<p>You may extract a single document from such a collection, and distribute
-it individually under this License, provided you insert a copy of this
-License into the extracted document, and follow this License in all
-other respects regarding verbatim copying of that document.
-</p>
-</li><li> AGGREGATION WITH INDEPENDENT WORKS
-
-<p>A compilation of the Document or its derivatives with other separate
-and independent documents or works, in or on a volume of a storage or
-distribution medium, is called an &ldquo;aggregate&rdquo; if the copyright
-resulting from the compilation is not used to limit the legal rights
-of the compilation&rsquo;s users beyond what the individual works permit.
-When the Document is included in an aggregate, this License does not
-apply to the other works in the aggregate which are not themselves
-derivative works of the Document.
-</p>
-<p>If the Cover Text requirement of section 3 is applicable to these
-copies of the Document, then if the Document is less than one half of
-the entire aggregate, the Document&rsquo;s Cover Texts may be placed on
-covers that bracket the Document within the aggregate, or the
-electronic equivalent of covers if the Document is in electronic form.
-Otherwise they must appear on printed covers that bracket the whole
-aggregate.
-</p>
-</li><li> TRANSLATION
-
-<p>Translation is considered a kind of modification, so you may
-distribute translations of the Document under the terms of section 4.
-Replacing Invariant Sections with translations requires special
-permission from their copyright holders, but you may include
-translations of some or all Invariant Sections in addition to the
-original versions of these Invariant Sections. You may include a
-translation of this License, and all the license notices in the
-Document, and any Warranty Disclaimers, provided that you also include
-the original English version of this License and the original versions
-of those notices and disclaimers. In case of a disagreement between
-the translation and the original version of this License or a notice
-or disclaimer, the original version will prevail.
-</p>
-<p>If a section in the Document is Entitled &ldquo;Acknowledgements&rdquo;,
-&ldquo;Dedications&rdquo;, or &ldquo;History&rdquo;, the requirement (section 4) to Preserve
-its Title (section 1) will typically require changing the actual
-title.
-</p>
-</li><li> TERMINATION
-
-<p>You may not copy, modify, sublicense, or distribute the Document
-except as expressly provided under this License. Any attempt
-otherwise to copy, modify, sublicense, or distribute it is void, and
-will automatically terminate your rights under this License.
-</p>
-<p>However, if you cease all violation of this License, then your license
-from a particular copyright holder is reinstated (a) provisionally,
-unless and until the copyright holder explicitly and finally
-terminates your license, and (b) permanently, if the copyright holder
-fails to notify you of the violation by some reasonable means prior to
-60 days after the cessation.
-</p>
-<p>Moreover, your license from a particular copyright holder is
-reinstated permanently if the copyright holder notifies you of the
-violation by some reasonable means, this is the first time you have
-received notice of violation of this License (for any work) from that
-copyright holder, and you cure the violation prior to 30 days after
-your receipt of the notice.
-</p>
-<p>Termination of your rights under this section does not terminate the
-licenses of parties who have received copies or rights from you under
-this License. If your rights have been terminated and not permanently
-reinstated, receipt of a copy of some or all of the same material does
-not give you any rights to use it.
-</p>
-</li><li> FUTURE REVISIONS OF THIS LICENSE
-
-<p>The Free Software Foundation may publish new, revised versions
-of the GNU Free Documentation License from time to time. Such new
-versions will be similar in spirit to the present version, but may
-differ in detail to address new problems or concerns. See
-<a href="https://www.gnu.org/licenses/">https://www.gnu.org/licenses/</a>.
-</p>
-<p>Each version of the License is given a distinguishing version number.
-If the Document specifies that a particular numbered version of this
-License &ldquo;or any later version&rdquo; applies to it, you have the option of
-following the terms and conditions either of that specified version or
-of any later version that has been published (not as a draft) by the
-Free Software Foundation. If the Document does not specify a version
-number of this License, you may choose any version ever published (not
-as a draft) by the Free Software Foundation. If the Document
-specifies that a proxy can decide which future versions of this
-License can be used, that proxy&rsquo;s public statement of acceptance of a
-version permanently authorizes you to choose that version for the
-Document.
-</p>
-</li><li> RELICENSING
-
-<p>&ldquo;Massive Multiauthor Collaboration Site&rdquo; (or &ldquo;MMC Site&rdquo;) means any
-World Wide Web server that publishes copyrightable works and also
-provides prominent facilities for anybody to edit those works. A
-public wiki that anybody can edit is an example of such a server. A
-&ldquo;Massive Multiauthor Collaboration&rdquo; (or &ldquo;MMC&rdquo;) contained in the
-site means any set of copyrightable works thus published on the MMC
-site.
-</p>
-<p>&ldquo;CC-BY-SA&rdquo; means the Creative Commons Attribution-Share Alike 3.0
-license published by Creative Commons Corporation, a not-for-profit
-corporation with a principal place of business in San Francisco,
-California, as well as future copyleft versions of that license
-published by that same organization.
-</p>
-<p>&ldquo;Incorporate&rdquo; means to publish or republish a Document, in whole or
-in part, as part of another Document.
-</p>
-<p>An MMC is &ldquo;eligible for relicensing&rdquo; if it is licensed under this
-License, and if all works that were first published under this License
-somewhere other than this MMC, and subsequently incorporated in whole
-or in part into the MMC, (1) had no cover texts or invariant sections,
-and (2) were thus incorporated prior to November 1, 2008.
-</p>
-<p>The operator of an MMC Site may republish an MMC contained in the site
-under CC-BY-SA on the same site at any time before August 1, 2009,
-provided the MMC is eligible for relicensing.
-</p>
-</li></ol>
-
-<span id="ADDENDUM_003a-How-to-use-this-License-for-your-documents"></span><h3 class="heading">ADDENDUM: How to use this License for your documents</h3>
-
-<p>To use this License in a document you have written, include a copy of
-the License in the document and put the following copyright and
-license notices just after the title page:
-</p>
-<div class="example">
-<pre class="example"> Copyright (C) <var>year</var> <var>your name</var>.
- Permission is granted to copy, distribute and/or modify this document
- under the terms of the GNU Free Documentation License, Version 1.3
- or any later version published by the Free Software Foundation;
- with no Invariant Sections, no Front-Cover Texts, and no Back-Cover
- Texts. A copy of the license is included in the section entitled ``GNU
- Free Documentation License''.
-</pre></div>
-
-<p>If you have Invariant Sections, Front-Cover Texts and Back-Cover Texts,
-replace the &ldquo;with&hellip;Texts.&rdquo; line with this:
-</p>
-<div class="example">
-<pre class="example"> with the Invariant Sections being <var>list their titles</var>, with
- the Front-Cover Texts being <var>list</var>, and with the Back-Cover Texts
- being <var>list</var>.
-</pre></div>
-
-<p>If you have Invariant Sections without Cover Texts, or some other
-combination of the three, merge those two alternatives to suit the
-situation.
-</p>
-<p>If your document contains nontrivial examples of program code, we
-recommend releasing these examples in parallel under your choice of
-free software license, such as the GNU General Public License,
-to permit their use in free software.
-</p>
-
-<hr>
-</div>
-<div class="unnumbered" id="Index">
-<div class="header">
-<p>
-Previous: <a href="#GNU-Free-Documentation-License" accesskey="p" rel="prev">GNU Free Documentation License</a>, Up: <a href="#Top" accesskey="u" rel="up">Ada Mode</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#Index" title="Index" rel="index">Index</a>]</p>
-</div>
-<span id="Index-1"></span><h2 class="unnumbered">Index</h2>
-
-<table><tr><th valign="top">Jump to: &nbsp; </th><td><a class="summary-letter" href="#Index_fn_letter-A"><b>A</b></a>
- &nbsp;
-</td></tr></table>
-<table class="index-fn" border="0">
-<tr><td></td><th align="left">Index Entry</th><td>&nbsp;</td><th align="left"> Section</th></tr>
-<tr><td colspan="4"> <hr></td></tr>
-<tr><th id="Index_fn_letter-A">A</th><td></td><td></td></tr>
-<tr><td></td><td valign="top"><a href="#index-ada_002dadjust_002dcase_002dbuffer"><code>ada-adjust-case-buffer</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Automatic-Casing">Automatic Casing</a></td></tr>
-<tr><td></td><td valign="top"><a href="#index-ada_002darray"><code>ada-array</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Statement-Templates">Statement Templates</a></td></tr>
-<tr><td></td><td valign="top"><a href="#index-ada_002dcase"><code>ada-case</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Statement-Templates">Statement Templates</a></td></tr>
-<tr><td></td><td valign="top"><a href="#index-ada_002dcase_002dread_002dexceptions"><code>ada-case-read-exceptions</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Automatic-Casing">Automatic Casing</a></td></tr>
-<tr><td></td><td valign="top"><a href="#index-ada_002dcomplete_002didentifier"><code>ada-complete-identifier</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Identifier-completion">Identifier completion</a></td></tr>
-<tr><td></td><td valign="top"><a href="#index-ada_002dcreate_002dcase_002dexception"><code>ada-create-case-exception</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Automatic-Casing">Automatic Casing</a></td></tr>
-<tr><td></td><td valign="top"><a href="#index-ada_002ddeclare_002dblock"><code>ada-declare-block</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Statement-Templates">Statement Templates</a></td></tr>
-<tr><td></td><td valign="top"><a href="#index-ada_002delse"><code>ada-else</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Statement-Templates">Statement Templates</a></td></tr>
-<tr><td></td><td valign="top"><a href="#index-ada_002delsif"><code>ada-elsif</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Statement-Templates">Statement Templates</a></td></tr>
-<tr><td></td><td valign="top"><a href="#index-ada_002dexception"><code>ada-exception</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Statement-Templates">Statement Templates</a></td></tr>
-<tr><td></td><td valign="top"><a href="#index-ada_002dexception_002dblock"><code>ada-exception-block</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Statement-Templates">Statement Templates</a></td></tr>
-<tr><td></td><td valign="top"><a href="#index-ada_002dexit"><code>ada-exit</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Statement-Templates">Statement Templates</a></td></tr>
-<tr><td></td><td valign="top"><a href="#index-ada_002dfind_002dreferences"><code>ada-find-references</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Moving-Through-Ada-Code">Moving Through Ada Code</a></td></tr>
-<tr><td></td><td valign="top"><a href="#index-ada_002dfor_002dloop"><code>ada-for-loop</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Statement-Templates">Statement Templates</a></td></tr>
-<tr><td></td><td valign="top"><a href="#index-ada_002dformat_002dparamlist"><code>ada-format-paramlist</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Formatting-Parameter-Lists">Formatting Parameter Lists</a></td></tr>
-<tr><td></td><td valign="top"><a href="#index-ada_002dfunction_002dspec"><code>ada-function-spec</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Statement-Templates">Statement Templates</a></td></tr>
-<tr><td></td><td valign="top"><a href="#index-ada_002dgoto_002ddeclaration"><code>ada-goto-declaration</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Moving-Through-Ada-Code">Moving Through Ada Code</a></td></tr>
-<tr><td></td><td valign="top"><a href="#index-ada_002dheader"><code>ada-header</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Statement-Templates">Statement Templates</a></td></tr>
-<tr><td></td><td valign="top"><a href="#index-ada_002dif"><code>ada-if</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Statement-Templates">Statement Templates</a></td></tr>
-<tr><td></td><td valign="top"><a href="#index-ada_002dloop"><code>ada-loop</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Statement-Templates">Statement Templates</a></td></tr>
-<tr><td></td><td valign="top"><a href="#index-ada_002dmove_002dto_002dend"><code>ada-move-to-end</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Moving-Through-Ada-Code">Moving Through Ada Code</a></td></tr>
-<tr><td></td><td valign="top"><a href="#index-ada_002dmove_002dto_002dstart"><code>ada-move-to-start</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Moving-Through-Ada-Code">Moving Through Ada Code</a></td></tr>
-<tr><td></td><td valign="top"><a href="#index-ada_002dnext_002dpackage"><code>ada-next-package</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Moving-Through-Ada-Code">Moving Through Ada Code</a></td></tr>
-<tr><td></td><td valign="top"><a href="#index-ada_002dnext_002dprocedure"><code>ada-next-procedure</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Moving-Through-Ada-Code">Moving Through Ada Code</a></td></tr>
-<tr><td></td><td valign="top"><a href="#index-ada_002dpackage_002dbody"><code>ada-package-body</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Statement-Templates">Statement Templates</a></td></tr>
-<tr><td></td><td valign="top"><a href="#index-ada_002dpackage_002dspec"><code>ada-package-spec</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Statement-Templates">Statement Templates</a></td></tr>
-<tr><td></td><td valign="top"><a href="#index-ada_002dprevious_002dpackage"><code>ada-previous-package</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Moving-Through-Ada-Code">Moving Through Ada Code</a></td></tr>
-<tr><td></td><td valign="top"><a href="#index-ada_002dprevious_002dprocedure"><code>ada-previous-procedure</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Moving-Through-Ada-Code">Moving Through Ada Code</a></td></tr>
-<tr><td></td><td valign="top"><a href="#index-ada_002dprivate"><code>ada-private</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Statement-Templates">Statement Templates</a></td></tr>
-<tr><td></td><td valign="top"><a href="#index-ada_002dprocedure_002dspec"><code>ada-procedure-spec</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Statement-Templates">Statement Templates</a></td></tr>
-<tr><td></td><td valign="top"><a href="#index-ada_002drecord"><code>ada-record</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Statement-Templates">Statement Templates</a></td></tr>
-<tr><td></td><td valign="top"><a href="#index-ada_002dsubprogram_002dbody"><code>ada-subprogram-body</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Statement-Templates">Statement Templates</a></td></tr>
-<tr><td></td><td valign="top"><a href="#index-ada_002dsubtype"><code>ada-subtype</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Statement-Templates">Statement Templates</a></td></tr>
-<tr><td></td><td valign="top"><a href="#index-ada_002dtask_002dbody"><code>ada-task-body</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Statement-Templates">Statement Templates</a></td></tr>
-<tr><td></td><td valign="top"><a href="#index-ada_002dtask_002dspec"><code>ada-task-spec</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Statement-Templates">Statement Templates</a></td></tr>
-<tr><td></td><td valign="top"><a href="#index-ada_002dtype"><code>ada-type</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Statement-Templates">Statement Templates</a></td></tr>
-<tr><td></td><td valign="top"><a href="#index-ada_002duse"><code>ada-use</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Statement-Templates">Statement Templates</a></td></tr>
-<tr><td></td><td valign="top"><a href="#index-ada_002dwhen"><code>ada-when</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Statement-Templates">Statement Templates</a></td></tr>
-<tr><td></td><td valign="top"><a href="#index-ada_002dwhile"><code>ada-while</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Statement-Templates">Statement Templates</a></td></tr>
-<tr><td></td><td valign="top"><a href="#index-ada_002dwith"><code>ada-with</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Statement-Templates">Statement Templates</a></td></tr>
-<tr><td colspan="4"> <hr></td></tr>
-</table>
-<table><tr><th valign="top">Jump to: &nbsp; </th><td><a class="summary-letter" href="#Index_fn_letter-A"><b>A</b></a>
- &nbsp;
-</td></tr></table>
-
-</div>
-</div>
-
-
-
-</body>
-</html>
diff --git a/old_ada/doc/ada-mode.info b/old_ada/doc/ada-mode.info
deleted file mode 100644
index e29172d..0000000
--- a/old_ada/doc/ada-mode.info
+++ /dev/null
@@ -1,1983 +0,0 @@
-This is ada-mode.info, produced by texi2any version 6.8 from
-ada-mode.texi.
-
-Copyright © 1999–2019 Free Software Foundation, Inc.
-
- Permission is granted to copy, distribute and/or modify this
- document under the terms of the GNU Free Documentation License,
- Version 1.3 or any later version published by the Free Software
- Foundation; with no Invariant Sections, with the Front-Cover Texts
- being “A GNU Manual”, and with the Back-Cover Texts as in (a)
- below. A copy of the license is included in the section entitled
- “GNU Free Documentation License”.
-
- (a) The FSF’s Back-Cover Text is: “You have the freedom to copy and
- modify this GNU manual.”
-INFO-DIR-SECTION Emacs editing modes
-START-INFO-DIR-ENTRY
-* Ada mode: (ada-mode). Emacs mode for editing and compiling Ada code.
-END-INFO-DIR-ENTRY
-
-
-File: ada-mode.info, Node: Top, Next: Overview, Up: (dir)
-
-Ada Mode
-********
-
-Copyright © 1999–2019 Free Software Foundation, Inc.
-
- Permission is granted to copy, distribute and/or modify this
- document under the terms of the GNU Free Documentation License,
- Version 1.3 or any later version published by the Free Software
- Foundation; with no Invariant Sections, with the Front-Cover Texts
- being “A GNU Manual”, and with the Back-Cover Texts as in (a)
- below. A copy of the license is included in the section entitled
- “GNU Free Documentation License”.
-
- (a) The FSF’s Back-Cover Text is: “You have the freedom to copy and
- modify this GNU manual.”
-
-* Menu:
-
-* Overview::
-* Installation:: Installing Ada mode on your system
-* Customization:: Setting up Ada mode to your taste
-* Compiling Executing:: Working with your application within Emacs
-* Project files:: Describing the organization of your project
-* Compiling Examples:: A small tutorial
-* Moving Through Ada Code:: Moving easily through Ada sources
-* Identifier completion:: Finishing words automatically
-* Automatic Smart Indentation:: Indenting your code automatically as you type
-* Formatting Parameter Lists:: Formatting subprograms’ parameter lists
- automatically
-* Automatic Casing:: Adjusting the case of words automatically
-* Statement Templates:: Inserting code templates
-* Comment Handling:: Reformatting comments easily
-* GNU Free Documentation License:: The license for this documentation.
-* Index::
-
-
-File: ada-mode.info, Node: Overview, Next: Installation, Prev: Top, Up: Top
-
-1 Overview
-**********
-
-The Emacs mode for programming in Ada helps the user in understanding
-existing code and facilitates writing new code.
-
- When the GNU Ada compiler GNAT is used, the cross-reference
-information output by the compiler is used to provide powerful code
-navigation (jump to definition, find all uses, etc.).
-
- When you open a file with a file extension of ‘.ads’ or ‘.adb’, Emacs
-will automatically load and activate Ada mode.
-
- Ada mode works without any customization, if you are using the GNAT
-compiler (<https://libre2.adacore.com/>) and the GNAT default naming
-convention.
-
- You must customize a few things if you are using a different compiler
-or file naming convention; *Note Other compiler::, *Note Non-standard
-file names::.
-
- In addition, you may want to customize the indentation,
-capitalization, and other things; *Note Other customization::.
-
- Finally, for large Ada projects, you will want to set up an Emacs Ada
-mode project file for each project; *Note Project files::. Note that
-these are different from the GNAT project files used by gnatmake and
-other GNAT commands.
-
- See the Emacs info manual, section ’Running Debuggers Under Emacs’,
-for general information on debugging.
-
-
-File: ada-mode.info, Node: Installation, Next: Customization, Prev: Overview, Up: Top
-
-2 Installation
-**************
-
-Ada mode is part of the standard Emacs distribution; if you use that, no
-files need to be installed.
-
- Ada mode is also available as a separate distribution, from the Emacs
-Ada mode website
-<http://stephe-leake.org/emacs/ada-mode/emacs-ada-mode.html>. The
-separate distribution may be more recent.
-
- For installing the separate distribution, see the ‘README’ file in
-the distribution.
-
- To see what version of Ada mode you have installed, do ‘M-x
-ada-mode-version’.
-
- The following files are provided with the Ada mode distribution:
-
- • ‘ada-mode.el’: The main file for Ada mode, providing indentation,
- formatting of parameter lists, moving through code, comment
- handling and automatic casing.
-
- • ‘ada-prj.el’: GUI editing of Ada mode project files, using Emacs
- widgets.
-
- • ‘ada-stmt.el’: Ada statement templates.
-
- • ‘ada-xref.el’: GNAT cross-references, completion of identifiers,
- and compilation. Also provides project files (which are not
- GNAT-specific).
-
-
-File: ada-mode.info, Node: Customization, Next: Compiling Executing, Prev: Installation, Up: Top
-
-3 Customizing Ada mode
-**********************
-
-Here we assume you are familiar with setting variables in Emacs, either
-thru ’customize’ or in elisp (in your ‘.emacs’ file). For a basic
-introduction to customize, elisp, and Emacs in general, see the tutorial
-in *note The GNU Emacs Manual: (emacs)Top.
-
- These global Emacs settings are strongly recommended (put them in
-your .emacs):
-
- (global-font-lock-mode t)
- (transient-mark-mode t)
-
- ‘(global-font-lock-mode t)’ turns on syntax highlighting for all
-buffers (it is off by default because it may be too slow for some
-machines).
-
- ‘(transient-mark-mode t)’ highlights selected text.
-
- See the Emacs help for each of these variables for more information.
-
-* Menu:
-
-* Non-standard file names::
-* Other compiler::
-* Other customization::
-
-
-File: ada-mode.info, Node: Non-standard file names, Next: Other compiler, Up: Customization
-
-3.1 Non-standard file names
-===========================
-
-By default, Ada mode is configured to use the GNAT file naming
-convention, where file names are a simple modification of the Ada names,
-and the extension for specs and bodies are ‘.ads’ and ‘.adb’,
-respectively.
-
- Ada mode uses the file extensions to allow moving from a package body
-to the corresponding spec and back.
-
- Ada mode supports a list of alternative file extensions for specs and
-bodies.
-
- For instance, if your spec and bodies files are called ‘UNIT_s.ada’
-and ‘UNIT_b.ada’, respectively, you can add the following to your
-‘.emacs’ file:
-
- (ada-add-extensions "_s.ada" "_b.ada")
-
- You can define additional extensions:
-
- (ada-add-extensions ".ads" "_b.ada")
- (ada-add-extensions ".ads" ".body")
-
- This means that whenever Ada mode looks for the body for a file whose
-extension is ‘.ads’, it will take the first available file that ends
-with either ‘.adb’, ‘_b.ada’ or ‘.body’.
-
- Similarly, if Ada mode is looking for a spec, it will look for ‘.ads’
-or ‘_s.ada’.
-
- If the filename is not derived from the Ada name following the GNAT
-convention, things are a little more complicated. You then need to
-rewrite the function ‘ada-make-filename-from-adaname’. Doing that is
-beyond the scope of this manual; see the current definitions in
-‘ada-mode.el’ and ‘ada-xref.el’ for examples.
-
-
-File: ada-mode.info, Node: Other compiler, Next: Other customization, Prev: Non-standard file names, Up: Customization
-
-3.2 Other compiler
-==================
-
-By default, Ada mode is configured to use the GNU Ada compiler GNAT.
-
- To use a different Ada compiler, you must specify the command lines
-used to run that compiler, either in lisp variables or in Emacs Ada mode
-project files. See *note Project file variables:: for the list of
-project variables, and the corresponding lisp variables.
-
-
-File: ada-mode.info, Node: Other customization, Prev: Other compiler, Up: Customization
-
-3.3 Other customization
-=======================
-
-All user-settable Ada mode variables can be set via the menu ‘Ada |
-Customize’. Click on the ‘Help’ button there for help on using
-customize.
-
- To modify a specific variable, you can directly call the function
-‘customize-variable’; just type ‘M-x customize-variable <RET>
-VARIABLE-NAME <RET>’).
-
- Alternately, you can specify variable settings in the Emacs
-configuration file, ‘.emacs’. This file is coded in Emacs lisp, and the
-syntax to set a variable is the following:
- (setq variable-name value)
-
-
-File: ada-mode.info, Node: Compiling Executing, Next: Project files, Prev: Customization, Up: Top
-
-4 Compiling Executing
-*********************
-
-Ada projects can be compiled, linked, and executed using commands on the
-Ada menu. All of these commands can be customized via a project file
-(*note Project files::), but the defaults are sufficient for using the
-GNAT compiler for simple projects (single files, or several files in a
-single directory).
-
- Even when no project file is used, the GUI project editor (menu ‘Ada
-| Project | Edit’) shows the settings of the various project file
-variables referenced here.
-
-* Menu:
-
-* Compile commands::
-* Compiler errors::
-
-
-File: ada-mode.info, Node: Compile commands, Next: Compiler errors, Up: Compiling Executing
-
-4.1 Compile commands
-====================
-
-Here are the commands for building and using an Ada project, as listed
-in the Ada menu.
-
- In multi-file projects, there must be one file that is the main
-program. That is given by the ‘main’ project file variable; it defaults
-to the current file if not yet set, but is also set by the “set main and
-build” command.
-
-‘Check file’
- Compiles the current file in syntax check mode, by running
- ‘check_cmd’ defined in the current project file. This typically
- runs faster than full compile mode, speeding up finding and fixing
- compilation errors.
-
- This sets ‘main’ only if it has not been set yet.
-
-‘Compile file’
- Compiles the current file, by running ‘comp_cmd’ from the current
- project file.
-
- This does not set ‘main’.
-
-‘Set main and Build’
- Sets ‘main’ to the current file, then executes the Build command.
-
-‘Show main’
- Display ‘main’ in the message buffer.
-
-‘Build’
- Compiles all obsolete units of the current ‘main’, and links
- ‘main’, by running ‘make_cmd’ from the current project.
-
- This sets ‘main’ only if it has not been set yet.
-
-‘Run’
- Executes the main program in a shell, displayed in a separate Emacs
- buffer. This runs ‘run_cmd’ from the current project. The
- execution buffer allows for interactive input/output.
-
- To modify the run command, in particular to provide or change the
- command line arguments, type ‘C-u’ before invoking the command.
-
- This command is not available for a cross-compilation toolchain.
-
- It is important when using these commands to understand how ‘main’ is
-used and changed.
-
- Build runs ’gnatmake’ on the main unit. During a typical
-edit/compile session, this is the only command you need to invoke, which
-is why it is bound to ‘C-c C-c’. It will compile all files needed by
-the main unit, and display compilation errors in any of them.
-
- Note that Build can be invoked from any Ada buffer; typically you
-will be fixing errors in files other than the main, but you don’t have
-to switch back to the main to invoke the compiler again.
-
- Novices and students typically work on single-file Ada projects. In
-this case, ‘C-c C-m’ will normally be the only command needed; it will
-build the current file, rather than the last-built main.
-
- There are three ways to change ‘main’:
-
- 1. Invoke ‘Ada | Set main and Build’, which sets ‘main’ to the current
- file.
-
- 2. Invoke ‘Ada | Project | Edit’, edit ‘main’ and ‘main’, and click
- ‘[save]’
-
- 3. Invoke ‘Ada | Project | Load’, and load a project file that
- specifies ‘main’
-
-
-File: ada-mode.info, Node: Compiler errors, Prev: Compile commands, Up: Compiling Executing
-
-4.2 Compiler errors
-===================
-
-The ‘Check file’, ‘Compile file’, and ‘Build’ commands all place
-compilation errors in a separate buffer named ‘*compilation*’.
-
- Each line in this buffer will become active: you can simply click on
-it with the middle button of the mouse, or move point to it and press
-<RET>. Emacs will then display the relevant source file and put point
-on the line and column where the error was found.
-
- You can also press the ‘C-x `’ key (‘next-error’), and Emacs will
-jump to the first error. If you press that key again, it will move you
-to the second error, and so on.
-
- Some error messages might also include references to other files.
-These references are also clickable in the same way, or put point after
-the line number and press <RET>.
-
-
-File: ada-mode.info, Node: Project files, Next: Compiling Examples, Prev: Compiling Executing, Up: Top
-
-5 Project files
-***************
-
-An Emacs Ada mode project file specifies what directories hold sources
-for your project, and allows you to customize the compilation commands
-and other things on a per-project basis.
-
- Note that Ada mode project files ‘*.adp’ are different than GNAT
-compiler project files ‘*.gpr’. However, Emacs Ada mode can use a GNAT
-project file to specify the project directories. If no other
-customization is needed, a GNAT project file can be used without an
-Emacs Ada mode project file.
-
-* Menu:
-
-* Project File Overview::
-* GUI Editor::
-* Project file variables::
-
-
-File: ada-mode.info, Node: Project File Overview, Next: GUI Editor, Up: Project files
-
-5.1 Project File Overview
-=========================
-
-Project files have a simple syntax; they may be edited directly. Each
-line specifies a project variable name and its value, separated by “=”:
- src_dir=/Projects/my_project/src_1
- src_dir=/Projects/my_project/src_2
-
- Some variables (like ‘src_dir’) are lists; multiple occurrences are
-concatenated.
-
- There must be no space between the variable name and “=”, and no
-trailing spaces.
-
- Alternately, a GUI editor for project files is available (*note GUI
-Editor::). It uses Emacs widgets, similar to Emacs customize.
-
- The GUI editor also provides a convenient way to view current project
-settings, if they have been modified using menu commands rather than by
-editing the project file.
-
- After the first Ada mode build command is invoked, there is always a
-current project file, given by the lisp variable
-‘ada-prj-default-project-file’. Currently, the only way to show the
-current project file is to invoke the GUI editor.
-
- To find the project file the first time, Ada mode uses the following
-search algorithm:
-
- • If ‘ada-prj-default-project-file’ is set, use that.
-
- • Otherwise, search for a file in the current directory with the same
- base name as the Ada file, but extension given by
- ‘ada-prj-file-extension’ (default ‘".adp"’).
-
- • If not found, search for ‘*.adp’ in the current directory; if
- several are found, prompt the user to select one.
-
- • If none are found, use ‘default.adp’ in the current directory (even
- if it does not exist).
-
- This algorithm always sets ‘ada-prj-default-project-file’, even when
-the file does not actually exist.
-
- To change the project file before or after the first one is found,
-invoke ‘Ada | Project | Load ...’.
-
- Or, in lisp, evaluate ‘(ada-set-default-project-file
-"/path/file.adp")’. This sets ‘ada-prj-default-project-file’, and reads
-the project file.
-
- You can also specify a GNAT project file to ‘Ada | Project | Load
-...’ or ‘ada-set-default-project-file’. Emacs Ada mode checks the file
-extension; if it is ‘.gpr’, the file is treated as a GNAT project file.
-Any other extension is treated as an Emacs Ada mode project file.
-
-
-File: ada-mode.info, Node: GUI Editor, Next: Project file variables, Prev: Project File Overview, Up: Project files
-
-5.2 GUI Editor
-==============
-
-The project file editor is invoked with the menu ‘Ada | Projects |
-Edit’.
-
- Once in the buffer for editing the project file, you can save your
-modification using the ‘[save]’ button at the bottom of the buffer, or
-the ‘C-x C-s’ binding. To cancel your modifications, kill the buffer or
-click on the ‘[cancel]’ button.
-
-
-File: ada-mode.info, Node: Project file variables, Prev: GUI Editor, Up: Project files
-
-5.3 Project file variables
-==========================
-
-The following variables can be defined in a project file; some can also
-be defined in lisp variables.
-
- To set a project variable that is a list, specify each element of the
-list on a separate line in the project file.
-
- Any project variable can be referenced in other project variables,
-using a shell-like notation. For instance, if the variable ‘comp_cmd’
-contains ‘${comp_opt}’, the value of the ‘comp_opt’ variable will be
-substituted when ‘comp_cmd’ is used.
-
- In addition, process environment variables can be referenced using
-the same syntax, or the normal ‘$var’ syntax.
-
- Most project variables have defaults that can be changed by setting
-lisp variables; the table below identifies the lisp variable for each
-project variable. Lisp variables corresponding to project variables
-that are lists are lisp lists.
-
- In general, project variables are evaluated when referenced in Emacs
-Ada mode commands. Relative file paths are expanded to absolute
-relative to ‘${build_dir}’.
-
- Here is the list of variables. In the default values, the current
-directory ‘"."’ is the project file directory.
-
-‘ada_project_path_sep’ [default: ‘":" or ";"’]
- Path separator for ‘ADA_PROJECT_PATH’. It defaults to the correct
- value for a native implementation of GNAT for the current operating
- system. The user must override this when using Windows native GNAT
- with Cygwin Emacs, and perhaps in other cases.
-
- Lisp variable: ‘ada-prj-ada-project-path-sep’.
-
-‘ada_project_path’ [default: ‘""’]
- A list of directories to search for GNAT project files.
-
- If set, the ‘ADA_PROJECT_PATH’ process environment variable is set
- to this value in the Emacs process when the Emacs Ada mode project
- is selected via menu ‘Ada | Project | Load’.
-
- For ‘ada_project_path’, relative file paths are expanded to
- absolute when the Emacs Ada project file is read, rather than when
- the project file is selected.
-
- For example if the project file is in the directory
- ‘/home/myproject’, the environment variable ‘GDS_ROOT’ is set to
- ‘/home/shared’, and the project file contains:
- ada_project_path_sep=:
- ada_project_path=$GDS_ROOT/makerules
- ada_project_path=../opentoken
- then as a result the environment variable ‘ADA_PROJECT_PATH’ will
- be set to ‘"/home/shared/makerules:/home/opentoken/"’.
-
- The default value is not the current value of this environment
- variable, because that will typically have been set by another
- project, and will therefore be incorrect for this project.
-
- If you have the environment variable set correctly for all of your
- projects, you do not need to set this project variable.
-
-‘bind_opt’ [default: ‘""’]
- Holds user binder options; used in the default build commands.
-
- Lisp variable: ‘ada-prj-default-bind-opt’.
-
-‘build_dir’ [default: ‘"."’]
- The compile commands will be issued in this directory.
-
-‘casing’ [default: ‘("~/.emacs_case_exceptions")’]
- List of files containing casing exceptions. See the help on
- ‘ada-case-exception-file’ for more info.
-
- Lisp variable: ‘ada-case-exception-file’.
-
-‘check_cmd’ [default: ‘"${cross_prefix}gnatmake -u -c -gnatc ${gnatmake_opt} ${full_current} -cargs ${comp_opt}"’]
- Command used to syntax check a single file. The name of the file
- is substituted for ‘full_current’.
-
- Lisp variable: ‘ada-prj-default-check-cmd’
-
-‘comp_cmd’ [default: ‘"${cross_prefix}gnatmake -u -c ${gnatmake_opt} ${full_current} -cargs ${comp_opt}"’]
- Command used to compile a single file. The name of the file is
- substituted for ‘full_current’.
-
- Lisp variable: ‘ada-prj-default-comp-cmd’.
-
-‘comp_opt’ [default: ‘"-gnatq -gnatQ"’]
- Holds user compiler options; used in the default compile commands.
- The default value tells gnatmake to generate library files for
- cross-referencing even when there are errors.
-
- If source code for the project is in multiple directories, the
- appropriate compiler options must be added here. *note Set source
- search path:: for examples of this. Alternately, GNAT project
- files may be used; *note Use GNAT project file::.
-
- Lisp variable: ‘ada-prj-default-comp-opt’.
-
-‘cross_prefix’ [default: ‘""’]
- Name of target machine in a cross-compilation environment. Used in
- default compile and build commands.
-
-‘debug_cmd’ [default: ‘"${cross_prefix}gdb ${main}"’]
- Command used to debug the application
-
- Lisp variable: ‘ada-prj-default-debugger’.
-
-‘debug_post_cmd’ [default: ‘""’]
- Command executed after ‘debug_cmd’.
-
-‘debug_pre_cmd’ [default: ‘"cd ${build_dir}"’]
- Command executed before ‘debug_cmd’.
-
-‘gnatfind_opt’ [default: ‘"-rf"’]
- Holds user gnatfind options; used in the default find commands.
-
- Lisp variable: ‘ada-prj-gnatfind-switches’.
-
-‘gnatmake_opt’ [default: ‘"-g"’]
- Holds user gnatmake options; used in the default build commands.
-
- Lisp variable: ‘ada-prj-default-gnatmake-opt’.
-
-‘gpr_file’ [default: ‘""’]
- Specify GNAT project file.
-
- If set, the source and object directories specified in the GNAT
- project file are appended to ‘src_dir’ and ‘obj_dir’. This allows
- specifying Ada source directories with a GNAT project file, and
- other source directories with the Emacs project file.
-
- In addition, ‘-P{gpr_file}’ is added to the project variable
- ‘gnatmake_opt’ whenever it is referenced. With the default project
- variables, this passes the project file to all gnatmake commands.
-
- Lisp variable: ‘ada-prj-default-gpr-file’.
-
-‘link_opt’ [default: ‘""’]
- Holds user linker options; used in the default build commands.
-
- Lisp variable: ‘ada-prj-default-link-opt’.
-
-‘main’ [default: current file]
- Specifies the name of the executable file for the project; used in
- the default build commands.
-
-‘make_cmd’ [default: ‘"${cross_prefix}gnatmake -o ${main} ${main} ${gnatmake_opt} -cargs ${comp_opt} -bargs ${bind_opt} -largs ${link_opt}"’]
- Command used to build the application.
-
- Lisp variable: ‘ada-prj-default-make-cmd’.
-
-‘obj_dir’ [default: ‘"."’]
- A list of directories to search for library files. Ada mode
- searches this list for the ‘.ali’ files generated by GNAT that
- contain cross-reference information.
-
- The compiler commands must place the ‘.ali’ files in one of these
- directories; the default commands do that.
-
-‘remote_machine’ [default: ‘""’]
- Name of the machine to log into before issuing the compile and
- build commands. If this variable is empty, the command will be run
- on the local machine.
-
-‘run_cmd’ [default: ‘"./${main}"’]
- Command used to run the application.
-
-‘src_dir’ [default: ‘"."’]
- A list of directories to search for source files, both for compile
- commands and source navigation.
-
-
-File: ada-mode.info, Node: Compiling Examples, Next: Moving Through Ada Code, Prev: Project files, Up: Top
-
-6 Compiling Examples
-********************
-
-We present several small projects, and walk thru the process of
-compiling, linking, and running them.
-
- The first example illustrates more Ada mode features than the others;
-you should work thru that example before doing the others.
-
- All of these examples assume you are using GNAT.
-
- The source for these examples is available on the Emacs Ada mode
-website mentioned in *Note Installation::.
-
-* Menu:
-
-* No project files:: Just menus
-* Set compiler options:: A basic Ada mode project file
-* Set source search path:: Source in multiple directories
-* Use GNAT project file::
-* Use multiple GNAT project files::
-
-
-File: ada-mode.info, Node: No project files, Next: Set compiler options, Up: Compiling Examples
-
-6.1 No project files
-====================
-
-This example uses no project files.
-
- First, create a directory ‘Example_1’, containing:
-
- ‘hello.adb’:
-
- with Ada.Text_IO;
- procedure Hello
- is begin
- Put_Line("Hello from hello.adb");
- end Hello;
-
- Yes, this is missing “use Ada.Text_IO;” - we want to demonstrate
-compiler error handling.
-
- ‘hello_2.adb’:
-
- with Hello_Pkg;
- procedure Hello_2
- is begin
- Hello_Pkg.Say_Hello;
- end Hello_2;
-
- This file has no errors.
-
- ‘hello_pkg.ads’:
-
- package Hello_Pkg is
- procedure Say_Hello;
- end Hello_Pkg;
-
- This file has no errors.
-
- ‘hello_pkg.adb’:
-
- with Ada.Text_IO;
- package Hello_Pkg is
- procedure Say_Hello
- is begin
- Ada.Text_IO.Put_Line ("Hello from hello_pkg.adb");
- end Say_Hello;
- end Hello_Pkg;
-
- Yes, this is missing the keyword ‘body’; another compiler error
-example.
-
- In buffer ‘hello.adb’, invoke ‘Ada | Check file’. You should get a
-‘*compilation*’ buffer containing something like (the directory paths
-will be different):
-
- cd c:/Examples/Example_1/
- gnatmake -u -c -gnatc -g c:/Examples/Example_1/hello.adb -cargs -gnatq -gnatQ
- gcc -c -Ic:/Examples/Example_1/ -gnatc -g -gnatq -gnatQ -I- c:/Examples/Example_1/hello.adb
- hello.adb:4:04: "Put_Line" is not visible
- hello.adb:4:04: non-visible declaration at a-textio.ads:264
- hello.adb:4:04: non-visible declaration at a-textio.ads:260
- gnatmake: "c:/Examples/Example_1/hello.adb" compilation error
-
- If you have enabled font-lock, the lines with actual errors (starting
-with ‘hello.adb’) are highlighted, with the file name in red.
-
- Now type ‘C-x `’ (on a PC keyboard, <`> is next to <1>). Or you can
-click the middle mouse button on the first error line. The compilation
-buffer scrolls to put the first error on the top line, and point is put
-at the place of the error in the ‘hello.adb’ buffer.
-
- To fix the error, change the line to be
-
- Ada.Text_IO.Put_Line ("hello from hello.adb");
-
- Now invoke ‘Ada | Show main’; this displays ‘Ada mode main: hello’.
-
- Now (in buffer ‘hello.adb’), invoke ‘Ada | Build’. You are prompted
-to save the file (if you haven’t already). Then the compilation buffer
-is displayed again, containing:
-
- cd c:/Examples/Example_1/
- gnatmake -o hello hello -g -cargs -gnatq -gnatQ -bargs -largs
- gcc -c -g -gnatq -gnatQ hello.adb
- gnatbind -x hello.ali
- gnatlink hello.ali -o hello.exe -g
-
- The compilation has succeeded without errors; ‘hello.exe’ now exists
-in the same directory as ‘hello.adb’.
-
- Now invoke ‘Ada | Run’. A ‘*run*’ buffer is displayed, containing
-
- Hello from hello.adb
-
- Process run finished
-
- That completes the first part of this example.
-
- Now we will compile a multi-file project. Open the file
-‘hello_2.adb’, and invoke ‘Ada | Set main and Build’. This finds an
-error in ‘hello_pkg.adb’:
-
- cd c:/Examples/Example_1/
- gnatmake -o hello_2 hello_2 -g -cargs -gnatq -gnatQ -bargs -largs
- gcc -c -g -gnatq -gnatQ hello_pkg.adb
- hello_pkg.adb:2:08: keyword "body" expected here [see file name]
- gnatmake: "hello_pkg.adb" compilation error
-
- This demonstrates that gnatmake finds the files needed by the main
-program. However, it cannot find files in a different directory, unless
-you use an Emacs Ada mode project file to specify the other directories;
-*Note Set source search path::, or a GNAT project file; *note Use GNAT
-project file::.
-
- Invoke ‘Ada | Show main’; this displays ‘Ada mode main: hello_2’.
-
- Move to the error with ‘C-x `’, and fix the error by adding ‘body’:
-
- package body Hello_Pkg is
-
- Now, while still in ‘hello_pkg.adb’, invoke ‘Ada | Build’. gnatmake
-successfully builds ‘hello_2’. This demonstrates that Emacs has
-remembered the main file, in the project variable ‘main’, and used it
-for the Build command.
-
- Finally, again while in ‘hello_pkg.adb’, invoke ‘Ada | Run’. The
-‘*run*’ buffer displays ‘Hello from hello_pkg.adb’.
-
- One final point. If you switch back to buffer ‘hello.adb’, and
-invoke ‘Ada | Run’, ‘hello_2.exe’ will be run. That is because ‘main’
-is still set to ‘hello_2’, as you can see when you invoke ‘Ada | Project
-| Edit’.
-
- There are three ways to change ‘main’:
-
- 1. Invoke ‘Ada | Set main and Build’, which sets ‘main’ to the current
- file.
-
- 2. Invoke ‘Ada | Project | Edit’, edit ‘main’, and click ‘[save]’
-
- 3. Invoke ‘Ada | Project | Load’, and load a project file that
- specifies ‘main’
-
-
-File: ada-mode.info, Node: Set compiler options, Next: Set source search path, Prev: No project files, Up: Compiling Examples
-
-6.2 Set compiler options
-========================
-
-This example illustrates using an Emacs Ada mode project file to set a
-compiler option.
-
- If you have files from ‘Example_1’ open in Emacs, you should close
-them so you don’t get confused. Use menu ‘File | Close (current
-buffer)’.
-
- In directory ‘Example_2’, create these files:
-
- ‘hello.adb’:
-
- with Ada.Text_IO;
- procedure Hello
- is begin
- Put_Line("Hello from hello.adb");
- end Hello;
-
- This is the same as ‘hello.adb’ from ‘Example_1’. It has two errors;
-missing “use Ada.Text_IO;”, and no space between ‘Put_Line’ and its
-argument list.
-
- ‘hello.adp’:
-
- comp_opt=-gnatyt
-
- This tells the GNAT compiler to check for token spacing; in
-particular, there must be a space preceding a parenthesis.
-
- In buffer ‘hello.adb’, invoke ‘Ada | Project | Load...’, and select
-‘Example_2/hello.adp’.
-
- Then, again in buffer ‘hello.adb’, invoke ‘Ada | Set main and Build’.
-You should get a ‘*compilation*’ buffer containing something like (the
-directory paths will be different):
-
- cd c:/Examples/Example_2/
- gnatmake -o hello hello -g -cargs -gnatyt -bargs -largs
- gcc -c -g -gnatyt hello.adb
- hello.adb:4:04: "Put_Line" is not visible
- hello.adb:4:04: non-visible declaration at a-textio.ads:264
- hello.adb:4:04: non-visible declaration at a-textio.ads:260
- hello.adb:4:12: (style) space required
- gnatmake: "hello.adb" compilation error
-
- Compare this to the compiler output in *note No project files::; the
-gnatmake option ‘-cargs -gnatq -gnatQ’ has been replaced by ‘-cargs
--gnaty’, and an additional error is reported in ‘hello.adb’ on line 4.
-This shows that ‘hello.adp’ is being used to set the compiler options.
-
- Fixing the error, linking and running the code proceed as in *note No
-project files::.
-
-
-File: ada-mode.info, Node: Set source search path, Next: Use GNAT project file, Prev: Set compiler options, Up: Compiling Examples
-
-6.3 Set source search path
-==========================
-
-In this example, we show how to deal with files in more than one
-directory. We start with the same code as in *note No project files::;
-create those files (with the errors present)
-
- Create the directory ‘Example_3’, containing:
-
- ‘hello_pkg.ads’:
-
- package Hello_Pkg is
- procedure Say_Hello;
- end Hello_Pkg;
-
- ‘hello_pkg.adb’:
-
- with Ada.Text_IO;
- package Hello_Pkg is
- procedure Say_Hello
- is begin
- Ada.Text_IO.Put_Line ("Hello from hello_pkg.adb");
- end Say_Hello;
- end Hello_Pkg;
-
- These are the same files from example 1; ‘hello_pkg.adb’ has an error
-on line 2.
-
- In addition, create a directory ‘Example_3/Other’, containing these
-files:
-
- ‘Other/hello_3.adb’:
-
- with Hello_Pkg;
- with Ada.Text_IO; use Ada.Text_IO;
- procedure Hello_3
- is begin
- Hello_Pkg.Say_Hello;
- Put_Line ("From hello_3");
- end Hello_3;
-
- There are no errors in this file.
-
- ‘Other/other.adp’:
-
- src_dir=..
- comp_opt=-I..
-
- Note that there must be no trailing spaces.
-
- In buffer ‘hello_3.adb’, invoke ‘Ada | Project | Load...’, and select
-‘Example_3/Other/other.adp’.
-
- Then, again in ‘hello_3.adb’, invoke ‘Ada | Set main and Build’. You
-should get a ‘*compilation*’ buffer containing something like (the
-directory paths will be different):
-
- cd c:/Examples/Example_3/Other/
- gnatmake -o hello_3 hello_3 -g -cargs -I.. -bargs -largs
- gcc -c -g -I.. hello_3.adb
- gcc -c -I./ -g -I.. -I- C:\Examples\Example_3\hello_pkg.adb
- hello_pkg.adb:2:08: keyword "body" expected here [see file name]
- gnatmake: "C:\Examples\Example_3\hello_pkg.adb" compilation error
-
- Compare the ‘-cargs’ option to the compiler output in *note Set
-compiler options::; this shows that ‘other.adp’ is being used to set the
-compiler options.
-
- Move to the error with ‘C-x `’. Ada mode searches the list of
-directories given by ‘src_dir’ for the file mentioned in the compiler
-error message.
-
- Fixing the error, linking and running the code proceed as in *note No
-project files::.
-
-
-File: ada-mode.info, Node: Use GNAT project file, Next: Use multiple GNAT project files, Prev: Set source search path, Up: Compiling Examples
-
-6.4 Use GNAT project file
-=========================
-
-In this example, we show how to use a GNAT project file, with no Ada
-mode project file.
-
- Create the directory ‘Example_4’, containing:
-
- ‘hello_pkg.ads’:
-
- package Hello_Pkg is
- procedure Say_Hello;
- end Hello_Pkg;
-
- ‘hello_pkg.adb’:
-
- with Ada.Text_IO;
- package Hello_Pkg is
- procedure Say_Hello
- is begin
- Ada.Text_IO.Put_Line ("Hello from hello_pkg.adb");
- end Say_Hello;
- end Hello_Pkg;
-
- These are the same files from example 1; ‘hello_pkg.adb’ has an error
-on line 2.
-
- In addition, create a directory ‘Example_4/Gnat_Project’, containing
-these files:
-
- ‘Gnat_Project/hello_4.adb’:
-
- with Hello_Pkg;
- with Ada.Text_IO; use Ada.Text_IO;
- procedure Hello_4
- is begin
- Hello_Pkg.Say_Hello;
- Put_Line ("From hello_4");
- end Hello_4;
-
- There are no errors in this file.
-
- ‘Gnat_Project/hello_4.gpr’:
-
- Project Hello_4 is
- for Source_Dirs use (".", "..");
- end Hello_4;
-
- In buffer ‘hello_4.adb’, invoke ‘Ada | Project | Load...’, and select
-‘Example_4/Gnat_Project/hello_4.gpr’.
-
- Then, again in ‘hello_4.adb’, invoke ‘Ada | Set main and Build’. You
-should get a ‘*compilation*’ buffer containing something like (the
-directory paths will be different):
-
- cd c:/Examples/Example_4/Gnat_Project/
- gnatmake -o hello_4 hello_4 -Phello_4.gpr -cargs -gnatq -gnatQ -bargs -largs
- gcc -c -g -gnatyt -gnatq -gnatQ -I- -gnatA c:\Examples\Example_4\Gnat_Project\hello_4.adb
- gcc -c -g -gnatyt -gnatq -gnatQ -I- -gnatA c:\Examples\Example_4\hello_pkg.adb
- hello_pkg.adb:2:08: keyword "body" expected here [see file name]
- gnatmake: "c:\examples\example_4\hello_pkg.adb" compilation error
-
- Compare the ‘gcc’ options to the compiler output in *note Set
-compiler options::; this shows that ‘hello_4.gpr’ is being used to set
-the compiler options.
-
- Fixing the error, linking and running the code proceed as in *note No
-project files::.
-
-
-File: ada-mode.info, Node: Use multiple GNAT project files, Prev: Use GNAT project file, Up: Compiling Examples
-
-6.5 Use multiple GNAT project files
-===================================
-
-In this example, we show how to use multiple GNAT project files,
-specifying the GNAT project search path in an Ada mode project file.
-
- Create the directory ‘Example_4’ as specified in *note Use GNAT
-project file::.
-
- Create the directory ‘Example_5’, containing:
-
- ‘hello_5.adb’:
-
- with Hello_Pkg;
- with Ada.Text_IO; use Ada.Text_IO;
- procedure Hello_5
- is begin
- Hello_Pkg.Say_Hello;
- Put_Line ("From hello_5");
- end Hello_5;
-
- There are no errors in this file.
-
- ‘hello_5.adp’:
-
- ada_project_path=../Example_4/Gnat_Project
- gpr_file=hello_5.gpr
-
- ‘hello_5.gpr’:
-
- with "hello_4";
- Project Hello_5 is
- for Source_Dirs use (".");
- package Compiler is
- for Default_Switches ("Ada") use ("-g", "-gnatyt");
- end Compiler;
- end Hello_5;
-
- In buffer ‘hello_5.adb’, invoke ‘Ada | Project | Load...’, and select
-‘Example_5/hello_5.adp’.
-
- Then, again in ‘hello_5.adb’, invoke ‘Ada | Set main and Build’. You
-should get a ‘*compilation*’ buffer containing something like (the
-directory paths will be different):
-
- cd c:/Examples/Example_5/
- gnatmake -o hello_5 hello_5 -Phello_5.gpr -g -cargs -gnatq -gnatQ -bargs -largs
- gcc -c -g -gnatyt -g -gnatq -gnatQ -I- -gnatA c:\Examples\Example_5\hello_5.adb
- gcc -c -g -gnatyt -g -gnatq -gnatQ -I- -gnatA c:\Examples\Example_4\hello_pkg.adb
- hello_pkg.adb:2:08: keyword "body" expected here [see file name]
- gnatmake: "c:\examples\example_4\hello_pkg.adb" compilation error
-
- Now type ‘C-x `’. ‘Example_4/hello_pkg.adb’ is shown, demonstrating
-that ‘hello_5.gpr’ and ‘hello_4.gpr’ are being used to set the
-compilation search path.
-
-
-File: ada-mode.info, Node: Moving Through Ada Code, Next: Identifier completion, Prev: Compiling Examples, Up: Top
-
-7 Moving Through Ada Code
-*************************
-
-There are several easy to use commands to navigate through Ada code.
-All these functions are available through the Ada menu, and you can also
-use the following key bindings or the command names. Some of these menu
-entries are available only if the GNAT compiler is used, since the
-implementation relies on the GNAT cross-referencing information.
-
-‘M-C-e’
- Move to the next function/procedure/task, which ever comes next
- (‘ada-next-procedure’).
-‘M-C-a’
- Move to previous function/procedure/task
- (‘ada-previous-procedure’).
-‘M-x ada-next-package’
- Move to next package.
-‘M-x ada-previous-package’
- Move to previous package.
-‘C-c C-a’
- Move to matching start of ‘end’ (‘ada-move-to-start’). If point is
- at the end of a subprogram, this command jumps to the corresponding
- ‘begin’ if the user option ‘ada-move-to-declaration’ is ‘nil’
- (default), otherwise it jumps to the subprogram declaration.
-‘C-c C-e’
- Move point to end of current block (‘ada-move-to-end’).
-‘C-c o’
- Switch between corresponding spec and body file
- (‘ff-find-other-file’). If point is in a subprogram, position
- point on the corresponding declaration or body in the other file.
-‘C-c c-d’
- Move from any reference to its declaration, for from a declaration
- to its body (for procedures, tasks, private and incomplete types).
-‘C-c C-r’
- Runs the ‘gnatfind’ command to search for all references to the
- identifier surrounding point (‘ada-find-references’). Use ‘C-x `’
- (‘next-error’) to visit each reference (as for compilation errors).
-
- If the ‘ada-xref-create-ali’ variable is non-‘nil’, Emacs will try to
-run GNAT for you whenever cross-reference information is needed, and is
-older than the current source file.
-
-
-File: ada-mode.info, Node: Identifier completion, Next: Automatic Smart Indentation, Prev: Moving Through Ada Code, Up: Top
-
-8 Identifier completion
-***********************
-
-Emacs and Ada mode provide two general ways for the completion of
-identifiers. This is an easy way to type faster: you just have to type
-the first few letters of an identifiers, and then loop through all the
-possible completions.
-
- The first method is general for Emacs. It works by parsing all open
-files for possible completions.
-
- For instance, if the words ‘my_identifier’, ‘my_subprogram’ are the
-only words starting with ‘my’ in any of the opened files, then you will
-have this scenario:
-
- You type: myM-/
- Emacs inserts: ‘my_identifier’
- If you press M-/ once again, Emacs replaces ‘my_identifier’ with
- ‘my_subprogram’.
- Pressing M-/ once more will bring you back to ‘my_identifier’.
-
- This is a very fast way to do completion, and the casing of words
-will also be respected.
-
- The second method (‘C-<TAB>’) is specific to Ada mode and the GNAT
-compiler. Emacs will search the cross-information for possible
-completions.
-
- The main advantage is that this completion is more accurate: only
-existing identifier will be suggested.
-
- On the other hand, this completion is a little bit slower and
-requires that you have compiled your file at least once since you
-created that identifier.
-
-‘C-<TAB>’
- Complete current identifier using cross-reference information.
-‘M-/’
- Complete identifier using buffer information (not Ada-specific).
-
-
-File: ada-mode.info, Node: Automatic Smart Indentation, Next: Formatting Parameter Lists, Prev: Identifier completion, Up: Top
-
-9 Automatic Smart Indentation
-*****************************
-
-Ada mode comes with a full set of rules for automatic indentation. You
-can also configure the indentation, via the following variables:
-
-‘ada-broken-indent’ (default value: 2)
- Number of columns to indent the continuation of a broken line.
-
-‘ada-indent’ (default value: 3)
- Number of columns for default indentation.
-
-‘ada-indent-record-rel-type’ (default value: 3)
- Indentation for ‘record’ relative to ‘type’ or ‘use’.
-
-‘ada-indent-return’ (default value: 0)
- Indentation for ‘return’ relative to ‘function’ (if
- ‘ada-indent-return’ is greater than 0), or the open parenthesis (if
- ‘ada-indent-return’ is negative or 0). Note that in the second
- case, when there is no open parenthesis, the indentation is done
- relative to ‘function’ with the value of ‘ada-broken-indent’.
-
-‘ada-label-indent’ (default value: -4)
- Number of columns to indent a label.
-
-‘ada-stmt-end-indent’ (default value: 0)
- Number of columns to indent a statement ‘end’ keyword on a separate
- line.
-
-‘ada-when-indent’ (default value: 3)
- Indentation for ‘when’ relative to ‘exception’ or ‘case’.
-
-‘ada-indent-is-separate’ (default value: t)
- Non-‘nil’ means indent ‘is separate’ or ‘is abstract’ if on a
- single line.
-
-‘ada-indent-to-open-paren’ (default value: t)
- Non-‘nil’ means indent according to the innermost open parenthesis.
-
-‘ada-indent-after-return’ (default value: t)
- Non-‘nil’ means that the current line will also be re-indented
- before inserting a newline, when you press <RET>.
-
- Most of the time, the indentation will be automatic, i.e., when you
-press <RET>, the cursor will move to the correct column on the next
-line.
-
- You can also indent single lines, or the current region, with <TAB>.
-
- Another mode of indentation exists that helps you to set up your
-indentation scheme. If you press ‘C-c <TAB>’, Ada mode will do the
-following:
-
- • Reindent the current line, as <TAB> would do.
- • Temporarily move the cursor to a reference line, i.e., the line
- that was used to calculate the current indentation.
- • Display in the message window the name of the variable that
- provided the offset for the indentation.
-
- The exact indentation of the current line is the same as the one for
-the reference line, plus an offset given by the variable.
-
-‘<TAB>’
- Indent the current line or the current region.
-‘C-M-\’
- Indent lines in the current region.
-‘C-c <TAB>’
- Indent the current line and display the name of the variable used
- for indentation.
-
-
-File: ada-mode.info, Node: Formatting Parameter Lists, Next: Automatic Casing, Prev: Automatic Smart Indentation, Up: Top
-
-10 Formatting Parameter Lists
-*****************************
-
-‘C-c C-f’
- Format the parameter list (‘ada-format-paramlist’).
-
- This aligns the declarations on the colon (‘:’) separating argument
-names and argument types, and aligns the ‘in’, ‘out’ and ‘in out’
-keywords.
-
-
-File: ada-mode.info, Node: Automatic Casing, Next: Statement Templates, Prev: Formatting Parameter Lists, Up: Top
-
-11 Automatic Casing
-*******************
-
-Casing of identifiers, attributes and keywords is automatically
-performed while typing when the variable ‘ada-auto-case’ is set. Every
-time you press a word separator, the previous word is automatically
-cased.
-
- You can customize the automatic casing differently for keywords,
-attributes and identifiers. The relevant variables are the following:
-‘ada-case-keyword’, ‘ada-case-attribute’ and ‘ada-case-identifier’.
-
- All these variables can have one of the following values:
-
-‘downcase-word’
- The word will be lowercase. For instance ‘My_vARIable’ is
- converted to ‘my_variable’.
-
-‘upcase-word’
- The word will be uppercase. For instance ‘My_vARIable’ is
- converted to ‘MY_VARIABLE’.
-
-‘ada-capitalize-word’
- The first letter and each letter following an underscore (‘_’) are
- uppercase, others are lowercase. For instance ‘My_vARIable’ is
- converted to ‘My_Variable’.
-
-‘ada-loose-case-word’
- Characters after an underscore ‘_’ character are uppercase, others
- are not modified. For instance ‘My_vARIable’ is converted to
- ‘My_VARIable’.
-
- Ada mode allows you to define exceptions to these rules, in a file
-specified by the variable ‘ada-case-exception-file’ (default
-‘~/.emacs_case_exceptions’). Each line in this file specifies the
-casing of one word or word fragment. Comments may be included,
-separated from the word by a space.
-
- If the word starts with an asterisk (‘*’), it defines the casing as a
-word fragment (or “substring”); part of a word between two underscores
-or word boundary.
-
- For example:
-
- DOD Department of Defense
- *IO
- GNAT The GNAT compiler from Ada Core Technologies
-
- The word fragment ‘*IO’ applies to any word containing “_io”;
-‘Text_IO’, ‘Hardware_IO’, etc.
-
- There are two ways to add new items to this file: you can simply edit
-it as you would edit any text file. Or you can position point on the
-word you want to add, and select menu ‘Ada | Edit | Create Case
-Exception’, or press ‘C-c C-y’ (‘ada-create-case-exception’). The word
-will automatically be added to the current list of exceptions and to the
-file.
-
- To define a word fragment case exception, select the word fragment,
-then select menu ‘Ada | Edit | Create Case Exception Substring’.
-
- It is sometimes useful to have multiple exception files around (for
-instance, one could be the standard Ada acronyms, the second some
-company specific exceptions, and the last one some project specific
-exceptions). If you set up the variable ‘ada-case-exception-file’ as a
-list of files, each of them will be parsed and used in your emacs
-session. However, when you save a new exception through the menu, as
-described above, the new exception will be added to the first file in
-the list.
-
-‘C-c C-b’
- Adjust case in the whole buffer (‘ada-adjust-case-buffer’).
-‘C-c C-y’
- Create a new entry in the exception dictionary, with the word under
- the cursor (‘ada-create-case-exception’)
-‘C-c C-t’
- Rereads the exception dictionary from the file
- ‘ada-case-exception-file’ (‘ada-case-read-exceptions’).
-
-
-File: ada-mode.info, Node: Statement Templates, Next: Comment Handling, Prev: Automatic Casing, Up: Top
-
-12 Statement Templates
-**********************
-
-Templates are defined for most Ada statements, using the Emacs
-“skeleton” package. They can be inserted in the buffer using the
-following commands:
-
-‘C-c t b’
- exception Block (‘ada-exception-block’).
-‘C-c t c’
- case (‘ada-case’).
-‘C-c t d’
- declare Block (‘ada-declare-block’).
-‘C-c t e’
- else (‘ada-else’).
-‘C-c t f’
- for Loop (‘ada-for-loop’).
-‘C-c t h’
- Header (‘ada-header’).
-‘C-c t i’
- if (‘ada-if’).
-‘C-c t k’
- package Body (‘ada-package-body’).
-‘C-c t l’
- loop (‘ada-loop’).
-‘C-c p’
- subprogram body (‘ada-subprogram-body’).
-‘C-c t t’
- task Body (‘ada-task-body’).
-‘C-c t w’
- while Loop (‘ada-while’).
-‘C-c t u’
- use (‘ada-use’).
-‘C-c t x’
- exit (‘ada-exit’).
-‘C-c t C-a’
- array (‘ada-array’).
-‘C-c t C-e’
- elsif (‘ada-elsif’).
-‘C-c t C-f’
- function Spec (‘ada-function-spec’).
-‘C-c t C-k’
- package Spec (‘ada-package-spec’).
-‘C-c t C-p’
- procedure Spec (‘ada-package-spec’.
-‘C-c t C-r’
- record (‘ada-record’).
-‘C-c t C-s’
- subtype (‘ada-subtype’).
-‘C-c t C-t’
- task Spec (‘ada-task-spec’).
-‘C-c t C-u’
- with (‘ada-with’).
-‘C-c t C-v’
- private (‘ada-private’).
-‘C-c t C-w’
- when (‘ada-when’).
-‘C-c t C-x’
- exception (‘ada-exception’).
-‘C-c t C-y’
- type (‘ada-type’).
-
-
-File: ada-mode.info, Node: Comment Handling, Next: GNU Free Documentation License, Prev: Statement Templates, Up: Top
-
-13 Comment Handling
-*******************
-
-By default, comment lines get indented like Ada code. There are a few
-additional functions to handle comments:
-
-‘M-;’
- Start a comment in default column.
-‘M-j’
- Continue comment on next line.
-‘C-c ;’
- Comment the selected region (add ‘--’ at the beginning of lines).
-‘C-c :’
- Uncomment the selected region
-‘M-q’
- autofill the current comment.
-
-
-File: ada-mode.info, Node: GNU Free Documentation License, Next: Index, Prev: Comment Handling, Up: Top
-
-Appendix A GNU Free Documentation License
-*****************************************
-
- Version 1.3, 3 November 2008
-
- Copyright © 2000, 2001, 2002, 2007, 2008 Free Software Foundation, Inc.
- <https://fsf.org/>
-
- Everyone is permitted to copy and distribute verbatim copies
- of this license document, but changing it is not allowed.
-
- 0. PREAMBLE
-
- The purpose of this License is to make a manual, textbook, or other
- functional and useful document “free” in the sense of freedom: to
- assure everyone the effective freedom to copy and redistribute it,
- with or without modifying it, either commercially or
- noncommercially. Secondarily, this License preserves for the
- author and publisher a way to get credit for their work, while not
- being considered responsible for modifications made by others.
-
- This License is a kind of “copyleft”, which means that derivative
- works of the document must themselves be free in the same sense.
- It complements the GNU General Public License, which is a copyleft
- license designed for free software.
-
- We have designed this License in order to use it for manuals for
- free software, because free software needs free documentation: a
- free program should come with manuals providing the same freedoms
- that the software does. But this License is not limited to
- software manuals; it can be used for any textual work, regardless
- of subject matter or whether it is published as a printed book. We
- recommend this License principally for works whose purpose is
- instruction or reference.
-
- 1. APPLICABILITY AND DEFINITIONS
-
- This License applies to any manual or other work, in any medium,
- that contains a notice placed by the copyright holder saying it can
- be distributed under the terms of this License. Such a notice
- grants a world-wide, royalty-free license, unlimited in duration,
- to use that work under the conditions stated herein. The
- “Document”, below, refers to any such manual or work. Any member
- of the public is a licensee, and is addressed as “you”. You accept
- the license if you copy, modify or distribute the work in a way
- requiring permission under copyright law.
-
- A “Modified Version” of the Document means any work containing the
- Document or a portion of it, either copied verbatim, or with
- modifications and/or translated into another language.
-
- A “Secondary Section” is a named appendix or a front-matter section
- of the Document that deals exclusively with the relationship of the
- publishers or authors of the Document to the Document’s overall
- subject (or to related matters) and contains nothing that could
- fall directly within that overall subject. (Thus, if the Document
- is in part a textbook of mathematics, a Secondary Section may not
- explain any mathematics.) The relationship could be a matter of
- historical connection with the subject or with related matters, or
- of legal, commercial, philosophical, ethical or political position
- regarding them.
-
- The “Invariant Sections” are certain Secondary Sections whose
- titles are designated, as being those of Invariant Sections, in the
- notice that says that the Document is released under this License.
- If a section does not fit the above definition of Secondary then it
- is not allowed to be designated as Invariant. The Document may
- contain zero Invariant Sections. If the Document does not identify
- any Invariant Sections then there are none.
-
- The “Cover Texts” are certain short passages of text that are
- listed, as Front-Cover Texts or Back-Cover Texts, in the notice
- that says that the Document is released under this License. A
- Front-Cover Text may be at most 5 words, and a Back-Cover Text may
- be at most 25 words.
-
- A “Transparent” copy of the Document means a machine-readable copy,
- represented in a format whose specification is available to the
- general public, that is suitable for revising the document
- straightforwardly with generic text editors or (for images composed
- of pixels) generic paint programs or (for drawings) some widely
- available drawing editor, and that is suitable for input to text
- formatters or for automatic translation to a variety of formats
- suitable for input to text formatters. A copy made in an otherwise
- Transparent file format whose markup, or absence of markup, has
- been arranged to thwart or discourage subsequent modification by
- readers is not Transparent. An image format is not Transparent if
- used for any substantial amount of text. A copy that is not
- “Transparent” is called “Opaque”.
-
- Examples of suitable formats for Transparent copies include plain
- ASCII without markup, Texinfo input format, LaTeX input format,
- SGML or XML using a publicly available DTD, and standard-conforming
- simple HTML, PostScript or PDF designed for human modification.
- Examples of transparent image formats include PNG, XCF and JPG.
- Opaque formats include proprietary formats that can be read and
- edited only by proprietary word processors, SGML or XML for which
- the DTD and/or processing tools are not generally available, and
- the machine-generated HTML, PostScript or PDF produced by some word
- processors for output purposes only.
-
- The “Title Page” means, for a printed book, the title page itself,
- plus such following pages as are needed to hold, legibly, the
- material this License requires to appear in the title page. For
- works in formats which do not have any title page as such, “Title
- Page” means the text near the most prominent appearance of the
- work’s title, preceding the beginning of the body of the text.
-
- The “publisher” means any person or entity that distributes copies
- of the Document to the public.
-
- A section “Entitled XYZ” means a named subunit of the Document
- whose title either is precisely XYZ or contains XYZ in parentheses
- following text that translates XYZ in another language. (Here XYZ
- stands for a specific section name mentioned below, such as
- “Acknowledgements”, “Dedications”, “Endorsements”, or “History”.)
- To “Preserve the Title” of such a section when you modify the
- Document means that it remains a section “Entitled XYZ” according
- to this definition.
-
- The Document may include Warranty Disclaimers next to the notice
- which states that this License applies to the Document. These
- Warranty Disclaimers are considered to be included by reference in
- this License, but only as regards disclaiming warranties: any other
- implication that these Warranty Disclaimers may have is void and
- has no effect on the meaning of this License.
-
- 2. VERBATIM COPYING
-
- You may copy and distribute the Document in any medium, either
- commercially or noncommercially, provided that this License, the
- copyright notices, and the license notice saying this License
- applies to the Document are reproduced in all copies, and that you
- add no other conditions whatsoever to those of this License. You
- may not use technical measures to obstruct or control the reading
- or further copying of the copies you make or distribute. However,
- you may accept compensation in exchange for copies. If you
- distribute a large enough number of copies you must also follow the
- conditions in section 3.
-
- You may also lend copies, under the same conditions stated above,
- and you may publicly display copies.
-
- 3. COPYING IN QUANTITY
-
- If you publish printed copies (or copies in media that commonly
- have printed covers) of the Document, numbering more than 100, and
- the Document’s license notice requires Cover Texts, you must
- enclose the copies in covers that carry, clearly and legibly, all
- these Cover Texts: Front-Cover Texts on the front cover, and
- Back-Cover Texts on the back cover. Both covers must also clearly
- and legibly identify you as the publisher of these copies. The
- front cover must present the full title with all words of the title
- equally prominent and visible. You may add other material on the
- covers in addition. Copying with changes limited to the covers, as
- long as they preserve the title of the Document and satisfy these
- conditions, can be treated as verbatim copying in other respects.
-
- If the required texts for either cover are too voluminous to fit
- legibly, you should put the first ones listed (as many as fit
- reasonably) on the actual cover, and continue the rest onto
- adjacent pages.
-
- If you publish or distribute Opaque copies of the Document
- numbering more than 100, you must either include a machine-readable
- Transparent copy along with each Opaque copy, or state in or with
- each Opaque copy a computer-network location from which the general
- network-using public has access to download using public-standard
- network protocols a complete Transparent copy of the Document, free
- of added material. If you use the latter option, you must take
- reasonably prudent steps, when you begin distribution of Opaque
- copies in quantity, to ensure that this Transparent copy will
- remain thus accessible at the stated location until at least one
- year after the last time you distribute an Opaque copy (directly or
- through your agents or retailers) of that edition to the public.
-
- It is requested, but not required, that you contact the authors of
- the Document well before redistributing any large number of copies,
- to give them a chance to provide you with an updated version of the
- Document.
-
- 4. MODIFICATIONS
-
- You may copy and distribute a Modified Version of the Document
- under the conditions of sections 2 and 3 above, provided that you
- release the Modified Version under precisely this License, with the
- Modified Version filling the role of the Document, thus licensing
- distribution and modification of the Modified Version to whoever
- possesses a copy of it. In addition, you must do these things in
- the Modified Version:
-
- A. Use in the Title Page (and on the covers, if any) a title
- distinct from that of the Document, and from those of previous
- versions (which should, if there were any, be listed in the
- History section of the Document). You may use the same title
- as a previous version if the original publisher of that
- version gives permission.
-
- B. List on the Title Page, as authors, one or more persons or
- entities responsible for authorship of the modifications in
- the Modified Version, together with at least five of the
- principal authors of the Document (all of its principal
- authors, if it has fewer than five), unless they release you
- from this requirement.
-
- C. State on the Title page the name of the publisher of the
- Modified Version, as the publisher.
-
- D. Preserve all the copyright notices of the Document.
-
- E. Add an appropriate copyright notice for your modifications
- adjacent to the other copyright notices.
-
- F. Include, immediately after the copyright notices, a license
- notice giving the public permission to use the Modified
- Version under the terms of this License, in the form shown in
- the Addendum below.
-
- G. Preserve in that license notice the full lists of Invariant
- Sections and required Cover Texts given in the Document’s
- license notice.
-
- H. Include an unaltered copy of this License.
-
- I. Preserve the section Entitled “History”, Preserve its Title,
- and add to it an item stating at least the title, year, new
- authors, and publisher of the Modified Version as given on the
- Title Page. If there is no section Entitled “History” in the
- Document, create one stating the title, year, authors, and
- publisher of the Document as given on its Title Page, then add
- an item describing the Modified Version as stated in the
- previous sentence.
-
- J. Preserve the network location, if any, given in the Document
- for public access to a Transparent copy of the Document, and
- likewise the network locations given in the Document for
- previous versions it was based on. These may be placed in the
- “History” section. You may omit a network location for a work
- that was published at least four years before the Document
- itself, or if the original publisher of the version it refers
- to gives permission.
-
- K. For any section Entitled “Acknowledgements” or “Dedications”,
- Preserve the Title of the section, and preserve in the section
- all the substance and tone of each of the contributor
- acknowledgements and/or dedications given therein.
-
- L. Preserve all the Invariant Sections of the Document, unaltered
- in their text and in their titles. Section numbers or the
- equivalent are not considered part of the section titles.
-
- M. Delete any section Entitled “Endorsements”. Such a section
- may not be included in the Modified Version.
-
- N. Do not retitle any existing section to be Entitled
- “Endorsements” or to conflict in title with any Invariant
- Section.
-
- O. Preserve any Warranty Disclaimers.
-
- If the Modified Version includes new front-matter sections or
- appendices that qualify as Secondary Sections and contain no
- material copied from the Document, you may at your option designate
- some or all of these sections as invariant. To do this, add their
- titles to the list of Invariant Sections in the Modified Version’s
- license notice. These titles must be distinct from any other
- section titles.
-
- You may add a section Entitled “Endorsements”, provided it contains
- nothing but endorsements of your Modified Version by various
- parties—for example, statements of peer review or that the text has
- been approved by an organization as the authoritative definition of
- a standard.
-
- You may add a passage of up to five words as a Front-Cover Text,
- and a passage of up to 25 words as a Back-Cover Text, to the end of
- the list of Cover Texts in the Modified Version. Only one passage
- of Front-Cover Text and one of Back-Cover Text may be added by (or
- through arrangements made by) any one entity. If the Document
- already includes a cover text for the same cover, previously added
- by you or by arrangement made by the same entity you are acting on
- behalf of, you may not add another; but you may replace the old
- one, on explicit permission from the previous publisher that added
- the old one.
-
- The author(s) and publisher(s) of the Document do not by this
- License give permission to use their names for publicity for or to
- assert or imply endorsement of any Modified Version.
-
- 5. COMBINING DOCUMENTS
-
- You may combine the Document with other documents released under
- this License, under the terms defined in section 4 above for
- modified versions, provided that you include in the combination all
- of the Invariant Sections of all of the original documents,
- unmodified, and list them all as Invariant Sections of your
- combined work in its license notice, and that you preserve all
- their Warranty Disclaimers.
-
- The combined work need only contain one copy of this License, and
- multiple identical Invariant Sections may be replaced with a single
- copy. If there are multiple Invariant Sections with the same name
- but different contents, make the title of each such section unique
- by adding at the end of it, in parentheses, the name of the
- original author or publisher of that section if known, or else a
- unique number. Make the same adjustment to the section titles in
- the list of Invariant Sections in the license notice of the
- combined work.
-
- In the combination, you must combine any sections Entitled
- “History” in the various original documents, forming one section
- Entitled “History”; likewise combine any sections Entitled
- “Acknowledgements”, and any sections Entitled “Dedications”. You
- must delete all sections Entitled “Endorsements.”
-
- 6. COLLECTIONS OF DOCUMENTS
-
- You may make a collection consisting of the Document and other
- documents released under this License, and replace the individual
- copies of this License in the various documents with a single copy
- that is included in the collection, provided that you follow the
- rules of this License for verbatim copying of each of the documents
- in all other respects.
-
- You may extract a single document from such a collection, and
- distribute it individually under this License, provided you insert
- a copy of this License into the extracted document, and follow this
- License in all other respects regarding verbatim copying of that
- document.
-
- 7. AGGREGATION WITH INDEPENDENT WORKS
-
- A compilation of the Document or its derivatives with other
- separate and independent documents or works, in or on a volume of a
- storage or distribution medium, is called an “aggregate” if the
- copyright resulting from the compilation is not used to limit the
- legal rights of the compilation’s users beyond what the individual
- works permit. When the Document is included in an aggregate, this
- License does not apply to the other works in the aggregate which
- are not themselves derivative works of the Document.
-
- If the Cover Text requirement of section 3 is applicable to these
- copies of the Document, then if the Document is less than one half
- of the entire aggregate, the Document’s Cover Texts may be placed
- on covers that bracket the Document within the aggregate, or the
- electronic equivalent of covers if the Document is in electronic
- form. Otherwise they must appear on printed covers that bracket
- the whole aggregate.
-
- 8. TRANSLATION
-
- Translation is considered a kind of modification, so you may
- distribute translations of the Document under the terms of section
- 4. Replacing Invariant Sections with translations requires special
- permission from their copyright holders, but you may include
- translations of some or all Invariant Sections in addition to the
- original versions of these Invariant Sections. You may include a
- translation of this License, and all the license notices in the
- Document, and any Warranty Disclaimers, provided that you also
- include the original English version of this License and the
- original versions of those notices and disclaimers. In case of a
- disagreement between the translation and the original version of
- this License or a notice or disclaimer, the original version will
- prevail.
-
- If a section in the Document is Entitled “Acknowledgements”,
- “Dedications”, or “History”, the requirement (section 4) to
- Preserve its Title (section 1) will typically require changing the
- actual title.
-
- 9. TERMINATION
-
- You may not copy, modify, sublicense, or distribute the Document
- except as expressly provided under this License. Any attempt
- otherwise to copy, modify, sublicense, or distribute it is void,
- and will automatically terminate your rights under this License.
-
- However, if you cease all violation of this License, then your
- license from a particular copyright holder is reinstated (a)
- provisionally, unless and until the copyright holder explicitly and
- finally terminates your license, and (b) permanently, if the
- copyright holder fails to notify you of the violation by some
- reasonable means prior to 60 days after the cessation.
-
- Moreover, your license from a particular copyright holder is
- reinstated permanently if the copyright holder notifies you of the
- violation by some reasonable means, this is the first time you have
- received notice of violation of this License (for any work) from
- that copyright holder, and you cure the violation prior to 30 days
- after your receipt of the notice.
-
- Termination of your rights under this section does not terminate
- the licenses of parties who have received copies or rights from you
- under this License. If your rights have been terminated and not
- permanently reinstated, receipt of a copy of some or all of the
- same material does not give you any rights to use it.
-
- 10. FUTURE REVISIONS OF THIS LICENSE
-
- The Free Software Foundation may publish new, revised versions of
- the GNU Free Documentation License from time to time. Such new
- versions will be similar in spirit to the present version, but may
- differ in detail to address new problems or concerns. See
- <https://www.gnu.org/licenses/>.
-
- Each version of the License is given a distinguishing version
- number. If the Document specifies that a particular numbered
- version of this License “or any later version” applies to it, you
- have the option of following the terms and conditions either of
- that specified version or of any later version that has been
- published (not as a draft) by the Free Software Foundation. If the
- Document does not specify a version number of this License, you may
- choose any version ever published (not as a draft) by the Free
- Software Foundation. If the Document specifies that a proxy can
- decide which future versions of this License can be used, that
- proxy’s public statement of acceptance of a version permanently
- authorizes you to choose that version for the Document.
-
- 11. RELICENSING
-
- “Massive Multiauthor Collaboration Site” (or “MMC Site”) means any
- World Wide Web server that publishes copyrightable works and also
- provides prominent facilities for anybody to edit those works. A
- public wiki that anybody can edit is an example of such a server.
- A “Massive Multiauthor Collaboration” (or “MMC”) contained in the
- site means any set of copyrightable works thus published on the MMC
- site.
-
- “CC-BY-SA” means the Creative Commons Attribution-Share Alike 3.0
- license published by Creative Commons Corporation, a not-for-profit
- corporation with a principal place of business in San Francisco,
- California, as well as future copyleft versions of that license
- published by that same organization.
-
- “Incorporate” means to publish or republish a Document, in whole or
- in part, as part of another Document.
-
- An MMC is “eligible for relicensing” if it is licensed under this
- License, and if all works that were first published under this
- License somewhere other than this MMC, and subsequently
- incorporated in whole or in part into the MMC, (1) had no cover
- texts or invariant sections, and (2) were thus incorporated prior
- to November 1, 2008.
-
- The operator of an MMC Site may republish an MMC contained in the
- site under CC-BY-SA on the same site at any time before August 1,
- 2009, provided the MMC is eligible for relicensing.
-
-ADDENDUM: How to use this License for your documents
-====================================================
-
-To use this License in a document you have written, include a copy of
-the License in the document and put the following copyright and license
-notices just after the title page:
-
- Copyright (C) YEAR YOUR NAME.
- Permission is granted to copy, distribute and/or modify this document
- under the terms of the GNU Free Documentation License, Version 1.3
- or any later version published by the Free Software Foundation;
- with no Invariant Sections, no Front-Cover Texts, and no Back-Cover
- Texts. A copy of the license is included in the section entitled ``GNU
- Free Documentation License''.
-
- If you have Invariant Sections, Front-Cover Texts and Back-Cover
-Texts, replace the “with...Texts.” line with this:
-
- with the Invariant Sections being LIST THEIR TITLES, with
- the Front-Cover Texts being LIST, and with the Back-Cover Texts
- being LIST.
-
- If you have Invariant Sections without Cover Texts, or some other
-combination of the three, merge those two alternatives to suit the
-situation.
-
- If your document contains nontrivial examples of program code, we
-recommend releasing these examples in parallel under your choice of free
-software license, such as the GNU General Public License, to permit
-their use in free software.
-
-
-File: ada-mode.info, Node: Index, Prev: GNU Free Documentation License, Up: Top
-
-Index
-*****
-
-
-* Menu:
-
-* ada-adjust-case-buffer: Automatic Casing. (line 74)
-* ada-array: Statement Templates. (line 39)
-* ada-case: Statement Templates. (line 13)
-* ada-case-read-exceptions: Automatic Casing. (line 79)
-* ada-complete-identifier: Identifier completion.
- (line 39)
-* ada-create-case-exception: Automatic Casing. (line 54)
-* ada-declare-block: Statement Templates. (line 15)
-* ada-else: Statement Templates. (line 17)
-* ada-elsif: Statement Templates. (line 41)
-* ada-exception: Statement Templates. (line 61)
-* ada-exception-block: Statement Templates. (line 11)
-* ada-exit: Statement Templates. (line 37)
-* ada-find-references: Moving Through Ada Code.
- (line 37)
-* ada-for-loop: Statement Templates. (line 19)
-* ada-format-paramlist: Formatting Parameter Lists.
- (line 7)
-* ada-function-spec: Statement Templates. (line 43)
-* ada-goto-declaration: Moving Through Ada Code.
- (line 34)
-* ada-header: Statement Templates. (line 21)
-* ada-if: Statement Templates. (line 23)
-* ada-loop: Statement Templates. (line 27)
-* ada-move-to-end: Moving Through Ada Code.
- (line 28)
-* ada-move-to-start: Moving Through Ada Code.
- (line 23)
-* ada-next-package: Moving Through Ada Code.
- (line 19)
-* ada-next-procedure: Moving Through Ada Code.
- (line 13)
-* ada-package-body: Statement Templates. (line 25)
-* ada-package-spec: Statement Templates. (line 45)
-* ada-previous-package: Moving Through Ada Code.
- (line 21)
-* ada-previous-procedure: Moving Through Ada Code.
- (line 16)
-* ada-private: Statement Templates. (line 57)
-* ada-procedure-spec: Statement Templates. (line 47)
-* ada-record: Statement Templates. (line 49)
-* ada-subprogram-body: Statement Templates. (line 29)
-* ada-subtype: Statement Templates. (line 51)
-* ada-task-body: Statement Templates. (line 31)
-* ada-task-spec: Statement Templates. (line 53)
-* ada-type: Statement Templates. (line 63)
-* ada-use: Statement Templates. (line 35)
-* ada-when: Statement Templates. (line 59)
-* ada-while: Statement Templates. (line 33)
-* ada-with: Statement Templates. (line 55)
-
-
-
-Tag Table:
-Node: Top862
-Node: Overview2536
-Node: Installation3858
-Node: Customization5019
-Node: Non-standard file names5943
-Node: Other compiler7474
-Node: Other customization7978
-Node: Compiling Executing8652
-Node: Compile commands9328
-Node: Compiler errors12177
-Node: Project files13082
-Node: Project File Overview13795
-Node: GUI Editor16150
-Node: Project file variables16642
-Node: Compiling Examples23982
-Node: No project files24780
-Node: Set compiler options29651
-Node: Set source search path31696
-Node: Use GNAT project file34044
-Node: Use multiple GNAT project files36288
-Node: Moving Through Ada Code38239
-Node: Identifier completion40280
-Node: Automatic Smart Indentation41884
-Node: Formatting Parameter Lists44754
-Node: Automatic Casing45184
-Node: Statement Templates48588
-Node: Comment Handling50251
-Node: GNU Free Documentation License50806
-Node: Index76164
-
-End Tag Table
-
-
-Local Variables:
-coding: utf-8
-End:
diff --git a/old_ada/doc/ada-mode.pdf b/old_ada/doc/ada-mode.pdf
deleted file mode 100644
index c3f3839..0000000
--- a/old_ada/doc/ada-mode.pdf
+++ /dev/null
Binary files differ
diff --git a/old_ada/doc/ada-mode.texi b/old_ada/doc/ada-mode.texi
deleted file mode 100644
index 1ac90cd..0000000
--- a/old_ada/doc/ada-mode.texi
+++ /dev/null
@@ -1,1526 +0,0 @@
-\input texinfo @c -*-texinfo-*-
-@setfilename ../../info/ada-mode.info
-@settitle Ada Mode
-@include docstyle.texi
-
-@copying
-Copyright @copyright{} 1999--2019 Free Software Foundation, Inc.
-
-@quotation
-Permission is granted to copy, distribute and/or modify this document
-under the terms of the GNU Free Documentation License, Version 1.3 or
-any later version published by the Free Software Foundation; with no
-Invariant Sections, with the Front-Cover Texts being ``A GNU Manual'',
-and with the Back-Cover Texts as in (a) below. A copy of the license
-is included in the section entitled ``GNU Free Documentation License''.
-
-(a) The FSF's Back-Cover Text is: ``You have the freedom to copy and
-modify this GNU manual.''
-@end quotation
-@end copying
-
-@dircategory Emacs editing modes
-@direntry
-* Ada mode: (ada-mode). Emacs mode for editing and compiling Ada code.
-@end direntry
-
-@titlepage
-@sp 10
-@title Ada Mode
-@sp 2
-@subtitle An Emacs major mode for programming in Ada
-@subtitle Ada Mode Version 4.00
-@sp 2
-@page
-@vskip 0pt plus 1filll
-@insertcopying
-@end titlepage
-
-@contents
-
-@node Top
-@top Ada Mode
-
-@ifnottex
-@insertcopying
-@end ifnottex
-
-@menu
-* Overview::
-* Installation:: Installing Ada mode on your system
-* Customization:: Setting up Ada mode to your taste
-* Compiling Executing:: Working with your application within Emacs
-* Project files:: Describing the organization of your project
-* Compiling Examples:: A small tutorial
-* Moving Through Ada Code:: Moving easily through Ada sources
-* Identifier completion:: Finishing words automatically
-* Automatic Smart Indentation:: Indenting your code automatically as you type
-* Formatting Parameter Lists:: Formatting subprograms' parameter lists
- automatically
-* Automatic Casing:: Adjusting the case of words automatically
-* Statement Templates:: Inserting code templates
-* Comment Handling:: Reformatting comments easily
-* GNU Free Documentation License:: The license for this documentation.
-* Index::
-@end menu
-
-
-@node Overview
-@chapter Overview
-
-The Emacs mode for programming in Ada helps the user in understanding
-existing code and facilitates writing new code.
-
-When the GNU Ada compiler GNAT is used, the cross-reference
-information output by the compiler is used to provide powerful code
-navigation (jump to definition, find all uses, etc.).
-
-When you open a file with a file extension of @file{.ads} or
-@file{.adb}, Emacs will automatically load and activate Ada mode.
-
-Ada mode works without any customization, if you are using the GNAT
-compiler (@url{https://libre2.adacore.com/}) and the GNAT default
-naming convention.
-
-You must customize a few things if you are using a different compiler
-or file naming convention; @xref{Other compiler}, @xref{Non-standard
-file names}.
-
-In addition, you may want to customize the indentation,
-capitalization, and other things; @xref{Other customization}.
-
-Finally, for large Ada projects, you will want to set up an Emacs
-Ada mode project file for each project; @xref{Project files}. Note
-that these are different from the GNAT project files used by gnatmake
-and other GNAT commands.
-
-See the Emacs info manual, section 'Running Debuggers Under Emacs',
-for general information on debugging.
-
-@node Installation
-@chapter Installation
-
-Ada mode is part of the standard Emacs distribution; if you use that,
-no files need to be installed.
-
-Ada mode is also available as a separate distribution, from the Emacs
-Ada mode website
-@uref{http://stephe-leake.org/emacs/ada-mode/emacs-ada-mode.html}. The
-separate distribution may be more recent.
-
-For installing the separate distribution, see the @file{README} file
-in the distribution.
-
-To see what version of Ada mode you have installed, do @kbd{M-x
-ada-mode-version}.
-
-The following files are provided with the Ada mode distribution:
-
-@itemize @bullet
-
-@item
-@file{ada-mode.el}: The main file for Ada mode, providing indentation,
-formatting of parameter lists, moving through code, comment handling
-and automatic casing.
-
-@item
-@file{ada-prj.el}: GUI editing of Ada mode project files, using Emacs
-widgets.
-
-@item
-@file{ada-stmt.el}: Ada statement templates.
-
-@item
-@file{ada-xref.el}: GNAT cross-references, completion of identifiers,
-and compilation. Also provides project files (which are not
-GNAT-specific).
-
-@end itemize
-
-@node Customization
-@chapter Customizing Ada mode
-
-Here we assume you are familiar with setting variables in Emacs,
-either thru 'customize' or in elisp (in your @file{.emacs} file). For
-a basic introduction to customize, elisp, and Emacs in general, see
-the tutorial in
-@iftex
-@cite{The GNU Emacs Manual}.
-@end iftex
-@ifhtml
-@cite{The GNU Emacs Manual}.
-@end ifhtml
-@ifinfo
-@ref{Top, , The GNU Emacs Manual, emacs, The GNU Emacs Manual}.
-@end ifinfo
-
-These global Emacs settings are strongly recommended (put them in your
-.emacs):
-
-@example
-(global-font-lock-mode t)
-(transient-mark-mode t)
-@end example
-
-@samp{(global-font-lock-mode t)} turns on syntax
-highlighting for all buffers (it is off by default because it may be
-too slow for some machines).
-
-@samp{(transient-mark-mode t)} highlights selected text.
-
-See the Emacs help for each of these variables for more information.
-
-@menu
-* Non-standard file names::
-* Other compiler::
-* Other customization::
-@end menu
-
-@node Non-standard file names
-@section Non-standard file names
-
-By default, Ada mode is configured to use the GNAT file naming
-convention, where file names are a simple modification of the Ada
-names, and the extension for specs and bodies are
-@samp{.ads} and @samp{.adb}, respectively.
-
-Ada mode uses the file extensions to allow moving from a package body
-to the corresponding spec and back.
-
-Ada mode supports a list of alternative file extensions for specs and bodies.
-
-For instance, if your spec and bodies files are called
-@file{@var{unit}_s.ada} and @file{@var{unit}_b.ada}, respectively, you
-can add the following to your @file{.emacs} file:
-
-@example
-(ada-add-extensions "_s.ada" "_b.ada")
-@end example
-
-You can define additional extensions:
-
-@example
-(ada-add-extensions ".ads" "_b.ada")
-(ada-add-extensions ".ads" ".body")
-@end example
-
-This means that whenever Ada mode looks for the body for a file
-whose extension is @file{.ads}, it will take the first available file
-that ends with either @file{.adb}, @file{_b.ada} or
-@file{.body}.
-
-Similarly, if Ada mode is looking for a spec, it will look for
-@file{.ads} or @file{_s.ada}.
-
-If the filename is not derived from the Ada name following the GNAT
-convention, things are a little more complicated. You then need to
-rewrite the function @code{ada-make-filename-from-adaname}. Doing that
-is beyond the scope of this manual; see the current definitions in
-@file{ada-mode.el} and @file{ada-xref.el} for examples.
-
-@node Other compiler
-@section Other compiler
-
-By default, Ada mode is configured to use the GNU Ada compiler GNAT.
-
-To use a different Ada compiler, you must specify the command lines
-used to run that compiler, either in lisp variables or in Emacs
-Ada mode project files. See @ref{Project file variables} for the list
-of project variables, and the corresponding lisp variables.
-
-@node Other customization
-@section Other customization
-
-All user-settable Ada mode variables can be set via the menu
-@samp{Ada | Customize}. Click on the @samp{Help} button there for help
-on using customize.
-
-To modify a specific variable, you can directly call the function
-@code{customize-variable}; just type @kbd{M-x customize-variable
-@key{RET} @var{variable-name} @key{RET}}).
-
-Alternately, you can specify variable settings in the Emacs
-configuration file, @file{.emacs}. This file is coded in Emacs lisp,
-and the syntax to set a variable is the following:
-@example
-(setq variable-name value)
-@end example
-
-@node Compiling Executing
-@chapter Compiling Executing
-
-Ada projects can be compiled, linked, and executed using commands on
-the Ada menu. All of these commands can be customized via a project
-file (@pxref{Project files}), but the defaults are sufficient for using
-the GNAT compiler for simple projects (single files, or several files
-in a single directory).
-
-Even when no project file is used, the GUI project editor (menu
-@samp{Ada | Project | Edit}) shows the settings of the various project
-file variables referenced here.
-
-@menu
-* Compile commands::
-* Compiler errors::
-@end menu
-
-@node Compile commands
-@section Compile commands
-
-Here are the commands for building and using an Ada project, as
-listed in the Ada menu.
-
-In multi-file projects, there must be one file that is the main
-program. That is given by the @code{main} project file variable;
-it defaults to the current file if not yet set, but is also set by the
-``set main and build'' command.
-
-@table @code
-
-@item Check file
-Compiles the current file in syntax check mode, by running
-@code{check_cmd} defined in the current project file. This typically
-runs faster than full compile mode, speeding up finding and fixing
-compilation errors.
-
-This sets @code{main} only if it has not been set yet.
-
-@item Compile file
-Compiles the current file, by running @code{comp_cmd} from the current
-project file.
-
-This does not set @code{main}.
-
-@item Set main and Build
-Sets @code{main} to the current file, then executes the Build
-command.
-
-@item Show main
-Display @code{main} in the message buffer.
-
-@item Build
-Compiles all obsolete units of the current @code{main}, and links
-@code{main}, by running @code{make_cmd} from the current project.
-
-This sets @code{main} only if it has not been set yet.
-
-@item Run
-Executes the main program in a shell, displayed in a separate Emacs
-buffer. This runs @code{run_cmd} from the current project. The
-execution buffer allows for interactive input/output.
-
-To modify the run command, in particular to provide or change the
-command line arguments, type @kbd{C-u} before invoking the command.
-
-This command is not available for a cross-compilation toolchain.
-
-@end table
-It is important when using these commands to understand how
-@code{main} is used and changed.
-
-Build runs 'gnatmake' on the main unit. During a typical edit/compile
-session, this is the only command you need to invoke, which is why it
-is bound to @kbd{C-c C-c}. It will compile all files needed by the
-main unit, and display compilation errors in any of them.
-
-Note that Build can be invoked from any Ada buffer; typically you will
-be fixing errors in files other than the main, but you don't have to
-switch back to the main to invoke the compiler again.
-
-Novices and students typically work on single-file Ada projects. In
-this case, @kbd{C-c C-m} will normally be the only command needed; it
-will build the current file, rather than the last-built main.
-
-There are three ways to change @code{main}:
-
-@enumerate
-@item
-Invoke @samp{Ada | Set main and Build}, which sets @code{main} to
-the current file.
-
-@item
-Invoke @samp{Ada | Project | Edit}, edit @code{main} and
-@code{main}, and click @samp{[save]}
-
-@item
-Invoke @samp{Ada | Project | Load}, and load a project file that specifies @code{main}
-
-@end enumerate
-
-@node Compiler errors
-@section Compiler errors
-
-The @code{Check file}, @code{Compile file}, and @code{Build} commands
-all place compilation errors in a separate buffer named
-@file{*compilation*}.
-
-Each line in this buffer will become active: you can simply click on
-it with the middle button of the mouse, or move point to it and press
-@key{RET}. Emacs will then display the relevant source file and put
-point on the line and column where the error was found.
-
-You can also press the @kbd{C-x `} key (@code{next-error}), and Emacs
-will jump to the first error. If you press that key again, it will
-move you to the second error, and so on.
-
-Some error messages might also include references to other files. These
-references are also clickable in the same way, or put point after the
-line number and press @key{RET}.
-
-@node Project files
-@chapter Project files
-
-An Emacs Ada mode project file specifies what directories hold sources
-for your project, and allows you to customize the compilation commands
-and other things on a per-project basis.
-
-Note that Ada mode project files @file{*.adp} are different than GNAT
-compiler project files @file{*.gpr}. However, Emacs Ada mode can use a
-GNAT project file to specify the project directories. If no
-other customization is needed, a GNAT project file can be used without
-an Emacs Ada mode project file.
-
-@menu
-* Project File Overview::
-* GUI Editor::
-* Project file variables::
-@end menu
-
-@node Project File Overview
-@section Project File Overview
-
-Project files have a simple syntax; they may be edited directly. Each
-line specifies a project variable name and its value, separated by ``='':
-@example
-src_dir=/Projects/my_project/src_1
-src_dir=/Projects/my_project/src_2
-@end example
-
-Some variables (like @code{src_dir}) are lists; multiple occurrences
-are concatenated.
-
-There must be no space between the variable name and ``='', and no
-trailing spaces.
-
-Alternately, a GUI editor for project files is available (@pxref{GUI
-Editor}). It uses Emacs widgets, similar to Emacs customize.
-
-The GUI editor also provides a convenient way to view current project
-settings, if they have been modified using menu commands rather than
-by editing the project file.
-
-After the first Ada mode build command is invoked, there is always a
-current project file, given by the lisp variable
-@code{ada-prj-default-project-file}. Currently, the only way to show
-the current project file is to invoke the GUI editor.
-
-To find the project file the first time, Ada mode uses the following
-search algorithm:
-
-@itemize @bullet
-@item
-If @code{ada-prj-default-project-file} is set, use that.
-
-@item
-Otherwise, search for a file in the current directory with
-the same base name as the Ada file, but extension given by
-@code{ada-prj-file-extension} (default @code{".adp"}).
-
-@item
-If not found, search for @file{*.adp} in the current directory; if
-several are found, prompt the user to select one.
-
-@item
-If none are found, use @file{default.adp} in the current directory (even
-if it does not exist).
-
-@end itemize
-
-This algorithm always sets @code{ada-prj-default-project-file}, even
-when the file does not actually exist.
-
-To change the project file before or after the first one is found,
-invoke @samp{Ada | Project | Load ...}.
-
-Or, in lisp, evaluate @code{(ada-set-default-project-file "/path/file.adp")}.
-This sets @code{ada-prj-default-project-file}, and reads the project file.
-
-You can also specify a GNAT project file to @samp{Ada | Project | Load
-...} or @code{ada-set-default-project-file}. Emacs Ada mode checks the
-file extension; if it is @code{.gpr}, the file is treated as a GNAT
-project file. Any other extension is treated as an Emacs Ada mode
-project file.
-
-@node GUI Editor
-@section GUI Editor
-
-The project file editor is invoked with the menu @samp{Ada | Projects
-| Edit}.
-
-Once in the buffer for editing the project file, you can save your
-modification using the @samp{[save]} button at the bottom of the
-buffer, or the @kbd{C-x C-s} binding. To cancel your modifications,
-kill the buffer or click on the @samp{[cancel]} button.
-
-@node Project file variables
-@section Project file variables
-
-The following variables can be defined in a project file; some can
-also be defined in lisp variables.
-
-To set a project variable that is a list, specify each element of the
-list on a separate line in the project file.
-
-Any project variable can be referenced in other project variables,
-using a shell-like notation. For instance, if the variable
-@code{comp_cmd} contains @code{$@{comp_opt@}}, the value of the
-@code{comp_opt} variable will be substituted when @code{comp_cmd} is
-used.
-
-In addition, process environment variables can be referenced using the
-same syntax, or the normal @code{$var} syntax.
-
-Most project variables have defaults that can be changed by setting
-lisp variables; the table below identifies the lisp variable for each
-project variable. Lisp variables corresponding to project variables
-that are lists are lisp lists.
-
-In general, project variables are evaluated when referenced in
-Emacs Ada mode commands. Relative file paths are expanded to
-absolute relative to @code{$@{build_dir@}}.
-
-Here is the list of variables. In the default values, the current
-directory @code{"."} is the project file directory.
-
-@table @asis
-@c defined in ada-default-prj-properties; alphabetical order
-
-@item @code{ada_project_path_sep} [default: @code{":" or ";"}]
-Path separator for @code{ADA_PROJECT_PATH}. It defaults to the correct
-value for a native implementation of GNAT for the current operating
-system. The user must override this when using Windows native GNAT
-with Cygwin Emacs, and perhaps in other cases.
-
-Lisp variable: @code{ada-prj-ada-project-path-sep}.
-
-@item @code{ada_project_path} [default: @code{""}]
-A list of directories to search for GNAT project files.
-
-If set, the @code{ADA_PROJECT_PATH} process environment variable is
-set to this value in the Emacs process when the Emacs Ada mode project
-is selected via menu @samp{Ada | Project | Load}.
-
-For @code{ada_project_path}, relative file paths are expanded to
-absolute when the Emacs Ada project file is read, rather than when the
-project file is selected.
-
-For example if the project file is in the directory
-@file{/home/myproject}, the environment variable @code{GDS_ROOT} is
-set to @code{/home/shared}, and the project file contains:
-@example
-ada_project_path_sep=:
-ada_project_path=$GDS_ROOT/makerules
-ada_project_path=../opentoken
-@end example
-then as a result the environment variable @code{ADA_PROJECT_PATH} will
-be set to @code{"/home/shared/makerules:/home/opentoken/"}.
-
-The default value is not the current value of this environment
-variable, because that will typically have been set by another
-project, and will therefore be incorrect for this project.
-
-If you have the environment variable set correctly for all of your
-projects, you do not need to set this project variable.
-
-@item @code{bind_opt} [default: @code{""}]
-Holds user binder options; used in the default build commands.
-
-Lisp variable: @code{ada-prj-default-bind-opt}.
-
-@item @code{build_dir} [default: @code{"."}]
-The compile commands will be issued in this directory.
-
-@item @code{casing} [default: @code{("~/.emacs_case_exceptions")}]
-List of files containing casing exceptions. See the help on
-@code{ada-case-exception-file} for more info.
-@c FIXME: section on case exceptions
-
-Lisp variable: @code{ada-case-exception-file}.
-
-@item @code{check_cmd} [default: @code{"$@{cross_prefix@}gnatmake -u -c -gnatc $@{gnatmake_opt@} $@{full_current@} -cargs $@{comp_opt@}"}]
-Command used to syntax check a single file.
-The name of the file is substituted for @code{full_current}.
-
-Lisp variable: @code{ada-prj-default-check-cmd}
-
-@item @code{comp_cmd} [default: @code{"$@{cross_prefix@}gnatmake -u -c $@{gnatmake_opt@} $@{full_current@} -cargs $@{comp_opt@}"}]
-Command used to compile a single file.
-The name of the file is substituted for @code{full_current}.
-
-Lisp variable: @code{ada-prj-default-comp-cmd}.
-
-@item @code{comp_opt} [default: @code{"-gnatq -gnatQ"}]
-Holds user compiler options; used in the default compile commands. The
-default value tells gnatmake to generate library files for
-cross-referencing even when there are errors.
-
-If source code for the project is in multiple directories, the
-appropriate compiler options must be added here. @ref{Set source
-search path} for examples of this. Alternately, GNAT project files may
-be used; @ref{Use GNAT project file}.
-
-Lisp variable: @code{ada-prj-default-comp-opt}.
-
-@item @code{cross_prefix} [default: @code{""}]
-Name of target machine in a cross-compilation environment. Used in
-default compile and build commands.
-
-@item @code{debug_cmd} [default: @code{"$@{cross_prefix@}gdb $@{main@}"}]
-Command used to debug the application
-
-Lisp variable: @code{ada-prj-default-debugger}.
-
-@item @code{debug_post_cmd} [default: @code{""}]
-Command executed after @code{debug_cmd}.
-
-@item @code{debug_pre_cmd} [default: @code{"cd $@{build_dir@}"}]
-Command executed before @code{debug_cmd}.
-
-@item @code{gnatfind_opt} [default: @code{"-rf"}]
-Holds user gnatfind options; used in the default find commands.
-
-Lisp variable: @code{ada-prj-gnatfind-switches}.
-
-@item @code{gnatmake_opt} [default: @code{"-g"}]
-Holds user gnatmake options; used in the default build commands.
-
-Lisp variable: @code{ada-prj-default-gnatmake-opt}.
-
-@item @code{gpr_file} [default: @code{""}]
-Specify GNAT project file.
-
-If set, the source and object directories specified in the GNAT
-project file are appended to @code{src_dir} and @code{obj_dir}. This
-allows specifying Ada source directories with a GNAT project file, and
-other source directories with the Emacs project file.
-
-In addition, @code{-P@{gpr_file@}} is added to the project variable
-@code{gnatmake_opt} whenever it is referenced. With the default
-project variables, this passes the project file to all gnatmake
-commands.
-
-Lisp variable: @code{ada-prj-default-gpr-file}.
-
-@c FIXME: add gnatstub-opts
-
-@item @code{link_opt} [default: @code{""}]
-Holds user linker options; used in the default build commands.
-
-Lisp variable: @code{ada-prj-default-link-opt}.
-
-@item @code{main} [default: current file]
-Specifies the name of the executable file for the project; used in the
-default build commands.
-
-@item @code{make_cmd} [default: @code{"$@{cross_prefix@}gnatmake -o $@{main@} $@{main@} $@{gnatmake_opt@} -cargs $@{comp_opt@} -bargs $@{bind_opt@} -largs $@{link_opt@}"}]
-Command used to build the application.
-
-Lisp variable: @code{ada-prj-default-make-cmd}.
-
-@item @code{obj_dir} [default: @code{"."}]
-A list of directories to search for library files. Ada mode searches
-this list for the @samp{.ali} files generated by GNAT that contain
-cross-reference information.
-
-The compiler commands must place the @samp{.ali} files in one of these
-directories; the default commands do that.
-
-@item @code{remote_machine} [default: @code{""}]
-Name of the machine to log into before issuing the compile and build
-commands. If this variable is empty, the command will be run on the
-local machine.
-
-@item @code{run_cmd} [default: @code{"./$@{main@}"}]
-Command used to run the application.
-
-@item @code{src_dir} [default: @code{"."}]
-A list of directories to search for source files, both for compile
-commands and source navigation.
-
-@end table
-
-@node Compiling Examples
-@chapter Compiling Examples
-
-We present several small projects, and walk thru the process of
-compiling, linking, and running them.
-
-The first example illustrates more Ada mode features than the others;
-you should work thru that example before doing the others.
-
-All of these examples assume you are using GNAT.
-
-The source for these examples is available on the Emacs Ada mode
-website mentioned in @xref{Installation}.
-
-@menu
-* No project files:: Just menus
-* Set compiler options:: A basic Ada mode project file
-* Set source search path:: Source in multiple directories
-* Use GNAT project file::
-* Use multiple GNAT project files::
-@end menu
-
-@node No project files
-@section No project files
-This example uses no project files.
-
-First, create a directory @file{Example_1}, containing:
-
-@file{hello.adb}:
-
-@example
-with Ada.Text_IO;
-procedure Hello
-is begin
- Put_Line("Hello from hello.adb");
-end Hello;
-@end example
-
-Yes, this is missing ``use Ada.Text_IO;'' - we want to demonstrate
-compiler error handling.
-
-@file{hello_2.adb}:
-
-@example
-with Hello_Pkg;
-procedure Hello_2
-is begin
- Hello_Pkg.Say_Hello;
-end Hello_2;
-@end example
-
-This file has no errors.
-
-@file{hello_pkg.ads}:
-
-@example
-package Hello_Pkg is
- procedure Say_Hello;
-end Hello_Pkg;
-@end example
-
-This file has no errors.
-
-@file{hello_pkg.adb}:
-
-@example
-with Ada.Text_IO;
-package Hello_Pkg is
- procedure Say_Hello
- is begin
- Ada.Text_IO.Put_Line ("Hello from hello_pkg.adb");
- end Say_Hello;
-end Hello_Pkg;
-@end example
-
-Yes, this is missing the keyword @code{body}; another compiler error
-example.
-
-In buffer @file{hello.adb}, invoke @samp{Ada | Check file}. You should
-get a @file{*compilation*} buffer containing something like (the
-directory paths will be different):
-
-@smallexample
-cd c:/Examples/Example_1/
-gnatmake -u -c -gnatc -g c:/Examples/Example_1/hello.adb -cargs -gnatq -gnatQ
-gcc -c -Ic:/Examples/Example_1/ -gnatc -g -gnatq -gnatQ -I- c:/Examples/Example_1/hello.adb
-hello.adb:4:04: "Put_Line" is not visible
-hello.adb:4:04: non-visible declaration at a-textio.ads:264
-hello.adb:4:04: non-visible declaration at a-textio.ads:260
-gnatmake: "c:/Examples/Example_1/hello.adb" compilation error
-@end smallexample
-
-If you have enabled font-lock, the lines with actual errors (starting
-with @file{hello.adb}) are highlighted, with the file name in red.
-
-Now type @kbd{C-x `} (on a PC keyboard, @key{`} is next to @key{1}).
-Or you can click the middle mouse button on the first error line. The
-compilation buffer scrolls to put the first error on the top line, and
-point is put at the place of the error in the @file{hello.adb} buffer.
-
-To fix the error, change the line to be
-
-@example
- Ada.Text_IO.Put_Line ("hello from hello.adb");
-@end example
-
-Now invoke @samp{Ada | Show main}; this displays @samp{Ada mode main: hello}.
-
-Now (in buffer @file{hello.adb}), invoke @samp{Ada | Build}. You are
-prompted to save the file (if you haven't already). Then the
-compilation buffer is displayed again, containing:
-
-@example
-cd c:/Examples/Example_1/
-gnatmake -o hello hello -g -cargs -gnatq -gnatQ -bargs -largs
-gcc -c -g -gnatq -gnatQ hello.adb
-gnatbind -x hello.ali
-gnatlink hello.ali -o hello.exe -g
-@end example
-
-The compilation has succeeded without errors; @file{hello.exe} now
-exists in the same directory as @file{hello.adb}.
-
-Now invoke @samp{Ada | Run}. A @file{*run*} buffer is displayed,
-containing
-
-@example
-Hello from hello.adb
-
-Process run finished
-@end example
-
-That completes the first part of this example.
-
-Now we will compile a multi-file project. Open the file
-@file{hello_2.adb}, and invoke @samp{Ada | Set main and Build}. This
-finds an error in @file{hello_pkg.adb}:
-
-@example
-cd c:/Examples/Example_1/
-gnatmake -o hello_2 hello_2 -g -cargs -gnatq -gnatQ -bargs -largs
-gcc -c -g -gnatq -gnatQ hello_pkg.adb
-hello_pkg.adb:2:08: keyword "body" expected here [see file name]
-gnatmake: "hello_pkg.adb" compilation error
-@end example
-
-This demonstrates that gnatmake finds the files needed by the main
-program. However, it cannot find files in a different directory,
-unless you use an Emacs Ada mode project file to specify the other directories;
-@xref{Set source search path}, or a GNAT project file; @ref{Use GNAT
-project file}.
-
-Invoke @samp{Ada | Show main}; this displays @file{Ada mode main: hello_2}.
-
-Move to the error with @kbd{C-x `}, and fix the error by adding @code{body}:
-
-@example
-package body Hello_Pkg is
-@end example
-
-Now, while still in @file{hello_pkg.adb}, invoke @samp{Ada | Build}.
-gnatmake successfully builds @file{hello_2}. This demonstrates that
-Emacs has remembered the main file, in the project variable
-@code{main}, and used it for the Build command.
-
-Finally, again while in @file{hello_pkg.adb}, invoke @samp{Ada | Run}.
-The @file{*run*} buffer displays @code{Hello from hello_pkg.adb}.
-
-One final point. If you switch back to buffer @file{hello.adb}, and
-invoke @samp{Ada | Run}, @file{hello_2.exe} will be run. That is
-because @code{main} is still set to @code{hello_2}, as you can
-see when you invoke @samp{Ada | Project | Edit}.
-
-There are three ways to change @code{main}:
-
-@enumerate
-@item
-Invoke @samp{Ada | Set main and Build}, which sets @code{main} to
-the current file.
-
-@item
-Invoke @samp{Ada | Project | Edit}, edit @code{main}, and click @samp{[save]}
-
-@item
-Invoke @samp{Ada | Project | Load}, and load a project file that specifies @code{main}
-
-@end enumerate
-
-@node Set compiler options
-@section Set compiler options
-
-This example illustrates using an Emacs Ada mode project file to set a
-compiler option.
-
-If you have files from @file{Example_1} open in Emacs, you should
-close them so you don't get confused. Use menu @samp{File | Close
-(current buffer)}.
-
-In directory @file{Example_2}, create these files:
-
-@file{hello.adb}:
-
-@example
-with Ada.Text_IO;
-procedure Hello
-is begin
- Put_Line("Hello from hello.adb");
-end Hello;
-@end example
-
-This is the same as @file{hello.adb} from @file{Example_1}. It has two
-errors; missing ``use Ada.Text_IO;'', and no space between
-@code{Put_Line} and its argument list.
-
-@file{hello.adp}:
-
-@example
-comp_opt=-gnatyt
-@end example
-
-This tells the GNAT compiler to check for token spacing; in
-particular, there must be a space preceding a parenthesis.
-
-In buffer @file{hello.adb}, invoke @samp{Ada | Project | Load...}, and
-select @file{Example_2/hello.adp}.
-
-Then, again in buffer @file{hello.adb}, invoke @samp{Ada | Set main and
-Build}. You should get a @file{*compilation*} buffer containing
-something like (the directory paths will be different):
-
-@example
-cd c:/Examples/Example_2/
-gnatmake -o hello hello -g -cargs -gnatyt -bargs -largs
-gcc -c -g -gnatyt hello.adb
-hello.adb:4:04: "Put_Line" is not visible
-hello.adb:4:04: non-visible declaration at a-textio.ads:264
-hello.adb:4:04: non-visible declaration at a-textio.ads:260
-hello.adb:4:12: (style) space required
-gnatmake: "hello.adb" compilation error
-@end example
-
-Compare this to the compiler output in @ref{No project files}; the
-gnatmake option @code{-cargs -gnatq -gnatQ} has been replaced by
-@code{-cargs -gnaty}, and an additional error is reported in
-@file{hello.adb} on line 4. This shows that @file{hello.adp} is being
-used to set the compiler options.
-
-Fixing the error, linking and running the code proceed as in @ref{No
-project files}.
-
-@node Set source search path
-@section Set source search path
-
-In this example, we show how to deal with files in more than one
-directory. We start with the same code as in @ref{No project files};
-create those files (with the errors present)
-
-Create the directory @file{Example_3}, containing:
-
-@file{hello_pkg.ads}:
-
-@example
-package Hello_Pkg is
- procedure Say_Hello;
-end Hello_Pkg;
-@end example
-
-@file{hello_pkg.adb}:
-
-@example
-with Ada.Text_IO;
-package Hello_Pkg is
- procedure Say_Hello
- is begin
- Ada.Text_IO.Put_Line ("Hello from hello_pkg.adb");
- end Say_Hello;
-end Hello_Pkg;
-@end example
-
-These are the same files from example 1; @file{hello_pkg.adb} has an
-error on line 2.
-
-In addition, create a directory @file{Example_3/Other}, containing these files:
-
-@file{Other/hello_3.adb}:
-
-@example
-with Hello_Pkg;
-with Ada.Text_IO; use Ada.Text_IO;
-procedure Hello_3
-is begin
- Hello_Pkg.Say_Hello;
- Put_Line ("From hello_3");
-end Hello_3;
-@end example
-
-There are no errors in this file.
-
-@file{Other/other.adp}:
-
-@example
-src_dir=..
-comp_opt=-I..
-@end example
-
-Note that there must be no trailing spaces.
-
-In buffer @file{hello_3.adb}, invoke @samp{Ada | Project | Load...}, and
-select @file{Example_3/Other/other.adp}.
-
-Then, again in @file{hello_3.adb}, invoke @samp{Ada | Set main and
-Build}. You should get a @file{*compilation*} buffer containing
-something like (the directory paths will be different):
-
-@example
-cd c:/Examples/Example_3/Other/
-gnatmake -o hello_3 hello_3 -g -cargs -I.. -bargs -largs
-gcc -c -g -I.. hello_3.adb
-gcc -c -I./ -g -I.. -I- C:\Examples\Example_3\hello_pkg.adb
-hello_pkg.adb:2:08: keyword "body" expected here [see file name]
-gnatmake: "C:\Examples\Example_3\hello_pkg.adb" compilation error
-@end example
-
-Compare the @code{-cargs} option to the compiler output in @ref{Set
-compiler options}; this shows that @file{other.adp} is being used to
-set the compiler options.
-
-Move to the error with @kbd{C-x `}. Ada mode searches the list of
-directories given by @code{src_dir} for the file mentioned in the
-compiler error message.
-
-Fixing the error, linking and running the code proceed as in @ref{No
-project files}.
-
-@node Use GNAT project file
-@section Use GNAT project file
-
-In this example, we show how to use a GNAT project file, with no Ada
-mode project file.
-
-Create the directory @file{Example_4}, containing:
-
-@file{hello_pkg.ads}:
-
-@example
-package Hello_Pkg is
- procedure Say_Hello;
-end Hello_Pkg;
-@end example
-
-@file{hello_pkg.adb}:
-
-@example
-with Ada.Text_IO;
-package Hello_Pkg is
- procedure Say_Hello
- is begin
- Ada.Text_IO.Put_Line ("Hello from hello_pkg.adb");
- end Say_Hello;
-end Hello_Pkg;
-@end example
-
-These are the same files from example 1; @file{hello_pkg.adb} has an
-error on line 2.
-
-In addition, create a directory @file{Example_4/Gnat_Project},
-containing these files:
-
-@file{Gnat_Project/hello_4.adb}:
-
-@example
-with Hello_Pkg;
-with Ada.Text_IO; use Ada.Text_IO;
-procedure Hello_4
-is begin
- Hello_Pkg.Say_Hello;
- Put_Line ("From hello_4");
-end Hello_4;
-@end example
-
-There are no errors in this file.
-
-@file{Gnat_Project/hello_4.gpr}:
-
-@example
-Project Hello_4 is
- for Source_Dirs use (".", "..");
-end Hello_4;
-@end example
-
-In buffer @file{hello_4.adb}, invoke @samp{Ada | Project | Load...}, and
-select @file{Example_4/Gnat_Project/hello_4.gpr}.
-
-Then, again in @file{hello_4.adb}, invoke @samp{Ada | Set main and
-Build}. You should get a @file{*compilation*} buffer containing
-something like (the directory paths will be different):
-
-@smallexample
-cd c:/Examples/Example_4/Gnat_Project/
-gnatmake -o hello_4 hello_4 -Phello_4.gpr -cargs -gnatq -gnatQ -bargs -largs
-gcc -c -g -gnatyt -gnatq -gnatQ -I- -gnatA c:\Examples\Example_4\Gnat_Project\hello_4.adb
-gcc -c -g -gnatyt -gnatq -gnatQ -I- -gnatA c:\Examples\Example_4\hello_pkg.adb
-hello_pkg.adb:2:08: keyword "body" expected here [see file name]
-gnatmake: "c:\examples\example_4\hello_pkg.adb" compilation error
-@end smallexample
-
-Compare the @code{gcc} options to the compiler output in @ref{Set
-compiler options}; this shows that @file{hello_4.gpr} is being used to
-set the compiler options.
-
-Fixing the error, linking and running the code proceed as in @ref{No
-project files}.
-
-@node Use multiple GNAT project files
-@section Use multiple GNAT project files
-
-In this example, we show how to use multiple GNAT project files,
-specifying the GNAT project search path in an Ada mode project file.
-
-Create the directory @file{Example_4} as specified in @ref{Use GNAT
-project file}.
-
-Create the directory @file{Example_5}, containing:
-
-@file{hello_5.adb}:
-
-@example
-with Hello_Pkg;
-with Ada.Text_IO; use Ada.Text_IO;
-procedure Hello_5
-is begin
- Hello_Pkg.Say_Hello;
- Put_Line ("From hello_5");
-end Hello_5;
-@end example
-
-There are no errors in this file.
-
-@file{hello_5.adp}:
-
-@example
-ada_project_path=../Example_4/Gnat_Project
-gpr_file=hello_5.gpr
-@end example
-
-@file{hello_5.gpr}:
-
-@example
-with "hello_4";
-Project Hello_5 is
- for Source_Dirs use (".");
- package Compiler is
- for Default_Switches ("Ada") use ("-g", "-gnatyt");
- end Compiler;
-end Hello_5;
-@end example
-
-In buffer @file{hello_5.adb}, invoke @samp{Ada | Project | Load...}, and
-select @file{Example_5/hello_5.adp}.
-
-Then, again in @file{hello_5.adb}, invoke @samp{Ada | Set main and
-Build}. You should get a @file{*compilation*} buffer containing
-something like (the directory paths will be different):
-
-@smallexample
-cd c:/Examples/Example_5/
-gnatmake -o hello_5 hello_5 -Phello_5.gpr -g -cargs -gnatq -gnatQ -bargs -largs
-gcc -c -g -gnatyt -g -gnatq -gnatQ -I- -gnatA c:\Examples\Example_5\hello_5.adb
-gcc -c -g -gnatyt -g -gnatq -gnatQ -I- -gnatA c:\Examples\Example_4\hello_pkg.adb
-hello_pkg.adb:2:08: keyword "body" expected here [see file name]
-gnatmake: "c:\examples\example_4\hello_pkg.adb" compilation error
-@end smallexample
-
-Now type @kbd{C-x `}. @file{Example_4/hello_pkg.adb} is shown,
-demonstrating that @file{hello_5.gpr} and @file{hello_4.gpr} are being
-used to set the compilation search path.
-
-@node Moving Through Ada Code
-@chapter Moving Through Ada Code
-
-There are several easy to use commands to navigate through Ada code. All
-these functions are available through the Ada menu, and you can also
-use the following key bindings or the command names. Some of these
-menu entries are available only if the GNAT compiler is used, since
-the implementation relies on the GNAT cross-referencing information.
-
-@table @kbd
-@item M-C-e
-@findex ada-next-procedure
-Move to the next function/procedure/task, which ever comes next
-(@code{ada-next-procedure}).
-@item M-C-a
-@findex ada-previous-procedure
-Move to previous function/procedure/task
-(@code{ada-previous-procedure}).
-@item M-x ada-next-package
-@findex ada-next-package
-Move to next package.
-@item M-x ada-previous-package
-@findex ada-previous-package
-Move to previous package.
-@item C-c C-a
-@findex ada-move-to-start
-Move to matching start of @code{end} (@code{ada-move-to-start}). If
-point is at the end of a subprogram, this command jumps to the
-corresponding @code{begin} if the user option
-@code{ada-move-to-declaration} is @code{nil} (default), otherwise it jumps to
-the subprogram declaration.
-@item C-c C-e
-@findex ada-move-to-end
-Move point to end of current block (@code{ada-move-to-end}).
-@item C-c o
-Switch between corresponding spec and body file
-(@code{ff-find-other-file}). If point is in a subprogram, position
-point on the corresponding declaration or body in the other file.
-@item C-c c-d
-@findex ada-goto-declaration
-Move from any reference to its declaration, for from a declaration to
-its body (for procedures, tasks, private and incomplete types).
-@item C-c C-r
-@findex ada-find-references
-Runs the @file{gnatfind} command to search for all references to the
-identifier surrounding point (@code{ada-find-references}). Use
-@kbd{C-x `} (@code{next-error}) to visit each reference (as for
-compilation errors).
-@end table
-
-If the @code{ada-xref-create-ali} variable is non-@code{nil}, Emacs
-will try to run GNAT for you whenever cross-reference information is
-needed, and is older than the current source file.
-
-@node Identifier completion
-@chapter Identifier completion
-
-Emacs and Ada mode provide two general ways for the completion of
-identifiers. This is an easy way to type faster: you just have to type
-the first few letters of an identifiers, and then loop through all the
-possible completions.
-
-The first method is general for Emacs. It works by parsing all open
-files for possible completions.
-
-For instance, if the words @samp{my_identifier}, @samp{my_subprogram}
-are the only words starting with @samp{my} in any of the opened files,
-then you will have this scenario:
-
-@example
-You type: my@kbd{M-/}
-Emacs inserts: @samp{my_identifier}
-If you press @kbd{M-/} once again, Emacs replaces @samp{my_identifier} with
-@samp{my_subprogram}.
-Pressing @kbd{M-/} once more will bring you back to @samp{my_identifier}.
-@end example
-
-This is a very fast way to do completion, and the casing of words will
-also be respected.
-
-The second method (@kbd{C-@key{TAB}}) is specific to Ada mode and the GNAT
-compiler. Emacs will search the cross-information for possible
-completions.
-
-The main advantage is that this completion is more accurate: only
-existing identifier will be suggested.
-
-On the other hand, this completion is a little bit slower and requires
-that you have compiled your file at least once since you created that
-identifier.
-
-@table @kbd
-@item C-@key{TAB}
-@findex ada-complete-identifier
-Complete current identifier using cross-reference information.
-@item M-/
-Complete identifier using buffer information (not Ada-specific).
-@end table
-
-@node Automatic Smart Indentation
-@chapter Automatic Smart Indentation
-
-Ada mode comes with a full set of rules for automatic indentation. You
-can also configure the indentation, via the following variables:
-
-@table @asis
-@item @code{ada-broken-indent} (default value: 2)
-Number of columns to indent the continuation of a broken line.
-
-@item @code{ada-indent} (default value: 3)
-Number of columns for default indentation.
-
-@item @code{ada-indent-record-rel-type} (default value: 3)
-Indentation for @code{record} relative to @code{type} or @code{use}.
-
-@item @code{ada-indent-return} (default value: 0)
-Indentation for @code{return} relative to @code{function} (if
-@code{ada-indent-return} is greater than 0), or the open parenthesis
-(if @code{ada-indent-return} is negative or 0). Note that in the second
-case, when there is no open parenthesis, the indentation is done
-relative to @code{function} with the value of @code{ada-broken-indent}.
-
-@item @code{ada-label-indent} (default value: -4)
-Number of columns to indent a label.
-
-@item @code{ada-stmt-end-indent} (default value: 0)
-Number of columns to indent a statement @code{end} keyword on a separate line.
-
-@item @code{ada-when-indent} (default value: 3)
-Indentation for @code{when} relative to @code{exception} or @code{case}.
-
-@item @code{ada-indent-is-separate} (default value: t)
-Non-@code{nil} means indent @code{is separate} or @code{is abstract} if on a single line.
-
-@item @code{ada-indent-to-open-paren} (default value: t)
-Non-@code{nil} means indent according to the innermost open parenthesis.
-
-@item @code{ada-indent-after-return} (default value: t)
-Non-@code{nil} means that the current line will also be re-indented
-before inserting a newline, when you press @key{RET}.
-@end table
-
-Most of the time, the indentation will be automatic, i.e., when you
-press @key{RET}, the cursor will move to the correct column on the
-next line.
-
-You can also indent single lines, or the current region, with @key{TAB}.
-
-Another mode of indentation exists that helps you to set up your
-indentation scheme. If you press @kbd{C-c @key{TAB}}, Ada mode will do
-the following:
-
-@itemize @bullet
-@item
-Reindent the current line, as @key{TAB} would do.
-@item
-Temporarily move the cursor to a reference line, i.e., the line that
-was used to calculate the current indentation.
-@item
-Display in the message window the name of the variable that provided
-the offset for the indentation.
-@end itemize
-
-The exact indentation of the current line is the same as the one for the
-reference line, plus an offset given by the variable.
-
-@table @kbd
-@item @key{TAB}
-Indent the current line or the current region.
-@item C-M-\
-Indent lines in the current region.
-@item C-c @key{TAB}
-Indent the current line and display the name of the variable used for
-indentation.
-@end table
-
-@node Formatting Parameter Lists
-@chapter Formatting Parameter Lists
-
-@table @kbd
-@item C-c C-f
-@findex ada-format-paramlist
-Format the parameter list (@code{ada-format-paramlist}).
-@end table
-
-This aligns the declarations on the colon (@samp{:}) separating
-argument names and argument types, and aligns the @code{in},
-@code{out} and @code{in out} keywords.
-
-@node Automatic Casing
-@chapter Automatic Casing
-
-Casing of identifiers, attributes and keywords is automatically
-performed while typing when the variable @code{ada-auto-case} is set.
-Every time you press a word separator, the previous word is
-automatically cased.
-
-You can customize the automatic casing differently for keywords,
-attributes and identifiers. The relevant variables are the following:
-@code{ada-case-keyword}, @code{ada-case-attribute} and
-@code{ada-case-identifier}.
-
-All these variables can have one of the following values:
-
-@table @code
-@item downcase-word
-The word will be lowercase. For instance @code{My_vARIable} is
-converted to @code{my_variable}.
-
-@item upcase-word
-The word will be uppercase. For instance @code{My_vARIable} is
-converted to @code{MY_VARIABLE}.
-
-@item ada-capitalize-word
-The first letter and each letter following an underscore (@samp{_})
-are uppercase, others are lowercase. For instance @code{My_vARIable}
-is converted to @code{My_Variable}.
-
-@item ada-loose-case-word
-Characters after an underscore @samp{_} character are uppercase,
-others are not modified. For instance @code{My_vARIable} is converted
-to @code{My_VARIable}.
-@end table
-
-Ada mode allows you to define exceptions to these rules, in a file
-specified by the variable @code{ada-case-exception-file}
-(default @file{~/.emacs_case_exceptions}). Each line in this file
-specifies the casing of one word or word fragment. Comments may be
-included, separated from the word by a space.
-
-If the word starts with an asterisk (@samp{*}), it defines the casing
-as a word fragment (or ``substring''); part of a word between two
-underscores or word boundary.
-
-For example:
-
-@example
-DOD Department of Defense
-*IO
-GNAT The GNAT compiler from Ada Core Technologies
-@end example
-
-The word fragment @code{*IO} applies to any word containing ``_io'';
-@code{Text_IO}, @code{Hardware_IO}, etc.
-
-@findex ada-create-case-exception
-There are two ways to add new items to this file: you can simply edit
-it as you would edit any text file. Or you can position point on the
-word you want to add, and select menu @samp{Ada | Edit | Create Case
-Exception}, or press @kbd{C-c C-y} (@code{ada-create-case-exception}).
-The word will automatically be added to the current list of exceptions
-and to the file.
-
-To define a word fragment case exception, select the word fragment,
-then select menu @samp{Ada | Edit | Create Case Exception Substring}.
-
-It is sometimes useful to have multiple exception files around (for
-instance, one could be the standard Ada acronyms, the second some
-company specific exceptions, and the last one some project specific
-exceptions). If you set up the variable @code{ada-case-exception-file}
-as a list of files, each of them will be parsed and used in your emacs
-session. However, when you save a new exception through the menu, as
-described above, the new exception will be added to the first file in
-the list.
-
-@table @kbd
-@item C-c C-b
-@findex ada-adjust-case-buffer
-Adjust case in the whole buffer (@code{ada-adjust-case-buffer}).
-@item C-c C-y
-Create a new entry in the exception dictionary, with the word under
-the cursor (@code{ada-create-case-exception})
-@item C-c C-t
-@findex ada-case-read-exceptions
-Rereads the exception dictionary from the file
-@code{ada-case-exception-file} (@code{ada-case-read-exceptions}).
-@end table
-
-@node Statement Templates
-@chapter Statement Templates
-
-Templates are defined for most Ada statements, using the Emacs
-``skeleton'' package. They can be inserted in the buffer using the
-following commands:
-
-@table @kbd
-@item C-c t b
-@findex ada-exception-block
-exception Block (@code{ada-exception-block}).
-@item C-c t c
-@findex ada-case
-case (@code{ada-case}).
-@item C-c t d
-@findex ada-declare-block
-declare Block (@code{ada-declare-block}).
-@item C-c t e
-@findex ada-else
-else (@code{ada-else}).
-@item C-c t f
-@findex ada-for-loop
-for Loop (@code{ada-for-loop}).
-@item C-c t h
-@findex ada-header
-Header (@code{ada-header}).
-@item C-c t i
-@findex ada-if
-if (@code{ada-if}).
-@item C-c t k
-@findex ada-package-body
-package Body (@code{ada-package-body}).
-@item C-c t l
-@findex ada-loop
-loop (@code{ada-loop}).
-@item C-c p
-@findex ada-subprogram-body
-subprogram body (@code{ada-subprogram-body}).
-@item C-c t t
-@findex ada-task-body
-task Body (@code{ada-task-body}).
-@item C-c t w
-@findex ada-while
-while Loop (@code{ada-while}).
-@item C-c t u
-@findex ada-use
-use (@code{ada-use}).
-@item C-c t x
-@findex ada-exit
-exit (@code{ada-exit}).
-@item C-c t C-a
-@findex ada-array
-array (@code{ada-array}).
-@item C-c t C-e
-@findex ada-elsif
-elsif (@code{ada-elsif}).
-@item C-c t C-f
-@findex ada-function-spec
-function Spec (@code{ada-function-spec}).
-@item C-c t C-k
-@findex ada-package-spec
-package Spec (@code{ada-package-spec}).
-@item C-c t C-p
-@findex ada-procedure-spec
-procedure Spec (@code{ada-package-spec}.
-@item C-c t C-r
-@findex ada-record
-record (@code{ada-record}).
-@item C-c t C-s
-@findex ada-subtype
-subtype (@code{ada-subtype}).
-@item C-c t C-t
-@findex ada-task-spec
-task Spec (@code{ada-task-spec}).
-@item C-c t C-u
-@findex ada-with
-with (@code{ada-with}).
-@item C-c t C-v
-@findex ada-private
-private (@code{ada-private}).
-@item C-c t C-w
-@findex ada-when
-when (@code{ada-when}).
-@item C-c t C-x
-@findex ada-exception
-exception (@code{ada-exception}).
-@item C-c t C-y
-@findex ada-type
-type (@code{ada-type}).
-@end table
-
-@node Comment Handling
-@chapter Comment Handling
-
-By default, comment lines get indented like Ada code. There are a few
-additional functions to handle comments:
-
-@table @kbd
-@item M-;
-Start a comment in default column.
-@item M-j
-Continue comment on next line.
-@item C-c ;
-Comment the selected region (add @samp{--} at the beginning of lines).
-@item C-c :
-Uncomment the selected region
-@item M-q
-autofill the current comment.
-@end table
-
-@node GNU Free Documentation License
-@appendix GNU Free Documentation License
-@include doclicense.texi
-
-@node Index
-@unnumbered Index
-
-@printindex fn
-
-@bye
diff --git a/old_ada/doc/build.sh b/old_ada/doc/build.sh
deleted file mode 100755
index a0799fe..0000000
--- a/old_ada/doc/build.sh
+++ /dev/null
@@ -1,3 +0,0 @@
-#! /usr/bin/env bash
-texi2any -o ada-mode.info --no-split ada-mode.texi
-texi2any --html -o ada-mode.html --no-split ada-mode.texi
diff --git a/old_ada/doc/clean.sh b/old_ada/doc/clean.sh
deleted file mode 100755
index f7e90b1..0000000
--- a/old_ada/doc/clean.sh
+++ /dev/null
@@ -1,2 +0,0 @@
-#! /bin/sh
-rm ada-mode.aux ada-mode.fn ada-mode.log ada-mode.toc
diff --git a/old_ada/doc/doclicense.texi b/old_ada/doc/doclicense.texi
deleted file mode 100644
index eaf3da0..0000000
--- a/old_ada/doc/doclicense.texi
+++ /dev/null
@@ -1,505 +0,0 @@
-@c The GNU Free Documentation License.
-@center Version 1.3, 3 November 2008
-
-@c This file is intended to be included within another document,
-@c hence no sectioning command or @node.
-
-@display
-Copyright @copyright{} 2000, 2001, 2002, 2007, 2008 Free Software Foundation, Inc.
-@uref{https://fsf.org/}
-
-Everyone is permitted to copy and distribute verbatim copies
-of this license document, but changing it is not allowed.
-@end display
-
-@enumerate 0
-@item
-PREAMBLE
-
-The purpose of this License is to make a manual, textbook, or other
-functional and useful document @dfn{free} in the sense of freedom: to
-assure everyone the effective freedom to copy and redistribute it,
-with or without modifying it, either commercially or noncommercially.
-Secondarily, this License preserves for the author and publisher a way
-to get credit for their work, while not being considered responsible
-for modifications made by others.
-
-This License is a kind of ``copyleft'', which means that derivative
-works of the document must themselves be free in the same sense. It
-complements the GNU General Public License, which is a copyleft
-license designed for free software.
-
-We have designed this License in order to use it for manuals for free
-software, because free software needs free documentation: a free
-program should come with manuals providing the same freedoms that the
-software does. But this License is not limited to software manuals;
-it can be used for any textual work, regardless of subject matter or
-whether it is published as a printed book. We recommend this License
-principally for works whose purpose is instruction or reference.
-
-@item
-APPLICABILITY AND DEFINITIONS
-
-This License applies to any manual or other work, in any medium, that
-contains a notice placed by the copyright holder saying it can be
-distributed under the terms of this License. Such a notice grants a
-world-wide, royalty-free license, unlimited in duration, to use that
-work under the conditions stated herein. The ``Document'', below,
-refers to any such manual or work. Any member of the public is a
-licensee, and is addressed as ``you''. You accept the license if you
-copy, modify or distribute the work in a way requiring permission
-under copyright law.
-
-A ``Modified Version'' of the Document means any work containing the
-Document or a portion of it, either copied verbatim, or with
-modifications and/or translated into another language.
-
-A ``Secondary Section'' is a named appendix or a front-matter section
-of the Document that deals exclusively with the relationship of the
-publishers or authors of the Document to the Document's overall
-subject (or to related matters) and contains nothing that could fall
-directly within that overall subject. (Thus, if the Document is in
-part a textbook of mathematics, a Secondary Section may not explain
-any mathematics.) The relationship could be a matter of historical
-connection with the subject or with related matters, or of legal,
-commercial, philosophical, ethical or political position regarding
-them.
-
-The ``Invariant Sections'' are certain Secondary Sections whose titles
-are designated, as being those of Invariant Sections, in the notice
-that says that the Document is released under this License. If a
-section does not fit the above definition of Secondary then it is not
-allowed to be designated as Invariant. The Document may contain zero
-Invariant Sections. If the Document does not identify any Invariant
-Sections then there are none.
-
-The ``Cover Texts'' are certain short passages of text that are listed,
-as Front-Cover Texts or Back-Cover Texts, in the notice that says that
-the Document is released under this License. A Front-Cover Text may
-be at most 5 words, and a Back-Cover Text may be at most 25 words.
-
-A ``Transparent'' copy of the Document means a machine-readable copy,
-represented in a format whose specification is available to the
-general public, that is suitable for revising the document
-straightforwardly with generic text editors or (for images composed of
-pixels) generic paint programs or (for drawings) some widely available
-drawing editor, and that is suitable for input to text formatters or
-for automatic translation to a variety of formats suitable for input
-to text formatters. A copy made in an otherwise Transparent file
-format whose markup, or absence of markup, has been arranged to thwart
-or discourage subsequent modification by readers is not Transparent.
-An image format is not Transparent if used for any substantial amount
-of text. A copy that is not ``Transparent'' is called ``Opaque''.
-
-Examples of suitable formats for Transparent copies include plain
-ASCII without markup, Texinfo input format, La@TeX{} input
-format, SGML or XML using a publicly available
-DTD, and standard-conforming simple HTML,
-PostScript or PDF designed for human modification. Examples
-of transparent image formats include PNG, XCF and
-JPG@. Opaque formats include proprietary formats that can be
-read and edited only by proprietary word processors, SGML or
-XML for which the DTD and/or processing tools are
-not generally available, and the machine-generated HTML,
-PostScript or PDF produced by some word processors for
-output purposes only.
-
-The ``Title Page'' means, for a printed book, the title page itself,
-plus such following pages as are needed to hold, legibly, the material
-this License requires to appear in the title page. For works in
-formats which do not have any title page as such, ``Title Page'' means
-the text near the most prominent appearance of the work's title,
-preceding the beginning of the body of the text.
-
-The ``publisher'' means any person or entity that distributes copies
-of the Document to the public.
-
-A section ``Entitled XYZ'' means a named subunit of the Document whose
-title either is precisely XYZ or contains XYZ in parentheses following
-text that translates XYZ in another language. (Here XYZ stands for a
-specific section name mentioned below, such as ``Acknowledgements'',
-``Dedications'', ``Endorsements'', or ``History''.) To ``Preserve the Title''
-of such a section when you modify the Document means that it remains a
-section ``Entitled XYZ'' according to this definition.
-
-The Document may include Warranty Disclaimers next to the notice which
-states that this License applies to the Document. These Warranty
-Disclaimers are considered to be included by reference in this
-License, but only as regards disclaiming warranties: any other
-implication that these Warranty Disclaimers may have is void and has
-no effect on the meaning of this License.
-
-@item
-VERBATIM COPYING
-
-You may copy and distribute the Document in any medium, either
-commercially or noncommercially, provided that this License, the
-copyright notices, and the license notice saying this License applies
-to the Document are reproduced in all copies, and that you add no other
-conditions whatsoever to those of this License. You may not use
-technical measures to obstruct or control the reading or further
-copying of the copies you make or distribute. However, you may accept
-compensation in exchange for copies. If you distribute a large enough
-number of copies you must also follow the conditions in section 3.
-
-You may also lend copies, under the same conditions stated above, and
-you may publicly display copies.
-
-@item
-COPYING IN QUANTITY
-
-If you publish printed copies (or copies in media that commonly have
-printed covers) of the Document, numbering more than 100, and the
-Document's license notice requires Cover Texts, you must enclose the
-copies in covers that carry, clearly and legibly, all these Cover
-Texts: Front-Cover Texts on the front cover, and Back-Cover Texts on
-the back cover. Both covers must also clearly and legibly identify
-you as the publisher of these copies. The front cover must present
-the full title with all words of the title equally prominent and
-visible. You may add other material on the covers in addition.
-Copying with changes limited to the covers, as long as they preserve
-the title of the Document and satisfy these conditions, can be treated
-as verbatim copying in other respects.
-
-If the required texts for either cover are too voluminous to fit
-legibly, you should put the first ones listed (as many as fit
-reasonably) on the actual cover, and continue the rest onto adjacent
-pages.
-
-If you publish or distribute Opaque copies of the Document numbering
-more than 100, you must either include a machine-readable Transparent
-copy along with each Opaque copy, or state in or with each Opaque copy
-a computer-network location from which the general network-using
-public has access to download using public-standard network protocols
-a complete Transparent copy of the Document, free of added material.
-If you use the latter option, you must take reasonably prudent steps,
-when you begin distribution of Opaque copies in quantity, to ensure
-that this Transparent copy will remain thus accessible at the stated
-location until at least one year after the last time you distribute an
-Opaque copy (directly or through your agents or retailers) of that
-edition to the public.
-
-It is requested, but not required, that you contact the authors of the
-Document well before redistributing any large number of copies, to give
-them a chance to provide you with an updated version of the Document.
-
-@item
-MODIFICATIONS
-
-You may copy and distribute a Modified Version of the Document under
-the conditions of sections 2 and 3 above, provided that you release
-the Modified Version under precisely this License, with the Modified
-Version filling the role of the Document, thus licensing distribution
-and modification of the Modified Version to whoever possesses a copy
-of it. In addition, you must do these things in the Modified Version:
-
-@enumerate A
-@item
-Use in the Title Page (and on the covers, if any) a title distinct
-from that of the Document, and from those of previous versions
-(which should, if there were any, be listed in the History section
-of the Document). You may use the same title as a previous version
-if the original publisher of that version gives permission.
-
-@item
-List on the Title Page, as authors, one or more persons or entities
-responsible for authorship of the modifications in the Modified
-Version, together with at least five of the principal authors of the
-Document (all of its principal authors, if it has fewer than five),
-unless they release you from this requirement.
-
-@item
-State on the Title page the name of the publisher of the
-Modified Version, as the publisher.
-
-@item
-Preserve all the copyright notices of the Document.
-
-@item
-Add an appropriate copyright notice for your modifications
-adjacent to the other copyright notices.
-
-@item
-Include, immediately after the copyright notices, a license notice
-giving the public permission to use the Modified Version under the
-terms of this License, in the form shown in the Addendum below.
-
-@item
-Preserve in that license notice the full lists of Invariant Sections
-and required Cover Texts given in the Document's license notice.
-
-@item
-Include an unaltered copy of this License.
-
-@item
-Preserve the section Entitled ``History'', Preserve its Title, and add
-to it an item stating at least the title, year, new authors, and
-publisher of the Modified Version as given on the Title Page. If
-there is no section Entitled ``History'' in the Document, create one
-stating the title, year, authors, and publisher of the Document as
-given on its Title Page, then add an item describing the Modified
-Version as stated in the previous sentence.
-
-@item
-Preserve the network location, if any, given in the Document for
-public access to a Transparent copy of the Document, and likewise
-the network locations given in the Document for previous versions
-it was based on. These may be placed in the ``History'' section.
-You may omit a network location for a work that was published at
-least four years before the Document itself, or if the original
-publisher of the version it refers to gives permission.
-
-@item
-For any section Entitled ``Acknowledgements'' or ``Dedications'', Preserve
-the Title of the section, and preserve in the section all the
-substance and tone of each of the contributor acknowledgements and/or
-dedications given therein.
-
-@item
-Preserve all the Invariant Sections of the Document,
-unaltered in their text and in their titles. Section numbers
-or the equivalent are not considered part of the section titles.
-
-@item
-Delete any section Entitled ``Endorsements''. Such a section
-may not be included in the Modified Version.
-
-@item
-Do not retitle any existing section to be Entitled ``Endorsements'' or
-to conflict in title with any Invariant Section.
-
-@item
-Preserve any Warranty Disclaimers.
-@end enumerate
-
-If the Modified Version includes new front-matter sections or
-appendices that qualify as Secondary Sections and contain no material
-copied from the Document, you may at your option designate some or all
-of these sections as invariant. To do this, add their titles to the
-list of Invariant Sections in the Modified Version's license notice.
-These titles must be distinct from any other section titles.
-
-You may add a section Entitled ``Endorsements'', provided it contains
-nothing but endorsements of your Modified Version by various
-parties---for example, statements of peer review or that the text has
-been approved by an organization as the authoritative definition of a
-standard.
-
-You may add a passage of up to five words as a Front-Cover Text, and a
-passage of up to 25 words as a Back-Cover Text, to the end of the list
-of Cover Texts in the Modified Version. Only one passage of
-Front-Cover Text and one of Back-Cover Text may be added by (or
-through arrangements made by) any one entity. If the Document already
-includes a cover text for the same cover, previously added by you or
-by arrangement made by the same entity you are acting on behalf of,
-you may not add another; but you may replace the old one, on explicit
-permission from the previous publisher that added the old one.
-
-The author(s) and publisher(s) of the Document do not by this License
-give permission to use their names for publicity for or to assert or
-imply endorsement of any Modified Version.
-
-@item
-COMBINING DOCUMENTS
-
-You may combine the Document with other documents released under this
-License, under the terms defined in section 4 above for modified
-versions, provided that you include in the combination all of the
-Invariant Sections of all of the original documents, unmodified, and
-list them all as Invariant Sections of your combined work in its
-license notice, and that you preserve all their Warranty Disclaimers.
-
-The combined work need only contain one copy of this License, and
-multiple identical Invariant Sections may be replaced with a single
-copy. If there are multiple Invariant Sections with the same name but
-different contents, make the title of each such section unique by
-adding at the end of it, in parentheses, the name of the original
-author or publisher of that section if known, or else a unique number.
-Make the same adjustment to the section titles in the list of
-Invariant Sections in the license notice of the combined work.
-
-In the combination, you must combine any sections Entitled ``History''
-in the various original documents, forming one section Entitled
-``History''; likewise combine any sections Entitled ``Acknowledgements'',
-and any sections Entitled ``Dedications''. You must delete all
-sections Entitled ``Endorsements.''
-
-@item
-COLLECTIONS OF DOCUMENTS
-
-You may make a collection consisting of the Document and other documents
-released under this License, and replace the individual copies of this
-License in the various documents with a single copy that is included in
-the collection, provided that you follow the rules of this License for
-verbatim copying of each of the documents in all other respects.
-
-You may extract a single document from such a collection, and distribute
-it individually under this License, provided you insert a copy of this
-License into the extracted document, and follow this License in all
-other respects regarding verbatim copying of that document.
-
-@item
-AGGREGATION WITH INDEPENDENT WORKS
-
-A compilation of the Document or its derivatives with other separate
-and independent documents or works, in or on a volume of a storage or
-distribution medium, is called an ``aggregate'' if the copyright
-resulting from the compilation is not used to limit the legal rights
-of the compilation's users beyond what the individual works permit.
-When the Document is included in an aggregate, this License does not
-apply to the other works in the aggregate which are not themselves
-derivative works of the Document.
-
-If the Cover Text requirement of section 3 is applicable to these
-copies of the Document, then if the Document is less than one half of
-the entire aggregate, the Document's Cover Texts may be placed on
-covers that bracket the Document within the aggregate, or the
-electronic equivalent of covers if the Document is in electronic form.
-Otherwise they must appear on printed covers that bracket the whole
-aggregate.
-
-@item
-TRANSLATION
-
-Translation is considered a kind of modification, so you may
-distribute translations of the Document under the terms of section 4.
-Replacing Invariant Sections with translations requires special
-permission from their copyright holders, but you may include
-translations of some or all Invariant Sections in addition to the
-original versions of these Invariant Sections. You may include a
-translation of this License, and all the license notices in the
-Document, and any Warranty Disclaimers, provided that you also include
-the original English version of this License and the original versions
-of those notices and disclaimers. In case of a disagreement between
-the translation and the original version of this License or a notice
-or disclaimer, the original version will prevail.
-
-If a section in the Document is Entitled ``Acknowledgements'',
-``Dedications'', or ``History'', the requirement (section 4) to Preserve
-its Title (section 1) will typically require changing the actual
-title.
-
-@item
-TERMINATION
-
-You may not copy, modify, sublicense, or distribute the Document
-except as expressly provided under this License. Any attempt
-otherwise to copy, modify, sublicense, or distribute it is void, and
-will automatically terminate your rights under this License.
-
-However, if you cease all violation of this License, then your license
-from a particular copyright holder is reinstated (a) provisionally,
-unless and until the copyright holder explicitly and finally
-terminates your license, and (b) permanently, if the copyright holder
-fails to notify you of the violation by some reasonable means prior to
-60 days after the cessation.
-
-Moreover, your license from a particular copyright holder is
-reinstated permanently if the copyright holder notifies you of the
-violation by some reasonable means, this is the first time you have
-received notice of violation of this License (for any work) from that
-copyright holder, and you cure the violation prior to 30 days after
-your receipt of the notice.
-
-Termination of your rights under this section does not terminate the
-licenses of parties who have received copies or rights from you under
-this License. If your rights have been terminated and not permanently
-reinstated, receipt of a copy of some or all of the same material does
-not give you any rights to use it.
-
-@item
-FUTURE REVISIONS OF THIS LICENSE
-
-The Free Software Foundation may publish new, revised versions
-of the GNU Free Documentation License from time to time. Such new
-versions will be similar in spirit to the present version, but may
-differ in detail to address new problems or concerns. See
-@uref{https://www.gnu.org/licenses/}.
-
-Each version of the License is given a distinguishing version number.
-If the Document specifies that a particular numbered version of this
-License ``or any later version'' applies to it, you have the option of
-following the terms and conditions either of that specified version or
-of any later version that has been published (not as a draft) by the
-Free Software Foundation. If the Document does not specify a version
-number of this License, you may choose any version ever published (not
-as a draft) by the Free Software Foundation. If the Document
-specifies that a proxy can decide which future versions of this
-License can be used, that proxy's public statement of acceptance of a
-version permanently authorizes you to choose that version for the
-Document.
-
-@item
-RELICENSING
-
-``Massive Multiauthor Collaboration Site'' (or ``MMC Site'') means any
-World Wide Web server that publishes copyrightable works and also
-provides prominent facilities for anybody to edit those works. A
-public wiki that anybody can edit is an example of such a server. A
-``Massive Multiauthor Collaboration'' (or ``MMC'') contained in the
-site means any set of copyrightable works thus published on the MMC
-site.
-
-``CC-BY-SA'' means the Creative Commons Attribution-Share Alike 3.0
-license published by Creative Commons Corporation, a not-for-profit
-corporation with a principal place of business in San Francisco,
-California, as well as future copyleft versions of that license
-published by that same organization.
-
-``Incorporate'' means to publish or republish a Document, in whole or
-in part, as part of another Document.
-
-An MMC is ``eligible for relicensing'' if it is licensed under this
-License, and if all works that were first published under this License
-somewhere other than this MMC, and subsequently incorporated in whole
-or in part into the MMC, (1) had no cover texts or invariant sections,
-and (2) were thus incorporated prior to November 1, 2008.
-
-The operator of an MMC Site may republish an MMC contained in the site
-under CC-BY-SA on the same site at any time before August 1, 2009,
-provided the MMC is eligible for relicensing.
-
-@end enumerate
-
-@page
-@heading ADDENDUM: How to use this License for your documents
-
-To use this License in a document you have written, include a copy of
-the License in the document and put the following copyright and
-license notices just after the title page:
-
-@smallexample
-@group
- Copyright (C) @var{year} @var{your name}.
- Permission is granted to copy, distribute and/or modify this document
- under the terms of the GNU Free Documentation License, Version 1.3
- or any later version published by the Free Software Foundation;
- with no Invariant Sections, no Front-Cover Texts, and no Back-Cover
- Texts. A copy of the license is included in the section entitled ``GNU
- Free Documentation License''.
-@end group
-@end smallexample
-
-If you have Invariant Sections, Front-Cover Texts and Back-Cover Texts,
-replace the ``with@dots{}Texts.''@: line with this:
-
-@smallexample
-@group
- with the Invariant Sections being @var{list their titles}, with
- the Front-Cover Texts being @var{list}, and with the Back-Cover Texts
- being @var{list}.
-@end group
-@end smallexample
-
-If you have Invariant Sections without Cover Texts, or some other
-combination of the three, merge those two alternatives to suit the
-situation.
-
-If your document contains nontrivial examples of program code, we
-recommend releasing these examples in parallel under your choice of
-free software license, such as the GNU General Public License,
-to permit their use in free software.
-
-@c Local Variables:
-@c ispell-local-pdict: "ispell-dict"
-@c End:
diff --git a/old_ada/doc/docstyle.texi b/old_ada/doc/docstyle.texi
deleted file mode 100644
index e740439..0000000
--- a/old_ada/doc/docstyle.texi
+++ /dev/null
@@ -1,19 +0,0 @@
-@c Emacs documentation style settings
-@documentencoding UTF-8
-@c These two require Texinfo 5.0 or later, so we use the older
-@c equivalent @set variables supported in 4.11 and hence
-@ignore
-@codequotebacktick on
-@codequoteundirected on
-@end ignore
-@set txicodequoteundirected
-@set txicodequotebacktick
-@iftex
-@c It turns out TeX sometimes fails to hyphenate, so we help it here
-@hyphenation{au-to-mat-i-cal-ly}
-@hyphenation{spec-i-fied}
-@hyphenation{work-a-round}
-@hyphenation{work-a-rounds}
-@hyphenation{un-marked}
-@hyphenation{dic-tion-ary}
-@end iftex