summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authoragc <agc@pkgsrc.org>1998-03-31 11:49:37 +0000
committeragc <agc@pkgsrc.org>1998-03-31 11:49:37 +0000
commit2d57c551adaa26520fc0cdae6570aa112cfbdef7 (patch)
treebb1b4ebfe21af22f654be0e4ef4040533769d65b
parent0f5b4576da93c53eb88e336952033e1a9d1a6aae (diff)
downloadpkgsrc-2d57c551adaa26520fc0cdae6570aa112cfbdef7.tar.gz
Initial import of elk-3.0.2, a scheme interpreter, into the NetBSD
packages collection, from the FreeBSD port.
-rw-r--r--lang/elk/Makefile36
-rw-r--r--lang/elk/files/md51
-rw-r--r--lang/elk/patches/patch-a76
-rw-r--r--lang/elk/patches/patch-c462
-rw-r--r--lang/elk/patches/patch-d77
-rw-r--r--lang/elk/patches/patch-e15
-rw-r--r--lang/elk/pkg/COMMENT1
-rw-r--r--lang/elk/pkg/DESCR10
-rw-r--r--lang/elk/pkg/PLIST84
-rw-r--r--lang/elk/scripts/configure4
10 files changed, 766 insertions, 0 deletions
diff --git a/lang/elk/Makefile b/lang/elk/Makefile
new file mode 100644
index 00000000000..79fb654e480
--- /dev/null
+++ b/lang/elk/Makefile
@@ -0,0 +1,36 @@
+# New ports collection makefile for: elk
+# Version required: 3.0pl2
+# Date created: 08 March 1995
+# Whom: Thomas Gellekum <tg@FreeBSD.org>
+#
+# FreeBSD Id: Makefile,v 1.15 1997/09/01 12:28:30 tg Exp
+#
+
+DISTNAME= elk-3.0
+PKGNAME= elk-3.0.2
+CATEGORIES= lang
+MASTER_SITES= ftp://ftp.uni-bremen.de/pub/programming/languages/scheme/elk/
+
+MAINTAINER= tg@freebsd.org
+
+PATCH_STRIP= -p1
+ALL_TARGET= default
+MAN1= elk.1
+
+#
+# we install the scheme binary as ${PREFIX}/bin/elk
+# to avoid a clash with mit-scheme.
+#
+
+pre-install:
+ @${MKDIR} ${PREFIX}/share/elk
+
+post-install:
+ @(cd ${PREFIX}/share/elk; \
+ ${CP} bin/scheme ${PREFIX}/bin/elk; \
+ ${MKDIR} ${PREFIX}/include/elk; \
+ ${CP} -R include/* ${PREFIX}/include/elk; \
+ rm -rf bin include)
+ @${INSTALL_MAN} ${WRKSRC}/doc/man/elk.1 ${PREFIX}/man/man1
+
+.include <bsd.port.mk>
diff --git a/lang/elk/files/md5 b/lang/elk/files/md5
new file mode 100644
index 00000000000..d9ed109b1b1
--- /dev/null
+++ b/lang/elk/files/md5
@@ -0,0 +1 @@
+MD5 (elk-3.0.tar.gz) = bbe018f9ba0fb77eb5477b8b992b595a
diff --git a/lang/elk/patches/patch-a b/lang/elk/patches/patch-a
new file mode 100644
index 00000000000..066abe53e52
--- /dev/null
+++ b/lang/elk/patches/patch-a
@@ -0,0 +1,76 @@
+diff -crP -x *.ps elk-3.0.orig/Makefile elk-3.0/Makefile
+*** elk-3.0.orig/Makefile Tue Feb 8 13:11:23 1994
+--- elk-3.0/Makefile Wed Mar 8 19:11:18 1995
+***************
+*** 16,24 ****
+ lib/unix\
+ lib/xlib\
+ lib/xt\
+! lib/xaw\
+! lib/xm\
+! lib/xm/xt
+
+ # ----------------------------------------------------------------------
+
+--- 16,24 ----
+ lib/unix\
+ lib/xlib\
+ lib/xt\
+! lib/xaw
+! # lib/xm\
+! # lib/xm/xt
+
+ # ----------------------------------------------------------------------
+
+diff -crP -x *.ps elk-3.0.orig/doc/man/elk.1.orig elk-3.0/doc/man/elk.1
+*** elk-3.0/doc/man/elk.1.orig Thu Apr 6 14:40:07 1995
+--- elk-3.0/doc/man/elk.1 Thu Apr 6 14:41:02 1995
+***************
+*** 2,10 ****
+ .TH ELK 1 "15 January 1991"
+ .UC 4
+ .SH NAME
+! elk, scheme \- extensible Scheme interpreter
+ .SH SYNOPSIS
+! .B scheme
+ [
+ .B \-l \f2file\fP
+ ] [
+--- 2,10 ----
+ .TH ELK 1 "15 January 1991"
+ .UC 4
+ .SH NAME
+! elk \- extensible Scheme interpreter
+ .SH SYNOPSIS
+! .B elk
+ [
+ .B \-l \f2file\fP
+ ] [
+***************
+*** 20,27 ****
+ ] [[
+ .B \-\^\-
+ ] \f2args\fP]
+- .LP
+- .BR elk .\|.\|.
+ .SH DESCRIPTION
+ .I Elk
+ (Extension Language Kit) is a Scheme interpreter intended
+--- 20,25 ----
+***************
+*** 32,38 ****
+ is linked with the application it serves, but a stand-alone version
+ of the Scheme interpreter is installed as well (usually under
+ the name
+! .BR scheme ).
+ This interpreter, together with the standard Scheme toplevel,
+ .I Elk
+ can be used as an ordinary, stand-alone implementation of the
+--- 30,36 ----
+ is linked with the application it serves, but a stand-alone version
+ of the Scheme interpreter is installed as well (usually under
+ the name
+! .BR elk ).
+ This interpreter, together with the standard Scheme toplevel,
+ .I Elk
+ can be used as an ordinary, stand-alone implementation of the
diff --git a/lang/elk/patches/patch-c b/lang/elk/patches/patch-c
new file mode 100644
index 00000000000..5278c4dbfbb
--- /dev/null
+++ b/lang/elk/patches/patch-c
@@ -0,0 +1,462 @@
+diff -crP -x *.ps elk-3.0.orig/config/sites/386pc-freebsd2 elk-3.0/config/sites/386pc-freebsd2
+*** elk-3.0.orig/config/sites/386pc-freebsd2.1 Thu Jan 1 01:00:00 1970
+--- elk-3.0/config/sites/386pc-freebsd2.1 Wed Mar 8 19:19:43 1995
+***************
+*** 0 ****
+--- 1,80 ----
++ # This is a shell script. It is sourced by the build scripts in the
++ # various subdirectories to gather site- and installation-specific
++ # information required for building the Makefiles.
++ #
++ # This script is read after the "system" file, therefore you can place
++ # variable settings here to override those from "system".
++ #
++ # Some variables in this script are interpreted as boolean variables and
++ # indicate presence or absence of one specific feature. The value "yes"
++ # is regarded as "true", all other values (including no value or even
++ # non-existence of the variable) are interpreted as "false".
++ #
++ # Do not forget to quote values that contain shell meta syntax.
++ #
++ # -----------------------------------------------------------------------
++
++
++ # The directory where all files are installed by running "make install".
++ # The subdirectories bin, lib, include, and runtime (with various
++ # subdirectories) are created automatically, but $install_dir isn't.
++ # Make sure $install_dir doesn't point to the top of the source tree
++ # (i.e. choose a subdirectory or a directory outside the source tree).
++
++ install_dir=${PREFIX}/share/elk
++
++
++ # Libraries against which to link the X11 extension (typically -lX11).
++ #
++ # Any of the following library lists may be prefixed by something like
++ # -L/usr/X11/lib if the X-libraries do not reside in a standard directory;
++ # an additional -R/usr/X11/lib and -lsocket may be required in case of
++ # SunOS 5.x/SysVR4).
++
++ libxlib="-L${X11BASE}/lib -lX11"
++
++ # Libraries against which to link the Xt extension (typically
++ # -lXaw -lXmu -lXt -lSM -lICE -lXext -lX11). -lXaw is needed to get the correct
++ # definition of the vendor shell widget class
++
++ libxt="-L${X11BASE}/lib -lX11 -lXext -lICE -lSM -lXt -lXmu -lXaw"
++
++
++ # Libraries against which to link the Athena widgets extension (typically
++ # identical to libxt above)
++
++ libxaw="-L${X11BASE}/lib -lX11 -lXext -lICE -lSM -lXt -lXmu -lXaw"
++
++
++ # Libraries against which to link the Motif extension (typically like
++ # libaw above with Xaw replaced by Xm)
++
++ libxmotif="-L${X11BASE}/lib -lX11 -lXext -lICE -lSM -lXt -lXmu -lXm"
++
++
++ # Additional flags (typically -Isomething) to be supplied to the C
++ # compiler when compiling an X11 application, or a Motif application,
++ # respectively.
++
++ x11_incl=-I${X11BASE}/include
++ motif_incl=-I${X11BASE}/include
++
++
++ # Set "gdbm" to "yes" if you have the GNU gdbm library installed and
++ # want the gdbm extension to be compiled. "gdbm_inc" gives additional
++ # C compiler flags required to compile a program using gdbm.
++
++ gdbm=
++ gdbm_incl=-I${PREFIX}/include/gdbm
++
++
++ # Do you want to use the generational garbage collector? If not, the
++ # stop-and-copy garbage collector will be used.
++
++ generational_gc=yes
++
++
++ # The default heap size of the Scheme interpreter in KBytes (if the
++ # stop-and-copy garbage collector is used).
++
++ default_heap_size=1024
+diff -crP -x *.ps elk-3.0.orig/config/untested/386pc-freebsd2-cc elk-3.0/config/untested/386pc-freebsd2-cc
+*** elk-3.0.orig/config/untested/386pc-freebsd2.1-cc Thu Jan 1 01:00:00 1970
+--- elk-3.0/config/untested/386pc-freebsd2.1-cc Wed Mar 8 19:19:21 1995
+***************
+*** 0 ****
+--- 1,370 ----
++ # This is a shell script. It is sourced by the build scripts in the
++ # various subdirectories to gather system-, compiler-, and OS-specific
++ # information required for building the Makefiles.
++ #
++ # Most variables in this script are interpreted as boolean variables and
++ # indicate presence or absence of one specific feature. The value "yes"
++ # is regarded as "true", all other values (including no value or even
++ # non-existence of the variable) are interpreted as "false".
++ #
++ # Do not forget to quote values that contain shell meta syntax.
++ #
++ # -----------------------------------------------------------------------
++
++
++ # $system should contain the name of this file. It may be used by some
++ # of the build scripts to do things that are specific to one single
++ # type of system.
++
++ system=386pc-freebsd2.1-cc
++
++
++ # Does the system support the vprintf library function? If not,
++ # availability of the (non-portable) _doprnt function is assumed.
++
++ vprintf=yes
++
++
++ # Does the directory(3) library follow the POSIX conventions (i.e.
++ # requires the <dirent.h> include file and uses "struct dirent")?
++ # If not, the (obsolete) BSD-style interface with <sys/dir.h> and
++ # "struct direct" is assumed.
++
++ dirent=yes
++
++
++ # Does the system have the random/srandom library functions? If not,
++ # rand/srand will be used instead.
++
++ random=yes
++
++
++ # Does the system have the index library function? If not, strchr
++ # will be used.
++
++ index=yes
++
++
++ # Does the system have the bcopy, bzero, and bcmp library functions?
++ # If not, memcpy/memset/memcmp will be used.
++
++ bstring=yes
++
++
++ # Does using the access system call require <unistd.h> to be included?
++ # (Look into the manual page for access if in doubt.)
++
++ include_unistd_h=yes
++
++
++ # If the FIONREAD ioctl command is defined, which file must be included?
++
++ fionread_include='<sys/ioctl.h>'
++
++
++ # What is the name of the a.out include file?
++
++ aout_h='<a.out.h>'
++
++
++ # The following variables control how certain system limits are obtained
++ # during runtime.
++ #
++ # If getdtablesize() is available to determine the maximum number of open
++ # files per process, set getdtablesize=yes.
++ # Alternatively, if POSIX-style sysconf() can be called with _SC_OPEN_MAX,
++ # set sysconf_open_max=yes.
++ # If neither is set to "yes", an educated guess will be made.
++
++ getdtablesize=yes
++ sysconf_open_max=yes
++
++ # If POSIX-style pathconf() can be invoked with _PC_PATH_MAX to determine
++ # the maximum pathname length, set pathconf_path_max=yes.
++
++ pathconf_path_max=yes
++
++ # If the system page size can be determined by calling getpagesize()
++ # set getpagesize=yes.
++ # Alternatively, if sysconf() can be invoked with _SC_PAGESIZE, set
++ # sysconf_pagesize=yes.
++ # These two variables are only required if the generational garbage
++ # collector is used.
++
++ getpagesize=yes
++ sysconf_pagesize=no
++
++
++ # Set reliable_signals=bsd if your system supports BSD-style reliable
++ # signals (has sigblock and related functions); set reliable_signals=posix
++ # for POSIX-style signals (sigprocmask, sigsets); otherwise old V7/SysV
++ # signal semantics are assumed.
++
++ reliable_signals=bsd
++
++
++ # To support dynamic loading of object files and "dump", the system's
++ # a.out format has to be known. Choose one of the following:
++ #
++ # coff ecoff xcoff elf macho hp9k convex
++ #
++ # Other values of "aout_format" are interpreted as BSD-style a.out format.
++
++ aout_format=
++
++
++ # Which mechanism should be used to dynamically load object files?
++ # Possible values currently are:
++ #
++ # ld BSD-style incremental loading based on ld -A
++ # rld NeXT-style rld_load()
++ # shl HP-UX shl_load()
++ # dl SysVR4/SunOS5 dlopen()
++ #
++ # Leave load_obj empty if dynamic loading is not supported.
++
++ load_obj=dl
++
++
++ # The following variables are only relevant if load_obj is set.
++
++ # Linker options to produce a shared object from a .o file.
++ # Only used if load_obj=dl.
++
++ ldflags_shared='-Bshareable'
++
++ # The libraries against which dynamically loaded files are resolved
++ # at the time they are loaded.
++
++ load_libraries=
++
++ # Does the ld-option -x really do what the manual says it does (i.e.
++ # omit local symbols), or does it somehow render the resulting object
++ # file unsuitable for dynamic loading? If in doubt, leave it out
++ # (which may result in somewhat larger object files).
++
++ incremental_ldflags=-x
++
++ # Systems with "aout_format=ecoff" may require a call to the cacheflush
++ # system call after an object file has been loaded. Which include file
++ # has to be included in this case?
++
++ cachectl_h=unused
++
++ # Is the ANSI-C atexit function supported to register an exit handler?
++ # If not, the exit library function will be redefined and will end in
++ # a call to _exit.
++
++ atexit=yes
++
++
++ # Do the names of external functions in the symbol table always begin
++ # with a special character (such as underline)? If so, syms_begin_with
++ # should hold this character, otherwise leave it empty.
++
++ syms_begin_with=_
++
++
++ # The symbol prefixes of extension initialization and finalization
++ # functions (without the initial $syms_begin_with). Do not change
++ # these unless the compiler or linker restricts the length of symbols!
++
++ init_prefix=elk_init_
++ finit_prefix=elk_finit_
++
++
++ # Is the "dump" function supported?
++
++ can_dump=no
++
++
++ # The following variables are only relevant if "can_dump=yes".
++
++ # Is the fchmod system call broken or unavailable?
++
++ fchmod_broken=no
++
++ # These four variables are only relevant if the system has the BSD-style
++ # a.out format.
++ # segment_size is the segment size of the system's memory management
++ # unit, i.e. the number to a multiple of which the size of an a.out
++ # segment (e.g. .text) is rounded up.
++ # file_text_start is the file offset at which the text segment starts
++ # in an a.out file.
++ # mem_text_start is the starting address of the text segment in memory.
++ # text_length_adj must be set to "sizeof (struct exec)" if the length of
++ # the text segment stored in the a.out header includes the a.out header
++ # itself.
++
++ segment_size=__LDPGSZ
++ file_text_start='(N_TXTOFF(hdr) + sizeof(struct exec))'
++ mem_text_start='(sizeof(struct exec) + getpagesize())'
++ text_length_adj='(sizeof(struct exec))'
++
++ # Only relevant if "aout_format=coff": the system's pagesize.
++
++ coff_pagesize=
++
++ # Only relevant if "aout_format=hp9k" and "load_obj=shl"
++
++ hp_shared_libraries=yes
++
++ # Print debug messages when dumping
++
++ debug_dump=yes
++
++
++ # Is the "termio" terminal interface supported by the system? If not,
++ # BSD-style tty handling will be used.
++
++ termio=yes
++
++
++ # flush_stdio and flush_tty indicate how clear-input/output-port can
++ # flush (purge) a FILE pointer and a TTY file descriptor.
++ # Possible values of flush_stdio:
++ # bsd assume old BSD-style FILE* (with _cnt, _ptr, _base)
++ # fpurge use 4.4BSD-style fpurge stdio library function
++ # linux use Linux-specific method
++ # Possible values of flush_tty:
++ # tiocflush use TIOCFLUSH ioctl from <sys/ioctl.h>
++ # tcflsh use TCFLSH ioctl from <termio.h>
++ # Leave the variable(s) empty if flushing is not supported.
++
++ flush_stdio=fpurge
++ flush_tty=tiocflush
++
++
++ # The interpreter uses the getrlimit function to determine the maximum
++ # stack size of the running program. If this function is not supported,
++ # set max_stack_size to a (fixed) maximum stack size (in bytes).
++
++ max_stack_size=
++
++
++ # Is the mprotect system call supported? The generational garbage collector
++ # requires mprotect to implement incremental GC. $mprotect is ignored if
++ # generational_gc is set to "no" in the site file. Set mprotect=mmap if
++ # mprotect is supported, but only for mmap()ed memory.
++
++ mprotect=yes
++
++
++ # How can a SIGSEGV or SIGBUS signal handler find out the address of
++ # the faulting memory reference? This variable is only used if
++ # $mprotect is "yes" or "mmap". Possible values are:
++ #
++ # siginfo handler is called with siginfo_t structure (enabled
++ # by a call to sigaction)
++ # sigcontext address is in the sigcontext structure (3rd arg, sc_badvaddr)
++ # arg4 address is delivered to handler as argument #4
++ # aix use an AIX-specific hack to get hold of the bad address
++ # hpux use a HP-UX-specific hack
++
++ sigsegv_addr=arg4
++
++
++ # Does the system support the alloca library function, and does this
++ # function actually extend the stack? If in doubt, extract alloca.o
++ # from the C library and check if it contains the symbols malloc and free.
++ # If this is the case, forget it.
++
++ use_alloca=yes
++
++
++ # Must <alloca.h> be included to use alloca? Is "#pragma alloca" required?
++
++ include_alloca_h=no
++ pragma_alloca=no
++
++
++ # Does the system (or compiler) require certain objects (e.g. doubles)
++ # to be aligned at 8-byte boundaries? If not, 4-byte alignment will
++ # be assumed.
++
++ align_8byte=yes
++
++
++ # The C compiler used to compile the source code.
++
++ cc=cc
++
++
++ # The name of the linker. This is usually just "ld", or /usr/ccs/bin/ld
++ # in SVR4-based systems.
++
++ ld=ld
++
++
++ # The C compiler flags used for all files.
++
++ cflags='-O2 -pipe -m486'
++
++
++ # Are extra C compiler flags (such as -D_NO_PROTO) required to compile
++ # Motif applications?
++
++ motif_cflags=
++
++
++ # Are extra C compiler flags (such as -G 0) required to compile
++ # dynamically loadable files?
++
++ obj_cflags='-fpic -DPIC'
++
++
++ # Are extra linker flags (such as -G 0) required to link several object
++ # files together to one dynamically loadable file?
++
++ obj_ldflags=
++
++
++ # The linker flags used to link the interpreter.
++
++ ldflags='-lm'
++
++
++ # The lint flags.
++
++ lintflags='-abxh'
++
++
++ # Are function prototypes in the header files required? If prototypes=yes,
++ # prototypes are used unconditionally; if prototypes=no, prototypes are
++ # not used; otherwise prototypes are only used if the source code is
++ # compiled with an ANSI-C- or C++-compiler.
++
++ prototypes=yes
++
++
++ # Does your C preprocessor support the ANSI-C ## operator, although
++ # __STDC__ is not defined?
++
++ ansi_cpp=no
++
++
++ # The UNIX extension likes to know which of the following system calls,
++ # library functions, and include files are supported by the system.
++
++ gettimeofday=yes
++ ftime=
++ vfork=yes
++ gethostname=yes
++ uname=yes
++ mktemp=yes
++ tmpnam=yes
++ tempnam=yes
++ getcwd=yes
++ getwd=yes
++ rename=yes
++ waitpid=yes
++ wait3=yes
++ wait4=yes
++ utime_h=yes
++ regcomp=yes
++
++
++ # Element type of the gidset argument of getgroups(); typically int
++ # or gid_t. Only needed by the UNIX extension.
++
++ getgroups_type=gid_t
diff --git a/lang/elk/patches/patch-d b/lang/elk/patches/patch-d
new file mode 100644
index 00000000000..44a4ca5c3c0
--- /dev/null
+++ b/lang/elk/patches/patch-d
@@ -0,0 +1,77 @@
+diff -crP -x *.ps elk-3.0.orig/src/dump-vanilla.c elk-3.0/src/dump-vanilla.c
+*** elk-3.0.orig/src/dump-vanilla.c.orig Thu Jun 29 13:55:51 1995
+--- elk-3.0/src/dump-vanilla.c Thu Sep 7 15:00:35 1995
+***************
+*** 12,17 ****
+--- 12,21 ----
+
+ extern void *sbrk();
+
++ #if defined(__FreeBSD__)
++ extern etext;
++ #endif
++
+ #if defined(hp9000s300) || defined(__hp9000s300) || defined(__hp9000s300__)
+ static int getpagesize () {
+ return EXEC_PAGESIZE;
+***************
+*** 113,125 ****
+ close (afd);
+ #if defined(__bsdi__)
+ data_start = N_DATADDR(hdr);
+ #else
+ data_start = hdr.a_text;
+ #if defined(sun) || defined(__sun__)
+ data_start += pagemask+1;
+ #endif
+ data_start = (data_start + SEG_SIZ-1) & ~(SEG_SIZ-1);
+- #endif
+ data_end = (unsigned)sbrk (0);
+ #if !defined(__bsdi__)
+ data_end = (data_end + pagemask) & ~pagemask;
+--- 117,131 ----
+ close (afd);
+ #if defined(__bsdi__)
+ data_start = N_DATADDR(hdr);
++ #elif defined (__FreeBSD__)
++ data_start = (int) &etext;
+ #else
+ data_start = hdr.a_text;
++ #endif
+ #if defined(sun) || defined(__sun__)
+ data_start += pagemask+1;
+ #endif
+ data_start = (data_start + SEG_SIZ-1) & ~(SEG_SIZ-1);
+ data_end = (unsigned)sbrk (0);
+ #if !defined(__bsdi__)
+ data_end = (data_end + pagemask) & ~pagemask;
+diff -crP -x *.ps elk-3.0.orig/src/print.c elk-3.0/src/print.c
+*** elk-3.0.orig/src/print.c.orig Mon Aug 7 09:28:42 1995
+--- elk-3.0/src/print.c Thu Sep 7 14:58:28 1995
+***************
+*** 6,11 ****
+--- 6,12 ----
+ #include <errno.h>
+ #include <ctype.h>
+ #include <varargs.h>
++ #include <sys/param.h>
+
+ #ifdef FLUSH_TIOCFLUSH
+ # include <sys/ioctl.h>
+***************
+*** 555,561 ****
+ register c;
+ char buf[256];
+ extern sys_nerr;
+! #ifndef __bsdi__
+ extern char *sys_errlist[];
+ #endif
+ GC_Node;
+--- 556,562 ----
+ register c;
+ char buf[256];
+ extern sys_nerr;
+! #if !(defined(BSD) && (BSD >= 199306))
+ extern char *sys_errlist[];
+ #endif
+ GC_Node;
diff --git a/lang/elk/patches/patch-e b/lang/elk/patches/patch-e
new file mode 100644
index 00000000000..23351628572
--- /dev/null
+++ b/lang/elk/patches/patch-e
@@ -0,0 +1,15 @@
+*** elk-3.0.orig/src/load-dl.c Sun Dec 17 15:45:40 1995
+--- elk-3.0/src/load-dl.c Sun Dec 17 15:46:22 1995
+***************
+*** 4,9 ****
+--- 4,13 ----
+ extern char *strrchr();
+ extern char *getenv();
+
++ #ifndef RTLD_NOW
++ #define RTLD_NOW 1
++ #endif
++
+ Dlopen_File (fn) char *fn; {
+ void *handle;
+ SYM *sp;
diff --git a/lang/elk/pkg/COMMENT b/lang/elk/pkg/COMMENT
new file mode 100644
index 00000000000..807441f1200
--- /dev/null
+++ b/lang/elk/pkg/COMMENT
@@ -0,0 +1 @@
+An embeddable Scheme interpreter.
diff --git a/lang/elk/pkg/DESCR b/lang/elk/pkg/DESCR
new file mode 100644
index 00000000000..50e4f9a7916
--- /dev/null
+++ b/lang/elk/pkg/DESCR
@@ -0,0 +1,10 @@
+Elk is a Scheme interpreter intended to be used as a general, reusable
+extension language subsystem for integration into existing and future
+applications. Elk can also be used as a stand-alone implementation of
+the Scheme programming language.
+
+One purpose of the Elk project is to end the recent proliferation of
+mutually incompatible Lisp-like extension languages. Instead of
+inventing and implementing yet another extension language, application
+programmers can integrate Elk into their application to make it
+extensible and highly customizable.
diff --git a/lang/elk/pkg/PLIST b/lang/elk/pkg/PLIST
new file mode 100644
index 00000000000..fc149cd8b94
--- /dev/null
+++ b/lang/elk/pkg/PLIST
@@ -0,0 +1,84 @@
+bin/elk
+include/elk/compat.h
+include/elk/config.h
+include/elk/cstring.h
+include/elk/exception.h
+include/elk/extern.h
+include/elk/funcproto.h
+include/elk/gc.h
+include/elk/misc.h
+include/elk/object.h
+include/elk/param.h
+include/elk/scheme.h
+include/elk/stkmem.h
+include/elk/type.h
+include/elk/extensions/unix.h
+include/elk/extensions/xlib.h
+include/elk/extensions/xt.h
+share/elk/lib/ldflags
+share/elk/lib/linkscheme
+share/elk/lib/makedl
+share/elk/lib/module.o
+share/elk/lib/standalone.o
+share/elk/runtime/obj/bitstring.o
+share/elk/runtime/obj/debug.o
+share/elk/runtime/obj/elk-eval.o
+share/elk/runtime/obj/hack.o
+share/elk/runtime/obj/monitor.o
+share/elk/runtime/obj/newhandler.o
+share/elk/runtime/obj/record.o
+share/elk/runtime/obj/regexp.o
+share/elk/runtime/obj/struct.o
+share/elk/runtime/obj/unix.o
+share/elk/runtime/obj/xlib.o
+share/elk/runtime/obj/xt.o
+share/elk/runtime/obj/xaw/ALIASES
+share/elk/runtime/obj/xaw/ascii.o
+share/elk/runtime/obj/xaw/box.o
+share/elk/runtime/obj/xaw/command.o
+share/elk/runtime/obj/xaw/dialog.o
+share/elk/runtime/obj/xaw/form.o
+share/elk/runtime/obj/xaw/grip.o
+share/elk/runtime/obj/xaw/label.o
+share/elk/runtime/obj/xaw/list.o
+share/elk/runtime/obj/xaw/menubutton.o
+share/elk/runtime/obj/xaw/paned.o
+share/elk/runtime/obj/xaw/panner.o
+share/elk/runtime/obj/xaw/porthole.o
+share/elk/runtime/obj/xaw/repeater.o
+share/elk/runtime/obj/xaw/scrollbar.o
+share/elk/runtime/obj/xaw/shell.o
+share/elk/runtime/obj/xaw/simplemenu.o
+share/elk/runtime/obj/xaw/sme.o
+share/elk/runtime/obj/xaw/smebsb.o
+share/elk/runtime/obj/xaw/smeline.o
+share/elk/runtime/obj/xaw/stripchart.o
+share/elk/runtime/obj/xaw/toggle.o
+share/elk/runtime/obj/xaw/tree.o
+share/elk/runtime/obj/xaw/viewport.o
+share/elk/runtime/scm/apropos.scm
+share/elk/runtime/scm/bitstring.scm
+share/elk/runtime/scm/cscheme.scm
+share/elk/runtime/scm/debug.scm
+share/elk/runtime/scm/describe.scm
+share/elk/runtime/scm/gdbmtest.scm
+share/elk/runtime/scm/initscheme.scm
+share/elk/runtime/scm/motif.scm
+share/elk/runtime/scm/oops.scm
+share/elk/runtime/scm/parse.scm
+share/elk/runtime/scm/pp.scm
+share/elk/runtime/scm/qsort.scm
+share/elk/runtime/scm/record.scm
+share/elk/runtime/scm/recordutil.scm
+share/elk/runtime/scm/regexp.scm
+share/elk/runtime/scm/safe-env.scm
+share/elk/runtime/scm/setf.scm
+share/elk/runtime/scm/siteinfo.scm
+share/elk/runtime/scm/struct.scm
+share/elk/runtime/scm/toplevel.scm
+share/elk/runtime/scm/trace.scm
+share/elk/runtime/scm/unix.scm
+share/elk/runtime/scm/xlib.scm
+share/elk/runtime/scm/xt.scm
+share/elk/runtime/scm/xwidgets.scm
+man/man1/elk.1.gz
diff --git a/lang/elk/scripts/configure b/lang/elk/scripts/configure
new file mode 100644
index 00000000000..8336f879540
--- /dev/null
+++ b/lang/elk/scripts/configure
@@ -0,0 +1,4 @@
+#!/bin/sh
+
+cp ${WRKSRC}/config/untested/386pc-freebsd2.1-cc ${WRKSRC}/config/system
+cp ${WRKSRC}/config/sites/386pc-freebsd2.1 ${WRKSRC}/config/site