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 / a-strmap.adb < prev    next >
Text File  |  1996-09-28  |  9KB  |  330 lines

  1. ------------------------------------------------------------------------------
  2. --                                                                          --
  3. --                         GNAT RUNTIME COMPONENTS                          --
  4. --                                                                          --
  5. --                     A D A . S T R I N G S . M A P S                      --
  6. --                                                                          --
  7. --                                 B o d y                                  --
  8. --                                                                          --
  9. --                            $Revision: 1.14 $                             --
  10. --                                                                          --
  11. --        Copyright (c) 1992,1993,1994,1995 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. --  Note: parts of this code are derived from the ADAR.CSH public domain
  27. --  Ada 83 versions of the Appendix C string handling packages. The main
  28. --  differences are that we avoid the use of the minimize function which
  29. --  is bit-by-bit or character-by-character and therefore rather slow.
  30. --  Generally for character sets we favor the full 32-byte representation.
  31.  
  32. package body Ada.Strings.Maps is
  33.  
  34.    ---------
  35.    -- "=" --
  36.    ---------
  37.  
  38.    function "=" (Left, Right : in Character_Set) return Boolean is
  39.    begin
  40.       return Character_Set_Internal (Left) = Character_Set_Internal (Right);
  41.    end "=";
  42.  
  43.    -----------
  44.    -- "and" --
  45.    -----------
  46.  
  47.    function "and" (Left, Right : in Character_Set) return Character_Set is
  48.    begin
  49.       return Character_Set
  50.         (Character_Set_Internal (Left) and Character_Set_Internal (Right));
  51.    end "and";
  52.  
  53.    -----------
  54.    -- "not" --
  55.    -----------
  56.  
  57.    function "not" (Right : in Character_Set) return Character_Set is
  58.    begin
  59.       return Character_Set (not Character_Set_Internal (Right));
  60.    end "not";
  61.  
  62.    ----------
  63.    -- "or" --
  64.    ----------
  65.  
  66.    function "or" (Left, Right : in Character_Set) return Character_Set is
  67.    begin
  68.       return Character_Set
  69.         (Character_Set_Internal (Left) or Character_Set_Internal (Right));
  70.    end "or";
  71.  
  72.    -----------
  73.    -- "xor" --
  74.    -----------
  75.  
  76.    function "xor" (Left, Right : in Character_Set) return Character_Set is
  77.    begin
  78.       return Character_Set
  79.         (Character_Set_Internal (Left) xor Character_Set_Internal (Right));
  80.    end "xor";
  81.  
  82.    ------------
  83.    -- To_Set --
  84.    ------------
  85.  
  86.    function To_Set (Ranges : in Character_Ranges) return Character_Set is
  87.       Result : Character_Set;
  88.  
  89.    begin
  90.       for C in Result'Range loop
  91.          Result (C) := False;
  92.       end loop;
  93.  
  94.       for R in Ranges'Range loop
  95.          for C in Ranges (R).Low .. Ranges (R).High loop
  96.             Result (C) := True;
  97.          end loop;
  98.       end loop;
  99.  
  100.       return Result;
  101.    end To_Set;
  102.  
  103.    function To_Set (Span   : in Character_Range) return Character_Set is
  104.       Result : Character_Set;
  105.  
  106.    begin
  107.       for C in Result'Range loop
  108.          Result (C) := False;
  109.       end loop;
  110.  
  111.       for C in Span.Low .. Span.High loop
  112.          Result (C) := True;
  113.       end loop;
  114.  
  115.       return Result;
  116.    end To_Set;
  117.  
  118.    ---------------
  119.    -- To_Ranges --
  120.    ---------------
  121.  
  122.    function To_Ranges (Set : in Character_Set) return Character_Ranges is
  123.       Max_Ranges : Character_Ranges (1 .. Set'Length / 2 + 1);
  124.       Range_Num  : Natural;
  125.       C          : Character;
  126.  
  127.    begin
  128.       C := Character'First;
  129.       Range_Num := 0;
  130.  
  131.       loop
  132.          --  Skip gap between subsets.
  133.  
  134.          while not Set (C) loop
  135.             exit when C = Character'Last;
  136.             C := Character'Succ (C);
  137.          end loop;
  138.  
  139.          exit when not Set (C);
  140.  
  141.          Range_Num := Range_Num + 1;
  142.          Max_Ranges (Range_Num).Low := C;
  143.  
  144.          --  Span a subset.
  145.  
  146.          loop
  147.             exit when not Set (C) or else C = Character'Last;
  148.             C := Character' Succ (C);
  149.          end loop;
  150.  
  151.          if Set (C) then
  152.             Max_Ranges (Range_Num). High := C;
  153.             exit;
  154.          else
  155.             Max_Ranges (Range_Num). High := Character'Pred (C);
  156.          end if;
  157.       end loop;
  158.  
  159.       return Max_Ranges (1 .. Range_Num);
  160.    end To_Ranges;
  161.  
  162.    ---------
  163.    -- "-" --
  164.    ---------
  165.  
  166.    function "-" (Left, Right : Character_Set) return Character_Set is
  167.    begin
  168.       return Left and not Right;
  169.    end "-";
  170.  
  171.    -----------
  172.    -- Is_In --
  173.    -----------
  174.  
  175.    function Is_In
  176.      (Element : Character;
  177.       Set     : Character_Set)
  178.       return    Boolean
  179.    is
  180.    begin
  181.       return Set (Element);
  182.    end Is_In;
  183.  
  184.    ---------------
  185.    -- Is_Subset --
  186.    ---------------
  187.  
  188.    function Is_Subset
  189.      (Elements : Character_Set;
  190.       Set      : Character_Set)
  191.       return     Boolean
  192.    is
  193.    begin
  194.       return (Elements and Set) = Elements;
  195.    end Is_Subset;
  196.  
  197.    ----------------
  198.    -- To_Mapping --
  199.    ----------------
  200.  
  201.    function To_Mapping
  202.      (From, To : in Character_Sequence)
  203.       return     Character_Mapping
  204.    is
  205.       Result   : Character_Mapping;
  206.       Inserted : Character_Set := Null_Set;
  207.       From_Len : constant Natural := From'Length;
  208.       To_Len   : constant Natural := To'Length;
  209.  
  210.    begin
  211.       if From_Len /= To_Len then
  212.          raise Strings.Translation_Error;
  213.       end if;
  214.  
  215.       for Char in Character loop
  216.          Result (Char) := Char;
  217.       end loop;
  218.  
  219.       for J in From'Range loop
  220.          if Inserted (From (J)) then
  221.             raise Strings.Translation_Error;
  222.          end if;
  223.  
  224.          Result   (From (J)) := To (J - From'First + To'First);
  225.          Inserted (From (J)) := True;
  226.       end loop;
  227.  
  228.       return Result;
  229.    end To_Mapping;
  230.  
  231.    -----------------
  232.    -- To_Sequence --
  233.    -----------------
  234.  
  235.    function To_Sequence
  236.      (Set  : Character_Set)
  237.       return Character_Sequence
  238.    is
  239.       Result : String (1 .. Character'Pos (Character'Last));
  240.       Count  : Natural := 0;
  241.  
  242.    begin
  243.       for Char in Set'Range loop
  244.          if Set (Char) then
  245.             Count := Count + 1;
  246.             Result (Count) := Char;
  247.          end if;
  248.       end loop;
  249.  
  250.       return Result (1 .. Count);
  251.    end To_Sequence;
  252.  
  253.    ------------
  254.    -- To_Set --
  255.    ------------
  256.  
  257.    function To_Set (Sequence : Character_Sequence) return Character_Set is
  258.       Result : Character_Set := Null_Set;
  259.  
  260.    begin
  261.       for J in Sequence'Range loop
  262.          Result (Sequence (J)) := True;
  263.       end loop;
  264.  
  265.       return Result;
  266.    end To_Set;
  267.  
  268.    function To_Set (Singleton : Character) return Character_Set is
  269.       Result : Character_Set := Null_Set;
  270.  
  271.    begin
  272.       Result (Singleton) := True;
  273.       return Result;
  274.    end To_Set;
  275.  
  276.    -----------
  277.    -- Value --
  278.    -----------
  279.  
  280.    function Value (Map : in Character_Mapping; Element : in Character)
  281.       return Character is
  282.  
  283.    begin
  284.       return Map (Element);
  285.    end Value;
  286.  
  287.    ---------------
  288.    -- To_Domain --
  289.    ---------------
  290.  
  291.    function To_Domain (Map : in Character_Mapping) return Character_Sequence
  292.    is
  293.       Result : String (1 .. Map'Length);
  294.       J      : Natural;
  295.  
  296.    begin
  297.       J := 1;
  298.       for C in Map'Range loop
  299.          if Map (C) /= C then
  300.             Result (J) := C;
  301.             J := J + 1;
  302.          end if;
  303.       end loop;
  304.  
  305.       return Result (1 .. J);
  306.    end To_Domain;
  307.  
  308.    --------------
  309.    -- To_Range --
  310.    --------------
  311.  
  312.    function To_Range (Map : in Character_Mapping) return Character_Sequence
  313.    is
  314.       Result : String (1 .. Map'Length);
  315.       J      : Natural;
  316.  
  317.    begin
  318.       J := 0;
  319.       for C in Map'Range loop
  320.          if Map (C) /= C then
  321.             Result (J) := Map (C);
  322.             J := J + 1;
  323.          end if;
  324.       end loop;
  325.  
  326.       return Result (1 .. J);
  327.    end To_Range;
  328.  
  329. end Ada.Strings.Maps;
  330.