summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMichael Sterrett <mr_bones_@gentoo.org>2005-03-19 19:40:23 +0000
committerMichael Sterrett <mr_bones_@gentoo.org>2005-03-19 19:40:23 +0000
commitd1143bbbc9d333d3c8fc5e26e004403fae1adfa6 (patch)
tree70a92c0c89432bcf7927c75125266730a17d0c0c /dev-lang/ocaml
parentDisabled src_test to fix bug #85689. Marked 1.50 and 1.51 stable. (diff)
downloadhistorical-d1143bbbc9d333d3c8fc5e26e004403fae1adfa6.tar.gz
historical-d1143bbbc9d333d3c8fc5e26e004403fae1adfa6.tar.bz2
historical-d1143bbbc9d333d3c8fc5e26e004403fae1adfa6.zip
resurrect versions to fix dep breakage
Package-Manager: portage-2.0.51.19
Diffstat (limited to 'dev-lang/ocaml')
-rw-r--r--dev-lang/ocaml/ChangeLog9
-rw-r--r--dev-lang/ocaml/Manifest19
-rw-r--r--dev-lang/ocaml/files/digest-ocaml-3.07-r12
-rw-r--r--dev-lang/ocaml/files/digest-ocaml-3.081
-rw-r--r--dev-lang/ocaml/files/ocaml-3.07-hppa.patch463
-rw-r--r--dev-lang/ocaml/ocaml-3.07-r1.ebuild108
-rw-r--r--dev-lang/ocaml/ocaml-3.08.ebuild86
7 files changed, 680 insertions, 8 deletions
diff --git a/dev-lang/ocaml/ChangeLog b/dev-lang/ocaml/ChangeLog
index 00dff44f32fd..a58faf07ea65 100644
--- a/dev-lang/ocaml/ChangeLog
+++ b/dev-lang/ocaml/ChangeLog
@@ -1,6 +1,13 @@
# ChangeLog for dev-lang/ocaml
# Copyright 2002-2005 Gentoo Foundation; Distributed under the GPL v2
-# $Header: /var/cvsroot/gentoo-x86/dev-lang/ocaml/ChangeLog,v 1.57 2005/03/18 17:36:55 mattam Exp $
+# $Header: /var/cvsroot/gentoo-x86/dev-lang/ocaml/ChangeLog,v 1.58 2005/03/19 19:40:23 mr_bones_ Exp $
+
+*ocaml-3.08 (19 Mar 2005)
+*ocaml-3.07-r1 (19 Mar 2005)
+
+ 19 Mar 2005; Michael Sterrett <mr_bones_@gentoo.org>
+ +files/ocaml-3.07-hppa.patch, +ocaml-3.07-r1.ebuild, +ocaml-3.08.ebuild:
+ resurrect versions to fix dep breakage
18 Mar 2005; Matthieu Sozeau <mattam@gentoo.org>
-files/ocaml-3.07-hppa.patch, files/ocaml-rebuild.sh, -ocaml-3.07-r1.ebuild,
diff --git a/dev-lang/ocaml/Manifest b/dev-lang/ocaml/Manifest
index 5e7e4d656c16..63567186ceba 100644
--- a/dev-lang/ocaml/Manifest
+++ b/dev-lang/ocaml/Manifest
@@ -1,11 +1,16 @@
-MD5 9af3c05574fb82ed2a91dab6d9f2d376 ocaml-3.08.1.ebuild 2152
+MD5 8b350f19c06fcabf1053b0421b7c3f5a metadata.xml 155
+MD5 275f54f1c5402ce80ed21fe6cb1d61a1 ChangeLog 9582
MD5 d3e28c5c99b056007b6b5b0781a4e542 ocaml-3.06-r2.ebuild 1660
+MD5 ef7cc12a4ff8aeec9ddb58ff65f7e3c0 ocaml-3.07-r1.ebuild 2910
+MD5 9af3c05574fb82ed2a91dab6d9f2d376 ocaml-3.08.1.ebuild 2152
MD5 44feed13b191a67cebac2e876395f246 ocaml-3.08.3.ebuild 2157
-MD5 23a28c630c7cb2aea1acdab1314b339c ChangeLog 9351
-MD5 8b350f19c06fcabf1053b0421b7c3f5a metadata.xml 155
-MD5 4df214d6cd74b3c5955d868879dd6cc7 files/ocaml-3.06-tcltk-8.4compat-patch.bz2 639
-MD5 8213fcf5533d0317af0486896b7afdd3 files/ocaml-rebuild.sh 1331
-MD5 13c4abf06e236e8835011a387f90ecc9 files/digest-ocaml-3.06-r2 63
-MD5 3854a7d6aaedc7d5fde7239776cec5cf files/digest-ocaml-3.08.1 66
+MD5 ede360aa66fcf54120c19798f0421e61 ocaml-3.08.ebuild 2209
MD5 d80f37fe859bc2ea8f71e13f02578275 files/digest-ocaml-3.08.3 66
+MD5 3854a7d6aaedc7d5fde7239776cec5cf files/digest-ocaml-3.08.1 66
+MD5 13c4abf06e236e8835011a387f90ecc9 files/digest-ocaml-3.06-r2 63
+MD5 45ff13419dd955aa86d021abbf325fc2 files/ocaml-3.07-hppa.patch 15730
MD5 91579cecf8659312c2324d8d40709433 files/ocaml-3.06-sparc-configure.patch 1660
+MD5 4df214d6cd74b3c5955d868879dd6cc7 files/ocaml-3.06-tcltk-8.4compat-patch.bz2 639
+MD5 c42de320103c2d3eb1aa4002e2e0716b files/digest-ocaml-3.07-r1 130
+MD5 77519cb4017543f060a963387b593299 files/digest-ocaml-3.08 65
+MD5 8213fcf5533d0317af0486896b7afdd3 files/ocaml-rebuild.sh 1331
diff --git a/dev-lang/ocaml/files/digest-ocaml-3.07-r1 b/dev-lang/ocaml/files/digest-ocaml-3.07-r1
new file mode 100644
index 000000000000..7ab2713f6106
--- /dev/null
+++ b/dev-lang/ocaml/files/digest-ocaml-3.07-r1
@@ -0,0 +1,2 @@
+MD5 2dd038055f5e1350078ad81270411b78 ocaml-3.07.tar.gz 2537449
+MD5 f91d1f1e531f77011bd554817dbbc12a ocaml-3.07-patch2.diffs 42799
diff --git a/dev-lang/ocaml/files/digest-ocaml-3.08 b/dev-lang/ocaml/files/digest-ocaml-3.08
new file mode 100644
index 000000000000..6b524fc89bd8
--- /dev/null
+++ b/dev-lang/ocaml/files/digest-ocaml-3.08
@@ -0,0 +1 @@
+MD5 c6ef478362295c150101cdd2efcd38e0 ocaml-3.08.0.tar.gz 2458425
diff --git a/dev-lang/ocaml/files/ocaml-3.07-hppa.patch b/dev-lang/ocaml/files/ocaml-3.07-hppa.patch
new file mode 100644
index 000000000000..caeed44596c4
--- /dev/null
+++ b/dev-lang/ocaml/files/ocaml-3.07-hppa.patch
@@ -0,0 +1,463 @@
+Files ocaml-3.07.orig/asmcomp/hppa/.emit.mlp.swp and ocaml-3.07/asmcomp/hppa/.emit.mlp.swp differ
+diff -uNr ocaml-3.07.orig/asmcomp/hppa/emit.mlp ocaml-3.07/asmcomp/hppa/emit.mlp
+--- ocaml-3.07.orig/asmcomp/hppa/emit.mlp 2004-05-05 11:54:21.000000000 -0700
++++ ocaml-3.07/asmcomp/hppa/emit.mlp 2004-05-08 12:10:48.000000000 -0700
+@@ -31,13 +31,13 @@
+ open Linearize
+ open Emitaux
+
+-(* Adaptation to HPUX and NextStep *)
++(* Adaptation to HPUX, NextStep and Linux *)
+
+-let hpux =
++(* let hpux =
+ match Config.system with
+ "hpux" -> true
+ | "nextstep" -> false
+- | _ -> fatal_error "Emit_hppa.hpux"
++ | _ -> fatal_error "Emit_hppa.hpux" *)
+
+ (* Tradeoff between code size and code speed *)
+
+@@ -66,14 +66,14 @@
+
+ (* Output a label *)
+
+-let label_prefix = if hpux then "L$" else "L"
++let label_prefix = if Config.system = "hpux" || Config.system = "linux" then "L$" else "L"
+
+ let emit_label lbl =
+ emit_string label_prefix; emit_int lbl
+
+ (* Output a symbol *)
+
+-let symbol_prefix = if hpux then "" else "_"
++let symbol_prefix = if Config.system = "hpux" || Config.system = "linux" then "" else "_"
+
+ let emit_symbol s =
+ emit_string symbol_prefix; Emitaux.emit_symbol '$' s
+@@ -87,8 +87,8 @@
+
+ (* Output low address / high address prefixes *)
+
+-let low_prefix = if hpux then "RR'" else "R\`"
+-let high_prefix = if hpux then "LR'" else "L\`"
++let low_prefix = if Config.system = "hpux" || Config.system = "linux" then "RR%" else "R\`"
++let high_prefix = if Config.system = "hpux" || Config.system = "linux" then "LR%" else "L\`"
+
+ let is_immediate n = (n < 16) && (n >= -16) (* 5 bits *)
+
+@@ -99,18 +99,18 @@
+ let emit_nativeint_high n = emit_string high_prefix; emit_nativeint n
+
+ let emit_symbol_low s =
+- if hpux
+- then `RR'{emit_symbol s}-$global$`
++ if Config.system = "hpux" || Config.system = "linux"
++ then `RR%{emit_symbol s}-$global$`
+ else `R\`{emit_symbol s}`
+
+ let load_symbol_high s =
+- if hpux
+- then ` addil LR'{emit_symbol s}-$global$, %r27\n`
++ if Config.system = "hpux" || Config.system = "linux"
++ then ` addil LR%{emit_symbol s}-$global$, %r27\n`
+ else ` ldil L\`{emit_symbol s}, %r1\n`
+
+ let load_symbol_offset_high s ofs =
+- if hpux
+- then ` addil LR'{emit_symbol s}-$global$+{emit_int ofs}, %r27\n`
++ if Config.system = "hpux" || Config.system = "linux"
++ then ` addil LR%{emit_symbol s}-$global$+{emit_int ofs}, %r27\n`
+ else ` ldil L\`{emit_symbol s}+{emit_int ofs}, %r1\n`
+
+ (* Record imported and defined symbols *)
+@@ -120,11 +120,11 @@
+ let called_symbols = ref StringSet.empty
+
+ let use_symbol s =
+- if hpux then used_symbols := StringSet.add s !used_symbols
++ if Config.system = "hpux" || Config.system = "linux" then used_symbols := StringSet.add s !used_symbols
+ let define_symbol s =
+ defined_symbols := StringSet.add s !defined_symbols
+ let call_symbol s =
+- if hpux then begin
++ if Config.system = "hpux" || Config.system = "linux" then begin
+ used_symbols := StringSet.add s !used_symbols;
+ called_symbols := StringSet.add s !called_symbols
+ end
+@@ -270,7 +270,7 @@
+ Undex NextStep: alignment = log2 of number of bytes *)
+
+ let emit_align n =
+- if hpux
++ if Config.system = "hpux" || Config.system = "linux"
+ then ` .align {emit_int n}\n`
+ else ` .align {emit_int(Misc.log2 n)}\n`
+
+@@ -315,10 +315,10 @@
+ let float_constants = ref ([] : (int * string) list)
+
+ let emit_float_constant (lbl, cst) =
+- if hpux then begin
++ if Config.system = "hpux" then begin
+ ` .space $TEXT$\n`;
+ ` .subspa $LIT$\n`
+- end else
++ end else if Config.system = "nextstep" then
+ ` .literal8\n`;
+ emit_align 8;
+ `{emit_label lbl}: .double {emit_string cst}\n`
+@@ -341,7 +341,7 @@
+
+ let emit_stubs () =
+ ` .text\n`;
+- emit_align 4;
++ if Config.system = "linux" then emit_align 8 else emit_align 4;
+ Hashtbl.iter emit_stub stub_label_table
+
+ (* Describe the registers used to pass arguments to a C function *)
+@@ -363,7 +363,7 @@
+ (* Output a function call *)
+
+ let emit_call s retreg =
+- if hpux then begin
++ if Config.system = "hpux" || Config.system = "linux" then begin
+ ` bl {emit_symbol s}, {emit_string retreg}\n`;
+ call_symbol s
+ end else
+@@ -510,11 +510,11 @@
+ | Lop(Iextcall(s, alloc)) ->
+ if alloc then begin
+ call_symbol s;
+- if hpux then begin
+- ` ldil LR'{emit_symbol s}, %r22\n`;
++ if Config.system = "hpux" || Config.system = "linux" then begin
++ ` ldil LR%{emit_symbol s}, %r22\n`;
+ describe_call i.arg;
+ emit_call "caml_c_call" "%r2";
+- ` ldo RR'{emit_symbol s}(%r22), %r22\n` (* in delay slot *)
++ ` ldo RR%{emit_symbol s}(%r22), %r22\n` (* in delay slot *)
+ end else begin
+ ` ldil L\`{emit_symbol s}, %r22\n`;
+ emit_call "caml_c_call" "%r2";
+@@ -522,7 +522,7 @@
+ end;
+ record_frame i.live
+ end else begin
+- if hpux then describe_call i.arg;
++ if Config.system = "hpux" || Config.system = "linux" then describe_call i.arg;
+ emit_call s "%r2";
+ fill_delay_slot dslot
+ end
+@@ -595,7 +595,7 @@
+ ` ldws,mb -8(%r30), {emit_reg i.res.(0)}\n`
+ | Lop(Iintop Idiv) ->
+ (* Arguments are assumed to be in %r26 and %r25, result in %r29 *)
+- if hpux then
++ if Config.system = "hpux" || Config.system = "linux" then
+ ` bl $$divI, %r31\n`
+ else begin
+ ` ldil L\`$$divI, %r1\n`;
+@@ -604,7 +604,7 @@
+ fill_delay_slot dslot
+ | Lop(Iintop Imod) ->
+ (* Arguments are assumed to be in %r26 and %r25, result in %r29 *)
+- if hpux then
++ if Config.system = "hpux" || Config.system = "linux" then
+ ` bl $$remI, %r31\n`
+ else begin
+ ` ldil L\`$$remI, %r1\n`;
+@@ -640,13 +640,19 @@
+ | Lop(Iintop_imm(Idiv, n)) ->
+ let l = Misc.log2 n in
+ ` comclr,>= {emit_reg i.arg.(0)}, %r0, %r1\n`;
+- ` zdepi -1, 31, {emit_int l}, %r1\n`;
++ if not (l = 0) then
++ ` zdepi -1, 31, {emit_int l}, %r1\n`
++ else
++ ` xor %r1, %r1, %r1\n`;
+ ` add {emit_reg i.arg.(0)}, %r1, %r1\n`;
+ ` extrs %r1, {emit_int(31-l)}, {emit_int(32-l)}, {emit_reg i.res.(0)}\n`
+ | Lop(Iintop_imm(Imod, n)) ->
+ let l = Misc.log2 n in
+ ` comclr,>= {emit_reg i.arg.(0)}, %r0, %r1\n`;
+- ` zdepi -1, 31, {emit_int l}, %r1\n`;
++ if not (l = 0) then
++ ` zdepi -1, 31, {emit_int l}, %r1\n`
++ else
++ ` xor %r1, %r1, %r1\n`;
+ ` add {emit_reg i.arg.(0)}, %r1, %r1\n`;
+ ` depi 0, 31, {emit_int l}, %r1\n`;
+ ` sub {emit_reg i.arg.(0)}, %r1, {emit_reg i.res.(0)}\n`
+@@ -969,7 +975,7 @@
+ define_symbol fundecl.fun_name;
+ range_check_trap := 0;
+ let n = frame_size() in
+- if hpux then begin
++ if Config.system = "hpux" then begin
+ ` .code\n`;
+ ` .align 4\n`;
+ ` .export {emit_symbol fundecl.fun_name}, entry, priv_lev=3\n`;
+@@ -980,6 +986,11 @@
+ else
+ ` .callinfo frame={emit_int n}, no_calls\n`;
+ ` .entry\n`
++ end else if Config.system = "linux" then begin
++ ` .text\n`;
++ ` .align 8\n`;
++ ` .globl {emit_symbol fundecl.fun_name}\n`;
++ `{emit_symbol fundecl.fun_name}:\n`;
+ end else begin
+ ` .text\n`;
+ ` .align 2\n`;
+@@ -994,7 +1005,7 @@
+ emit_all fundecl.fun_body;
+ if !range_check_trap > 0 then begin
+ `{emit_label !range_check_trap}:\n`;
+- if hpux then begin
++ if Config.system = "hpux" || Config.system = "linux" then begin
+ emit_call "caml_array_bound_error" "%r31";
+ ` nop\n`
+ end else begin
+@@ -1002,7 +1013,7 @@
+ ` ble,n {emit_symbol_low "caml_array_bound_error"}(4, %r1)\n`
+ end
+ end;
+- if hpux then begin
++ if Config.system = "hpux"then begin
+ ` .exit\n`;
+ ` .procend\n`
+ end;
+@@ -1012,7 +1023,7 @@
+
+ let declare_global s =
+ define_symbol s;
+- if hpux
++ if Config.system = "hpux"
+ then ` .export {emit_symbol s}, data\n`
+ else ` .globl {emit_symbol s}\n`
+
+@@ -1037,7 +1048,7 @@
+ | Cdouble f ->
+ ` .double {emit_string f}\n`
+ | Csymbol_address s ->
+- if hpux && String.length s >= 5 && String.sub s 0 5 = "caml_" then
++ if Config.system = "hpux" && String.length s >= 5 && String.sub s 0 5 = "caml_" then
+ ` .import {emit_symbol s}, code\n`;
+ ` .long {emit_symbol s}\n`
+ | Clabel_address lbl ->
+@@ -1046,7 +1057,7 @@
+ emit_string_directive " .ascii " s
+ | Cskip n ->
+ if n > 0 then
+- if hpux then ` .block {emit_int n}\n`
++ if Config.system = "hpux" then ` .block {emit_int n}\n`
+ else ` .space {emit_int n}\n`
+ | Calign n ->
+ emit_align n
+@@ -1058,7 +1069,7 @@
+ (* Beginning / end of an assembly file *)
+
+ let begin_assembly() =
+- if hpux then begin
++ if Config.system = "hpux" then begin
+ ` .space $PRIVATE$\n`;
+ ` .subspa $DATA$,quad=1,align=8,access=31\n`;
+ ` .subspa $BSS$,quad=1,align=8,access=31,zero,sort=82\n`;
+@@ -1075,29 +1086,29 @@
+ Hashtbl.clear stub_label_table;
+ let lbl_begin = Compilenv.current_unit_name() ^ "__data_begin" in
+ ` .data\n`;
+- emit_global lbl_begin;
++ declare_global lbl_begin;
+ `{emit_symbol lbl_begin}:\n`;
+ let lbl_begin = Compilenv.current_unit_name() ^ "__code_begin" in
+ ` .code\n`;
+- emit_global lbl_begin;
++ declare_global lbl_begin;
+ `{emit_symbol lbl_begin}:\n`
+
+
+ let end_assembly() =
+- if not hpux then emit_stubs();
++ if not ( Config.system = "hpux" ) then emit_stubs();
+ ` .code\n`;
+ let lbl_end = Compilenv.current_unit_name() ^ "__code_end" in
+- emit_global lbl_end;
++ declare_global lbl_end;
+ `{emit_symbol lbl_end}:\n`;
+ ` .data\n`;
+ let lbl_end = Compilenv.current_unit_name() ^ "__data_end" in
+- emit_global lbl_end;
++ declare_global lbl_end;
+ `{emit_symbol lbl_end}:\n`;
+ ` .long 0\n`;
+ let lbl = Compilenv.current_unit_name() ^ "__frametable" in
+- emit_global lbl;
++ declare_global lbl;
+ `{emit_symbol lbl}:\n`;
+ ` .long {emit_int (List.length !frame_descriptors)}\n`;
+ List.iter emit_frame !frame_descriptors;
+ frame_descriptors := [];
+- if hpux then emit_imports()
++ if Config.system = "hpux" then emit_imports()
+diff -uNr ocaml-3.07.orig/asmcomp/hppa/proc.ml ocaml-3.07/asmcomp/hppa/proc.ml
+--- ocaml-3.07.orig/asmcomp/hppa/proc.ml 2004-05-05 11:54:21.000000000 -0700
++++ ocaml-3.07/asmcomp/hppa/proc.ml 2004-05-08 11:31:29.000000000 -0700
+@@ -217,7 +217,7 @@
+ (* Calling the assembler *)
+
+ let assemble_file infile outfile =
+- Ccomp.command ("gas -o " ^ Filename.quote outfile ^ " " ^ Filename.quote infile)
++ Ccomp.command ("as -o " ^ Filename.quote outfile ^ " " ^ Filename.quote infile)
+
+ open Clflags;;
+ open Config;;
+diff -uNr ocaml-3.07.orig/asmrun/Makefile ocaml-3.07/asmrun/Makefile
+--- ocaml-3.07.orig/asmrun/Makefile 2004-05-05 11:54:21.000000000 -0700
++++ ocaml-3.07/asmrun/Makefile 2004-05-08 11:31:29.000000000 -0700
+@@ -151,10 +151,10 @@
+
+ # For HPUX, we can't use gcc as ASPP because it may have been configured with
+ # the vendor's assembler
+-hppa.o: hppa.S
+- gcc -traditional -E -DSYS_$(SYSTEM) -o hppa.s hppa.S
+- gas -o hppa.o hppa.s || { rm -f hppa.s; exit 2; }
+- rm -f hppa.s
++#hppa.o: hppa.S
++# gcc -traditional -E -DSYS_$(SYSTEM) -o hppa.s hppa.S
++# gas -o hppa.o hppa.s || { rm -f hppa.s; exit 2; }
++# rm -f hppa.s
+
+ .SUFFIXES: .S .d.o .p.o
+
+diff -uNr ocaml-3.07.orig/asmrun/hppa.S ocaml-3.07/asmrun/hppa.S
+--- ocaml-3.07.orig/asmrun/hppa.S 2004-05-05 11:54:21.000000000 -0700
++++ ocaml-3.07/asmrun/hppa.S 2004-05-08 11:31:29.000000000 -0700
+@@ -30,6 +30,20 @@
+ #define LOWLABEL(x) RR%x
+ #endif
+
++#ifdef SYS_linux
++#define G(x) x
++#define CODESPACE .text
++#define CODE_ALIGN 8
++#define EXPORT_CODE(x) .globl x
++#define EXPORT_DATA(x) .globl x
++#define STARTPROC
++#define ENDPROC
++#define LOADHIGH(x) addil LR%x-$global$, %r27
++#define LOW(x) RR%x-$global$
++#define LOADHIGHLABEL(x) ldil LR%x, %r1
++#define LOWLABEL(x) RR%x
++#endif
++
+ #ifdef SYS_nextstep
+ #define G(x) _##x
+ #define CODESPACE .text
+@@ -69,6 +83,18 @@
+ caml_required_size .comm 8
+ #endif
+
++
++#ifdef SYS_linux
++ .align 8
++ .comm G(young_limit), 4
++ .comm G(young_ptr), 4
++ .comm G(caml_bottom_of_stack), 4
++ .comm G(caml_last_return_address), 4
++ .comm G(caml_gc_regs), 4
++ .comm G(caml_exception_pointer), 4
++ .comm G(caml_required_size), 4
++#endif
++
+ #ifdef SYS_nextstep
+ .comm G(young_limit), 8
+ .comm G(young_ptr), 8
+@@ -529,7 +555,7 @@
+ G(caml_array_bound_error):
+ STARTPROC
+ ; Load address of array_bound_error in %r22
+-#ifdef SYS_hpux
++#if defined(SYS_hpux) || defined(SYS_linux)
+ ldil LR%array_bound_error, %r22
+ ldo RR%array_bound_error(%r22), %r22
+ #else
+diff -uNr ocaml-3.07.orig/byterun/config.h ocaml-3.07/byterun/config.h
+--- ocaml-3.07.orig/byterun/config.h 2004-05-05 11:54:21.000000000 -0700
++++ ocaml-3.07/byterun/config.h 2004-05-08 11:31:29.000000000 -0700
+@@ -50,7 +50,7 @@
+ typedef ARCH_INT64_TYPE int64;
+ typedef ARCH_UINT64_TYPE uint64;
+ #else
+-# if ARCH_BIG_ENDIAN
++# if defined(ARCH_BIG_ENDIAN)
+ typedef struct { uint32 h, l; } uint64, int64;
+ # else
+ typedef struct { uint32 l, h; } uint64, int64;
+diff -uNr ocaml-3.07.orig/configure ocaml-3.07/configure
+--- ocaml-3.07.orig/configure 2004-05-05 11:54:21.000000000 -0700
++++ ocaml-3.07/configure 2004-05-08 11:31:29.000000000 -0700
+@@ -401,7 +401,7 @@
+ # Determine alignment constraints
+
+ case "$host" in
+- sparc-*-*)
++ sparc-*-*|hppa*-*-*)
+ # On Sparc V9 with certain versions of gcc, determination of double
+ # alignment is not reliable (PR#1521), hence force it
+ echo "Doubles must be doubleword-aligned."
+@@ -421,22 +421,28 @@
+ esac;;
+ esac
+
+-if $int64_native; then
+- sh ./runtest int64align.c
+- case $? in
+- 0) echo "64-bit integers can be word-aligned."
+- echo "#undef ARCH_ALIGN_INT64" >> m.h;;
+- 1) echo "64-bit integers must be doubleword-aligned."
+- echo "#define ARCH_ALIGN_INT64" >> m.h;;
+- *) echo "Something went wrong during alignment determination for 64-bit integers."
+- echo "I'm going to assume this architecture has alignment constraints."
+- echo "That's a safe bet: Objective Caml will work even if"
+- echo "this architecture has actually no alignment constraints."
+- echo "#define ARCH_ALIGN_INT64" >> m.h;;
+- esac
+-else
+- echo "#undef ARCH_ALIGN_INT64" >> m.h
+-fi
++case "$host" in
++ hppa*-*-*)
++ echo "64-bit integers must be doubleword-aligned."
++ echo "#define ARCH_ALIGN_INT64" >> m.h;;
++ *)
++ if $int64_native; then
++ sh ./runtest int64align.c
++ case $? in
++ 0) echo "64-bit integers can be word-aligned."
++ echo "#undef ARCH_ALIGN_INT64" >> m.h;;
++ 1) echo "64-bit integers must be doubleword-aligned."
++ echo "#define ARCH_ALIGN_INT64" >> m.h;;
++ *) echo "Something went wrong during alignment determination for 64-bit integers."
++ echo "I'm going to assume this architecture has alignment constraints."
++ echo "That's a safe bet: Objective Caml will work even if"
++ echo "this architecture has actually no alignment constraints."
++ echo "#define ARCH_ALIGN_INT64" >> m.h;;
++ esac
++ else
++ echo "#undef ARCH_ALIGN_INT64" >> m.h
++ fi
++esac
+
+ # Check semantics of division and modulus
+
+@@ -541,6 +547,7 @@
+ sparc*-*-solaris2.*) arch=sparc; system=solaris;;
+ sparc*-*-*bsd*) arch=sparc; system=bsd;;
+ sparc*-*-linux*) arch=sparc; system=linux;;
++ hppa*-*-linux*) arch=hppa; system=linux;;
+ i[3456]86-*-linux*) arch=i386; system=linux_`sh ./runtest elf.c`;;
+ i[3456]86-*-*bsd*) arch=i386; system=bsd_`sh ./runtest elf.c`;;
+ i[3456]86-*-nextstep*) arch=i386; system=nextstep;;
diff --git a/dev-lang/ocaml/ocaml-3.07-r1.ebuild b/dev-lang/ocaml/ocaml-3.07-r1.ebuild
new file mode 100644
index 000000000000..fd2863ea01d0
--- /dev/null
+++ b/dev-lang/ocaml/ocaml-3.07-r1.ebuild
@@ -0,0 +1,108 @@
+# Copyright 1999-2005 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Header: /var/cvsroot/gentoo-x86/dev-lang/ocaml/ocaml-3.07-r1.ebuild,v 1.30 2005/03/19 19:40:23 mr_bones_ Exp $
+
+inherit flag-o-matic eutils
+
+DESCRIPTION="fast modern type-inferring functional programming language descended from the ML (Meta Language) family"
+HOMEPAGE="http://www.ocaml.org/"
+
+SRC_URI="http://caml.inria.fr/distrib/${P}/${P}.tar.gz
+ http://caml.inria.fr/distrib/${P}/${P}-patch2.diffs"
+
+LICENSE="QPL-1.0 LGPL-2"
+SLOT="0"
+KEYWORDS="x86 sparc ppc alpha ~ia64 ~amd64 hppa ~ppc-macos"
+IUSE="tcltk latex"
+
+DEPEND="virtual/libc
+ tcltk? ( >=dev-lang/tk-3.3.3 )"
+
+pkg_setup() {
+ ewarn
+ ewarn "Building ocaml with unsafe CFLAGS can have unexpected results"
+ ewarn "Please retry building with safer CFLAGS before reporting bugs"
+ ewarn
+}
+
+src_unpack() {
+ unpack ${P}.tar.gz
+ cd ${S}
+ use hppa && epatch ${FILESDIR}/${P}-hppa.patch
+ epatch ${DISTDIR}/${P}-patch2.diffs
+ grep -rle "head -1" . | xargs sed -i "s:head -1:head -n 1:g"
+}
+
+src_compile() {
+ filter-flags "-fstack-protector"
+ replace-flags "-O?" -O2
+
+ local myconf
+ use tcltk || myconf="-no-tk"
+
+ # Fix for bug #23767.
+ if [ "${ARCH}" = "sparc" ]; then
+ myconf="${myconf} -host sparc-unknown-linux-gnu"
+ fi
+
+ # Fix for bug #46703
+ export LC_ALL=C
+
+ ./configure -prefix /usr \
+ -bindir /usr/bin \
+ -libdir /usr/lib/ocaml \
+ -mandir /usr/share/man \
+ --with-pthread ${myconf} || die
+
+ sed -i -e "s/\(BYTECCCOMPOPTS=.*\)/\1 ${CFLAGS}/" config/Makefile
+ sed -i -e "s/\(NATIVECCCOMPOPTS=.*\)/\1 ${CFLAGS}/" config/Makefile
+
+ make world || die
+ make opt || die
+ make opt.opt || die
+}
+
+src_install() {
+ make BINDIR=${D}/usr/bin \
+ LIBDIR=${D}/usr/lib/ocaml \
+ MANDIR=${D}/usr/share/man \
+ install || die
+
+ # silly, silly makefiles
+ dosed "s:${D}::g" /usr/lib/ocaml/ld.conf
+
+ # documentation
+ dodoc Changes INSTALL LICENSE README Upgrading
+}
+
+pkg_postinst() {
+ ranlib /usr/lib/ocaml/libasmrunp.a
+ ranlib /usr/lib/ocaml/libbigarray.a
+ ranlib /usr/lib/ocaml/libcamlrun.a
+ ranlib /usr/lib/ocaml/libgraphics.a
+ ranlib /usr/lib/ocaml/libmldbm.a
+ ranlib /usr/lib/ocaml/libnums.a
+ ranlib /usr/lib/ocaml/libstr.a
+ ranlib /usr/lib/ocaml/libthreads.a
+ ranlib /usr/lib/ocaml/libthreadsnat.a
+ ranlib /usr/lib/ocaml/libunix.a
+ ranlib /usr/lib/ocaml/libstr.a
+ ranlib /usr/lib/ocaml/str.a
+ ranlib /usr/lib/ocaml/unix.a
+ ranlib /usr/lib/ocaml/stdlib.a
+ ranlib /usr/lib/ocaml/libasmrun.a
+
+
+ if use latex; then
+ echo "TEXINPUTS=/usr/lib/ocaml/ocamldoc:" > /etc/env.d/99ocamldoc
+ fi
+
+ echo
+ einfo "OCaml is not binary compatible from version to version,"
+ einfo "so you (may) need to rebuild all packages depending on it that"
+ einfo "are actually installed on your system."
+ einfo "To do so, you can run: "
+ einfo "sh ${FILESDIR}/ocaml-rebuild.sh [-h | emerge options]"
+ einfo "Which will call emerge on all old packages with the given options"
+ echo
+}
diff --git a/dev-lang/ocaml/ocaml-3.08.ebuild b/dev-lang/ocaml/ocaml-3.08.ebuild
new file mode 100644
index 000000000000..d5b5fdbf42dd
--- /dev/null
+++ b/dev-lang/ocaml/ocaml-3.08.ebuild
@@ -0,0 +1,86 @@
+# Copyright 1999-2005 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Header: /var/cvsroot/gentoo-x86/dev-lang/ocaml/ocaml-3.08.ebuild,v 1.12 2005/03/19 19:40:23 mr_bones_ Exp $
+
+inherit flag-o-matic eutils
+
+DESCRIPTION="fast modern type-inferring functional programming language descended from the ML (Meta Language) family"
+HOMEPAGE="http://www.ocaml.org/"
+
+SRC_URI="http://caml.inria.fr/distrib/ocaml-3.08/${P}.0.tar.gz"
+
+LICENSE="QPL-1.0 LGPL-2"
+SLOT="0"
+KEYWORDS="~x86 ~sparc ~ppc ~alpha ~ia64 amd64 hppa ~ppc-macos"
+IUSE="tcltk latex"
+
+DEPEND="virtual/libc
+ tcltk? ( >=dev-lang/tk-3.3.3 )"
+
+S="${WORKDIR}/${P}.0"
+
+pkg_setup() {
+ ewarn
+ ewarn "Building ocaml with unsafe CFLAGS can have unexpected results"
+ ewarn "Please retry building with safer CFLAGS before reporting bugs"
+ ewarn
+}
+
+src_compile() {
+ filter-flags "-fstack-protector"
+ replace-flags "-O?" -O2
+
+ local myconf
+ use tcltk || myconf="-no-tk"
+
+ # Fix for bug #23767.
+ if [ "${ARCH}" = "sparc" ]; then
+ myconf="${myconf} -host sparc-unknown-linux-gnu"
+ fi
+
+ # Fix for bug #46703
+ export LC_ALL=C
+
+ ./configure -prefix /usr \
+ -bindir /usr/bin \
+ -libdir /usr/lib/ocaml \
+ -mandir /usr/share/man \
+ --with-pthread ${myconf} || die
+
+ sed -i -e "s/\(BYTECCCOMPOPTS=.*\)/\1 ${CFLAGS}/" config/Makefile
+ sed -i -e "s/\(NATIVECCCOMPOPTS=.*\)/\1 ${CFLAGS}/" config/Makefile
+
+ make world || die
+ make opt || die
+ make opt.opt || die
+}
+
+src_install() {
+ make BINDIR=${D}/usr/bin \
+ LIBDIR=${D}/usr/lib/ocaml \
+ MANDIR=${D}/usr/share/man \
+ install || die
+
+ # silly, silly makefiles
+ dosed "s:${D}::g" /usr/lib/ocaml/ld.conf
+
+ # documentation
+ dodoc Changes INSTALL LICENSE README Upgrading
+}
+
+pkg_postinst() {
+ ranlib /usr/lib/ocaml/*.a
+
+ if use latex; then
+ echo "TEXINPUTS=/usr/lib/ocaml/ocamldoc:" > /etc/env.d/99ocamldoc
+ fi
+
+ echo
+ einfo "OCaml is not binary compatible from version to version,"
+ einfo "so you (may) need to rebuild all packages depending on it that"
+ einfo "are actually installed on your system."
+ einfo "To do so, you can run: "
+ einfo "sh ${FILESDIR}/ocaml-rebuild.sh [-h | emerge options]"
+ einfo "Which will call emerge on all old packages with the given options"
+ echo
+}