File: arm_indx.ads

package info (click to toggle)
ada-reference-manual 1%3A2012.3-2
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 12,872 kB
  • sloc: ada: 29,393; makefile: 193; python: 92
file content (110 lines) | stat: -rwxr-xr-x 4,740 bytes parent folder | download | duplicates (7)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
with ARM_Output;
package ARM_Index is

    --
    -- Ada reference manual formatter (ARM_Form).
    --
    -- This package contains the routines to manage and generate the index.
    --
    -- ---------------------------------------
    -- Copyright 2000, 2005, 2006, 2011
    --   AXE Consultants. All rights reserved.
    -- P.O. Box 1512, Madison WI  53701
    -- E-Mail: randy@rrsoftware.com
    --
    -- ARM_Form is free software: you can redistribute it and/or modify
    -- it under the terms of the GNU General Public License version 3
    -- as published by the Free Software Foundation.
    --
    -- AXE CONSULTANTS MAKES THIS TOOL AND SOURCE CODE AVAILABLE ON AN "AS IS"
    -- BASIS AND MAKES NO WARRANTY, EXPRESS OR IMPLIED, AS TO THE ACCURACY,
    -- CAPABILITY, EFFICIENCY, MERCHANTABILITY, OR FUNCTIONING OF THIS TOOL.
    -- IN NO EVENT WILL AXE CONSULTANTS BE LIABLE FOR ANY GENERAL,
    -- CONSEQUENTIAL, INDIRECT, INCIDENTAL, EXEMPLARY, OR SPECIAL DAMAGES,
    -- EVEN IF AXE CONSULTANTS HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH
    -- DAMAGES.
    --
    -- A copy of the GNU General Public License is available in the file
    -- gpl-3-0.txt in the standard distribution of the ARM_Form tool.
    -- Otherwise, see <http://www.gnu.org/licenses/>.
    --
    -- If the GPLv3 license is not satisfactory for your needs, a commercial
    -- use license is available for this tool. Contact Randy at AXE Consultants
    -- for more information.
    --
    -- ---------------------------------------
    --
    -- Edit History:
    --
    --  5/28/00 - RLB - Created package.
    --  8/11/00 - RLB - Made Clean visible.
    -- 10/28/05 - RLB - Added key reuse.
    -- 10/30/05 - RLB - Added subtype declaration.
    --  2/17/06 - RLB - Added Remove_Soft_Hyphens flag to Clean (for output).
    -- 10/18/11 - RLB - Changed to GPLv3 license.

    Not_Valid_Error : exception;

    subtype Index_Key is Natural range 0 .. 20000;

    procedure Create;
	-- Initialize this package.

    procedure Destroy;
	-- Finalize this package; make sure the index is empty.

    type Index_Item_Kind_Type is (
	Primary_Term,			-- A primary index term.
	Partial_Term,			-- A partial index term.
	Primary_Term_and_Subterm,	-- A primary index term with a subterm.
	Partial_Term_with_Subterm,	-- A partial index term with a subterm.
	Syntax_NT_Used,			-- A non-terminal, with a subterm of "Used".
	Child_Unit_Parent,		-- A child unit, with a subterm of "child of <subterm>".
	Declaration_in_Package,		-- A declaration, with a subterm of "in <package>".
	SubDeclaration_in_Package,	-- A term, with a subterm of "<item> in <package>".
	Subtype_Declaration_in_Package,	-- A term (of the form "<item> subtype of <item2>, with a subterm of "in <package>".
	See_Term,			-- A "see <subterm>" with reference.
	See_Also_Term,			-- A "see also <subterm>" with reference.
	See_Other_Term,			-- A "see <subterm>" without reference.
	See_Also_Other_Term);		-- A "see also <subterm>" without reference.
	-- Note: These are declared in the sorting order.

    function Get_Key return Index_Key;
	-- Returns a Key value to refer to one or more index entries
	-- (for a single entity).

    procedure Add (Term  : in String;
		   Subterm : in String := "";
		   Kind : in Index_Item_Kind_Type := Primary_Term;
		   Clause : in String := "";
		   Paragraph : in String := "";
                   Key : out Index_Key);
	-- Add an index reference to the index. Returns a Key value to
	-- refer to this index entry.
	-- Raises Not_Valid_Error if Subterm, Clause, or Paragraph is not
	-- empty when the kind does not use it.

    procedure Add_Reusing_Key (Term  : in String;
			       Subterm : in String := "";
			       Kind : in Index_Item_Kind_Type := Primary_Term;
			       Clause : in String := "";
			       Paragraph : in String := "";
	                       Key : in Index_Key);
	-- Add an index reference to the index, (re)using the specified Key
	-- to refer to this index entry. Key must have previously
	-- returned by Add or Get_Key.
	-- Raises Not_Valid_Error if Subterm, Clause, or Paragraph is not
	-- empty when the kind does not use it.

    function Clean (Item : in String;
		    Remove_Soft_Hyphens : in Boolean) return String;
	-- Remove any commands from Item. (Except for soft hyphens
	-- if Remove_Soft_Hyphens is False.)

    procedure Generate_Index_Body (Output_Object : in out ARM_Output.Output_Type'Class;
				   Use_Paragraphs : in Boolean := True);
	-- Generate the index body. (The section header has already been
	-- generated). References include paragraph numbers if Use_Paragraphs
	-- is true.

end ARM_Index;