OpenCores
URL https://opencores.org/ocsvn/openrisc_me/openrisc_me/trunk

Subversion Repositories openrisc_me

[/] [openrisc/] [trunk/] [gnu-src/] [gcc-4.5.1/] [gcc/] [ada/] [switch.ads] - Blame information for rev 282

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 281 jeremybenn
------------------------------------------------------------------------------
2
--                                                                          --
3
--                         GNAT COMPILER COMPONENTS                         --
4
--                                                                          --
5
--                               S W I T C H                                --
6
--                                                                          --
7
--                                 S p e c                                  --
8
--                                                                          --
9
--          Copyright (C) 1992-2009, Free Software Foundation, Inc.         --
10
--                                                                          --
11
-- GNAT is free software;  you can  redistribute it  and/or modify it under --
12
-- terms of the  GNU General Public License as published  by the Free Soft- --
13
-- ware  Foundation;  either version 3,  or (at your option) any later ver- --
14
-- sion.  GNAT is distributed in the hope that it will be useful, but WITH- --
15
-- OUT ANY WARRANTY;  without even the  implied warranty of MERCHANTABILITY --
16
-- or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License --
17
-- for  more details.  You should have  received  a copy of the GNU General --
18
-- Public License  distributed with GNAT; see file COPYING3.  If not, go to --
19
-- http://www.gnu.org/licenses for a complete copy of the license.          --
20
--                                                                          --
21
-- GNAT was originally developed  by the GNAT team at  New York University. --
22
-- Extensive contributions were provided by Ada Core Technologies Inc.      --
23
--                                                                          --
24
------------------------------------------------------------------------------
25
 
26
--  This package together with a child package appropriate to the client tool
27
--  scans switches. Note that the body of the appropriate Usage package must be
28
--  coordinated with the switches that are recognized by this package. These
29
--  Usage packages also act as the official documentation for the switches
30
--  that are recognized. In addition, package Debug documents the otherwise
31
--  undocumented debug switches that are also recognized.
32
 
33
with Gnatvsn;
34
with Types; use Types;
35
 
36
------------
37
-- Switch --
38
------------
39
 
40
package Switch is
41
 
42
   --  Common switches for GNU tools
43
 
44
   Version_Switch : constant String := "--version";
45
   Help_Switch    : constant String := "--help";
46
 
47
   -----------------
48
   -- Subprograms --
49
   -----------------
50
 
51
   generic
52
      with procedure Usage;
53
      --  Print tool-specific part of --help message
54
   procedure Check_Version_And_Help_G
55
     (Tool_Name      : String;
56
      Initial_Year   : String;
57
      Version_String : String := Gnatvsn.Gnat_Version_String);
58
   --  Check if switches --version or --help is used. If one of this switch is
59
   --  used, issue the proper messages and end the process.
60
 
61
   procedure Display_Version
62
     (Tool_Name      : String;
63
      Initial_Year   : String;
64
      Version_String : String := Gnatvsn.Gnat_Version_String);
65
   --  Display version of a tool when switch --version is used
66
 
67
   function Is_Switch (Switch_Chars : String) return Boolean;
68
   --  Returns True iff Switch_Chars is at least two characters long, and the
69
   --  first character is an hyphen ('-').
70
 
71
   function Is_Front_End_Switch (Switch_Chars : String) return Boolean;
72
   --  Returns True iff Switch_Chars represents a front-end switch, i.e. it
73
   --  starts with -I, -gnat or -?RTS.
74
 
75
   function Is_Internal_GCC_Switch (Switch_Chars : String) return Boolean;
76
   --  Returns True iff Switch_Chars represents an internal GCC switch to be
77
   --  followed by a single argument, such as -dumpbase, --param or -auxbase.
78
   --  Eventhough passed by the "gcc" driver, these need not be stored in ALI
79
   --  files and may safely be ignored by non GCC back-ends.
80
 
81
   function Switch_Last (Switch_Chars : String) return Natural;
82
   --  Index in Switch_Chars of the last relevant character for later string
83
   --  comparison purposes. This is typically 'Last, minus one if there is a
84
   --  terminating ASCII.NUL.
85
 
86
private
87
   --  This section contains some common routines used by the tool dependent
88
   --  child packages (there is one such child package for each tool that uses
89
   --  Switches to scan switches - Compiler/gnatbind/gnatmake/.
90
 
91
   Switch_Max_Value : constant := 999_999;
92
   --  Maximum value permitted in switches that take a value
93
 
94
   function Nat_Present
95
     (Switch_Chars : String;
96
      Max          : Integer;
97
      Ptr          : Integer) return Boolean;
98
   --  Returns True if an integer is at the current scan location or an equal
99
   --  sign. This is used as a guard for calling Scan_Nat. Switch_Chars is the
100
   --  string containing the switch, and Ptr points just past the switch
101
   --  character. Max is the maximum alllowed value of Ptr.
102
 
103
   procedure Scan_Nat
104
     (Switch_Chars : String;
105
      Max          : Integer;
106
      Ptr          : in out Integer;
107
      Result       : out Nat;
108
      Switch       : Character);
109
   --  Scan natural integer parameter for switch. On entry, Ptr points just
110
   --  past the switch character, on exit it points past the last digit of the
111
   --  integer value. Max is the maximum allowed value of Ptr, so the scan is
112
   --  restricted to Switch_Chars (Ptr .. Max). It is posssible for Ptr to be
113
   --  one greater than Max on return if the entire string is digits. Scan_Nat
114
   --  will skip an optional equal sign if it is present. Nat_Present must be
115
   --  True, or an error will be signalled.
116
 
117
   procedure Scan_Pos
118
     (Switch_Chars : String;
119
      Max          : Integer;
120
      Ptr          : in out Integer;
121
      Result       : out Pos;
122
      Switch       : Character);
123
   --  Scan positive integer parameter for switch. On entry, Ptr points just
124
   --  past the switch character, on exit it points past the last digit of the
125
   --  integer value.
126
 
127
   procedure Bad_Switch (Switch : Character);
128
   procedure Bad_Switch (Switch : String);
129
   --  Fail with an appropriate message when a switch is not recognized
130
 
131
end Switch;

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.