mirror of
https://github.com/Stichting-MINIX-Research-Foundation/pkgsrc-ng.git
synced 2025-09-08 03:44:13 -04:00
Step 1: bootstrap: lang/perl5
This commit is contained in:
parent
81f5ac5907
commit
ab8df800c5
@ -205,6 +205,7 @@ LIBSWANTED.HPUX= cl pthread $$libswanted # see Perl's README.hpux
|
|||||||
LIBSWANTED.IRIX= m crypt
|
LIBSWANTED.IRIX= m crypt
|
||||||
LIBSWANTED.Interix= m dl
|
LIBSWANTED.Interix= m dl
|
||||||
LIBSWANTED.Linux= m crypt dl nsl
|
LIBSWANTED.Linux= m crypt dl nsl
|
||||||
|
LIBSWANTED.Minix= m crypt c
|
||||||
LIBSWANTED.MirBSD= m crypt
|
LIBSWANTED.MirBSD= m crypt
|
||||||
LIBSWANTED.NetBSD= m crypt
|
LIBSWANTED.NetBSD= m crypt
|
||||||
LIBSWANTED.OpenBSD= m crypt
|
LIBSWANTED.OpenBSD= m crypt
|
||||||
@ -224,6 +225,7 @@ SYSLIBPATH.Darwin= /usr/lib
|
|||||||
SYSLIBPATH.DragonFly= /usr/lib
|
SYSLIBPATH.DragonFly= /usr/lib
|
||||||
SYSLIBPATH.FreeBSD= /usr/lib
|
SYSLIBPATH.FreeBSD= /usr/lib
|
||||||
SYSLIBPATH.Interix= /usr/lib
|
SYSLIBPATH.Interix= /usr/lib
|
||||||
|
SYSLIBPATH.Minix= /usr/lib
|
||||||
SYSLIBPATH.MirBSD= /usr/lib
|
SYSLIBPATH.MirBSD= /usr/lib
|
||||||
SYSLIBPATH.NetBSD= /usr/lib
|
SYSLIBPATH.NetBSD= /usr/lib
|
||||||
SYSLIBPATH.OpenBSD= /usr/lib
|
SYSLIBPATH.OpenBSD= /usr/lib
|
||||||
@ -289,6 +291,8 @@ post-extract:
|
|||||||
${WRKSRC}/cpan/DB_File/hints/netbsd.pl
|
${WRKSRC}/cpan/DB_File/hints/netbsd.pl
|
||||||
cp ${FILESDIR}/cpan-DB_File-hints-openbsd.pl \
|
cp ${FILESDIR}/cpan-DB_File-hints-openbsd.pl \
|
||||||
${WRKSRC}/cpan/DB_File/hints/openbsd.pl
|
${WRKSRC}/cpan/DB_File/hints/openbsd.pl
|
||||||
|
# MINIX:
|
||||||
|
cp ${FILESDIR}/minix.sh ${WRKSRC}/hints/minix.sh
|
||||||
|
|
||||||
pre-configure:
|
pre-configure:
|
||||||
cd ${WRKSRC} && find `pwd` -name "*.orig" -type f -exec ${RM} -f {} \;
|
cd ${WRKSRC} && find `pwd` -name "*.orig" -type f -exec ${RM} -f {} \;
|
||||||
|
@ -24,3 +24,4 @@ SHA1 (patch-hints_sco.sh) = 8d43cdc0632799e1cdb5dc6fdb968052a9ae4216
|
|||||||
SHA1 (patch-hints_solaris__2.sh) = 0e54889648a6f0f2a0232c5e01bef89d245c213d
|
SHA1 (patch-hints_solaris__2.sh) = 0e54889648a6f0f2a0232c5e01bef89d245c213d
|
||||||
SHA1 (patch-ta) = a9d13eeec22733e4087942f217a0d47a19498a6f
|
SHA1 (patch-ta) = a9d13eeec22733e4087942f217a0d47a19498a6f
|
||||||
SHA1 (patch-ze) = d6fb718a1417e37a7d6bee1ae89fe2beec51c81b
|
SHA1 (patch-ze) = d6fb718a1417e37a7d6bee1ae89fe2beec51c81b
|
||||||
|
SHA1 (patch-zz-minix) = e324d4a3f6e7bad648b0721093a09e6f047101ca
|
||||||
|
257
lang/perl5/files/minix.sh
Normal file
257
lang/perl5/files/minix.sh
Normal file
@ -0,0 +1,257 @@
|
|||||||
|
# hints/netbsd.sh
|
||||||
|
#
|
||||||
|
# Please check with packages@netbsd.org before making modifications
|
||||||
|
# to this file.
|
||||||
|
|
||||||
|
case "$archname" in
|
||||||
|
'')
|
||||||
|
archname=`uname -m`-${osname}
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
# NetBSD keeps dynamic loading dl*() functions in /usr/lib/crt0.o,
|
||||||
|
# so Configure doesn't find them (unless you abandon the nm scan).
|
||||||
|
# Also, NetBSD 0.9a was the first release to introduce shared
|
||||||
|
# libraries.
|
||||||
|
#
|
||||||
|
case "$osvers" in
|
||||||
|
0.9|0.8*)
|
||||||
|
usedl="$undef"
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
case `uname -m` in
|
||||||
|
pmax)
|
||||||
|
# NetBSD 1.3 and 1.3.1 on pmax shipped an `old' ld.so,
|
||||||
|
# which will not work.
|
||||||
|
case "$osvers" in
|
||||||
|
1.3|1.3.1)
|
||||||
|
d_dlopen=$undef
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
if test -f /usr/libexec/ld.elf_so; then
|
||||||
|
# ELF
|
||||||
|
d_dlopen=$define
|
||||||
|
d_dlerror=$define
|
||||||
|
cccdlflags="-DPIC -fPIC $cccdlflags"
|
||||||
|
lddlflags="-shared $lddlflags"
|
||||||
|
cat >UU/cc.cbu <<'EOCBU'
|
||||||
|
# gcc 4.6 doesn't support --whole-archive, but it's required for the
|
||||||
|
# system gcc to build correctly, so check for it
|
||||||
|
echo 'int f(void) { return 0; }' >try.c
|
||||||
|
if ${cc:-cc} $cccdlflags -c try.c -otry.o 2>&1 &&
|
||||||
|
${cc:-cc} --whole-archive $lddlflags try.o -otry.so 2>&1 ; then
|
||||||
|
lddlflags="--whole-archive $lddlflags"
|
||||||
|
fi
|
||||||
|
rm try.c try.o try.so 2>/dev/null
|
||||||
|
EOCBU
|
||||||
|
rpathflag="-Wl,-rpath,"
|
||||||
|
case "$osvers" in
|
||||||
|
1.[0-5]*)
|
||||||
|
#
|
||||||
|
# Include the whole libgcc.a into the perl executable
|
||||||
|
# so that certain symbols needed by loadable modules
|
||||||
|
# built as C++ objects (__eh_alloc, __pure_virtual,
|
||||||
|
# etc.) will always be defined.
|
||||||
|
#
|
||||||
|
ccdlflags="-Wl,-whole-archive -lgcc \
|
||||||
|
-Wl,-no-whole-archive -Wl,-E $ccdlflags"
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
ccdlflags="-Wl,-E $ccdlflags"
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
elif test -f /usr/libexec/ld.so; then
|
||||||
|
# a.out
|
||||||
|
d_dlopen=$define
|
||||||
|
d_dlerror=$define
|
||||||
|
cccdlflags="-DPIC -fPIC $cccdlflags"
|
||||||
|
lddlflags="-Bshareable $lddlflags"
|
||||||
|
rpathflag="-R"
|
||||||
|
else
|
||||||
|
d_dlopen=$undef
|
||||||
|
rpathflag=
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
# netbsd had these but they don't really work as advertised, in the
|
||||||
|
# versions listed below. if they are defined, then there isn't a
|
||||||
|
# way to make perl call setuid() or setgid(). if they aren't, then
|
||||||
|
# ($<, $>) = ($u, $u); will work (same for $(/$)). this is because
|
||||||
|
# you can not change the real userid of a process under 4.4BSD.
|
||||||
|
# netbsd fixed this in 1.3.2.
|
||||||
|
case "$osvers" in
|
||||||
|
0.9*|1.[012]*|1.3|1.3.1)
|
||||||
|
d_setregid="$undef"
|
||||||
|
d_setreuid="$undef"
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
case "$osvers" in
|
||||||
|
0.9*|1.*|2.*|3.*|4.*|5.*|6.*)
|
||||||
|
d_getprotoent_r="$undef"
|
||||||
|
d_getprotobyname_r="$undef"
|
||||||
|
d_getprotobynumber_r="$undef"
|
||||||
|
d_setprotoent_r="$undef"
|
||||||
|
d_endprotoent_r="$undef"
|
||||||
|
d_getservent_r="$undef"
|
||||||
|
d_getservbyname_r="$undef"
|
||||||
|
d_getservbyport_r="$undef"
|
||||||
|
d_setservent_r="$undef"
|
||||||
|
d_endservent_r="$undef"
|
||||||
|
d_getprotoent_r_proto="0"
|
||||||
|
d_getprotobyname_r_proto="0"
|
||||||
|
d_getprotobynumber_r_proto="0"
|
||||||
|
d_setprotoent_r_proto="0"
|
||||||
|
d_endprotoent_r_proto="0"
|
||||||
|
d_getservent_r_proto="0"
|
||||||
|
d_getservbyname_r_proto="0"
|
||||||
|
d_getservbyport_r_proto="0"
|
||||||
|
d_setservent_r_proto="0"
|
||||||
|
d_endservent_r_proto="0"
|
||||||
|
# MINIX Specific
|
||||||
|
d_gethostbyname_r="$undef"
|
||||||
|
d_gethostbyaddr_r="$undef"
|
||||||
|
d_gethostent_r="$undef"
|
||||||
|
d_sethostent_r="$undef"
|
||||||
|
d_endhostent_r="$undef"
|
||||||
|
d_inetntop="undef"
|
||||||
|
d_inetpton="undef"
|
||||||
|
d_ipv6_mreq="undef"
|
||||||
|
d_ipv6_mreq_source="undef"
|
||||||
|
d_sockaddr_in6="undef"
|
||||||
|
d_sin6_scope_id="undef"
|
||||||
|
d_usethreads="undef"
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
# These are obsolete in any netbsd.
|
||||||
|
d_setrgid="$undef"
|
||||||
|
d_setruid="$undef"
|
||||||
|
|
||||||
|
# there's no problem with vfork.
|
||||||
|
usevfork=true
|
||||||
|
|
||||||
|
# This is there but in machine/ieeefp_h.
|
||||||
|
ieeefp_h="define"
|
||||||
|
|
||||||
|
# This script UU/usethreads.cbu will get 'called-back' by Configure
|
||||||
|
# after it has prompted the user for whether to use threads.
|
||||||
|
cat > UU/usethreads.cbu <<'EOCBU'
|
||||||
|
case "$usethreads" in
|
||||||
|
$define|true|[yY]*)
|
||||||
|
lpthread=
|
||||||
|
for xxx in pthread; do
|
||||||
|
for yyy in $loclibpth $plibpth $glibpth dummy; do
|
||||||
|
zzz=$yyy/lib$xxx.a
|
||||||
|
if test -f "$zzz"; then
|
||||||
|
lpthread=$xxx
|
||||||
|
break;
|
||||||
|
fi
|
||||||
|
zzz=$yyy/lib$xxx.so
|
||||||
|
if test -f "$zzz"; then
|
||||||
|
lpthread=$xxx
|
||||||
|
break;
|
||||||
|
fi
|
||||||
|
zzz=`ls $yyy/lib$xxx.so.* 2>/dev/null`
|
||||||
|
if test "X$zzz" != X; then
|
||||||
|
lpthread=$xxx
|
||||||
|
break;
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
if test "X$lpthread" != X; then
|
||||||
|
break;
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
if test "X$lpthread" != X; then
|
||||||
|
# Add -lpthread.
|
||||||
|
libswanted="$libswanted $lpthread"
|
||||||
|
# There is no libc_r as of NetBSD 1.5.2, so no c -> c_r.
|
||||||
|
# This will be revisited when NetBSD gains a native pthreads
|
||||||
|
# implementation.
|
||||||
|
else
|
||||||
|
echo "$0: No POSIX threads library (-lpthread) found. " \
|
||||||
|
"You may want to install GNU pth. Aborting." >&4
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
unset lpthread
|
||||||
|
|
||||||
|
# several reentrant functions are embedded in libc, but haven't
|
||||||
|
# been added to the header files yet. Let's hold off on using
|
||||||
|
# them until they are a valid part of the API
|
||||||
|
case "$osvers" in
|
||||||
|
[012].*|3.[0-1])
|
||||||
|
d_getprotobyname_r=$undef
|
||||||
|
d_getprotobynumber_r=$undef
|
||||||
|
d_getprotoent_r=$undef
|
||||||
|
d_getservbyname_r=$undef
|
||||||
|
d_getservbyport_r=$undef
|
||||||
|
d_getservent_r=$undef
|
||||||
|
d_setprotoent_r=$undef
|
||||||
|
d_setservent_r=$undef
|
||||||
|
d_endprotoent_r=$undef
|
||||||
|
d_endservent_r=$undef ;;
|
||||||
|
esac
|
||||||
|
;;
|
||||||
|
|
||||||
|
esac
|
||||||
|
EOCBU
|
||||||
|
|
||||||
|
# Set sensible defaults for NetBSD: look for local software in
|
||||||
|
# /usr/local, plus the build prefix, which might or might not be
|
||||||
|
# /usr/pkg.
|
||||||
|
#
|
||||||
|
loclibpth="/usr/local/lib ${prefix}/lib"
|
||||||
|
locincpth="/usr/local/include ${prefix}/include"
|
||||||
|
|
||||||
|
case "$rpathflag" in
|
||||||
|
'')
|
||||||
|
ldflags=
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
ldflags=
|
||||||
|
for yyy in $loclibpth; do
|
||||||
|
ldflags="$ldflags $rpathflag$yyy"
|
||||||
|
done
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
case `uname -m` in
|
||||||
|
alpha)
|
||||||
|
echo 'int main() {}' > try.c
|
||||||
|
gcc=`${cc:-cc} -v -c try.c 2>&1|grep 'gcc version egcs-2'`
|
||||||
|
case "$gcc" in
|
||||||
|
'' | "gcc version egcs-2.95."[3-9]*) ;; # 2.95.3 or better okay
|
||||||
|
*) cat >&4 <<EOF
|
||||||
|
***
|
||||||
|
*** Your gcc ($gcc) is known to be
|
||||||
|
*** too buggy on netbsd/alpha to compile Perl with optimization.
|
||||||
|
*** It is suggested you install the lang/gcc package which should
|
||||||
|
*** have at least gcc 2.95.3 which should work okay: use for example
|
||||||
|
*** Configure -Dcc=/usr/pkg/gcc-2.95.3/bin/cc. You could also
|
||||||
|
*** Configure -Doptimize=-O0 to compile Perl without any optimization
|
||||||
|
*** but that is not recommended.
|
||||||
|
***
|
||||||
|
EOF
|
||||||
|
exit 1
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
rm -f try.*
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
# NetBSD/sparc 1.5.3/1.6.1 dumps core in the semid_ds test of Configure.
|
||||||
|
case `uname -m` in
|
||||||
|
sparc) d_semctl_semid_ds=undef ;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
# malloc wrap works
|
||||||
|
case "$usemallocwrap" in
|
||||||
|
'') usemallocwrap='define' ;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
# don't use perl malloc by default
|
||||||
|
case "$usemymalloc" in
|
||||||
|
'') usemymalloc=n ;;
|
||||||
|
esac
|
@ -88,4 +88,10 @@ CFLAGS+= -fno-reorder-blocks
|
|||||||
. endif
|
. endif
|
||||||
.endif
|
.endif
|
||||||
|
|
||||||
|
### Minix, no pthreads available
|
||||||
|
### Perl cannot be compiled with threading support ATM.
|
||||||
|
.if ${OPSYS} == "NetBSD" && ${OS_VARIANT:U} == "Minix"
|
||||||
|
PKG_HACKS+= broken-minix-pthreads
|
||||||
|
PERL5_BUILD_THREADS_SUPPORT= no
|
||||||
|
.endif
|
||||||
.endif # PERL5_HACKS_MK
|
.endif # PERL5_HACKS_MK
|
||||||
|
21
lang/perl5/patches/patch-zz-minix
Normal file
21
lang/perl5/patches/patch-zz-minix
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
--- Configure.orig Fri Apr 24 10:51:48 2015
|
||||||
|
+++ Configure Fri Apr 24 10:54:52 2015
|
||||||
|
@@ -3401,6 +3401,9 @@
|
||||||
|
;;
|
||||||
|
MiNT) osname=mint
|
||||||
|
;;
|
||||||
|
+ minix*) osname=minix
|
||||||
|
+ osvers=`$uname -r | UU/tr '[A-Z]' '[a-z]'`
|
||||||
|
+ ;;
|
||||||
|
netbsd*) osname=netbsd
|
||||||
|
osvers=`$uname -r | UU/tr '[A-Z]' '[a-z]'`
|
||||||
|
;;
|
||||||
|
@@ -8557,7 +8560,7 @@
|
||||||
|
solaris)
|
||||||
|
xxx="-R $shrpdir"
|
||||||
|
;;
|
||||||
|
- freebsd|mirbsd|netbsd|openbsd|interix|dragonfly|bitrig)
|
||||||
|
+ freebsd|mirbsd|minix|netbsd|openbsd|interix|dragonfly|bitrig)
|
||||||
|
xxx="-Wl,-R$shrpdir"
|
||||||
|
;;
|
||||||
|
bsdos|linux|irix*|dec_osf|gnu*|haiku)
|
Loading…
x
Reference in New Issue
Block a user