gnoga_2.1.2_5f127c56/deps/simple_components/strings_edit-fields.adb

  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
--                                                                    --
--  package Strings_Edit.Fields     Copyright (c)  Dmitry A. Kazakov  --
--  Implementation                                 Luebeck            --
--                                                 Spring, 2002       --
--                                                                    --
--                                Last revision :  21:03 21 Apr 2009  --
--                                                                    --
--  This  library  is  free software; you can redistribute it and/or  --
--  modify it under the terms of the GNU General Public  License  as  --
--  published by the Free Software Foundation; either version  2  of  --
--  the License, or (at your option) any later version. This library  --
--  is distributed in the hope that it will be useful,  but  WITHOUT  --
--  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 along with  --
--  this library; if not, write to  the  Free  Software  Foundation,  --
--  Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.    --
--                                                                    --
--  As a special exception, if other files instantiate generics from  --
--  this unit, or you link this unit with other files to produce  an  --
--  executable, this unit does not by  itself  cause  the  resulting  --
--  executable to be covered by the GNU General Public License. This  --
--  exception  does not however invalidate any other reasons why the  --
--  executable file might be covered by the GNU Public License.       --
--____________________________________________________________________--

with Ada.IO_Exceptions; use Ada.IO_Exceptions;

package body Strings_Edit.Fields is

   function Get_Output_Field
            (  Destination : String;
               Pointer     : Integer;
               Field       : Natural
            )  return Natural is
      Result : Natural := Field;
   begin
      if Result = 0 then
         Result := Destination'Last - Pointer + 1;
      end if;
      if (  Pointer < Destination'First
         or else
            Pointer + Result - 1 > Destination'Last
         )
      then
         raise Layout_Error;
      end if;
      return Result;
   end Get_Output_Field;

   procedure Adjust_Output_Field
             (  Destination : in out String;
                Pointer     : in out Integer;
                Index       : Integer;
                Out_Field   : Natural;
                Field       : Natural;
                Justify     : Alignment;
                Fill        : Character
             )  is
   begin
      if Field = 0 then
         Pointer := Index;
      else
         declare
            Last : constant Integer := Pointer + Out_Field - 1;
         begin
            if Out_Field /= Index - Pointer then
               case Justify is
                  when Left =>
                     for Position in Index..Last loop
                        Destination (Position) := Fill;
                     end loop;
                  when Center =>
                     declare
                        Length : constant Natural := Index - Pointer;
                        First  : constant Integer :=
                                    Pointer + (Out_Field - Length) / 2;
                        Next   : constant Integer := First + Length;
                     begin
                        Destination (First..Next - 1) :=
                        Destination (Pointer..Index - 1);
                        for Position in Pointer..First - 1 loop
                           Destination (Position) := Fill;
                        end loop;
                        for Position in Next..Last loop
                           Destination (Position) := Fill;
                        end loop;
                     end;
                  when Right =>
                     declare
                        First : constant Integer :=
                                   Last + 1 - Index + Pointer;
                     begin
                        Destination (First..Last) :=
                           Destination (Pointer..Index - 1);
                        for Position in Pointer..First - 1 loop
                           Destination (Position) := Fill;
                        end loop;
                     end;
               end case;
            end if;
            Pointer := Last + 1;
         end;
      end if;
   end Adjust_Output_Field;

end Strings_Edit.Fields;