diff options
author | kevlo <kevlo@FreeBSD.org> | 2002-02-09 16:20:42 +0800 |
---|---|---|
committer | kevlo <kevlo@FreeBSD.org> | 2002-02-09 16:20:42 +0800 |
commit | 01a29e0edb31f805e02adda51a157f5a7630175d (patch) | |
tree | da66d9da749882a2c810fac05ba5faa18ca78d9a /lang | |
parent | 637d67d22b0cc8dfa2429f35e2aab693528a380f (diff) | |
download | freebsd-ports-gnome-01a29e0edb31f805e02adda51a157f5a7630175d.tar.gz freebsd-ports-gnome-01a29e0edb31f805e02adda51a157f5a7630175d.tar.zst freebsd-ports-gnome-01a29e0edb31f805e02adda51a157f5a7630175d.zip |
Update jgnat so it will continue to build with the new compiler which
has much stricter Ada 95 style checking.
PR: 34749
Submitted by: MAINTAINER
Diffstat (limited to 'lang')
-rw-r--r-- | lang/jgnat/Makefile | 6 | ||||
-rw-r--r-- | lang/jgnat/files/patch-a-chahan.adb | 10 | ||||
-rw-r--r-- | lang/jgnat/files/patch-bindgen.adb | 15 | ||||
-rw-r--r-- | lang/jgnat/files/patch-exp_ch4.adb | 11 | ||||
-rw-r--r-- | lang/jgnat/files/patch-gnatbind.adb | 11 | ||||
-rw-r--r-- | lang/jgnat/files/patch-gnatls.adb | 11 | ||||
-rw-r--r-- | lang/jgnat/files/patch-make.adb | 11 | ||||
-rw-r--r-- | lang/jgnat/files/patch-par-ch3.adb | 11 | ||||
-rw-r--r-- | lang/jgnat/files/patch-par-ch5.adb | 11 | ||||
-rw-r--r-- | lang/jgnat/files/patch-s-imgenu.adb | 133 | ||||
-rw-r--r-- | lang/jgnat/files/patch-s-imgenu.ads | 81 | ||||
-rw-r--r-- | lang/jgnat/files/patch-sem_dist.adb | 20 | ||||
-rw-r--r-- | lang/jgnat/files/patch-sem_res.adb | 11 | ||||
-rw-r--r-- | lang/jgnat/files/patch-sem_util.adb | 11 | ||||
-rw-r--r-- | lang/jgnat/pkg-message | 2 | ||||
-rw-r--r-- | lang/jgnat/pkg-plist | 2 |
16 files changed, 353 insertions, 4 deletions
diff --git a/lang/jgnat/Makefile b/lang/jgnat/Makefile index 936bf59418d9..70937b21169d 100644 --- a/lang/jgnat/Makefile +++ b/lang/jgnat/Makefile @@ -7,6 +7,7 @@ PORTNAME= jgnat PORTVERSION= 1.1.p +PORTREVISION= 1 CATEGORIES= lang java MASTER_SITES= ftp://cs.nyu.edu/pub/gnat/jgnat/jgnat-1.1p/split-1.1p/ \ ftp://ftp.cdrom.com/pub/languages/ada/compiler/gnat/jgnat/jgnat-1.1p/split-1.1p/ \ @@ -34,13 +35,14 @@ WRKSRC= ${WRKDIR}/${DISTNAME:C@-([^\-]+)$@/\1@} LIBDIR= ${PREFIX}/lib/jgnat ADAINCDIR= ${LIBDIR}/adainclude ADALIBDIR= ${LIBDIR}/adalib +JARDIR= ${PREFIX}/share/java/classes do-install: -.for dir in ${LIBDIR} ${ADAINCDIR} ${ADALIBDIR} +.for dir in ${LIBDIR} ${ADAINCDIR} ${ADALIBDIR} ${JARDIR} @${MKDIR} ${dir} .endfor @${INSTALL_PROGRAM} ${WRKSRC}/../bin/* ${PREFIX}/bin - @${INSTALL_DATA} ${WRKSRC}/../lib/jgnat.jar ${LIBDIR} + @${INSTALL_DATA} ${WRKSRC}/../lib/jgnat.jar ${JARDIR} @${INSTALL_DATA} ${WRKSRC}/../lib/jgnat/adainclude/* ${ADAINCDIR} @${INSTALL_DATA} ${WRKSRC}/../lib/jgnat/adalib/* ${ADALIBDIR} @${CHMOD} a-r ${ADALIBDIR}/*.ali diff --git a/lang/jgnat/files/patch-a-chahan.adb b/lang/jgnat/files/patch-a-chahan.adb new file mode 100644 index 000000000000..03667e3d72e5 --- /dev/null +++ b/lang/jgnat/files/patch-a-chahan.adb @@ -0,0 +1,10 @@ +--- a-chahan.adb.orig Fri Sep 1 10:13:48 2000 ++++ a-chahan.adb Fri Feb 8 22:14:02 2002 +@@ -38,7 +38,6 @@ + with Ada.Strings.Maps.Constants; use Ada.Strings.Maps.Constants; + + package body Ada.Characters.Handling is +-pragma Preelaborate (Handling); + + ------------------------------------ + -- Character Classification Table -- diff --git a/lang/jgnat/files/patch-bindgen.adb b/lang/jgnat/files/patch-bindgen.adb new file mode 100644 index 000000000000..517bf404ea2f --- /dev/null +++ b/lang/jgnat/files/patch-bindgen.adb @@ -0,0 +1,15 @@ +--- bindgen.adb.orig Fri Sep 1 10:13:49 2000 ++++ bindgen.adb Fri Feb 8 21:58:21 2002 +@@ -1890,10 +1890,10 @@ + + -- Constants to help defining periods + +- Always : constant := 0; ++ -- Always : constant := 0; + Hour : constant := 60; + Day : constant := 24 * Hour; +- Month : constant := 30 * Day; ++ -- Month : constant := 30 * Day; + + Never : constant := Integer'Last; + -- Special value indicating no warnings should be given diff --git a/lang/jgnat/files/patch-exp_ch4.adb b/lang/jgnat/files/patch-exp_ch4.adb new file mode 100644 index 000000000000..f1f32aee7cd4 --- /dev/null +++ b/lang/jgnat/files/patch-exp_ch4.adb @@ -0,0 +1,11 @@ +--- exp_ch4.adb.orig Fri Sep 1 10:13:50 2000 ++++ exp_ch4.adb Fri Feb 8 21:20:29 2002 +@@ -2623,7 +2623,7 @@ + Expand_Concatenate_Other (Cnode, Opnds); + end if; + +- exit when Cnode = N; ++ exit Outer when Cnode = N; + Cnode := Parent (Cnode); + end loop Outer; + end Expand_N_Op_Concat; diff --git a/lang/jgnat/files/patch-gnatbind.adb b/lang/jgnat/files/patch-gnatbind.adb new file mode 100644 index 000000000000..7dfaa0b49f43 --- /dev/null +++ b/lang/jgnat/files/patch-gnatbind.adb @@ -0,0 +1,11 @@ +--- gnatbind.adb.orig Fri Sep 1 10:13:51 2000 ++++ gnatbind.adb Fri Feb 8 21:50:43 2002 +@@ -183,7 +183,7 @@ + + Next_Arg := 1; + Scan_Args : loop +- exit when Next_Arg >= Arg_Count; ++ exit Scan_Args when Next_Arg >= Arg_Count; + declare + Next_Argv : String (1 .. Len_Arg (Next_Arg)); + diff --git a/lang/jgnat/files/patch-gnatls.adb b/lang/jgnat/files/patch-gnatls.adb new file mode 100644 index 000000000000..713fceb35f65 --- /dev/null +++ b/lang/jgnat/files/patch-gnatls.adb @@ -0,0 +1,11 @@ +--- gnatls.adb.orig Fri Sep 1 10:13:51 2000 ++++ gnatls.adb Fri Feb 8 22:04:50 2002 +@@ -678,7 +678,7 @@ + + Next_Arg := 1; + Scan_Args : loop +- exit when Next_Arg >= Arg_Count; ++ exit Scan_Args when Next_Arg >= Arg_Count; + declare + Next_Argv : String (1 .. Len_Arg (Next_Arg)); + diff --git a/lang/jgnat/files/patch-make.adb b/lang/jgnat/files/patch-make.adb new file mode 100644 index 000000000000..3db59fb56b86 --- /dev/null +++ b/lang/jgnat/files/patch-make.adb @@ -0,0 +1,11 @@ +--- make.adb.orig Fri Sep 1 10:13:54 2000 ++++ make.adb Fri Feb 8 21:44:31 2002 +@@ -1824,7 +1824,7 @@ + + Next_Arg := 1; + Scan_Args : loop +- exit when Next_Arg > Argument_Count; ++ exit Scan_Args when Next_Arg > Argument_Count; + Scan_Make_Arg (Argument (Next_Arg)); + Next_Arg := Next_Arg + 1; + end loop Scan_Args; diff --git a/lang/jgnat/files/patch-par-ch3.adb b/lang/jgnat/files/patch-par-ch3.adb new file mode 100644 index 000000000000..ace324b10bf8 --- /dev/null +++ b/lang/jgnat/files/patch-par-ch3.adb @@ -0,0 +1,11 @@ +--- par-ch3.adb.orig Fri Sep 1 10:13:57 2000 ++++ par-ch3.adb Fri Feb 8 21:14:11 2002 +@@ -2587,7 +2587,7 @@ + P_Component_Items (Decls_List); + P_Pragmas_Opt (Decls_List); + +- exit when Token = Tok_End ++ exit Component_Scan_Loop when Token = Tok_End + or else Token = Tok_Case + or else Token = Tok_When; + diff --git a/lang/jgnat/files/patch-par-ch5.adb b/lang/jgnat/files/patch-par-ch5.adb new file mode 100644 index 000000000000..340ee7bd8b79 --- /dev/null +++ b/lang/jgnat/files/patch-par-ch5.adb @@ -0,0 +1,11 @@ +--- par-ch5.adb.orig Fri Sep 1 10:13:57 2000 ++++ par-ch5.adb Fri Feb 8 21:15:01 2002 +@@ -1006,7 +1006,7 @@ + + -- Error recovery: can raise Error_Resync + +- function P_Assignment_Statement (Lhs : Node_Id) return Node_Id is ++ function P_Assignment_Statement (LHS : Node_Id) return Node_Id is + Assign_Node : Node_Id; + + begin diff --git a/lang/jgnat/files/patch-s-imgenu.adb b/lang/jgnat/files/patch-s-imgenu.adb new file mode 100644 index 000000000000..ae7c4a64400a --- /dev/null +++ b/lang/jgnat/files/patch-s-imgenu.adb @@ -0,0 +1,133 @@ +--- /dev/null Fri Feb 8 20:51:30 2002 ++++ s-imgenu.adb Fri Feb 8 20:53:07 2002 +@@ -0,0 +1,130 @@ ++------------------------------------------------------------------------------ ++-- -- ++-- GNAT RUNTIME COMPONENTS -- ++-- -- ++-- S Y S T E M . I M G _ E N U M -- ++-- -- ++-- B o d y -- ++-- -- ++-- $Revision: 1.2 $ ++-- -- ++-- Copyright (C) 2000 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. -- ++-- -- ++-- 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. -- ++-- -- ++-- GNAT was originally developed by the GNAT team at New York University. -- ++-- It is now maintained by Ada Core Technologies Inc (http://www.gnat.com). -- ++-- -- ++------------------------------------------------------------------------------ ++ ++with Unchecked_Conversion; ++ ++package body System.Img_Enum is ++ ++ ------------------------- ++ -- Image_Enumeration_8 -- ++ ------------------------- ++ ++ function Image_Enumeration_8 ++ (Pos : Natural; ++ Names : String; ++ Indexes : System.Address) ++ return String ++ is ++ type Natural_8 is range 0 .. 2 ** 7 - 1; ++ type Index_Table is array (Natural) of Natural_8; ++ type Index_Table_Ptr is access Index_Table; ++ ++ function To_Index_Table_Ptr is ++ new Unchecked_Conversion (System.Address, Index_Table_Ptr); ++ ++ IndexesT : constant Index_Table_Ptr := To_Index_Table_Ptr (Indexes); ++ ++ Start : Natural := Natural (IndexesT (Pos)); ++ Next : Natural := Natural (IndexesT (Pos + 1)); ++ ++ subtype Result_Type is String (1 .. Next - Start); ++ -- We need this result type to force the result to have the ++ -- required lower bound of 1, rather than the slice bounds. ++ ++ begin ++ return Result_Type (Names (Start .. Next - 1)); ++ end Image_Enumeration_8; ++ ++ -------------------------- ++ -- Image_Enumeration_16 -- ++ -------------------------- ++ ++ function Image_Enumeration_16 ++ (Pos : Natural; ++ Names : String; ++ Indexes : System.Address) ++ return String ++ is ++ type Natural_16 is range 0 .. 2 ** 15 - 1; ++ type Index_Table is array (Natural) of Natural_16; ++ type Index_Table_Ptr is access Index_Table; ++ ++ function To_Index_Table_Ptr is ++ new Unchecked_Conversion (System.Address, Index_Table_Ptr); ++ ++ IndexesT : constant Index_Table_Ptr := To_Index_Table_Ptr (Indexes); ++ ++ Start : Natural := Natural (IndexesT (Pos)); ++ Next : Natural := Natural (IndexesT (Pos + 1)); ++ ++ subtype Result_Type is String (1 .. Next - Start); ++ -- We need this result type to force the result to have the ++ -- required lower bound of 1, rather than the slice bounds. ++ ++ begin ++ return Result_Type (Names (Start .. Next - 1)); ++ end Image_Enumeration_16; ++ ++ -------------------------- ++ -- Image_Enumeration_32 -- ++ -------------------------- ++ ++ function Image_Enumeration_32 ++ (Pos : Natural; ++ Names : String; ++ Indexes : System.Address) ++ return String ++ is ++ type Natural_32 is range 0 .. 2 ** 31 - 1; ++ type Index_Table is array (Natural) of Natural_32; ++ type Index_Table_Ptr is access Index_Table; ++ ++ function To_Index_Table_Ptr is ++ new Unchecked_Conversion (System.Address, Index_Table_Ptr); ++ ++ IndexesT : constant Index_Table_Ptr := To_Index_Table_Ptr (Indexes); ++ ++ Start : Natural := Natural (IndexesT (Pos)); ++ Next : Natural := Natural (IndexesT (Pos + 1)); ++ ++ subtype Result_Type is String (1 .. Next - Start); ++ -- We need this result type to force the result to have the ++ -- required lower bound of 1, rather than the slice bounds. ++ ++ begin ++ return Result_Type (Names (Start .. Next - 1)); ++ end Image_Enumeration_32; ++ ++end System.Img_Enum; diff --git a/lang/jgnat/files/patch-s-imgenu.ads b/lang/jgnat/files/patch-s-imgenu.ads new file mode 100644 index 000000000000..6c204defc01f --- /dev/null +++ b/lang/jgnat/files/patch-s-imgenu.ads @@ -0,0 +1,81 @@ +--- /dev/null Fri Feb 8 20:51:30 2002 ++++ s-imgenu.ads Fri Feb 8 20:53:06 2002 +@@ -0,0 +1,78 @@ ++------------------------------------------------------------------------------ ++-- -- ++-- GNAT RUNTIME COMPONENTS -- ++-- -- ++-- S Y S T E M . I M G _ E N U M -- ++-- -- ++-- S p e c -- ++-- -- ++-- $Revision: 1.2 $ ++-- -- ++-- Copyright (C) 2000 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. -- ++-- -- ++-- 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. -- ++-- -- ++-- GNAT was originally developed by the GNAT team at New York University. -- ++-- It is now maintained by Ada Core Technologies Inc (http://www.gnat.com). -- ++-- -- ++------------------------------------------------------------------------------ ++ ++-- Enumeration_Type'Image for all enumeration types except those in package ++-- Standard (where we have no opportunity to build image tables), and in ++-- package System (where it is too early to start building image tables). ++-- Special routines exist for the enumeration routines in these packages. ++ ++package System.Img_Enum is ++pragma Pure (Img_Enum); ++ ++ function Image_Enumeration_8 ++ (Pos : Natural; ++ Names : String; ++ Indexes : System.Address) ++ return String; ++ -- Used to compute Enum'Image (Str) where Enum is some enumeration type ++ -- other than those defined in package Standard. Names is a string with ++ -- a lower bound of 1 containing the characters of all the enumeration ++ -- literals concatenated together in sequence. Indexes is the address ++ -- of an array of type array (0 .. N) of Natural_8, where N is the ++ -- is the number of enumeration literals in the type. The Indexes values ++ -- are the starting subscript of each enumeration literal, indexed by Pos ++ -- values, with an extra entry at the end containing Names'Length + 1. ++ -- The reason that Indexes is passed by address is that the actual type ++ -- is created on the fly by the expander. The value returned is the ++ -- desired 'Image value. ++ ++ function Image_Enumeration_16 ++ (Pos : Natural; ++ Names : String; ++ Indexes : System.Address) ++ return String; ++ -- Identical to Image_Enumeration_8 except that it handles types ++ -- using array (0 .. Num) of Natural_16 for the Indexes table. ++ ++ function Image_Enumeration_32 ++ (Pos : Natural; ++ Names : String; ++ Indexes : System.Address) ++ return String; ++ -- Identical to Image_Enumeration_8 except that it handles types ++ -- using array (0 .. Num) of Natural_32 for the Indexes table. ++ ++ ++end System.Img_Enum; diff --git a/lang/jgnat/files/patch-sem_dist.adb b/lang/jgnat/files/patch-sem_dist.adb new file mode 100644 index 000000000000..48975743c4c4 --- /dev/null +++ b/lang/jgnat/files/patch-sem_dist.adb @@ -0,0 +1,20 @@ +--- sem_dist.adb.orig Fri Sep 1 10:14:00 2000 ++++ sem_dist.adb Fri Feb 8 21:38:20 2002 +@@ -213,7 +213,7 @@ + -- Process_Partition_ID -- + -------------------------- + +- procedure Process_Partition_ID (N : Node_Id) is ++ procedure Process_Partition_Id (N : Node_Id) is + Loc : constant Source_Ptr := Sloc (N); + Ety : Entity_Id; + Nd : Node_Id; +@@ -288,7 +288,7 @@ + Rewrite (N, Convert_To (Typ, Get_Pt_Id_Call)); + Analyze_And_Resolve (N, Typ); + +- end Process_Partition_ID; ++ end Process_Partition_Id; + + ---------------------------------- + -- Process_Remote_AST_Attribute -- diff --git a/lang/jgnat/files/patch-sem_res.adb b/lang/jgnat/files/patch-sem_res.adb new file mode 100644 index 000000000000..c9fabc3d0400 --- /dev/null +++ b/lang/jgnat/files/patch-sem_res.adb @@ -0,0 +1,11 @@ +--- sem_res.adb.orig Fri Sep 1 10:14:00 2000 ++++ sem_res.adb Fri Feb 8 21:31:04 2002 +@@ -1460,7 +1460,7 @@ + if Present (It.Typ) then + Get_Next_Interp (I, It); + else +- exit; ++ exit Interp_Loop; + end if; + end loop Interp_Loop; + end if; diff --git a/lang/jgnat/files/patch-sem_util.adb b/lang/jgnat/files/patch-sem_util.adb new file mode 100644 index 000000000000..c053692f4ae7 --- /dev/null +++ b/lang/jgnat/files/patch-sem_util.adb @@ -0,0 +1,11 @@ +--- sem_util.adb.orig Fri Sep 1 10:14:00 2000 ++++ sem_util.adb Fri Feb 8 21:08:34 2002 +@@ -1745,7 +1745,7 @@ + Assoc := First (Governed_By); + Find_Constraint : loop + Discrim := First (Choices (Assoc)); +- exit when Chars (Discrim_Name) = Chars (Discrim) ++ exit Find_Constraint when Chars (Discrim_Name) = Chars (Discrim) + or else (Present (Corresponding_Discriminant (Entity (Discrim))) + and then + Chars (Corresponding_Discriminant (Entity (Discrim))) diff --git a/lang/jgnat/pkg-message b/lang/jgnat/pkg-message index 54e0fe8ebf69..f7507b97939c 100644 --- a/lang/jgnat/pkg-message +++ b/lang/jgnat/pkg-message @@ -11,7 +11,7 @@ using /bin/sh, you should: --Set your CLASSPATH as follows: - $CLASSPATH=.:/usr/local/lib/gnat/jgnat.jar:$CLASSPATH + $CLASSPATH=.:/usr/local/share/java/classes/jgnat.jar:$CLASSPATH $export CLASSPATH ----------------------------------------------------------------------- diff --git a/lang/jgnat/pkg-plist b/lang/jgnat/pkg-plist index eafc5ca3fff1..82d24beda242 100644 --- a/lang/jgnat/pkg-plist +++ b/lang/jgnat/pkg-plist @@ -700,7 +700,7 @@ lib/jgnat/adalib/s-wwdenu.ali lib/jgnat/adalib/s-wwdwch.ali lib/jgnat/adalib/system.ali lib/jgnat/adalib/text_io.ali -lib/jgnat/jgnat.jar +share/java/classes/jgnat.jar @dirrm lib/jgnat/adainclude @dirrm lib/jgnat/adalib @dirrm lib/jgnat |