------------------------------------------------------------------------------ -- -- -- GNAT COMPILER COMPONENTS -- -- -- -- S W I T C H -- -- -- -- S p e c -- -- -- -- Copyright (C) 1992-2003 Free Software Foundation, Inc. -- -- -- -- GNAT is free software; you can redistribute it and/or modify it under -- -- terms of the GNU General Public License as published by the Free Soft- -- -- ware Foundation; either version 2, or (at your option) any later ver- -- -- sion. GNAT is distributed in the hope that it will be useful, but WITH- -- -- OUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY -- -- or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License -- -- for more details. You should have received a copy of the GNU General -- -- Public License distributed with GNAT; see file COPYING. If not, write -- -- to the Free Software Foundation, 59 Temple Place - Suite 330, Boston, -- -- MA 02111-1307, USA. -- -- -- -- GNAT was originally developed by the GNAT team at New York University. -- -- Extensive contributions were provided by Ada Core Technologies Inc. -- -- -- ------------------------------------------------------------------------------ -- This package together with a child package appropriate to the client -- tool scans switches. Note that the body of the appropraite Usage package -- must be coordinated with the switches that are recognized by this package. -- These Usage packages also act as the official documentation for the -- switches that are recognized. In addition, package Debug documents -- the otherwise undocumented debug switches that are also recognized. with Types; use Types; package Switch is -- Note: The default switch character is indicated by Switch_Character, -- but regardless of what it is, a hyphen is always allowed as an -- (alternative) switch character. -- Note: In GNAT, the case of switches is not significant if -- Switches_Case_Sensitive is False. If this is the case, switch -- characters, or letters appearing in the parameter to a switch, may be -- either upper case or lower case. ----------------- -- Subprograms -- ----------------- function Is_Switch (Switch_Chars : String) return Boolean; -- Returns True iff Switch_Chars is at least two characters long, -- and the first character indicates it is a switch. function Is_Front_End_Switch (Switch_Chars : String) return Boolean; -- Returns True iff Switch_Chars represents a front-end switch, -- ie. it starts with -I or -gnat. private -- This section contains some common routines used by the tool dependent -- child packages (there is one such child package for each tool that -- uses Switches to scan switches - Compiler/gnatbind/gnatmake/. Bad_Switch : exception; -- Exception raised if bad switch encountered Bad_Switch_Value : exception; -- Exception raised if bad switch value encountered Missing_Switch_Value : exception; -- Exception raised if no switch value encountered Too_Many_Output_Files : exception; -- Exception raised if the -o switch is encountered more than once Switch_Max_Value : constant := 999_999; -- Maximum value permitted in switches that take a value procedure Scan_Nat (Switch_Chars : String; Max : Integer; Ptr : in out Integer; Result : out Nat); -- Scan natural integer parameter for switch. On entry, Ptr points -- just past the switch character, on exit it points past the last -- digit of the integer value. procedure Scan_Pos (Switch_Chars : String; Max : Integer; Ptr : in out Integer; Result : out Pos); -- Scan positive integer parameter for switch. On entry, Ptr points -- just past the switch character, on exit it points past the last -- digit of the integer value. end Switch;