[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
gnatxref
and gnatfind
The compiler generates cross-referencing information (unless you set the `-gnatx' switch), which are saved in the `.ali' files. This information indicates where in the source each entity is declared and referenced.
Before using any of these two tools, you need to compile successfully your application, so that GNAT gets a chance to generate the cross-referencing information.
The two tools gnatxref
and gnatfind
take advantage of this
information to provide the user with the capability to easily locate the
declaration and references to an entity. These tools are quite similar,
the difference being that gnatfind
is intended for locating
definitions and/or references to a specified entity or entities, whereas
gnatxref
is oriented to generating a full report of all
cross-references.
To use these tools, you must not compile your application using the `-gnatx' switch on the `gnatmake' command line (See Info file `gnat_ug', node `The GNAT Make Program gnatmake'). Otherwise, cross-referencing information will not be generated.
10.1 Gnatxref switches 10.2 Gnatfind switches 10.3 Project files 10.4 Regular expressions in gnatfind and gnatxref 10.5 Examples of gnatxref
usage10.6 Examples of gnatfind
usage
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
The command lines for gnatxref
is:
$ gnatxref [switches] sourcefile1 [sourcefile2 ...] |
where
sourcefile1, sourcefile2
These file names are considered to be regular expressions, so for instance specifying 'source*.adb' is the same as giving every file in the current directory whose name starts with 'source' and whose extension is 'adb'.
The switches can be :
-a
gnatfind
and gnatxref
will parse
the read-only files found in the library search path. Otherwise, these files
will be ignored. This option can be used to protect Gnat sources or your own
libraries from being parsed, thus making gnatfind
and gnatxref
much faster, and their output much smaller.
-aIDIR
-aODIR
-f
-g
gnatfind
and gnatxref
.
-IDIR
-pFILE
gnatxref
and gnatfind
will try to locate a
project file in the current directory.
If a project file is either specified or found by the tools, then the content of the source directory and object directory lines are added as if they had been specified respectively by `-aI' and `-aO'.
-u
gnatxref
will then
display every unused entity and 'with'ed package.
-v
gnatxref
will generate a
`tags' file that can be used by vi. For examples how to use this
feature, see See section 10.5 Examples of gnatxref
usage. The tags file is output
to the standard output, thus you will have to redirect it to a file.
All these switches may be in any order on the command line, and may even appear after the file names. They need not be separated by spaces, thus you can say `gnatxref -ag' instead of `gnatxref -a -g'.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
The command line for gnatfind
is:
$ gnatfind [switches] pattern[:sourcefile[:line[:column]]] [file1 file2 ...] |
where
pattern
Omitting the pattern is equivalent to specifying `*', which will match any entity. Note that if you do not provide a pattern, you have to provide both a sourcefile and a line.
Entity names are given in Latin-1, with upper-lower case equivalence for matching purposes. At the current time there is no support for 8-bit codes other than Latin-1, or for wide characters in identifiers.
sourcefile
gnatfind
will look for references, bodies or declarations
of symbols referenced in `sourcefile', at line `line'
and column `column'. See see section 10.6 Examples of gnatfind
usage
for syntax examples.
line
column
file1 file2 ...
These file names are considered to be regular expressions, so for instance specifying 'source*.adb' is the same as giving every file in the current directory whose name starts with 'source' and whose extension is 'adb'.
Not that if you specify at least one file in this part, gnatfind
may
sometimes not be able to find the body of the subprograms...
At least one of 'sourcefile' or 'pattern' has to be present on the command line.
The following switches are available:
-a
gnatfind
and gnatxref
will parse
the read-only files found in the library search path. Otherwise, these files
will be ignored. This option can be used to protect Gnat sources or your own
libraries from being parsed, thus making gnatfind
and gnatxref
much faster, and their output much smaller.
-aIDIR
-aODIR
-e
gnatfind
accept the simple regular expression set for
`pattern'. If this switch is set, then the pattern will be
considered as full Unix-style regular expression.
-f
-g
gnatfind
and gnatxref
.
-IDIR
-pFILE
gnatxref
and gnatfind
will try to locate a
project file in the current directory.
If a project file is either specified or found by the tools, then the content of the source directory and object directory lines are added as if they had been specified respectively by `-aI' and `-aO'.
-r
gnatfind
will output only the information about the
declaration, body or type completion of the entities. If this switch is
set, the gnatfind
will locate every reference to the entities in
the files specified on the command line (or in every file in the search
path if no file is given on the command line).
-s
gnatfind
will output the content
of the Ada source file lines were the entity was found.
All these switches may be in any order on the command line, and may even appear after the file names. They need not be separated by spaces, thus you can say `gnatxref -ag' instead of `gnatxref -a -g'.
As stated previously, gnatfind will search in every directory in the
search path. You can force it to look only in the current directory if
you specify *
at the end of the command line.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
The project files allows a programmer to specify how to compile its
application, where to find sources,... These files are used primarily by
the Emacs Ada mode, but they can also be used by the two tools
gnatxref
and gnatfind
.
A project file name must end with `.adp'. If a single one is
present in the current directory, then gnatxref
and gnatfind
will
extract the information from it. If multiple project files are found, none of
them is read, and you have to use the `-p' switch to specify the one
you want to use.
The following lines can be included, even though most of them have default values which can be used in most cases. The lines can be entered in any order in the file. Except for `src_dir' and `obj_dir', you can only have one instance of each line. If you have multiple instances, only the last one is taken into account.
gnatxref
and gnatfind
only take into account the `src_dir'
and `obj_dir' lines, and ignore the others.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
As specified in the section about gnatfind
, the pattern can be a
regular expression. Actually, there are to set of regular expressions
which are recognized by the program :
Here is a more formal grammar :
regexp ::= term term ::= elmt -- matches elmt term ::= elmt elmt -- concatenation (elmt then elmt) term ::= * -- any string of 0 or more characters term ::= ? -- matches any character term ::= [char {char}] -- matches any character listed term ::= [char - char] -- matches any character in range |
The following is the form of a regular expression, expressed in Ada reference manual style BNF is as follows
regexp ::= term {| term} -- alternation (term or term ...) term ::= item {item} -- concatenation (item then item) item ::= elmt -- match elmt item ::= elmt * -- zero or more elmt's item ::= elmt + -- one or more elmt's item ::= elmt ? -- matches elmt or nothing elmt ::= nschar -- matches given character elmt ::= [nschar {nschar}] -- matches any character listed elmt ::= [^ nschar {nschar}] -- matches any character not listed elmt ::= [char - char] -- matches chars in given range elmt ::= \ char -- matches given character elmt ::= . -- matches any single character elmt ::= ( regexp ) -- parens used for grouping char ::= any character, including special characters nschar ::= any character except ()[].*+?^ |
Following are a few examples :
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
gnatxref
usage
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
For the following examples, we will consider the following units :
main.ads: 1: with Bar; 2: package Main is 3: procedure Foo (B : in Integer); 4: C : Integer; 5: private 6: D : Integer; 7: end Main; main.adb: 1: package body Main is 2: procedure Foo (B : in Integer) is 3: begin 4: C := B; 5: D := B; 6: Bar.Print (B); 7: Bar.Print (C); 8: end Foo; 9: end Main; bar.ads: 1: package Bar is 2: procedure Print (B : Integer); 3: end bar; |
gnatxref main.adb
gnatxref
generates cross-reference information for main.adb
and every unit 'with'ed by main.adb.
The output would be:
B Type: Integer Decl: bar.ads 2:22 B Type: Integer Decl: main.ads 3:20 Body: main.adb 2:20 Ref: main.adb 4:13 5:13 6:19 Bar Type: Unit Decl: bar.ads 1:9 Ref: main.adb 6:8 7:8 main.ads 1:6 C Type: Integer Decl: main.ads 4:5 Modi: main.adb 4:8 Ref: main.adb 7:19 D Type: Integer Decl: main.ads 6:5 Modi: main.adb 5:8 Foo Type: Unit Decl: main.ads 3:15 Body: main.adb 2:15 Main Type: Unit Decl: main.ads 2:9 Body: main.adb 1:14 Print Type: Unit Decl: bar.ads 2:15 Ref: main.adb 6:12 7:12 |
that is the entity Main
is declared in main.ads, line 2, column 9,
its body is in main.adb, line 1, column 14 and is not referenced any where.
The entity Print
is declared in bar.ads, line 2, column 15 and it
it referenced in main.adb, line 6 column 12 and line 7 column 12.
gnatxref package1.adb package2.ads
gnatxref
will generates cross-reference information for
package1.adb, package2.ads and any other package 'with'ed by any
of these.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
gnatxref
can generate a tags file output, which can be used
directly from `vi'. Note that the standard version of `vi'
will not work properly with overloaded symbols. Consider using another
free implementation of `vi', such as `vim'.
$ gnatxref -v gnatfind.adb > tags |
will generate the tags file for gnatfind
itself (if the sources
are in the search path!).
From `vi', you can then use the command `:tag entity' (replacing entity by whatever you are looking for), and vi will display a new file with the corresponding declaration of entity.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
gnatfind
usage
gnatfind -f xyz:main.adb
The directories will be printed as well (as the `-f' switch is set)
The output will look like:
directory/main.ads:106:14: xyz <= declaration directory/main.adb:24:10: xyz <= body directory/foo.ads:45:23: xyz <= declaration |
that is to say, one of the entities xyz found in main.adb is declared at line 12 of main.ads (and its body is in main.adb), and another one is declared at line 45 of foo.ads
gnatfind -fs xyz:main.adb
gnatfind
will
display the content of the Ada source file lines.
The output will look like:
directory/main.ads:106:14: xyz <= declaration procedure xyz; directory/main.adb:24:10: xyz <= body procedure xyz is directory/foo.ads:45:23: xyz <= declaration xyz : Integer; |
This can make it easier to find exactly the location your are looking for.
gnatfind -r "*x*":main.ads:123 foo.adb
gnatfind main.ads:123
This is the same as gnatfind "*":main.adb:123
.
gnatfind mydir/main.adb:123:45
The column has to be the beginning of the identifier, and should not point to any character in the middle of the identifier.
[ << ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |