home *** CD-ROM | disk | FTP | other *** search
/ Geek Gadgets 1 / ADE-1.bin / ade-dist / gnat-2.06-src.tgz / tar.out / fsf / gnat / ada / s-imgwiu.adb < prev    next >
Text File  |  1996-09-28  |  4KB  |  128 lines

  1. ------------------------------------------------------------------------------
  2. --                                                                          --
  3. --                         GNAT RUNTIME COMPONENTS                          --
  4. --                                                                          --
  5. --                       S Y S T E M . I M G _ W I U                        --
  6. --                                                                          --
  7. --                                 B o d y                                  --
  8. --                                                                          --
  9. --                            $Revision: 1.2 $                              --
  10. --                                                                          --
  11. --           Copyright (c) 1992,1993,1994 NYU, All Rights Reserved          --
  12. --                                                                          --
  13. -- The GNAT library is free software; you can redistribute it and/or modify --
  14. -- it under terms of the GNU Library General Public License as published by --
  15. -- the Free Software  Foundation; either version 2, or (at your option) any --
  16. -- later version.  The GNAT library is distributed in the hope that it will --
  17. -- be useful, but WITHOUT ANY WARRANTY;  without even  the implied warranty --
  18. -- of MERCHANTABILITY  or  FITNESS FOR  A PARTICULAR PURPOSE.  See the  GNU --
  19. -- Library  General  Public  License for  more  details.  You  should  have --
  20. -- received  a copy of the GNU  Library  General Public License  along with --
  21. -- the GNAT library;  see the file  COPYING.LIB.  If not, write to the Free --
  22. -- Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.        --
  23. --                                                                          --
  24. ------------------------------------------------------------------------------
  25.  
  26. with System.Unsigned_Types; use System.Unsigned_Types;
  27.  
  28. package body System.Img_WIU is
  29.  
  30.    -----------------------------
  31.    -- Set_Image_Width_Integer --
  32.    -----------------------------
  33.  
  34.    procedure Set_Image_Width_Integer
  35.      (V : Integer;
  36.       W : Integer;
  37.       S : out String;
  38.       P : in out Natural)
  39.    is
  40.       Start : Natural;
  41.  
  42.    begin
  43.       --  Positive case can just use the unsigned circuit directly
  44.  
  45.       if V >= 0 then
  46.          Set_Image_Width_Unsigned (Unsigned (V), W, S, P);
  47.  
  48.       --  Negative case has to set a minus sign. Note also that we have to be
  49.       --  careful not to generate overflow with the largest negative number.
  50.  
  51.       else
  52.          P := P + 1;
  53.          S (P) := ' ';
  54.          Start := P;
  55.  
  56.          begin
  57.             pragma Suppress (Overflow_Check);
  58.             pragma Suppress (Range_Check);
  59.             Set_Image_Width_Unsigned (Unsigned (-V), W - 1, S, P);
  60.          end;
  61.  
  62.          --  Set minus sign in last leading blank location. Because of the
  63.          --  code above, there must be at least one such location.
  64.  
  65.          while S (Start + 1) = ' ' loop
  66.             Start := Start + 1;
  67.          end loop;
  68.  
  69.          S (Start) := '-';
  70.       end if;
  71.  
  72.    end Set_Image_Width_Integer;
  73.  
  74.    ------------------------------
  75.    -- Set_Image_Width_Unsigned --
  76.    ------------------------------
  77.  
  78.    procedure Set_Image_Width_Unsigned
  79.      (V : Unsigned;
  80.       W : Integer;
  81.       S : out String;
  82.       P : in out Natural)
  83.    is
  84.       Start : constant Natural := P;
  85.       F, T  : Natural;
  86.  
  87.       procedure Set_Digits (T : Unsigned);
  88.       --  Set digits of absolute value of T
  89.  
  90.       procedure Set_Digits (T : Unsigned) is
  91.       begin
  92.          if T >= 10 then
  93.             Set_Digits (T / 10);
  94.             P := P + 1;
  95.             S (P) := Character'Val (T mod 10 + Character'Pos ('0'));
  96.          else
  97.             P := P + 1;
  98.             S (P) := Character'Val (T + Character'Pos ('0'));
  99.          end if;
  100.       end Set_Digits;
  101.  
  102.    --  Start of processing for Set_Image_Width_Unsigned
  103.  
  104.    begin
  105.       Set_Digits (V);
  106.  
  107.       --  Add leading spaces if required by width parameter
  108.  
  109.       if P - Start < W then
  110.          F := P;
  111.          P := P + (W - (P - Start));
  112.          T := P;
  113.  
  114.          while F > Start loop
  115.             S (T) := S (F);
  116.             T := T - 1;
  117.             F := F - 1;
  118.          end loop;
  119.  
  120.          for J in Start + 1 .. T loop
  121.             S (J) := ' ';
  122.          end loop;
  123.       end if;
  124.  
  125.    end Set_Image_Width_Unsigned;
  126.  
  127. end System.Img_WIU;
  128.