summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorKeri Harris <keri@gentoo.org>2006-03-21 08:28:26 +0000
committerKeri Harris <keri@gentoo.org>2006-03-21 08:28:26 +0000
commit8bf29c05f1b78cba17e2103d71398702eaf985e1 (patch)
tree008f87f0bd2be60a5ee8b92eb3114a57e94ae815 /dev-lang/gprolog/files
parentVersion Bump (diff)
downloadhistorical-8bf29c05f1b78cba17e2103d71398702eaf985e1.tar.gz
historical-8bf29c05f1b78cba17e2103d71398702eaf985e1.tar.bz2
historical-8bf29c05f1b78cba17e2103d71398702eaf985e1.zip
Version bump. Closes #116843
Package-Manager: portage-2.1_pre6-r5
Diffstat (limited to 'dev-lang/gprolog/files')
-rw-r--r--dev-lang/gprolog/files/digest-gprolog-1.2.193
-rw-r--r--dev-lang/gprolog/files/gprolog-1.2.19-CFLAGS.patch28
-rw-r--r--dev-lang/gprolog/files/gprolog-1.2.19-bootstrap.patch94
-rw-r--r--dev-lang/gprolog/files/gprolog-1.2.19-gcc4.patch360
-rw-r--r--dev-lang/gprolog/files/gprolog-1.2.19-noexecstack.patch24
-rw-r--r--dev-lang/gprolog/files/gprolog-1.2.19-test.patch280
6 files changed, 789 insertions, 0 deletions
diff --git a/dev-lang/gprolog/files/digest-gprolog-1.2.19 b/dev-lang/gprolog/files/digest-gprolog-1.2.19
new file mode 100644
index 000000000000..4c6e06a967e4
--- /dev/null
+++ b/dev-lang/gprolog/files/digest-gprolog-1.2.19
@@ -0,0 +1,3 @@
+MD5 f884e48b48a73c0785f2e6441bf5b4d7 gprolog-1.2.19.tar.gz 2690586
+RMD160 07c6c26bf6e2dcbf66bd430f23d4789fd7511227 gprolog-1.2.19.tar.gz 2690586
+SHA256 d98bb71e6c7cbf33931fa3d5e89c7d99ff36343cd1a1ba9c5977a41a94087296 gprolog-1.2.19.tar.gz 2690586
diff --git a/dev-lang/gprolog/files/gprolog-1.2.19-CFLAGS.patch b/dev-lang/gprolog/files/gprolog-1.2.19-CFLAGS.patch
new file mode 100644
index 000000000000..71136561c00f
--- /dev/null
+++ b/dev-lang/gprolog/files/gprolog-1.2.19-CFLAGS.patch
@@ -0,0 +1,28 @@
+--- gprolog-1.2.19.orig/src/configure.in 2005-06-14 03:13:41.000000000 +1200
++++ gprolog-1.2.19/src/configure.in 2005-12-31 18:06:04.000000000 +1300
+@@ -354,7 +354,6 @@
+ # * C compiler flags *
+ # ********************
+
+-CFLAGS_MACHINE=
+ CFLAGS_PREFIX_REG=
+
+ AC_C_INLINE
+@@ -388,16 +387,7 @@
+ CFLAGS_PREFIX_REG='-ffixed-%s'
+ CFLAGS_UNSIGNED_CHAR='-funsigned-char'
+
+- CFLAGS_MACHINE=
+- case "$host" in
+- mips*irix*) CFLAGS_MACHINE='-march=4000';;
+- *sparc*sunos4.1.3) CFLAGS_MACHINE='-msupersparc';;
+- *sparc*solaris) CFLAGS_MACHINE='-msupersparc';;
+- i686*) CFLAGS_MACHINE='-march=pentiumpro';;
+- i586*) CFLAGS_MACHINE='-march=pentium';;
+- i*86*) CFLAGS_MACHINE='-march=i486';;
+- powerpc*darwin*) CFLAGS_MACHINE='-mpowerpc -no-cpp-precomp';;
+- esac
++ CFLAGS_MACHINE="$CFLAGS_MACHINE"
+
+ case "$host" in
+ i*86*) if test "$USE_EBP" != no; then
diff --git a/dev-lang/gprolog/files/gprolog-1.2.19-bootstrap.patch b/dev-lang/gprolog/files/gprolog-1.2.19-bootstrap.patch
new file mode 100644
index 000000000000..0eb0e9164484
--- /dev/null
+++ b/dev-lang/gprolog/files/gprolog-1.2.19-bootstrap.patch
@@ -0,0 +1,94 @@
+diff -ur gprolog-1.2.19.orig/src/BipsFD/Makefile.in gprolog-1.2.19/src/BipsFD/Makefile.in
+--- gprolog-1.2.19.orig/src/BipsFD/Makefile.in 2005-06-14 03:13:36.000000000 +1200
++++ gprolog-1.2.19/src/BipsFD/Makefile.in 2006-03-05 10:06:58.000000000 +1300
+@@ -1,6 +1,6 @@
+ LIB_BIPS_FD = @LIB_BIPS_FD@
+ LIB_ENGINE_FD = @LIB_ENGINE_FD@
+-GPLC = @GPLC@
++GPLC = ../TopComp/@GPLC@
+ CC = @CC@
+ CFLAGS = @CFLAGS@
+ AR_RC = @AR_RC@
+diff -ur gprolog-1.2.19.orig/src/BipsPl/Makefile.in gprolog-1.2.19/src/BipsPl/Makefile.in
+--- gprolog-1.2.19.orig/src/BipsPl/Makefile.in 2005-06-14 03:13:38.000000000 +1200
++++ gprolog-1.2.19/src/BipsPl/Makefile.in 2006-03-05 10:07:17.000000000 +1300
+@@ -3,7 +3,7 @@
+ LIB_BIPS_PL = @LIB_BIPS_PL@
+ LIB_ENGINE_PL = @LIB_ENGINE_PL@
+ LIB_LINEDIT = @LIB_LINEDIT@
+-GPLC = @GPLC@
++GPLC = ../TopComp/@GPLC@
+ CC = @CC@
+ CFLAGS = @CFLAGS@
+ CFLAGS_UNSIGNED_CHAR = @CFLAGS_UNSIGNED_CHAR@
+diff -ur gprolog-1.2.19.orig/src/EngineFD/Makefile.in gprolog-1.2.19/src/EngineFD/Makefile.in
+--- gprolog-1.2.19.orig/src/EngineFD/Makefile.in 2005-06-14 03:13:42.000000000 +1200
++++ gprolog-1.2.19/src/EngineFD/Makefile.in 2006-03-05 10:07:50.000000000 +1300
+@@ -1,5 +1,5 @@
+ LIB_ENGINE_FD = @LIB_ENGINE_FD@
+-GPLC = @GPLC@
++GPLC = ../TopComp/@GPLC@
+ CC = @CC@
+ CFLAGS = @CFLAGS@
+ AR_RC = @AR_RC@
+diff -ur gprolog-1.2.19.orig/src/EnginePl/Makefile.in gprolog-1.2.19/src/EnginePl/Makefile.in
+--- gprolog-1.2.19.orig/src/EnginePl/Makefile.in 2005-06-14 03:13:43.000000000 +1200
++++ gprolog-1.2.19/src/EnginePl/Makefile.in 2006-03-05 10:06:39.000000000 +1300
+@@ -1,7 +1,7 @@
+ ROOT_DIR1 = @ROOT_DIR1@
+ TOP_LEVEL = @TOP_LEVEL@
+ LIB_ENGINE_PL = @LIB_ENGINE_PL@
+-GPLC = @GPLC@
++GPLC = ../TopComp/@GPLC@
+ CC = @CC@
+ CFLAGS = @CFLAGS@
+ AR_RC = @AR_RC@
+diff -ur gprolog-1.2.19.orig/src/Fd2C/Makefile.in gprolog-1.2.19/src/Fd2C/Makefile.in
+--- gprolog-1.2.19.orig/src/Fd2C/Makefile.in 2005-06-14 03:13:44.000000000 +1200
++++ gprolog-1.2.19/src/Fd2C/Makefile.in 2006-03-05 10:08:29.000000000 +1300
+@@ -1,4 +1,4 @@
+-GPLC = @GPLC@
++GPLC = ../TopComp/@GPLC@
+ GPLCFLAGS = --fast-math
+ OBJS = fd2c@OBJ_SUFFIX@ read_file@OBJ_SUFFIX@ parse@OBJ_SUFFIX@ \
+ compile@OBJ_SUFFIX@
+diff -ur gprolog-1.2.19.orig/src/Ma2Asm/Makefile.in gprolog-1.2.19/src/Ma2Asm/Makefile.in
+--- gprolog-1.2.19.orig/src/Ma2Asm/Makefile.in 2005-06-14 03:13:45.000000000 +1200
++++ gprolog-1.2.19/src/Ma2Asm/Makefile.in 2006-03-05 10:09:03.000000000 +1300
+@@ -1,4 +1,4 @@
+-GPLC = @GPLC@
++GPLC = ../TopComp/@GPLC@
+ CC = @CC@
+ CFLAGS = @CFLAGS@
+
+diff -ur gprolog-1.2.19.orig/src/Pl2Wam/Makefile.in gprolog-1.2.19/src/Pl2Wam/Makefile.in
+--- gprolog-1.2.19.orig/src/Pl2Wam/Makefile.in 2005-06-14 03:13:46.000000000 +1200
++++ gprolog-1.2.19/src/Pl2Wam/Makefile.in 2006-03-05 10:09:28.000000000 +1300
+@@ -1,4 +1,4 @@
+-GPLC = @GPLC@
++GPLC = ../TopComp/@GPLC@
+ GPLCFLAGS = --fast-math
+ OBJS = pl2wam@OBJ_SUFFIX@ read_file@OBJ_SUFFIX@ bip_list@OBJ_SUFFIX@ \
+ syn_sugar@OBJ_SUFFIX@ internal@OBJ_SUFFIX@ code_gen@OBJ_SUFFIX@ \
+@@ -58,7 +58,7 @@
+
+
+ make_bip_list@EXE_SUFFIX@: make_bip_list.pl ../Bips??/[a-z]??*.pl
+- $(GPLC) -o make_bip_list@EXE_SUFFIX@ make_bip_list.pl
++ ../TopComp/$(GPLC) -o make_bip_list@EXE_SUFFIX@ make_bip_list.pl
+ ./make_bip_list@EXE_SUFFIX@ >bip_list.pl
+ make
+
+diff -ur gprolog-1.2.19.orig/src/TopComp/Makefile.in gprolog-1.2.19/src/TopComp/Makefile.in
+--- gprolog-1.2.19.orig/src/TopComp/Makefile.in 2005-06-14 03:13:47.000000000 +1200
++++ gprolog-1.2.19/src/TopComp/Makefile.in 2006-03-05 10:09:53.000000000 +1300
+@@ -1,7 +1,7 @@
+ TOP_LEVEL = @TOP_LEVEL@
+ TOP_LEVEL_FLAGS = @TOP_LEVEL_FLAGS@
+-GPLC = @GPLC@
+-HEXGPLC = @HEXGPLC@
++GPLC = ../TopComp/@GPLC@
++HEXGPLC = ../TopComp/@HEXGPLC@
+ CC = @CC@
+ CFLAGS = @CFLAGS@
+ LDLIBS = @LDLIBS@
diff --git a/dev-lang/gprolog/files/gprolog-1.2.19-gcc4.patch b/dev-lang/gprolog/files/gprolog-1.2.19-gcc4.patch
new file mode 100644
index 000000000000..f56207d306b7
--- /dev/null
+++ b/dev-lang/gprolog/files/gprolog-1.2.19-gcc4.patch
@@ -0,0 +1,360 @@
+--- gprolog-1.2.19.orig/src/BipsFD/fd_bool_c.c 2005-06-14 03:40:09.000000000 +1200
++++ gprolog-1.2.19/src/BipsFD/fd_bool_c.c 2006-01-23 09:46:19.000000000 +1300
+@@ -201,6 +201,8 @@
+ static void
+ Fd_Bool_Initializer(void)
+ {
++ SET_OBJ_CHAIN_STOP;
++
+ bool_tbl[NOT] = Functor_Arity(Create_Atom("#\\"), 1);
+
+ bool_tbl[EQUIV] = Functor_Arity(Create_Atom("#<=>"), 2);
+--- gprolog-1.2.19.orig/src/BipsFD/math_supp.c 2005-06-14 03:40:10.000000000 +1200
++++ gprolog-1.2.19/src/BipsFD/math_supp.c 2006-01-23 09:46:39.000000000 +1300
+@@ -206,6 +206,8 @@
+ static void
+ Math_Supp_Initializer(void)
+ {
++ SET_OBJ_CHAIN_STOP;
++
+ arith_tbl[PLUS_1] = Functor_Arity(ATOM_CHAR('+'), 1);
+ arith_tbl[PLUS_2] = Functor_Arity(ATOM_CHAR('+'), 2);
+ arith_tbl[MINUS_1] = Functor_Arity(ATOM_CHAR('-'), 1);
+--- gprolog-1.2.19.orig/src/BipsPl/all_solut_c.c 2005-06-14 03:40:10.000000000 +1200
++++ gprolog-1.2.19/src/BipsPl/all_solut_c.c 2006-01-23 09:47:09.000000000 +1300
+@@ -123,6 +123,8 @@
+ static void
+ All_Solut_Initializer(void)
+ {
++ SET_OBJ_CHAIN_STOP;
++
+ exist_2 = Functor_Arity(ATOM_CHAR('^'), 2);
+ }
+
+--- gprolog-1.2.19.orig/src/BipsPl/arith_inl_c.c 2005-06-14 03:40:10.000000000 +1200
++++ gprolog-1.2.19/src/BipsPl/arith_inl_c.c 2006-01-23 09:47:20.000000000 +1300
+@@ -99,6 +99,8 @@
+ static void
+ Arith_Initializer(void)
+ {
++ SET_OBJ_CHAIN_STOP;
++
+ ArithInf arith_info;
+
+ arith_tbl = Hash_Alloc_Table(START_ARITH_TBL_SIZE, sizeof(ArithInf));
+--- gprolog-1.2.19.orig/src/BipsPl/bc_supp.c 2005-06-14 03:40:10.000000000 +1200
++++ gprolog-1.2.19/src/BipsPl/bc_supp.c 2006-01-23 09:47:35.000000000 +1300
+@@ -283,6 +283,8 @@
+ static void
+ Byte_Code_Initializer(void)
+ {
++ SET_OBJ_CHAIN_STOP;
++
+ BCWord *p = op_tbl;
+
+ Op_In_Tbl("get_variable", GET_X_VARIABLE);
+--- gprolog-1.2.19.orig/src/BipsPl/debugger_c.c 2005-06-14 03:40:11.000000000 +1200
++++ gprolog-1.2.19/src/BipsPl/debugger_c.c 2006-01-23 09:47:53.000000000 +1300
+@@ -164,6 +164,8 @@
+ static void
+ Debug_Initializer(void)
+ {
++ SET_OBJ_CHAIN_STOP;
++
+ New_Object(My_System_Directives, NULL);
+ }
+
+--- gprolog-1.2.19.orig/src/BipsPl/dynam_supp.c 2005-06-14 03:40:11.000000000 +1200
++++ gprolog-1.2.19/src/BipsPl/dynam_supp.c 2006-01-23 09:20:39.000000000 +1300
+@@ -601,7 +601,8 @@
+ dyn = scan->dyn;
+
+ if (dyn->first_erased_cl) /* we must keep it - free impossible */
+- (unsigned long) (dyn->first_erased_cl) |= 1; /* mark it */
++ dyn->first_erased_cl = (DynCInf *)
++ ((unsigned long) (dyn->first_erased_cl) | 1); /* mark it */
+ }
+
+
+--- gprolog-1.2.19.orig/src/BipsPl/error_supp.c 2005-06-14 03:40:11.000000000 +1200
++++ gprolog-1.2.19/src/BipsPl/error_supp.c 2006-01-23 09:48:04.000000000 +1300
+@@ -117,6 +117,8 @@
+ static void
+ Error_Supp_Initializer(void)
+ {
++ SET_OBJ_CHAIN_STOP;
++
+ type_atom = Create_Atom("atom");
+ type_atomic = Create_Atom("atomic");
+ type_byte = Create_Atom("byte");
+--- gprolog-1.2.19.orig/src/BipsPl/expand_c.c 2005-06-14 03:40:11.000000000 +1200
++++ gprolog-1.2.19/src/BipsPl/expand_c.c 2006-01-23 09:48:16.000000000 +1300
+@@ -92,6 +92,8 @@
+ static void
+ Expand_Initializer(void)
+ {
++ SET_OBJ_CHAIN_STOP;
++
+ int atom_dcg;
+
+ atom_dcg = Create_Atom("-->");
+--- gprolog-1.2.19.orig/src/BipsPl/flag_c.c 2005-06-14 03:40:11.000000000 +1200
++++ gprolog-1.2.19/src/BipsPl/flag_c.c 2006-01-23 09:48:33.000000000 +1300
+@@ -77,7 +77,6 @@
+ static int atom_on;
+ static int atom_off;
+
+-static int atom_error;
+ static int atom_warning;
+ static int atom_fail;
+
+@@ -118,6 +117,8 @@
+ static void
+ Flag_Initializer(void)
+ {
++ SET_OBJ_CHAIN_STOP;
++
+ atom_flag_tbl[FLAG_BOUNDED] = Create_Atom("bounded");
+ atom_flag_tbl[FLAG_MAX_INTEGER] = Create_Atom("max_integer");
+ atom_flag_tbl[FLAG_MIN_INTEGER] = Create_Atom("min_integer");
+--- gprolog-1.2.19.orig/src/BipsPl/foreign_supp.c 2005-06-14 03:40:11.000000000 +1200
++++ gprolog-1.2.19/src/BipsPl/foreign_supp.c 2006-01-23 09:48:42.000000000 +1300
+@@ -98,6 +98,8 @@
+ static void
+ Foreign_Initializer(void)
+ {
++ SET_OBJ_CHAIN_STOP;
++
+ goal_H = H;
+ H = H + MAX_ARITY + 1;
+
+--- gprolog-1.2.19.orig/src/BipsPl/g_var_inl_c.c 2005-06-16 05:04:06.000000000 +1200
++++ gprolog-1.2.19/src/BipsPl/g_var_inl_c.c 2006-01-23 09:49:06.000000000 +1300
+@@ -167,6 +167,8 @@
+ static void
+ G_Var_Initializer(void)
+ {
++ SET_OBJ_CHAIN_STOP;
++
+ atom_g_array = Create_Atom("g_array");
+ atom_g_array_auto = Create_Atom("g_array_auto");
+ atom_g_array_extend = Create_Atom("g_array_extend");
+--- gprolog-1.2.19.orig/src/BipsPl/oper_c.c 2005-06-14 03:40:11.000000000 +1200
++++ gprolog-1.2.19/src/BipsPl/oper_c.c 2006-01-23 09:49:19.000000000 +1300
+@@ -86,6 +86,8 @@
+ static void
+ Oper_Initializer(void)
+ {
++ SET_OBJ_CHAIN_STOP;
++
+ char *a[7] = { "fx", "fy", "xf", "yf", "xfx", "xfy", "yfx" };
+ int i;
+
+--- gprolog-1.2.19.orig/src/BipsPl/os_interf_c.c 2005-06-14 03:40:11.000000000 +1200
++++ gprolog-1.2.19/src/BipsPl/os_interf_c.c 2006-01-23 09:49:33.000000000 +1300
+@@ -94,8 +94,6 @@
+
+ static int atom_dt;
+
+-static int atom_read;
+-static int atom_write;
+ static int atom_execute;
+ static int atom_search;
+
+@@ -138,6 +136,8 @@
+ static void
+ Os_Interf_Initializer(void)
+ {
++ SET_OBJ_CHAIN_STOP;
++
+ atom_dt = Create_Atom("dt");
+
+ atom_read = Create_Atom("read");
+--- gprolog-1.2.19.orig/src/BipsPl/parse_supp.c 2005-06-14 03:40:11.000000000 +1200
++++ gprolog-1.2.19/src/BipsPl/parse_supp.c 2006-01-23 09:49:53.000000000 +1300
+@@ -124,6 +124,8 @@
+ static void
+ Parse_Supp_Initializer(void)
+ {
++ SET_OBJ_CHAIN_STOP;
++
+ atom_var = Create_Atom("var");
+ atom_string = Create_Atom("string");
+ atom_punct = Create_Atom("punct");
+--- gprolog-1.2.19.orig/src/BipsPl/pretty_c.c 2005-06-14 03:40:12.000000000 +1200
++++ gprolog-1.2.19/src/BipsPl/pretty_c.c 2006-01-23 09:50:07.000000000 +1300
+@@ -112,6 +112,8 @@
+ static void
+ Pretty_Initializer(void)
+ {
++ SET_OBJ_CHAIN_STOP;
++
+ atom_clause = Create_Atom(":-");
+ atom_dcg = Create_Atom("-->");
+ atom_if = Create_Atom("->");
+--- gprolog-1.2.19.orig/src/BipsPl/sockets_c.c 2005-06-14 03:40:12.000000000 +1200
++++ gprolog-1.2.19/src/BipsPl/sockets_c.c 2006-01-23 09:50:20.000000000 +1300
+@@ -100,6 +100,8 @@
+ static void
+ Socket_Initializer(void)
+ {
++ SET_OBJ_CHAIN_STOP;
++
+ #ifdef _WIN32
+ WORD versReqstd = MAKEWORD( 2, 2); // Current Winsock 2 DLL's
+ WSADATA wsaData;
+--- gprolog-1.2.19.orig/src/BipsPl/sort_c.c 2005-06-14 03:40:12.000000000 +1200
++++ gprolog-1.2.19/src/BipsPl/sort_c.c 2006-01-23 09:50:31.000000000 +1300
+@@ -68,6 +68,8 @@
+ static void
+ Sort_Initializer(void)
+ {
++ SET_OBJ_CHAIN_STOP;
++
+ minus_2 = Functor_Arity(ATOM_CHAR('-'), 2);
+ }
+
+--- gprolog-1.2.19.orig/src/BipsPl/write_supp.c 2005-06-14 03:40:12.000000000 +1200
++++ gprolog-1.2.19/src/BipsPl/write_supp.c 2006-01-23 09:50:54.000000000 +1300
+@@ -143,6 +143,8 @@
+ static void
+ Write_Supp_Initializer(void)
+ {
++ SET_OBJ_CHAIN_STOP;
++
+ atom_dots = Create_Atom("...");
+
+ curly_brackets_1 = Functor_Arity(atom_curly_brackets, 1);
+--- gprolog-1.2.19.orig/src/EngineFD/fd_inst.h 2005-06-14 03:40:14.000000000 +1200
++++ gprolog-1.2.19/src/EngineFD/fd_inst.h 2006-01-23 09:52:35.000000000 +1300
+@@ -111,8 +111,8 @@
+
+ #define CHAIN_RECORD_FRAME_SIZE 2
+
+-#define CF_Pointer(rec_adr) ((WamWord *) (rec_adr[0]))
+-#define Next_Chain(rec_adr) ((WamWord *) (rec_adr[1]))
++#define CF_Pointer(rec_adr) (*(WamWord **) &(rec_adr[0]))
++#define Next_Chain(rec_adr) (*(WamWord **) &(rec_adr[1]))
+
+
+
+@@ -123,9 +123,9 @@
+
+ #define OFFSET_OF_OPTIM_POINTER 1 /* this offset must corresponds to */
+
+-#define AF_Pointer(cf) ((WamWord *) (cf[0]))
+-#define Optim_Pointer(cf) ((WamWord *) (cf[1])) /* this cell */
+-#define Cstr_Address(cf) ((long (*)()) (cf[2]))
++#define AF_Pointer(cf) (*(WamWord **) &(cf[0]))
++#define Optim_Pointer(cf) (*(WamWord **) &(cf[1])) /* this cell */
++#define Cstr_Address(cf) (*(long (**)()) &(cf[2]))
+
+
+
+--- gprolog-1.2.19.orig/src/EnginePl/obj_chain.c 2005-06-14 03:40:15.000000000 +1200
++++ gprolog-1.2.19/src/EnginePl/obj_chain.c 2006-01-23 09:40:36.000000000 +1300
+@@ -24,6 +24,8 @@
+
+ /* $Id: gprolog-1.2.19-gcc4.patch,v 1.1 2006/03/21 08:28:26 keri Exp $ */
+
++#define OBJ_CHAIN 1
++
+ #include <stdio.h>
+
+ #include "obj_chain.h"
+@@ -181,7 +183,7 @@
+ {
+ if (p->magic1 != OBJ_CHAIN_MAGIC_1 || p->magic2 != OBJ_CHAIN_MAGIC_2
+ || (q = p->next) < (ObjChain **) &obj_chain_begin
+- || q > &obj_chain_end || *q != p)
++ || q > &obj_chain_end)
+ {
+ #ifdef DEBUG
+ #if 0
+--- gprolog-1.2.19.orig/src/EnginePl/obj_chain.h 2005-06-14 03:40:15.000000000 +1200
++++ gprolog-1.2.19/src/EnginePl/obj_chain.h 2006-01-23 09:31:49.000000000 +1300
+@@ -83,18 +83,24 @@
+ #define ATTR_TO_KEEP_UNREF_STATIC_VAR __attribute__ ((unused))
+ #endif
+
++#ifdef OBJ_CHAIN
++ObjChain *obj_chain_stop_extern = NULL;
++#else
++
+ #ifdef OBJ_INIT
+
+ static void (OBJ_INIT) ();
+
+ #ifndef _MSC_VER
+
+-extern ObjChain *obj_chain_stop;
++static ObjChain obj_chain_start_mark;
++
++static ObjChain *obj_chain_stop = &obj_chain_start_mark;
+
+ static ObjChain obj_chain_start ATTR_TO_KEEP_UNREF_STATIC_VAR =
+ { OBJ_CHAIN_MAGIC_1, OBJ_CHAIN_MAGIC_2, &obj_chain_stop, OBJ_INIT };
+
+-static ObjChain *obj_chain_stop = &obj_chain_start;
++#define SET_OBJ_CHAIN_STOP {}
+
+ #if 0 /* antoher way to force to keep the chain : a fct using obj_chain_start
+ which references the initializer function (OBJ_INIT) */
+@@ -114,3 +120,5 @@
+ #endif /* _MSC_VER */
+
+ #endif /* OBJ_INIT */
++
++#endif /* OBJ_CHAIN */
+--- gprolog-1.2.19.orig/src/EnginePl/test_oc_defs.h 2005-06-14 03:13:43.000000000 +1200
++++ gprolog-1.2.19/src/EnginePl/test_oc_defs.h 2006-01-23 09:45:21.000000000 +1300
+@@ -25,6 +25,7 @@
+ \
+ static void Init_Tables() \
+ { \
++ SET_OBJ_CHAIN_STOP; \
+ printf("object <%s> found\n",name); \
+ printf(" start at:%#lx\n",(long) &obj_chain_start); \
+ printf(" &name:%#lx\n",(long) &name); \
+--- gprolog-1.2.19.orig/src/EnginePl/wam_inst.h 2005-06-14 03:40:15.000000000 +1200
++++ gprolog-1.2.19/src/EnginePl/wam_inst.h 2006-01-23 09:16:11.000000000 +1300
+@@ -67,10 +67,10 @@
+
+ #define ENVIR_STATIC_SIZE 3
+
+-#define CPE(e) ((WamCont) (e[-1]))
+-#define BCIE(e) ((WamWord) (e[-2]))
+-#define EE(e) ((WamWord *) (e[-3]))
+-#define Y(e, y) ((WamWord) (e[-4 - (y)]))
++#define CPE(e) (*(WamCont *) &(e[-1]))
++#define BCIE(e) (*(WamWord *) &(e[-2]))
++#define EE(e) (*(WamWord **) &(e[-3]))
++#define Y(e, y) (*(WamWord *) &(e[-4 - (y)]))
+
+ #define ENVIR_NAMES {"CPE", "BCIE", "EE"}
+
+@@ -81,15 +81,15 @@
+
+ #define CHOICE_STATIC_SIZE 8
+
+-#define ALTB(b) ((CodePtr) (b[-1]))
+-#define CPB(b) ((WamCont) (b[-2]))
+-#define BCIB(b) ((WamWord) (b[-3]))
+-#define EB(b) ((WamWord *) (b[-4]))
+-#define BB(b) ((WamWord *) (b[-5]))
+-#define HB(b) ((WamWord *) (b[-6]))
+-#define TRB(b) ((WamWord *) (b[-7]))
+-#define CSB(b) ((WamWord *) (b[-8]))
+-#define AB(b, a) ((WamWord) (b[-9 - (a)]))
++#define ALTB(b) (*(CodePtr *) &(b[-1]))
++#define CPB(b) (*(WamCont *) &(b[-2]))
++#define BCIB(b) (*(WamWord *) &(b[-3]))
++#define EB(b) (*(WamWord **) &(b[-4]))
++#define BB(b) (*(WamWord **) &(b[-5]))
++#define HB(b) (*(WamWord **) &(b[-6]))
++#define TRB(b) (*(WamWord **) &(b[-7]))
++#define CSB(b) (*(WamWord **) &(b[-8]))
++#define AB(b, a) (*(WamWord *) &(b[-9 - (a)]))
+
+ #define CHOICE_NAMES {"ALTB", "CPB", "BCIB", "EB", "BB", \
+ "HB", "TRB", "CSB"}
diff --git a/dev-lang/gprolog/files/gprolog-1.2.19-noexecstack.patch b/dev-lang/gprolog/files/gprolog-1.2.19-noexecstack.patch
new file mode 100644
index 000000000000..26e2793655b6
--- /dev/null
+++ b/dev-lang/gprolog/files/gprolog-1.2.19-noexecstack.patch
@@ -0,0 +1,24 @@
+--- gprolog-1.2.19.orig/src/Ma2Asm/ix86_any.c 2005-06-14 03:40:15.000000000 +1200
++++ gprolog-1.2.19/src/Ma2Asm/ix86_any.c 2006-03-05 09:26:21.000000000 +1300
+@@ -164,6 +164,9 @@
+ void
+ Asm_Stop(void)
+ {
++ Label_Printf("#ifdef __ELF__");
++ Label_Printf(".section .note.GNU-stack,\"\",@progbits");
++ Label_Printf("#endif");
+ }
+
+
+--- gprolog-1.2.19.orig/src/Ma2Asm/powerpc_any.c 2005-06-14 03:40:22.000000000 +1200
++++ gprolog-1.2.19/src/Ma2Asm/powerpc_any.c 2006-03-05 09:40:34.000000000 +1300
+@@ -161,6 +161,9 @@
+ void
+ Asm_Stop(void)
+ {
++ Label_Printf("#ifdef __ELF__");
++ Label_Printf(".section .note.GNU-stack,\"\",@progbits");
++ Label_Printf("#endif");
+ }
+
+
diff --git a/dev-lang/gprolog/files/gprolog-1.2.19-test.patch b/dev-lang/gprolog/files/gprolog-1.2.19-test.patch
new file mode 100644
index 000000000000..81aba9164ef8
--- /dev/null
+++ b/dev-lang/gprolog/files/gprolog-1.2.19-test.patch
@@ -0,0 +1,280 @@
+--- gprolog-1.2.19.orig/src/Makefile.in 2005-06-14 03:13:45.000000000 +1200
++++ gprolog-1.2.19/src/Makefile.in 2006-01-23 11:52:07.000000000 +1300
+@@ -145,7 +145,8 @@
+ # --- CHECKS --- #
+
+ check:
+- @echo "No checks implemented (yet)."
++ (cd EnginePl; $(MAKE) test_oc) || exit 1
++ . ./SETVARS; (cd Ma2Asm; $(MAKE) check) || exit 1
+
+
+ # --- CLEAN --- #
+--- gprolog-1.2.19.orig/src/EnginePl/Makefile.in 2005-06-14 03:13:43.000000000 +1200
++++ gprolog-1.2.19/src/EnginePl/Makefile.in 2006-01-23 15:37:43.000000000 +1300
+@@ -134,6 +134,7 @@
+ $(CC) @CC_EXE_NAME_OPT@test_oc@EXE_SUFFIX@ obj_begin1@OBJ_SUFFIX@ \
+ $(TEST_OC_OBJS) obj_chain1@OBJ_SUFFIX@ test_oc@OBJ_SUFFIX@ \
+ obj_end1@OBJ_SUFFIX@
++ ./test_oc || exit 1
+
+ clean-test_oc:
+ rm -f obj_begin1@OBJ_SUFFIX@ obj_chain1@OBJ_SUFFIX@ obj_end1@OBJ_SUFFIX@ \
+--- gprolog-1.2.19.orig/src/Ma2Asm/Makefile.in 2005-06-14 03:13:45.000000000 +1200
++++ gprolog-1.2.19/src/Ma2Asm/Makefile.in 2006-01-23 13:21:58.000000000 +1300
+@@ -46,19 +46,17 @@
+ FC=-DFAST
+
+ check@OBJ_SUFFIX@: check.c
+- if [ "$$FC" = "Y" ]; then FCFLAGS='-DFAST'; fi; \
+- $(GPLC) -C "$(CFLAGS) $$FCFLAGS" -c check.c
++ $(GPLC) -C "$(CFLAGS)" -c check.c
+
+ check_ma@ASM_SUFFIX@: check_ma.ma ma2asm@EXE_SUFFIX@
+- if [ "$$FC" = "Y" ]; then cp check_ma.ma tmp.ma; \
+- else sed -e 's/ fast / /' check_ma.ma >tmp.ma; fi; \
+- $(GPLC) -S --comment tmp.ma -o check_ma@ASM_SUFFIX@
++ $(GPLC) -S --comment check_ma.ma -o check_ma@ASM_SUFFIX@
+
+ check_ma@OBJ_SUFFIX@: check_ma@ASM_SUFFIX@
+ $(GPLC) -c check_ma@ASM_SUFFIX@
+
+ check@EXE_SUFFIX@: $(CHECK_OBJS)
+ $(CC) $(CFLAGS) @CC_EXE_NAME_OPT@check@EXE_SUFFIX@ $(CHECK_OBJS)
++ ./check || exit 1
+
+ clean-check:
+ rm -f check@OBJ_SUFFIX@ check_ma@ASM_SUFFIX@ check_ma@OBJ_SUFFIX@ check@EXE_SUFFIX@
+--- gprolog-1.2.19.orig/src/Ma2Asm/check.c 2005-06-14 03:40:15.000000000 +1200
++++ gprolog-1.2.19/src/Ma2Asm/check.c 2006-01-23 21:20:11.000000000 +1300
+@@ -30,24 +30,11 @@
+ #define IF_NO_FD_FILE
+ #include "engine_pl.h"
+
+-#ifndef FAST /* see Makefile */
+-
+-#ifdef FC_USED_TO_COMPILE_CORE
+-#warning NO FC
++#ifndef FC_USED_TO_COMPILE_CORE
+ #undef FC
+ #define FC
+ #endif
+
+-#elif !defined(FC_USED_TO_COMPILE_CORE)
+-
+-#error FAST defined but cannot compile for FC
+-
+-#else
+-
+-#warning WITH FC
+-
+-#endif
+-
+ /*---------------------------------*
+ * Constants *
+ *---------------------------------*/
+@@ -272,7 +259,7 @@
+
+
+
+-void
++void FC
+ Allocate(int x) /* only to update the register for E */
+ {
+ }
+@@ -398,7 +385,7 @@
+
+ void FC test_call_c1(void);
+
+-void
++void FC
+ test_call_c1(void)
+ {
+ x++;
+@@ -456,7 +443,7 @@
+
+ void FC test_arg_int1(int a, int b, int c, int d);
+
+-void
++void FC
+ test_arg_int1(int a, int b, int c, int d)
+ {
+ if (a != 12 || b != -1 || c != 4095 || d != 123456789)
+@@ -480,7 +467,7 @@
+
+ void FC test_arg_double1(double a, double b, double c);
+
+-void
++void FC
+ test_arg_double1(double a, double b, double c)
+ {
+ if (a != 12.456 || b != -1.3e-102 || c != -3.141593)
+@@ -504,7 +491,7 @@
+
+ void FC test_arg_string1(char *a, char *b);
+
+-void
++void FC
+ test_arg_string1(char *a, char *b)
+ {
+ #ifdef DEBUG
+@@ -533,7 +520,7 @@
+
+ void FC test_arg_mem_l1(long a, long b, long *c, long d, long e, long *f);
+
+-void
++void FC
+ test_arg_mem_l1(long a, long b, long *c, long d, long e, long *f)
+ {
+ if (a != 128 || b != 12345 || c != (long *) test_arg_mem_l
+@@ -560,7 +547,7 @@
+
+ void FC test_arg_x1(WamWord a, WamWord *b, WamWord c, WamWord *d);
+
+-void
++void FC
+ test_arg_x1(WamWord a, WamWord *b, WamWord c, WamWord *d)
+ {
+ if (a != 123987 || b != &X(0) || c != 987654321 || d != &X(128))
+@@ -586,7 +573,7 @@
+
+ void FC test_arg_y1(WamWord a, WamWord *b, WamWord c, WamWord *d);
+
+-void
++void FC
+ test_arg_y1(WamWord a, WamWord *b, WamWord c, WamWord *d)
+ {
+ if (a != 1928374 || b != &Y(E, 0) || c != 456789 || d != &Y(E, 6))
+@@ -613,7 +600,7 @@
+
+ void FC test_arg_fl_array1(long a, long b, long *c, long *d);
+
+-void
++void FC
+ test_arg_fl_array1(long a, long b, long *c, long *d)
+ {
+ #ifdef DEBUG
+@@ -645,7 +632,7 @@
+
+ void FC test_arg_fd_array1(double a, double b, double *c, double *d);
+
+-void
++void FC
+ test_arg_fd_array1(double a, double b, double *c, double *d)
+ {
+ if (a != 1.2e30 || b != -1.234567 || c != foreign_double
+@@ -684,7 +671,7 @@
+ WamWord k, WamWord *l, WamWord m, WamWord *n,
+ double o);
+
+-void
++void FC
+ test_call_c_lot_args1(WamWord n0, WamWord n1, WamWord n2, WamWord n3,
+ WamWord n4, WamWord n5,
+ void (*a) (), long b, int c, int d, double e, char *f,
+@@ -716,7 +703,7 @@
+
+ long FC test_jump_ret1(long addr);
+
+-long
++long FC
+ test_jump_ret1(long addr)
+ {
+ #ifdef DEBUG
+@@ -733,7 +720,7 @@
+
+ void FC test_jump_ret2(void);
+
+-void
++void FC
+ test_jump_ret2(void)
+ {
+ #ifdef DEBUG
+@@ -762,7 +749,7 @@
+
+ int FC test_fail_ret1(void);
+
+-int
++int FC
+ test_fail_ret1(void)
+ {
+ x++;
+@@ -816,7 +803,7 @@
+
+ long FC test_move_ret_x1(void);
+
+-long
++long FC
+ test_move_ret_x1(void)
+ {
+ x++;
+@@ -843,7 +830,7 @@
+
+ long FC test_move_ret_y1(void);
+
+-long
++long FC
+ test_move_ret_y1(void)
+ {
+ x++;
+@@ -870,7 +857,7 @@
+
+ long FC test_move_ret_fl1(void);
+
+-long
++long FC
+ test_move_ret_fl1(void)
+ {
+ x++;
+@@ -897,7 +884,7 @@
+
+ double FC test_move_ret_fd1(void);
+
+-double
++double FC
+ test_move_ret_fd1(void)
+ {
+ x++;
+@@ -922,7 +909,7 @@
+
+ long FC test_switch_ret1(void);
+
+-long
++long FC
+ test_switch_ret1(void)
+ {
+ return swt[i];
+@@ -931,7 +918,7 @@
+
+ void FC test_switch_ret2(int k);
+
+-void
++void FC
+ test_switch_ret2(int k)
+ {
+ if (k != i)
+@@ -968,13 +955,13 @@
+ Fd_Init_Engine(void)
+ {
+ }
+-int
++int FC
+ Create_Atom(char *name)
+ {
+ return 1;
+ }
+
+-PredInf *
++PredInf * FC
+ Lookup_Pred(int func, int arity)
+ {
+ return NULL;
+@@ -985,7 +972,7 @@
+ {
+ }
+ AtomInf atom_tbl[1];
+-void
++void FC
+ Create_Choice_Point(CodePtr codep_alt, int arity)
+ {
+ }