| ------------------------------------------------------------------------------ |
| -- -- |
| -- GNAT COMPILER COMPONENTS -- |
| -- -- |
| -- G E N _ I L -- |
| -- -- |
| -- B o d y -- |
| -- -- |
| -- Copyright (C) 2020-2022, 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 3, 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 COPYING3. If not, go to -- |
| -- http://www.gnu.org/licenses for a complete copy of the license. -- |
| -- -- |
| -- GNAT was originally developed by the GNAT team at New York University. -- |
| -- Extensive contributions were provided by Ada Core Technologies Inc. -- |
| -- -- |
| ------------------------------------------------------------------------------ |
| |
| with Ada.Streams.Stream_IO; use Ada.Streams.Stream_IO; |
| |
| package body Gen_IL is |
| |
| procedure Put (F : File_Type; S : String); |
| -- The output primitive |
| |
| ----------- |
| -- Image -- |
| ----------- |
| |
| function Image (X : Root_Int) return String is |
| Result : constant String := X'Img; |
| begin |
| if Result (1) = ' ' then |
| return Result (2 .. Result'Last); |
| else |
| return Result; |
| end if; |
| end Image; |
| |
| ---------------- |
| -- Capitalize -- |
| ---------------- |
| |
| procedure Capitalize (S : in out String) is |
| Cap : Boolean := True; |
| begin |
| for X of S loop |
| declare |
| Old : constant Character := X; |
| begin |
| if Cap then |
| X := To_Upper (X); |
| else |
| X := To_Lower (X); |
| end if; |
| |
| Cap := not (Is_Letter (Old) or else Is_Digit (Old)); |
| end; |
| end loop; |
| end Capitalize; |
| |
| ---------------- |
| -- Capitalize -- |
| ---------------- |
| |
| function Capitalize (S : String) return String is |
| begin |
| return Result : String (S'Range) := S do |
| Capitalize (Result); |
| end return; |
| end Capitalize; |
| |
| ----------------- |
| -- Create_File -- |
| ----------------- |
| |
| procedure Create_File (Buffer : in out Sink; Name : String) is |
| begin |
| Create (Buffer.File, Out_File, Name); |
| Buffer.Indent := 0; |
| Buffer.New_Line := True; |
| end Create_File; |
| |
| --------------------- |
| -- Increase_Indent -- |
| --------------------- |
| |
| procedure Increase_Indent (Buffer : in out Sink; Amount : Natural) is |
| begin |
| Buffer.Indent := Buffer.Indent + Amount; |
| end Increase_Indent; |
| |
| --------------------- |
| -- Decrease_Indent -- |
| --------------------- |
| |
| procedure Decrease_Indent (Buffer : in out Sink; Amount : Natural) is |
| begin |
| Buffer.Indent := Buffer.Indent - Amount; |
| end Decrease_Indent; |
| |
| --------- |
| -- Put -- |
| --------- |
| |
| procedure Put (F : File_Type; S : String) is |
| begin |
| String'Write (Stream (F), S); |
| end Put; |
| |
| procedure Put (Buffer : in out Sink; Item : String) is |
| begin |
| -- If the first character is LF, indent after it only |
| |
| if Item (Item'First) = ASCII.LF then |
| Put (Buffer.File, LF); |
| Buffer.New_Line := True; |
| |
| if Item'Length > 1 then |
| Put (Buffer, Item (Item'First + 1 .. Item'Last)); |
| end if; |
| |
| return; |
| end if; |
| |
| -- If this is a new line, indent |
| |
| if Buffer.New_Line and then Buffer.Indent > 0 then |
| declare |
| S : constant String (1 .. Buffer.Indent) := (others => ' '); |
| begin |
| Put (Buffer.File, S); |
| end; |
| end if; |
| |
| Put (Buffer.File, Item); |
| |
| Buffer.New_Line := Item (Item'Last) = ASCII.LF; |
| end Put; |
| |
| end Gen_IL; |