diff options
Diffstat (limited to 'dev-lang')
-rw-r--r-- | dev-lang/cm3-bin/ChangeLog | 8 | ||||
-rw-r--r-- | dev-lang/cm3-bin/cm3-bin-5.2.6.ebuild | 42 | ||||
-rw-r--r-- | dev-lang/cm3-bin/files/05cm3 | 1 | ||||
-rw-r--r-- | dev-lang/cm3-bin/files/cm3.cfg | 351 | ||||
-rw-r--r-- | dev-lang/cm3-bin/files/digest-cm3-bin-5.2.6 | 1 | ||||
-rw-r--r-- | dev-lang/cm3-bin/files/m3build | 2 | ||||
-rw-r--r-- | dev-lang/cm3-bin/files/m3ship | 2 |
7 files changed, 407 insertions, 0 deletions
diff --git a/dev-lang/cm3-bin/ChangeLog b/dev-lang/cm3-bin/ChangeLog new file mode 100644 index 000000000000..4d7e579b316c --- /dev/null +++ b/dev-lang/cm3-bin/ChangeLog @@ -0,0 +1,8 @@ +# ChangeLog for dev-lang/cm3-bin +# Copyright 2000-2003 Gentoo Technologies, Inc.; Distributed under the GPL v2 +# $Header: /var/cvsroot/gentoo-x86/dev-lang/cm3-bin/ChangeLog,v 1.1 2003/07/17 17:11:38 vapier Exp $ + +*cm3-bin-5.2.6 (17 Jul 2003) + + 17 Jul 2003; Mike Frysinger <vapier@gentoo.org> : + Initial import. Ebuild submitted by me. diff --git a/dev-lang/cm3-bin/cm3-bin-5.2.6.ebuild b/dev-lang/cm3-bin/cm3-bin-5.2.6.ebuild new file mode 100644 index 000000000000..9b2430a6fb11 --- /dev/null +++ b/dev-lang/cm3-bin/cm3-bin-5.2.6.ebuild @@ -0,0 +1,42 @@ +# Copyright 1999-2003 Gentoo Technologies, Inc. +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/dev-lang/cm3-bin/cm3-bin-5.2.6.ebuild,v 1.1 2003/07/17 17:11:38 vapier Exp $ + +DESCRIPTION="Critical Mass Modula-3 compiler (binary version)" +HOMEPAGE="http://www.elegosoft.com/cm3/" +SRC_URI="x86? ( http://www.elegosoft.com/cm3/cm3-min-POSIX-LINUXLIBC6-${PV}.tgz ) + ppc? ( http://www.elegosoft.com/cm3/cm3-min-POSIX-PPC_LINUX-${PV}.tgz )" + +LICENSE="CMASS-M3 DEC-M3" +SLOT="0" +KEYWORDS="~x86 ~ppc" +IUSE="tcltk" + +S=${WORKDIR} + +src_unpack() { + unpack ${A} + tar -zxf system.tgz || die "unpacking system.tgz" + + sed \ + -e "s:GENTOO_INITIAL_REACTOR_EDITOR:${EDITOR:-/usr/bin/nano}:" \ + -e "s:GENTOO_INSTALL_ROOT:/usr/lib/cm3/:" \ + -e "s:GENTOO_GNU_CC:${CC:-gcc}:" \ + -e "s:GENTOO_GNU_CFLAGS:${CFLAGS:--O}:" \ + -e "s:GENTOO_GNU_MAKE:${MAKE:-make}:" \ + ${FILESDIR}/cm3.cfg > bin/cm3.cfg + echo "ROOT=\"/usr/lib/cm3/pkg/\"" >> bin/cm3.cfg + rm -rf doc elisp examples man +} + +src_install() { + dodir /usr/lib/cm3 /usr/bin + mv pkg bin lib ${D}/usr/lib/cm3/ + dosym /usr/lib/cm3/bin/cm3 /usr/bin/cm3 + dosym /usr/lib/cm3/bin/cm3.cfg /usr/bin/cm3.cfg + dosym /usr/lib/cm3/bin/cm3cg /usr/bin/cm3cg + dobin ${FILESDIR}/m3{build,ship} + + insinto /etc/env.d + doins ${FILESDIR}/05cm3 +} diff --git a/dev-lang/cm3-bin/files/05cm3 b/dev-lang/cm3-bin/files/05cm3 new file mode 100644 index 000000000000..af1b2d9d1abc --- /dev/null +++ b/dev-lang/cm3-bin/files/05cm3 @@ -0,0 +1 @@ +LDPATH="/usr/lib/cm3/lib" diff --git a/dev-lang/cm3-bin/files/cm3.cfg b/dev-lang/cm3-bin/files/cm3.cfg new file mode 100644 index 000000000000..bbe323e51431 --- /dev/null +++ b/dev-lang/cm3-bin/files/cm3.cfg @@ -0,0 +1,351 @@ +% Copyright 1996 Critical Mass, Inc. All rights reserved. +% +% Standard configuration file for LINUX with ELF object files +% + +%-------------------------------------------------- compilation environment --- + +%M3_PROFILING = TRUE % set by cm3 since 5.1.2 (option -profile) +%M3_PROFILING = FALSE + +readonly TARGET = "LINUXLIBC6" % code generation target +if M3_PROFILING + readonly BUILD_DIR = TARGET & "p" % code generation target +else + readonly BUILD_DIR = TARGET % directory for results +end +readonly OS_TYPE = "POSIX" % { "WIN32" or "POSIX" } +readonly WORD_SIZE = "32BITS" % { "32BITS" or "64BITS" } +readonly GNU_PLATFORM = "i486--linuxelf" % "cpu-vendor-os" string for GNU +%readonly INSTALL_KEY = BEGIN_CONFIG +% "What is your installation key?" +% 14 %-- user specified key +%END_CONFIG + +readonly NAMING_CONVENTIONS = "0" +% object files libraries +% 0=Unix => .o .io .mo libXX.a +% 1=Unix with a grumpy C compiler => .o _i.o _m.o libXX.a +% 2=Windows NT or Windows 95 => .obj .io .mo XX.lib +% + +%-------------------------------------------------- default compile options --- +% "set_config_options" is called before starting the compilation. It should +% be used to provide system-wide default options. + +proc set_config_options () is + m3_option ("-why") %-- produce a listing that explains what's happening and why + m3_debug (TRUE) %-- produce object code with debugging symbols + M3_OPTIONS += "-w1" %-- produce "level 1" warnings +end + +%--------------------------------------------------------- Reactor defaults --- +% The first time a user runs Reactor, it will configure itself to use +% the executables defined below. + +%INITIAL_REACTOR_BROWSER = BEGIN_CONFIG +% "What should be the default World-Wide Web browser for new Reactor users?" +% 0 "netscape" +% 6 "/usr/local/bin" "netscape" +% 6 "/usr/local/netscape/bin" "netscape" +% 6 "/usr/local/netscape/bin" "netscape-3" +% 6 "/usr/local/netscape/bin" "netscape-2" +% 6 "/usr/local/netscape" "netscape" +% 6 "/usr/local/mosaic" "mosaic" +% 6 "/usr/local/moasic" "Xmosaic" +%END_CONFIG +% A World-Wide Web browser. Reactor passes it an initial URL +% its first command-line argument. + +INITIAL_REACTOR_EDITOR = "GENTOO_INITIAL_REACTOR_EDITOR" +% A text editor. Reactor passes it "<file> +<line>" on the +% command-line when it wants to edit <file> initially positioned +% at <line>. + +%------------------------------------------------------------- export paths --- +% During the installation, destination directories that do not exists +% will be created. You need the necessary permissions to do so; otherwise, +% the installation will fail, but can be restarted after you have +% fixed the permissions. + +INSTALL_ROOT = "GENTOO_INSTALL_ROOT" + +BIN_INSTALL = INSTALL_ROOT & "/bin" % executables +if M3_PROFILING + LIB_INSTALL = INSTALL_ROOT & "/libp" % libraries +else + LIB_INSTALL = INSTALL_ROOT & "/lib" % libraries +end +PKG_INSTALL = INSTALL_ROOT & "/pkg" % packages +DOC_INSTALL = INSTALL_ROOT & "/doc" % documents +EMACS_INSTALL = INSTALL_ROOT & "/elisp" % emacs lisp code +MAN_INSTALL = INSTALL_ROOT & "/man" % man pages +HTML_INSTALL = INSTALL_ROOT & "/www" % public hypertext + +% On some systems (e.g. AFS) you must install public files in a different +% place from where you use them. If that is the case for your system, +% specify the "use" location here, otherwise leave them alone. +% +USE_ROOT = INSTALL_ROOT +BIN_USE = BIN_INSTALL % executables +LIB_USE = LIB_INSTALL % libraries +PKG_USE = PKG_INSTALL % packages + +readonly INSTALL_IMPLS = TRUE +% TRUE +% => save all source files during the install +% => makes debugging easier and browsing more fruitful +% FALSE +% => save only the exported interfaces and templates +% => makes the installed system slightly smaller. + +%------------------------------------------------ external system libraries --- +% SYSTEM_LIBS provides a mapping from Modula-3 names for the common +% external libraries to site-dependent information about how they +% are accessed. If SYSTEM_LIBS{x} is defined it should be a list +% of linker arguments that are used when linking against that library. +% If SYSTEM_LIBS{x} is not defined, the Modula-3 system will assume +% that the library is not available. + +SYSTEM_LIBS = { + "LIBC" : [ "-lm" ], +%-- not on most Linux platforms +% "LEX-YACC" : [ BEGIN_CONFIG +% "Where are the lex/yacc libraries?" +% 11 "libl.a" +% 12 "/usr/lib" +% 12 "/usr/local/lib" +% 12 "/usr/local/gnu/lib" +% 13 "/usr/lib" +% END_CONFIG, "-ll" ], + "FLEX-BISON" : [ "-L/usr/lib", "-lfl" ], +% "POSTGRES95" : [ BEGIN_CONFIG +% "OPENGL" : [ BEGIN_CONFIG +% "ODBC" : [ BEGIN_CONFIG +% "MOTIF" : [ BEGIN_CONFIG +% "X11" : [ BEGIN_CONFIG + "TCP" : [ ] +} + +% SYSTEM_LIBORDER defines the order in which SYSTEM_LIBS should be +% scanned by the linker. + +SYSTEM_LIBORDER = [ "OPENGL", "DECPEX", "MOTIF", "X11", "TCP", "ODBC", + "POSTGRES95", "FLEX-BISON", "LEX-YACC", "LIBC" ] + +%---------------------------------------------------------- system programs --- + +readonly SYSTEM_CC = "/usr/bin/gcc" % C compiler +readonly SYSTEM_AR = "/usr/bin/ar" % Archiver +readonly SYSTEM_ASM = "/usr/bin/as" % Assembler + +%--------------------------------------------------------- Modula-3 backend --- +% For platforms without an integrated backend, "m3_backend" is called to +% translate Modula-3 intermediate code to object code. + +readonly m3back = "@" & BIN_USE & "/cm3cg" + +proc m3_backend (source, object, optimize, debug) is + local args = [ "-quiet", source, "-o", object ] + if optimize args += "-O" end + if debug args += "-g" end + if M3_PROFILING args += "-p" end + return try_exec (m3back, args) +end + +M3_BACKEND_MODE = "3" +% -- defines how the frontend, backend, and assembler interact +% "0" -- don't call m3_backend, M3CG produces object code +% "1" -- don't call m3_backend, M3CG produces assembly code +% "2" -- call m3_backend, it produces object code +% "3" -- call m3_backend, it produces assembly code + +%--------------------------------------------------------------- C compiler --- +% "compile_c" is called to compile C source files. Note that this function +% is only called if your program or library explicitly includes C source +% code, the system distributed by Critical Mass does not. + +proc compile_c (source, object, options, optimize, debug) is + local args = [ "-fPIC", options ] + if optimize args += "-O" end + if debug args += "-g" end + if M3_PROFILING args += "-pg" end + return try_exec ("@" & SYSTEM_CC, args, "-c", source) +end + +%---------------------------------------------------------------- assembler --- +% "assemble" is called to assemble .s or .asm files. Note that this function +% is only called if your program or library explicitly includes assembly source +% code, the system distributed by Critical Mass does not. + +proc assemble (source, object) is + return try_exec ("@" & SYSTEM_ASM, source, "-o", object) +end + +%--------------------------------------------------------- library creation --- +% "make_lib" is called to combine a collection of object modules into +% a library. + +GCWRAPFLAGS = "-Wl,--wrap,adjtime,--wrap,getdirentries,--wrap,readv,--wrap,utimes,--wrap,wait3" + +proc make_lib (lib, options, objects, imported_libs, shared) is + local ret_code = 0 + local lib_a = format ("lib%s.a", lib) + local lib_so = format ("lib%s.so", lib) + local lib_sox = format ("lib%s.so.5", lib) + + % first, build the non-shared library + ret_code = try_exec ("@/usr/bin/ar", "crus", lib_a, objects) + if not equal (ret_code, 0) return ret_code end + + if shared + % build the shared library + if M3_PROFILING + ret_code = try_exec ("@" & SYSTEM_CC, "-pg -shared " & GCWRAPFLAGS & + "-Wl,-soname," & lib_sox, + "-o", lib_sox, objects) + else + ret_code = try_exec ("@" & SYSTEM_CC, "-shared " & GCWRAPFLAGS & + "-Wl,-soname," & lib_sox, + "-o", lib_sox, objects) + end + if not equal (ret_code, 0) return ret_code end + + % create the version aliases + link_file(lib_sox, lib_so) + + % finally, make sure the shared library stuff gets installed properly + install_derived (lib_sox) + install_derived_link (lib_sox, lib_so) + install_link_to_derived (lib_sox, LIB_INSTALL) + install_link_to_derived (lib_so, LIB_INSTALL) + else + delete_file (lib_so) + delete_file (lib_sox) + end + + return 0 +end + +%------------------------------------------------------------------- +% "skip_lib" is called when the compiler decides it doesn't need to +% call "make_lib", but it wants to discover the names of the derived +% files that should be deleted or shipped. + +proc skip_lib (lib, shared) is + local lib_so = format ("lib%s.so", lib) + local lib_sox = format ("lib%s.so.5", lib) + + if shared + % make sure the shared library stuff gets installed properly + install_derived (lib_sox) + install_derived (lib_so) + install_link_to_derived (lib_sox, LIB_INSTALL) + install_link_to_derived (lib_so, LIB_INSTALL) + else + delete_file (lib_so) + delete_file (lib_sox) + end + + return 0 +end + +%------------------------------------------------------------------- linker --- +% "m3_link" is called to produce a final executable. +%--- "-pdb:none" enables the use of windbg with the resulting executable. + +proc m3_link (prog, options, objects, imported_libs, shared) is + local args = [] + if M3_PROFILING args += "-pg" end + args += [ "-o", prog, options, objects, imported_libs ] + if shared + return try_exec ("@" & SYSTEM_CC, args, GCWRAPFLAGS) + else + return try_exec ("@" & SYSTEM_CC, "-static", args, GCWRAPFLAGS) + %%% -- see M3_NEED_STANDALONE_LINKS below + %%%return try_exec ("@" & SYSTEM_CC, args) + end +end + +%------------------------------------------------------------------- +% "skip_link" is called when the compiler decides it doesn't need to +% call "m3_link", but it wants to discover the names of the derived +% files that should be deleted or shipped. + +proc skip_link (prog, shared) is + return 0 +end + +%------------------------------------------------------------ misc. options --- +% Note, most of these options can be set from the command line. Otherwise, +% they can be set "permanently" here in the config file or in as needed +% in user's m3makefiles. + +M3_FRONT_FLAGS = [ ] +% --- internal configuration options passed directly to the Modula-3 front-end + +M3_OPTIONS = [ ] +% --- user options passed directly to the Modula-3 front-end + +% M3_KEEP_FILES = TRUE +% --- keep intermediate and temporary files + +M3_WINDOWS_GUI = FALSE +% --- generate a Windows GUI subsystem program instead of a console one. + +% M3_COVERAGE = TRUE +% --- compile & link with coverage options + +M3_COVERAGE_LIB = LIB_USE & "/report_coverage.o" +% --- library linked in programs compiled with "-Z" coverage option + +M3_SPLIT_LIBNAMES = TRUE +% --- split library names and pass -L/-l arguments to the linker + +M3_SHARED_LIB_ARG = "-Wl,-R" +% --- pass "-R" flags to the linker too... + +% M3_BOOTSTRAP = TRUE +% --- generate bootstrap code (assembly) instead of finaly object code + +% M3_COMPILE_ONCE = TRUE +% --- don't recompile code to improve opaque object references + +% SYS_HAS_LOADER = TRUE +% --- generate a loader info file with objects, libraries and timestamps + +% M3_SKIP_LINK = TRUE +% --- skip the final link for programs, presumably to use the loader instead + +% M3_MAIN_IN_C = TRUE +% --- generate the Modula-3 main program as C code + +% X11_WITH_SHARED_MEM = TRUE +% --- X11 libraries include the shared memory extensions (XShm...) + +%M3_NEED_STANDALONE_LINKS = TRUE +% --- linker is broken and we need to build a directory of symbolic +% links pointing to the non-shared libraries. + +%-------------------------------------------------------------------- emacs --- +% If you have emacs and want to compile ".el" files to ".elc" files, +% fill in the function below. Otherwise, comment out or delete the +% entire function. Note, the distributed code assumes gnuemacs version 19 +% or later. + +%readonly proc emacs_compile (el) is +% exec ("emacs -batch -f batch-byte-compile", el) +%end + +%------------------------------------------------------------- GNU variants --- +% The two large pieces of GNU software used by the Modula-3 system +% gcc(=m3cc) and gdb(=m3gdb) often require slightly different C compilers +% or flags. They are specified here. Note that they may be overridden +% from the m3build command line. +% +% To use the GNU defaults for CC and CFLAGS, specify "*". +% + +GNU_CC = "GENTOO_GNU_CC" +GNU_CFLAGS = "GENTOO_GNU_CFLAGS" +GNU_MAKE = "GENTOO_GNU_MAKE" diff --git a/dev-lang/cm3-bin/files/digest-cm3-bin-5.2.6 b/dev-lang/cm3-bin/files/digest-cm3-bin-5.2.6 new file mode 100644 index 000000000000..3156fc7472b5 --- /dev/null +++ b/dev-lang/cm3-bin/files/digest-cm3-bin-5.2.6 @@ -0,0 +1 @@ +MD5 c473f5c15072c4b454ec193ea8d672ac cm3-min-POSIX-LINUXLIBC6-5.2.6.tgz 5552629 diff --git a/dev-lang/cm3-bin/files/m3build b/dev-lang/cm3-bin/files/m3build new file mode 100644 index 000000000000..15f78321353f --- /dev/null +++ b/dev-lang/cm3-bin/files/m3build @@ -0,0 +1,2 @@ +#!/bin/bash +cm3 -build $@ diff --git a/dev-lang/cm3-bin/files/m3ship b/dev-lang/cm3-bin/files/m3ship new file mode 100644 index 000000000000..a816c7ae8a8f --- /dev/null +++ b/dev-lang/cm3-bin/files/m3ship @@ -0,0 +1,2 @@ +#!/bin/bash +cm3 -ship $@ |