The package rpms/erlang-corba.git has added or updated architecture specific content in
its
spec file (ExclusiveArch/ExcludeArch or %ifarch/%ifnarch) in commit(s):
https://src.fedoraproject.org/cgit/rpms/erlang-corba.git/commit/?id=e6a0d....
Change:
+%ifarch %{arm} %{mips} riscv64
Thanks.
Full change:
============
commit e6a0d5318c2d9101ae768d34eb48ccb812330ee5
Author: Peter Lemenkov <lemenkov(a)gmail.com>
Date: Fri Feb 1 23:26:49 2019 +0300
Initial commit (see rhbz #1670999)
Signed-off-by: Peter Lemenkov <lemenkov(a)gmail.com>
diff --git a/.gitignore b/.gitignore
new file mode 100644
index 0000000..dc66b01
--- /dev/null
+++ b/.gitignore
@@ -0,0 +1 @@
+/corba-4.5.2.tar.gz
diff --git a/erlang-corba-0001-Add-files-from-OTP-tree.patch
b/erlang-corba-0001-Add-files-from-OTP-tree.patch
new file mode 100644
index 0000000..a3583c6
--- /dev/null
+++ b/erlang-corba-0001-Add-files-from-OTP-tree.patch
@@ -0,0 +1,2384 @@
+From: Peter Lemenkov <lemenkov(a)gmail.com>
+Date: Tue, 29 Jan 2019 17:54:52 +0300
+Subject: [PATCH] Add files from OTP tree
+
+Signed-off-by: Peter Lemenkov <lemenkov(a)gmail.com>
+
+diff --git a/Makefile b/Makefile
+index 2a0f6b6..6dce23d 100644
+--- a/Makefile
++++ b/Makefile
+@@ -23,14 +23,15 @@ ifeq ($(ERL_TOP),)
+ $(error ERL_TOP needs to be set)
+ endif
+
+-OTP_CONF := $(shell $(MAKE) -f $(ERL_TOP)/Makefile erlang_inst_libdir_configured
1>/dev/null 2>/dev/null; echo $$?)
+-ifneq ($(OTP_CONF),0)
+-$(error Either there is no OTP source tree in $(ERL_TOP), the OTP version is too old, or
the OTP source tree has not been configured)
+-endif
++#OTP_CONF := $(shell $(MAKE) -f $(ERL_TOP)/Makefile erlang_inst_libdir_configured
1>/dev/null 2>/dev/null; echo $$?)
++#ifneq ($(OTP_CONF),0)
++#$(error Either there is no OTP source tree in $(ERL_TOP), the OTP version is too old,
or the OTP source tree has not been configured)
++#endif
+
+-INST_DIR := $(shell $(MAKE) -f $(ERL_TOP)/Makefile erlang_inst_libdir_configured)
++#INST_DIR := $(shell $(MAKE) -f $(ERL_TOP)/Makefile erlang_inst_libdir_configured)
+
+-TARGET := $(shell $(MAKE) -f $(ERL_TOP)/Makefile target_configured)
++#TARGET := $(shell $(MAKE) -f $(ERL_TOP)/Makefile target_configured)
++TARGET=target
+ include $(ERL_TOP)/make/target.mk
+ export TARGET
+ include $(ERL_TOP)/make/$(TARGET)/otp.mk
+@@ -113,7 +114,7 @@ opt debug release docs release_docs clean depend xmllint:
+ fi ; \
+ done ;
+
+-install install-docs: TESTROOT=$(DESTDIR)$(shell $(MAKE) -f $(ERL_TOP)/Makefile
erlang_inst_libdir_configured)
++install install-docs: TESTROOT=$(DESTDIR)
+
+ install: release
+
+diff --git a/erts/autoconf/config.guess b/erts/autoconf/config.guess
+new file mode 100755
+index 0000000..f7eb141
+--- /dev/null
++++ b/erts/autoconf/config.guess
+@@ -0,0 +1,1438 @@
++#! /bin/sh
++# Attempt to guess a canonical system name.
++# Copyright 1992-2015 Free Software Foundation, Inc.
++
++timestamp='2015-03-04'
++
++# This file is free software; you can redistribute it and/or modify it
++# under the terms of the GNU General Public License as published by
++# the Free Software Foundation; either version 3 of the License, or
++# (at your option) any later version.
++#
++# This program is distributed in the hope that it will be useful, but
++# WITHOUT ANY WARRANTY; without even the implied warranty of
++# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
++# General Public License for more details.
++#
++# You should have received a copy of the GNU General Public License
++# along with this program; if not, see <
http://www.gnu.org/licenses/>.
++#
++# As a special exception to the GNU General Public License, if you
++# distribute this file as part of a program that contains a
++# configuration script generated by Autoconf, you may include it under
++# the same distribution terms that you use for the rest of that
++# program. This Exception is an additional permission under section 7
++# of the GNU General Public License, version 3 ("GPLv3").
++#
++# Originally written by Per Bothner; maintained since 2000 by Ben Elliston.
++#
++# You can get the latest version of this script from:
++#
http://git.savannah.gnu.org/gitweb/?p=config.git;a=blob_plain;f=config.gu...
++#
++# Please send patches to <config-patches(a)gnu.org>.
++
++
++me=`echo "$0" | sed -e 's,.*/,,'`
++
++usage="\
++Usage: $0 [OPTION]
++
++Output the configuration name of the system \`$me' is run on.
++
++Operation modes:
++ -h, --help print this help, then exit
++ -t, --time-stamp print date of last modification, then exit
++ -v, --version print version number, then exit
++
++Report bugs and patches to <config-patches(a)gnu.org>."
++
++version="\
++GNU config.guess ($timestamp)
++
++Originally written by Per Bothner.
++Copyright 1992-2015 Free Software Foundation, Inc.
++
++This is free software; see the source for copying conditions. There is NO
++warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE."
++
++help="
++Try \`$me --help' for more information."
++
++# Parse command line
++while test $# -gt 0 ; do
++ case $1 in
++ --time-stamp | --time* | -t )
++ echo "$timestamp" ; exit ;;
++ --version | -v )
++ echo "$version" ; exit ;;
++ --help | --h* | -h )
++ echo "$usage"; exit ;;
++ -- ) # Stop option processing
++ shift; break ;;
++ - ) # Use stdin as input.
++ break ;;
++ -* )
++ echo "$me: invalid option $1$help" >&2
++ exit 1 ;;
++ * )
++ break ;;
++ esac
++done
++
++if test $# != 0; then
++ echo "$me: too many arguments$help" >&2
++ exit 1
++fi
++
++trap 'exit 1' 1 2 15
++
++# CC_FOR_BUILD -- compiler used by this script. Note that the use of a
++# compiler to aid in system detection is discouraged as it requires
++# temporary files to be created and, as you can see below, it is a
++# headache to deal with in a portable fashion.
++
++# Historically, `CC_FOR_BUILD' used to be named `HOST_CC'. We still
++# use `HOST_CC' if defined, but it is deprecated.
++
++# Portable tmp directory creation inspired by the Autoconf team.
++
++set_cc_for_build='
++trap "exitcode=\$?; (rm -f \$tmpfiles 2>/dev/null; rmdir \$tmp 2>/dev/null)
&& exit \$exitcode" 0 ;
++trap "rm -f \$tmpfiles 2>/dev/null; rmdir \$tmp 2>/dev/null; exit 1" 1 2
13 15 ;
++: ${TMPDIR=/tmp} ;
++ { tmp=`(umask 077 && mktemp -d "$TMPDIR/cgXXXXXX") 2>/dev/null`
&& test -n "$tmp" && test -d "$tmp" ; } ||
++ { test -n "$RANDOM" && tmp=$TMPDIR/cg$$-$RANDOM && (umask 077
&& mkdir $tmp) ; } ||
++ { tmp=$TMPDIR/cg-$$ && (umask 077 && mkdir $tmp) && echo
"Warning: creating insecure temp directory" >&2 ; } ||
++ { echo "$me: cannot create a temporary directory in $TMPDIR" >&2 ;
exit 1 ; } ;
++dummy=$tmp/dummy ;
++tmpfiles="$dummy.c $dummy.o $dummy.rel $dummy" ;
++case $CC_FOR_BUILD,$HOST_CC,$CC in
++ ,,) echo "int x;" > $dummy.c ;
++ for c in cc gcc c89 c99 ; do
++ if ($c -c -o $dummy.o $dummy.c) >/dev/null 2>&1 ; then
++ CC_FOR_BUILD="$c"; break ;
++ fi ;
++ done ;
++ if test x"$CC_FOR_BUILD" = x ; then
++ CC_FOR_BUILD=no_compiler_found ;
++ fi
++ ;;
++ ,,*) CC_FOR_BUILD=$CC ;;
++ ,*,*) CC_FOR_BUILD=$HOST_CC ;;
++esac ; set_cc_for_build= ;'
++
++# This is needed to find uname on a Pyramid OSx when run in the BSD universe.
++# (ghazi(a)noc.rutgers.edu 1994-08-24)
++if (test -f /.attbin/uname) >/dev/null 2>&1 ; then
++ PATH=$PATH:/.attbin ; export PATH
++fi
++
++UNAME_MACHINE=`(uname -m) 2>/dev/null` || UNAME_MACHINE=unknown
++UNAME_RELEASE=`(uname -r) 2>/dev/null` || UNAME_RELEASE=unknown
++UNAME_SYSTEM=`(uname -s) 2>/dev/null` || UNAME_SYSTEM=unknown
++UNAME_VERSION=`(uname -v) 2>/dev/null` || UNAME_VERSION=unknown
++
++case "${UNAME_SYSTEM}" in
++Linux|GNU|GNU/*)
++ # If the system lacks a compiler, then just pick glibc.
++ # We could probably try harder.
++ LIBC=gnu
++
++ eval $set_cc_for_build
++ cat <<-EOF > $dummy.c
++ #include <features.h>
++ #if defined(__UCLIBC__)
++ LIBC=uclibc
++ #elif defined(__dietlibc__)
++ LIBC=dietlibc
++ #else
++ LIBC=gnu
++ #endif
++ EOF
++ eval `$CC_FOR_BUILD -E $dummy.c 2>/dev/null | grep '^LIBC' | sed 's,
,,g'`
++ ;;
++esac
++
++# Note: order is significant - the case branches are not exclusive.
++
++case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in
++ *:NetBSD:*:*)
++ # NetBSD (nbsd) targets should (where applicable) match one or
++ # more of the tuples: *-*-netbsdelf*, *-*-netbsdaout*,
++ # *-*-netbsdecoff* and *-*-netbsd*. For targets that recently
++ # switched to ELF, *-*-netbsd* would select the old
++ # object file format. This provides both forward
++ # compatibility and a consistent mechanism for selecting the
++ # object file format.
++ #
++ # Note: NetBSD doesn't particularly care about the vendor
++ # portion of the name. We always set it to "unknown".
++ sysctl="sysctl -n hw.machine_arch"
++ UNAME_MACHINE_ARCH=`(uname -p 2>/dev/null || \
++ /sbin/$sysctl 2>/dev/null || \
++ /usr/sbin/$sysctl 2>/dev/null || \
++ echo unknown)`
++ case "${UNAME_MACHINE_ARCH}" in
++ armeb) machine=armeb-unknown ;;
++ arm*) machine=arm-unknown ;;
++ sh3el) machine=shl-unknown ;;
++ sh3eb) machine=sh-unknown ;;
++ sh5el) machine=sh5le-unknown ;;
++ earmv*)
++ arch=`echo ${UNAME_MACHINE_ARCH} | sed -e 's,^e\(armv[0-9]\).*$,\1,'`
++ endian=`echo ${UNAME_MACHINE_ARCH} | sed -ne 's,^.*\(eb\)$,\1,p'`
++ machine=${arch}${endian}-unknown
++ ;;
++ *) machine=${UNAME_MACHINE_ARCH}-unknown ;;
++ esac
++ # The Operating System including object format, if it has switched
++ # to ELF recently, or will in the future.
++ case "${UNAME_MACHINE_ARCH}" in
++ arm*|earm*|i386|m68k|ns32k|sh3*|sparc|vax)
++ eval $set_cc_for_build
++ if echo __ELF__ | $CC_FOR_BUILD -E - 2>/dev/null \
++ | grep -q __ELF__
++ then
++ # Once all utilities can be ECOFF (netbsdecoff) or a.out (netbsdaout).
++ # Return netbsd for either. FIX?
++ os=netbsd
++ else
++ os=netbsdelf
++ fi
++ ;;
++ *)
++ os=netbsd
++ ;;
++ esac
++ # Determine ABI tags.
++ case "${UNAME_MACHINE_ARCH}" in
++ earm*)
++ expr='s/^earmv[0-9]/-eabi/;s/eb$//'
++ abi=`echo ${UNAME_MACHINE_ARCH} | sed -e "$expr"`
++ ;;
++ esac
++ # The OS release
++ # Debian GNU/NetBSD machines have a different userland, and
++ # thus, need a distinct triplet. However, they do not need
++ # kernel version information, so it can be replaced with a
++ # suitable tag, in the style of linux-gnu.
++ case "${UNAME_VERSION}" in
++ Debian*)
++ release='-gnu'
++ ;;
++ *)
++ release=`echo ${UNAME_RELEASE}|sed -e 's/[-_].*/\./'`
++ ;;
++ esac
++ # Since CPU_TYPE-MANUFACTURER-KERNEL-OPERATING_SYSTEM:
++ # contains redundant information, the shorter form:
++ # CPU_TYPE-MANUFACTURER-OPERATING_SYSTEM is used.
++ echo "${machine}-${os}${release}${abi}"
++ exit ;;
++ *:Bitrig:*:*)
++ UNAME_MACHINE_ARCH=`arch | sed 's/Bitrig.//'`
++ echo ${UNAME_MACHINE_ARCH}-unknown-bitrig${UNAME_RELEASE}
++ exit ;;
++ *:OpenBSD:*:*)
++ UNAME_MACHINE_ARCH=`arch | sed 's/OpenBSD.//'`
++ echo ${UNAME_MACHINE_ARCH}-unknown-openbsd${UNAME_RELEASE}
++ exit ;;
++ *:ekkoBSD:*:*)
++ echo ${UNAME_MACHINE}-unknown-ekkobsd${UNAME_RELEASE}
++ exit ;;
++ *:SolidBSD:*:*)
++ echo ${UNAME_MACHINE}-unknown-solidbsd${UNAME_RELEASE}
++ exit ;;
++ macppc:MirBSD:*:*)
++ echo powerpc-unknown-mirbsd${UNAME_RELEASE}
++ exit ;;
++ *:MirBSD:*:*)
++ echo ${UNAME_MACHINE}-unknown-mirbsd${UNAME_RELEASE}
++ exit ;;
++ alpha:OSF1:*:*)
++ case $UNAME_RELEASE in
++ *4.0)
++ UNAME_RELEASE=`/usr/sbin/sizer -v | awk '{print $3}'`
++ ;;
++ *5.*)
++ UNAME_RELEASE=`/usr/sbin/sizer -v | awk '{print $4}'`
++ ;;
++ esac
++ # According to Compaq, /usr/sbin/psrinfo has been available on
++ # OSF/1 and Tru64 systems produced since 1995. I hope that
++ # covers most systems running today. This code pipes the CPU
++ # types through head -n 1, so we only detect the type of CPU 0.
++ ALPHA_CPU_TYPE=`/usr/sbin/psrinfo -v | sed -n -e 's/^ The alpha \(.*\)
processor.*$/\1/p' | head -n 1`
++ case "$ALPHA_CPU_TYPE" in
++ "EV4 (21064)")
++ UNAME_MACHINE="alpha" ;;
++ "EV4.5 (21064)")
++ UNAME_MACHINE="alpha" ;;
++ "LCA4 (21066/21068)")
++ UNAME_MACHINE="alpha" ;;
++ "EV5 (21164)")
++ UNAME_MACHINE="alphaev5" ;;
++ "EV5.6 (21164A)")
++ UNAME_MACHINE="alphaev56" ;;
++ "EV5.6 (21164PC)")
++ UNAME_MACHINE="alphapca56" ;;
++ "EV5.7 (21164PC)")
++ UNAME_MACHINE="alphapca57" ;;
++ "EV6 (21264)")
++ UNAME_MACHINE="alphaev6" ;;
++ "EV6.7 (21264A)")
++ UNAME_MACHINE="alphaev67" ;;
++ "EV6.8CB (21264C)")
++ UNAME_MACHINE="alphaev68" ;;
++ "EV6.8AL (21264B)")
++ UNAME_MACHINE="alphaev68" ;;
++ "EV6.8CX (21264D)")
++ UNAME_MACHINE="alphaev68" ;;
++ "EV6.9A (21264/EV69A)")
++ UNAME_MACHINE="alphaev69" ;;
++ "EV7 (21364)")
++ UNAME_MACHINE="alphaev7" ;;
++ "EV7.9 (21364A)")
++ UNAME_MACHINE="alphaev79" ;;
++ esac
++ # A Pn.n version is a patched version.
++ # A Vn.n version is a released version.
++ # A Tn.n version is a released field test version.
++ # A Xn.n version is an unreleased experimental baselevel.
++ # 1.2 uses "1.2" for uname -r.
++ echo ${UNAME_MACHINE}-dec-osf`echo ${UNAME_RELEASE} | sed -e 's/^[PVTX]//' | tr
'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz'`
++ # Reset EXIT trap before exiting to avoid spurious non-zero exit code.
++ exitcode=$?
++ trap '' 0
++ exit $exitcode ;;
++ Alpha\ *:Windows_NT*:*)
++ # How do we know it's Interix rather than the generic POSIX subsystem?
++ # Should we change UNAME_MACHINE based on the output of uname instead
++ # of the specific Alpha model?
++ echo alpha-pc-interix
++ exit ;;
++ 21064:Windows_NT:50:3)
++ echo alpha-dec-winnt3.5
++ exit ;;
++ Amiga*:UNIX_System_V:4.0:*)
++ echo m68k-unknown-sysv4
++ exit ;;
++ *:[Aa]miga[Oo][Ss]:*:*)
++ echo ${UNAME_MACHINE}-unknown-amigaos
++ exit ;;
++ *:[Mm]orph[Oo][Ss]:*:*)
++ echo ${UNAME_MACHINE}-unknown-morphos
++ exit ;;
++ *:OS/390:*:*)
++ echo i370-ibm-openedition
++ exit ;;
++ *:z/VM:*:*)
++ echo s390-ibm-zvmoe
++ exit ;;
++ *:OS400:*:*)
++ echo powerpc-ibm-os400
++ exit ;;
++ arm:RISC*:1.[012]*:*|arm:riscix:1.[012]*:*)
++ echo arm-acorn-riscix${UNAME_RELEASE}
++ exit ;;
++ arm*:riscos:*:*|arm*:RISCOS:*:*)
++ echo arm-unknown-riscos
++ exit ;;
++ SR2?01:HI-UX/MPP:*:* | SR8000:HI-UX/MPP:*:*)
++ echo hppa1.1-hitachi-hiuxmpp
++ exit ;;
++ Pyramid*:OSx*:*:* | MIS*:OSx*:*:* | MIS*:SMP_DC-OSx*:*:*)
++ # akee(a)wpdis03.wpafb.af.mil (Earle F. Ake) contributed MIS and NILE.
++ if test "`(/bin/universe) 2>/dev/null`" = att ; then
++ echo pyramid-pyramid-sysv3
++ else
++ echo pyramid-pyramid-bsd
++ fi
++ exit ;;
++ NILE*:*:*:dcosx)
++ echo pyramid-pyramid-svr4
++ exit ;;
++ DRS?6000:unix:4.0:6*)
++ echo sparc-icl-nx6
++ exit ;;
++ DRS?6000:UNIX_SV:4.2*:7* | DRS?6000:isis:4.2*:7*)
++ case `/usr/bin/uname -p` in
++ sparc) echo sparc-icl-nx7; exit ;;
++ esac ;;
++ s390x:SunOS:*:*)
++ echo ${UNAME_MACHINE}-ibm-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'`
++ exit ;;
++ sun4H:SunOS:5.*:*)
++ echo sparc-hal-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'`
++ exit ;;
++ sun4*:SunOS:5.*:* | tadpole*:SunOS:5.*:*)
++ echo sparc-sun-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'`
++ exit ;;
++ i86pc:AuroraUX:5.*:* | i86xen:AuroraUX:5.*:*)
++ echo i386-pc-auroraux${UNAME_RELEASE}
++ exit ;;
++ i86pc:SunOS:5.*:* | i86xen:SunOS:5.*:*)
++ eval $set_cc_for_build
++ SUN_ARCH="i386"
++ # If there is a compiler, see if it is configured for 64-bit objects.
++ # Note that the Sun cc does not turn __LP64__ into 1 like gcc does.
++ # This test works for both compilers.
++ if [ "$CC_FOR_BUILD" != 'no_compiler_found' ]; then
++ if (echo '#ifdef __amd64'; echo IS_64BIT_ARCH; echo '#endif') | \
++ (CCOPTS= $CC_FOR_BUILD -E - 2>/dev/null) | \
++ grep IS_64BIT_ARCH >/dev/null
++ then
++ SUN_ARCH="x86_64"
++ fi
++ fi
++ echo ${SUN_ARCH}-pc-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'`
++ exit ;;
++ sun4*:SunOS:6*:*)
++ # According to config.sub, this is the proper way to canonicalize
++ # SunOS6. Hard to guess exactly what SunOS6 will be like, but
++ # it's likely to be more like Solaris than SunOS4.
++ echo sparc-sun-solaris3`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'`
++ exit ;;
++ sun4*:SunOS:*:*)
++ case "`/usr/bin/arch -k`" in
++ Series*|S4*)
++ UNAME_RELEASE=`uname -v`
++ ;;
++ esac
++ # Japanese Language versions have a version number like `4.1.3-JL'.
++ echo sparc-sun-sunos`echo ${UNAME_RELEASE}|sed -e 's/-/_/'`
++ exit ;;
++ sun3*:SunOS:*:*)
++ echo m68k-sun-sunos${UNAME_RELEASE}
++ exit ;;
++ sun*:*:4.2BSD:*)
++ UNAME_RELEASE=`(sed 1q /etc/motd | awk '{print substr($5,1,3)}')
2>/dev/null`
++ test "x${UNAME_RELEASE}" = "x" && UNAME_RELEASE=3
++ case "`/bin/arch`" in
++ sun3)
++ echo m68k-sun-sunos${UNAME_RELEASE}
++ ;;
++ sun4)
++ echo sparc-sun-sunos${UNAME_RELEASE}
++ ;;
++ esac
++ exit ;;
++ aushp:SunOS:*:*)
++ echo sparc-auspex-sunos${UNAME_RELEASE}
++ exit ;;
++ # The situation for MiNT is a little confusing. The machine name
++ # can be virtually everything (everything which is not
++ # "atarist" or "atariste" at least should have a processor
++ # > m68000). The system name ranges from "MiNT" over
"FreeMiNT"
++ # to the lowercase version "mint" (or "freemint"). Finally
++ # the system name "TOS" denotes a system which is actually not
++ # MiNT. But MiNT is downward compatible to TOS, so this should
++ # be no problem.
++ atarist[e]:*MiNT:*:* | atarist[e]:*mint:*:* | atarist[e]:*TOS:*:*)
++ echo m68k-atari-mint${UNAME_RELEASE}
++ exit ;;
++ atari*:*MiNT:*:* | atari*:*mint:*:* | atarist[e]:*TOS:*:*)
++ echo m68k-atari-mint${UNAME_RELEASE}
++ exit ;;
++ *falcon*:*MiNT:*:* | *falcon*:*mint:*:* | *falcon*:*TOS:*:*)
++ echo m68k-atari-mint${UNAME_RELEASE}
++ exit ;;
++ milan*:*MiNT:*:* | milan*:*mint:*:* | *milan*:*TOS:*:*)
++ echo m68k-milan-mint${UNAME_RELEASE}
++ exit ;;
++ hades*:*MiNT:*:* | hades*:*mint:*:* | *hades*:*TOS:*:*)
++ echo m68k-hades-mint${UNAME_RELEASE}
++ exit ;;
++ *:*MiNT:*:* | *:*mint:*:* | *:*TOS:*:*)
++ echo m68k-unknown-mint${UNAME_RELEASE}
++ exit ;;
++ m68k:machten:*:*)
++ echo m68k-apple-machten${UNAME_RELEASE}
++ exit ;;
++ powerpc:machten:*:*)
++ echo powerpc-apple-machten${UNAME_RELEASE}
++ exit ;;
++ RISC*:Mach:*:*)
++ echo mips-dec-mach_bsd4.3
++ exit ;;
++ RISC*:ULTRIX:*:*)
++ echo mips-dec-ultrix${UNAME_RELEASE}
++ exit ;;
++ VAX*:ULTRIX*:*:*)
++ echo vax-dec-ultrix${UNAME_RELEASE}
++ exit ;;
++ 2020:CLIX:*:* | 2430:CLIX:*:*)
++ echo clipper-intergraph-clix${UNAME_RELEASE}
++ exit ;;
++ mips:*:*:UMIPS | mips:*:*:RISCos)
++ eval $set_cc_for_build
++ sed 's/^ //' << EOF >$dummy.c
++#ifdef __cplusplus
++#include <stdio.h> /* for printf() prototype */
++ int main (int argc, char *argv[]) {
++#else
++ int main (argc, argv) int argc; char *argv[]; {
++#endif
++ #if defined (host_mips) && defined (MIPSEB)
++ #if defined (SYSTYPE_SYSV)
++ printf ("mips-mips-riscos%ssysv\n", argv[1]); exit (0);
++ #endif
++ #if defined (SYSTYPE_SVR4)
++ printf ("mips-mips-riscos%ssvr4\n", argv[1]); exit (0);
++ #endif
++ #if defined (SYSTYPE_BSD43) || defined(SYSTYPE_BSD)
++ printf ("mips-mips-riscos%sbsd\n", argv[1]); exit (0);
++ #endif
++ #endif
++ exit (-1);
++ }
++EOF
++ $CC_FOR_BUILD -o $dummy $dummy.c &&
++ dummyarg=`echo "${UNAME_RELEASE}" | sed -n 's/\([0-9]*\).*/\1/p'`
&&
++ SYSTEM_NAME=`$dummy $dummyarg` &&
++ { echo "$SYSTEM_NAME"; exit; }
++ echo mips-mips-riscos${UNAME_RELEASE}
++ exit ;;
++ Motorola:PowerMAX_OS:*:*)
++ echo powerpc-motorola-powermax
++ exit ;;
++ Motorola:*:4.3:PL8-*)
++ echo powerpc-harris-powermax
++ exit ;;
++ Night_Hawk:*:*:PowerMAX_OS | Synergy:PowerMAX_OS:*:*)
++ echo powerpc-harris-powermax
++ exit ;;
++ Night_Hawk:Power_UNIX:*:*)
++ echo powerpc-harris-powerunix
++ exit ;;
++ m88k:CX/UX:7*:*)
++ echo m88k-harris-cxux7
++ exit ;;
++ m88k:*:4*:R4*)
++ echo m88k-motorola-sysv4
++ exit ;;
++ m88k:*:3*:R3*)
++ echo m88k-motorola-sysv3
++ exit ;;
++ AViiON:dgux:*:*)
++ # DG/UX returns AViiON for all architectures
++ UNAME_PROCESSOR=`/usr/bin/uname -p`
++ if [ $UNAME_PROCESSOR = mc88100 ] || [ $UNAME_PROCESSOR = mc88110 ]
++ then
++ if [ ${TARGET_BINARY_INTERFACE}x = m88kdguxelfx ] || \
++ [ ${TARGET_BINARY_INTERFACE}x = x ]
++ then
++ echo m88k-dg-dgux${UNAME_RELEASE}
++ else
++ echo m88k-dg-dguxbcs${UNAME_RELEASE}
++ fi
++ else
++ echo i586-dg-dgux${UNAME_RELEASE}
++ fi
++ exit ;;
++ M88*:DolphinOS:*:*) # DolphinOS (SVR3)
++ echo m88k-dolphin-sysv3
++ exit ;;
++ M88*:*:R3*:*)
++ # Delta 88k system running SVR3
++ echo m88k-motorola-sysv3
++ exit ;;
++ XD88*:*:*:*) # Tektronix XD88 system running UTekV (SVR3)
++ echo m88k-tektronix-sysv3
++ exit ;;
++ Tek43[0-9][0-9]:UTek:*:*) # Tektronix 4300 system running UTek (BSD)
++ echo m68k-tektronix-bsd
++ exit ;;
++ *:IRIX*:*:*)
++ echo mips-sgi-irix`echo ${UNAME_RELEASE}|sed -e 's/-/_/g'`
++ exit ;;
++ ????????:AIX?:[12].1:2) # AIX 2.2.1 or AIX 2.1.1 is RT/PC AIX.
++ echo romp-ibm-aix # uname -m gives an 8 hex-code CPU id
++ exit ;; # Note that: echo "'`uname -s`'" gives 'AIX
'
++ i*86:AIX:*:*)
++ echo i386-ibm-aix
++ exit ;;
++ ia64:AIX:*:*)
++ if [ -x /usr/bin/oslevel ] ; then
++ IBM_REV=`/usr/bin/oslevel`
++ else
++ IBM_REV=${UNAME_VERSION}.${UNAME_RELEASE}
++ fi
++ echo ${UNAME_MACHINE}-ibm-aix${IBM_REV}
++ exit ;;
++ *:AIX:2:3)
++ if grep bos325 /usr/include/stdio.h >/dev/null 2>&1; then
++ eval $set_cc_for_build
++ sed 's/^ //' << EOF >$dummy.c
++ #include <sys/systemcfg.h>
++
++ main()
++ {
++ if (!__power_pc())
++ exit(1);
++ puts("powerpc-ibm-aix3.2.5");
++ exit(0);
++ }
++EOF
++ if $CC_FOR_BUILD -o $dummy $dummy.c && SYSTEM_NAME=`$dummy`
++ then
++ echo "$SYSTEM_NAME"
++ else
++ echo rs6000-ibm-aix3.2.5
++ fi
++ elif grep bos324 /usr/include/stdio.h >/dev/null 2>&1; then
++ echo rs6000-ibm-aix3.2.4
++ else
++ echo rs6000-ibm-aix3.2
++ fi
++ exit ;;
++ *:AIX:*:[4567])
++ IBM_CPU_ID=`/usr/sbin/lsdev -C -c processor -S available | sed 1q | awk '{ print $1
}'`
++ if /usr/sbin/lsattr -El ${IBM_CPU_ID} | grep ' POWER' >/dev/null
2>&1; then
++ IBM_ARCH=rs6000
++ else
++ IBM_ARCH=powerpc
++ fi
++ if [ -x /usr/bin/lslpp ] ; then
++ IBM_REV=`/usr/bin/lslpp -Lqc bos.rte.libc |
++ awk -F: '{ print $3 }' | sed s/[0-9]*$/0/`
++ else
++ IBM_REV=${UNAME_VERSION}.${UNAME_RELEASE}
++ fi
++ echo ${IBM_ARCH}-ibm-aix${IBM_REV}
++ exit ;;
++ *:AIX:*:*)
++ echo rs6000-ibm-aix
++ exit ;;
++ ibmrt:4.4BSD:*|romp-ibm:BSD:*)
++ echo romp-ibm-bsd4.4
++ exit ;;
++ ibmrt:*BSD:*|romp-ibm:BSD:*) # covers RT/PC BSD and
++ echo romp-ibm-bsd${UNAME_RELEASE} # 4.3 with uname added to
++ exit ;; # report: romp-ibm BSD 4.3
++ *:BOSX:*:*)
++ echo rs6000-bull-bosx
++ exit ;;
++ DPX/2?00:B.O.S.:*:*)
++ echo m68k-bull-sysv3
++ exit ;;
++ 9000/[34]??:4.3bsd:1.*:*)
++ echo m68k-hp-bsd
++ exit ;;
++ hp300:4.4BSD:*:* | 9000/[34]??:4.3bsd:2.*:*)
++ echo m68k-hp-bsd4.4
++ exit ;;
++ 9000/[34678]??:HP-UX:*:*)
++ HPUX_REV=`echo ${UNAME_RELEASE}|sed -e 's/[^.]*.[0B]*//'`
++ case "${UNAME_MACHINE}" in
++ 9000/31? ) HP_ARCH=m68000 ;;
++ 9000/[34]?? ) HP_ARCH=m68k ;;
++ 9000/[678][0-9][0-9])
++ if [ -x /usr/bin/getconf ]; then
++ sc_cpu_version=`/usr/bin/getconf SC_CPU_VERSION 2>/dev/null`
++ sc_kernel_bits=`/usr/bin/getconf SC_KERNEL_BITS 2>/dev/null`
++ case "${sc_cpu_version}" in
++ 523) HP_ARCH="hppa1.0" ;; # CPU_PA_RISC1_0
++ 528) HP_ARCH="hppa1.1" ;; # CPU_PA_RISC1_1
++ 532) # CPU_PA_RISC2_0
++ case "${sc_kernel_bits}" in
++ 32) HP_ARCH="hppa2.0n" ;;
++ 64) HP_ARCH="hppa2.0w" ;;
++ '') HP_ARCH="hppa2.0" ;; # HP-UX 10.20
++ esac ;;
++ esac
++ fi
++ if [ "${HP_ARCH}" = "" ]; then
++ eval $set_cc_for_build
++ sed 's/^ //' << EOF >$dummy.c
++
++ #define _HPUX_SOURCE
++ #include <stdlib.h>
++ #include <unistd.h>
++
++ int main ()
++ {
++ #if defined(_SC_KERNEL_BITS)
++ long bits = sysconf(_SC_KERNEL_BITS);
++ #endif
++ long cpu = sysconf (_SC_CPU_VERSION);
++
++ switch (cpu)
++ {
++ case CPU_PA_RISC1_0: puts ("hppa1.0"); break;
++ case CPU_PA_RISC1_1: puts ("hppa1.1"); break;
++ case CPU_PA_RISC2_0:
++ #if defined(_SC_KERNEL_BITS)
++ switch (bits)
++ {
++ case 64: puts ("hppa2.0w"); break;
++ case 32: puts ("hppa2.0n"); break;
++ default: puts ("hppa2.0"); break;
++ } break;
++ #else /* !defined(_SC_KERNEL_BITS) */
++ puts ("hppa2.0"); break;
++ #endif
++ default: puts ("hppa1.0"); break;
++ }
++ exit (0);
++ }
++EOF
++ (CCOPTS= $CC_FOR_BUILD -o $dummy $dummy.c 2>/dev/null) &&
HP_ARCH=`$dummy`
++ test -z "$HP_ARCH" && HP_ARCH=hppa
++ fi ;;
++ esac
++ if [ ${HP_ARCH} = "hppa2.0w" ]
++ then
++ eval $set_cc_for_build
++
++ # hppa2.0w-hp-hpux* has a 64-bit kernel and a compiler generating
++ # 32-bit code. hppa64-hp-hpux* has the same kernel and a compiler
++ # generating 64-bit code. GNU and HP use different nomenclature:
++ #
++ # $ CC_FOR_BUILD=cc ./config.guess
++ # => hppa2.0w-hp-hpux11.23
++ # $ CC_FOR_BUILD="cc +DA2.0w" ./config.guess
++ # => hppa64-hp-hpux11.23
++
++ if echo __LP64__ | (CCOPTS= $CC_FOR_BUILD -E - 2>/dev/null) |
++ grep -q __LP64__
++ then
++ HP_ARCH="hppa2.0w"
++ else
++ HP_ARCH="hppa64"
++ fi
++ fi
++ echo ${HP_ARCH}-hp-hpux${HPUX_REV}
++ exit ;;
++ ia64:HP-UX:*:*)
++ HPUX_REV=`echo ${UNAME_RELEASE}|sed -e 's/[^.]*.[0B]*//'`
++ echo ia64-hp-hpux${HPUX_REV}
++ exit ;;
++ 3050*:HI-UX:*:*)
++ eval $set_cc_for_build
++ sed 's/^ //' << EOF >$dummy.c
++ #include <unistd.h>
++ int
++ main ()
++ {
++ long cpu = sysconf (_SC_CPU_VERSION);
++ /* The order matters, because CPU_IS_HP_MC68K erroneously returns
++ true for CPU_PA_RISC1_0. CPU_IS_PA_RISC returns correct
++ results, however. */
++ if (CPU_IS_PA_RISC (cpu))
++ {
++ switch (cpu)
++ {
++ case CPU_PA_RISC1_0: puts ("hppa1.0-hitachi-hiuxwe2"); break;
++ case CPU_PA_RISC1_1: puts ("hppa1.1-hitachi-hiuxwe2"); break;
++ case CPU_PA_RISC2_0: puts ("hppa2.0-hitachi-hiuxwe2"); break;
++ default: puts ("hppa-hitachi-hiuxwe2"); break;
++ }
++ }
++ else if (CPU_IS_HP_MC68K (cpu))
++ puts ("m68k-hitachi-hiuxwe2");
++ else puts ("unknown-hitachi-hiuxwe2");
++ exit (0);
++ }
++EOF
++ $CC_FOR_BUILD -o $dummy $dummy.c && SYSTEM_NAME=`$dummy` &&
++ { echo "$SYSTEM_NAME"; exit; }
++ echo unknown-hitachi-hiuxwe2
++ exit ;;
++ 9000/7??:4.3bsd:*:* | 9000/8?[79]:4.3bsd:*:* )
++ echo hppa1.1-hp-bsd
++ exit ;;
++ 9000/8??:4.3bsd:*:*)
++ echo hppa1.0-hp-bsd
++ exit ;;
++ *9??*:MPE/iX:*:* | *3000*:MPE/iX:*:*)
++ echo hppa1.0-hp-mpeix
++ exit ;;
++ hp7??:OSF1:*:* | hp8?[79]:OSF1:*:* )
++ echo hppa1.1-hp-osf
++ exit ;;
++ hp8??:OSF1:*:*)
++ echo hppa1.0-hp-osf
++ exit ;;
++ i*86:OSF1:*:*)
++ if [ -x /usr/sbin/sysversion ] ; then
++ echo ${UNAME_MACHINE}-unknown-osf1mk
++ else
++ echo ${UNAME_MACHINE}-unknown-osf1
++ fi
++ exit ;;
++ parisc*:Lites*:*:*)
++ echo hppa1.1-hp-lites
++ exit ;;
++ C1*:ConvexOS:*:* | convex:ConvexOS:C1*:*)
++ echo c1-convex-bsd
++ exit ;;
++ C2*:ConvexOS:*:* | convex:ConvexOS:C2*:*)
++ if getsysinfo -f scalar_acc
++ then echo c32-convex-bsd
++ else echo c2-convex-bsd
++ fi
++ exit ;;
++ C34*:ConvexOS:*:* | convex:ConvexOS:C34*:*)
++ echo c34-convex-bsd
++ exit ;;
++ C38*:ConvexOS:*:* | convex:ConvexOS:C38*:*)
++ echo c38-convex-bsd
++ exit ;;
++ C4*:ConvexOS:*:* | convex:ConvexOS:C4*:*)
++ echo c4-convex-bsd
++ exit ;;
++ CRAY*Y-MP:*:*:*)
++ echo ymp-cray-unicos${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/'
++ exit ;;
++ CRAY*[A-Z]90:*:*:*)
++ echo ${UNAME_MACHINE}-cray-unicos${UNAME_RELEASE} \
++ | sed -e 's/CRAY.*\([A-Z]90\)/\1/' \
++ -e y/ABCDEFGHIJKLMNOPQRSTUVWXYZ/abcdefghijklmnopqrstuvwxyz/ \
++ -e 's/\.[^.]*$/.X/'
++ exit ;;
++ CRAY*TS:*:*:*)
++ echo t90-cray-unicos${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/'
++ exit ;;
++ CRAY*T3E:*:*:*)
++ echo alphaev5-cray-unicosmk${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/'
++ exit ;;
++ CRAY*SV1:*:*:*)
++ echo sv1-cray-unicos${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/'
++ exit ;;
++ *:UNICOS/mp:*:*)
++ echo craynv-cray-unicosmp${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/'
++ exit ;;
++ F30[01]:UNIX_System_V:*:* | F700:UNIX_System_V:*:*)
++ FUJITSU_PROC=`uname -m | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ'
'abcdefghijklmnopqrstuvwxyz'`
++ FUJITSU_SYS=`uname -p | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ'
'abcdefghijklmnopqrstuvwxyz' | sed -e 's/\///'`
++ FUJITSU_REL=`echo ${UNAME_RELEASE} | sed -e 's/ /_/'`
++ echo "${FUJITSU_PROC}-fujitsu-${FUJITSU_SYS}${FUJITSU_REL}"
++ exit ;;
++ 5000:UNIX_System_V:4.*:*)
++ FUJITSU_SYS=`uname -p | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ'
'abcdefghijklmnopqrstuvwxyz' | sed -e 's/\///'`
++ FUJITSU_REL=`echo ${UNAME_RELEASE} | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ'
'abcdefghijklmnopqrstuvwxyz' | sed -e 's/ /_/'`
++ echo "sparc-fujitsu-${FUJITSU_SYS}${FUJITSU_REL}"
++ exit ;;
++ i*86:BSD/386:*:* | i*86:BSD/OS:*:* | *:Ascend\ Embedded/OS:*:*)
++ echo ${UNAME_MACHINE}-pc-bsdi${UNAME_RELEASE}
++ exit ;;
++ sparc*:BSD/OS:*:*)
++ echo sparc-unknown-bsdi${UNAME_RELEASE}
++ exit ;;
++ *:BSD/OS:*:*)
++ echo ${UNAME_MACHINE}-unknown-bsdi${UNAME_RELEASE}
++ exit ;;
++ *:FreeBSD:*:*)
++ UNAME_PROCESSOR=`/usr/bin/uname -p`
++ case ${UNAME_PROCESSOR} in
++ amd64)
++ echo x86_64-unknown-freebsd`echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'` ;;
++ *)
++ echo ${UNAME_PROCESSOR}-unknown-freebsd`echo ${UNAME_RELEASE}|sed -e
's/[-(].*//'` ;;
++ esac
++ exit ;;
++ i*:CYGWIN*:*)
++ echo ${UNAME_MACHINE}-pc-cygwin
++ exit ;;
++ *:MINGW64*:*)
++ echo ${UNAME_MACHINE}-pc-mingw64
++ exit ;;
++ *:MINGW*:*)
++ echo ${UNAME_MACHINE}-pc-mingw32
++ exit ;;
++ *:MSYS*:*)
++ echo ${UNAME_MACHINE}-pc-msys
++ exit ;;
++ i*:windows32*:*)
++ # uname -m includes "-pc" on this system.
++ echo ${UNAME_MACHINE}-mingw32
++ exit ;;
++ i*:PW*:*)
++ echo ${UNAME_MACHINE}-pc-pw32
++ exit ;;
++ *:Interix*:*)
++ case ${UNAME_MACHINE} in
++ x86)
++ echo i586-pc-interix${UNAME_RELEASE}
++ exit ;;
++ authenticamd | genuineintel | EM64T)
++ echo x86_64-unknown-interix${UNAME_RELEASE}
++ exit ;;
++ IA64)
++ echo ia64-unknown-interix${UNAME_RELEASE}
++ exit ;;
++ esac ;;
++ [345]86:Windows_95:* | [345]86:Windows_98:* | [345]86:Windows_NT:*)
++ echo i${UNAME_MACHINE}-pc-mks
++ exit ;;
++ 8664:Windows_NT:*)
++ echo x86_64-pc-mks
++ exit ;;
++ i*:Windows_NT*:* | Pentium*:Windows_NT*:*)
++ # How do we know it's Interix rather than the generic POSIX subsystem?
++ # It also conflicts with pre-2.0 versions of AT&T UWIN. Should we
++ # UNAME_MACHINE based on the output of uname instead of i386?
++ echo i586-pc-interix
++ exit ;;
++ i*:UWIN*:*)
++ echo ${UNAME_MACHINE}-pc-uwin
++ exit ;;
++ amd64:CYGWIN*:*:* | x86_64:CYGWIN*:*:*)
++ echo x86_64-unknown-cygwin
++ exit ;;
++ p*:CYGWIN*:*)
++ echo powerpcle-unknown-cygwin
++ exit ;;
++ prep*:SunOS:5.*:*)
++ echo powerpcle-unknown-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'`
++ exit ;;
++ *:GNU:*:*)
++ # the GNU system
++ echo `echo ${UNAME_MACHINE}|sed -e 's,[-/].*$,,'`-unknown-${LIBC}`echo
${UNAME_RELEASE}|sed -e 's,/.*$,,'`
++ exit ;;
++ *:GNU/*:*:*)
++ # other systems with GNU libc and userland
++ echo ${UNAME_MACHINE}-unknown-`echo ${UNAME_SYSTEM} | sed 's,^[^/]*/,,' | tr
'[A-Z]' '[a-z]'``echo ${UNAME_RELEASE}|sed -e
's/[-(].*//'`-${LIBC}
++ exit ;;
++ i*86:Minix:*:*)
++ echo ${UNAME_MACHINE}-pc-minix
++ exit ;;
++ aarch64:Linux:*:*)
++ echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
++ exit ;;
++ aarch64_be:Linux:*:*)
++ UNAME_MACHINE=aarch64_be
++ echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
++ exit ;;
++ alpha:Linux:*:*)
++ case `sed -n '/^cpu model/s/^.*: \(.*\)/\1/p' < /proc/cpuinfo` in
++ EV5) UNAME_MACHINE=alphaev5 ;;
++ EV56) UNAME_MACHINE=alphaev56 ;;
++ PCA56) UNAME_MACHINE=alphapca56 ;;
++ PCA57) UNAME_MACHINE=alphapca56 ;;
++ EV6) UNAME_MACHINE=alphaev6 ;;
++ EV67) UNAME_MACHINE=alphaev67 ;;
++ EV68*) UNAME_MACHINE=alphaev68 ;;
++ esac
++ objdump --private-headers /bin/sh | grep -q ld.so.1
++ if test "$?" = 0 ; then LIBC="gnulibc1" ; fi
++ echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
++ exit ;;
++ arc:Linux:*:* | arceb:Linux:*:*)
++ echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
++ exit ;;
++ arm*:Linux:*:*)
++ eval $set_cc_for_build
++ if echo __ARM_EABI__ | $CC_FOR_BUILD -E - 2>/dev/null \
++ | grep -q __ARM_EABI__
++ then
++ echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
++ else
++ if echo __ARM_PCS_VFP | $CC_FOR_BUILD -E - 2>/dev/null \
++ | grep -q __ARM_PCS_VFP
++ then
++ echo ${UNAME_MACHINE}-unknown-linux-${LIBC}eabi
++ else
++ echo ${UNAME_MACHINE}-unknown-linux-${LIBC}eabihf
++ fi
++ fi
++ exit ;;
++ avr32*:Linux:*:*)
++ echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
++ exit ;;
++ cris:Linux:*:*)
++ echo ${UNAME_MACHINE}-axis-linux-${LIBC}
++ exit ;;
++ crisv32:Linux:*:*)
++ echo ${UNAME_MACHINE}-axis-linux-${LIBC}
++ exit ;;
++ e2k:Linux:*:*)
++ echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
++ exit ;;
++ frv:Linux:*:*)
++ echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
++ exit ;;
++ hexagon:Linux:*:*)
++ echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
++ exit ;;
++ i*86:Linux:*:*)
++ echo ${UNAME_MACHINE}-pc-linux-${LIBC}
++ exit ;;
++ ia64:Linux:*:*)
++ echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
++ exit ;;
++ m32r*:Linux:*:*)
++ echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
++ exit ;;
++ m68*:Linux:*:*)
++ echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
++ exit ;;
++ mips:Linux:*:* | mips64:Linux:*:*)
++ eval $set_cc_for_build
++ sed 's/^ //' << EOF >$dummy.c
++ #undef CPU
++ #undef ${UNAME_MACHINE}
++ #undef ${UNAME_MACHINE}el
++ #if defined(__MIPSEL__) || defined(__MIPSEL) || defined(_MIPSEL) || defined(MIPSEL)
++ CPU=${UNAME_MACHINE}el
++ #else
++ #if defined(__MIPSEB__) || defined(__MIPSEB) || defined(_MIPSEB) || defined(MIPSEB)
++ CPU=${UNAME_MACHINE}
++ #else
++ CPU=
++ #endif
++ #endif
++EOF
++ eval `$CC_FOR_BUILD -E $dummy.c 2>/dev/null | grep '^CPU'`
++ test x"${CPU}" != x && { echo
"${CPU}-unknown-linux-${LIBC}"; exit; }
++ ;;
++ openrisc*:Linux:*:*)
++ echo or1k-unknown-linux-${LIBC}
++ exit ;;
++ or32:Linux:*:* | or1k*:Linux:*:*)
++ echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
++ exit ;;
++ padre:Linux:*:*)
++ echo sparc-unknown-linux-${LIBC}
++ exit ;;
++ parisc64:Linux:*:* | hppa64:Linux:*:*)
++ echo hppa64-unknown-linux-${LIBC}
++ exit ;;
++ parisc:Linux:*:* | hppa:Linux:*:*)
++ # Look for CPU level
++ case `grep '^cpu[^a-z]*:' /proc/cpuinfo 2>/dev/null | cut -d' ' -f2`
in
++ PA7*) echo hppa1.1-unknown-linux-${LIBC} ;;
++ PA8*) echo hppa2.0-unknown-linux-${LIBC} ;;
++ *) echo hppa-unknown-linux-${LIBC} ;;
++ esac
++ exit ;;
++ ppc64:Linux:*:*)
++ echo powerpc64-unknown-linux-${LIBC}
++ exit ;;
++ ppc:Linux:*:*)
++ echo powerpc-unknown-linux-${LIBC}
++ exit ;;
++ ppc64le:Linux:*:*)
++ echo powerpc64le-unknown-linux-${LIBC}
++ exit ;;
++ ppcle:Linux:*:*)
++ echo powerpcle-unknown-linux-${LIBC}
++ exit ;;
++ s390:Linux:*:* | s390x:Linux:*:*)
++ echo ${UNAME_MACHINE}-ibm-linux-${LIBC}
++ exit ;;
++ sh64*:Linux:*:*)
++ echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
++ exit ;;
++ sh*:Linux:*:*)
++ echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
++ exit ;;
++ sparc:Linux:*:* | sparc64:Linux:*:*)
++ echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
++ exit ;;
++ tile*:Linux:*:*)
++ echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
++ exit ;;
++ vax:Linux:*:*)
++ echo ${UNAME_MACHINE}-dec-linux-${LIBC}
++ exit ;;
++ x86_64:Linux:*:*)
++ echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
++ exit ;;
++ xtensa*:Linux:*:*)
++ echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
++ exit ;;
++ i*86:DYNIX/ptx:4*:*)
++ # ptx 4.0 does uname -s correctly, with DYNIX/ptx in there.
++ # earlier versions are messed up and put the nodename in both
++ # sysname and nodename.
++ echo i386-sequent-sysv4
++ exit ;;
++ i*86:UNIX_SV:4.2MP:2.*)
++ # Unixware is an offshoot of SVR4, but it has its own version
++ # number series starting with 2...
++ # I am not positive that other SVR4 systems won't match this,
++ # I just have to hope. -- rms.
++ # Use sysv4.2uw... so that sysv4* matches it.
++ echo ${UNAME_MACHINE}-pc-sysv4.2uw${UNAME_VERSION}
++ exit ;;
++ i*86:OS/2:*:*)
++ # If we were able to find `uname', then EMX Unix compatibility
++ # is probably installed.
++ echo ${UNAME_MACHINE}-pc-os2-emx
++ exit ;;
++ i*86:XTS-300:*:STOP)
++ echo ${UNAME_MACHINE}-unknown-stop
++ exit ;;
++ i*86:atheos:*:*)
++ echo ${UNAME_MACHINE}-unknown-atheos
++ exit ;;
++ i*86:syllable:*:*)
++ echo ${UNAME_MACHINE}-pc-syllable
++ exit ;;
++ i*86:LynxOS:2.*:* | i*86:LynxOS:3.[01]*:* | i*86:LynxOS:4.[02]*:*)
++ echo i386-unknown-lynxos${UNAME_RELEASE}
++ exit ;;
++ i*86:*DOS:*:*)
++ echo ${UNAME_MACHINE}-pc-msdosdjgpp
++ exit ;;
++ i*86:*:4.*:* | i*86:SYSTEM_V:4.*:*)
++ UNAME_REL=`echo ${UNAME_RELEASE} | sed 's/\/MP$//'`
++ if grep Novell /usr/include/link.h >/dev/null 2>/dev/null; then
++ echo ${UNAME_MACHINE}-univel-sysv${UNAME_REL}
++ else
++ echo ${UNAME_MACHINE}-pc-sysv${UNAME_REL}
++ fi
++ exit ;;
++ i*86:*:5:[678]*)
++ # UnixWare 7.x, OpenUNIX and OpenServer 6.
++ case `/bin/uname -X | grep "^Machine"` in
++ *486*) UNAME_MACHINE=i486 ;;
++ *Pentium) UNAME_MACHINE=i586 ;;
++ *Pent*|*Celeron) UNAME_MACHINE=i686 ;;
++ esac
++ echo ${UNAME_MACHINE}-unknown-sysv${UNAME_RELEASE}${UNAME_SYSTEM}${UNAME_VERSION}
++ exit ;;
++ i*86:*:3.2:*)
++ if test -f /usr/options/cb.name; then
++ UNAME_REL=`sed -n 's/.*Version //p' </usr/options/cb.name`
++ echo ${UNAME_MACHINE}-pc-isc$UNAME_REL
++ elif /bin/uname -X 2>/dev/null >/dev/null ; then
++ UNAME_REL=`(/bin/uname -X|grep Release|sed -e 's/.*= //')`
++ (/bin/uname -X|grep i80486 >/dev/null) && UNAME_MACHINE=i486
++ (/bin/uname -X|grep '^Machine.*Pentium' >/dev/null) \
++ && UNAME_MACHINE=i586
++ (/bin/uname -X|grep '^Machine.*Pent *II' >/dev/null) \
++ && UNAME_MACHINE=i686
++ (/bin/uname -X|grep '^Machine.*Pentium Pro' >/dev/null) \
++ && UNAME_MACHINE=i686
++ echo ${UNAME_MACHINE}-pc-sco$UNAME_REL
++ else
++ echo ${UNAME_MACHINE}-pc-sysv32
++ fi
++ exit ;;
++ pc:*:*:*)
++ # Left here for compatibility:
++ # uname -m prints for DJGPP always 'pc', but it prints nothing about
++ # the processor, so we play safe by assuming i586.
++ # Note: whatever this is, it MUST be the same as what config.sub
++ # prints for the "djgpp" host, or else GDB configury will decide that
++ # this is a cross-build.
++ echo i586-pc-msdosdjgpp
++ exit ;;
++ Intel:Mach:3*:*)
++ echo i386-pc-mach3
++ exit ;;
++ paragon:*:*:*)
++ echo i860-intel-osf1
++ exit ;;
++ i860:*:4.*:*) # i860-SVR4
++ if grep Stardent /usr/include/sys/uadmin.h >/dev/null 2>&1 ; then
++ echo i860-stardent-sysv${UNAME_RELEASE} # Stardent Vistra i860-SVR4
++ else # Add other i860-SVR4 vendors below as they are discovered.
++ echo i860-unknown-sysv${UNAME_RELEASE} # Unknown i860-SVR4
++ fi
++ exit ;;
++ mini*:CTIX:SYS*5:*)
++ # "miniframe"
++ echo m68010-convergent-sysv
++ exit ;;
++ mc68k:UNIX:SYSTEM5:3.51m)
++ echo m68k-convergent-sysv
++ exit ;;
++ M680?0:D-NIX:5.3:*)
++ echo m68k-diab-dnix
++ exit ;;
++ M68*:*:R3V[5678]*:*)
++ test -r /sysV68 && { echo 'm68k-motorola-sysv'; exit; } ;;
++ 3[345]??:*:4.0:3.0 | 3[34]??A:*:4.0:3.0 | 3[34]??,*:*:4.0:3.0 | 3[34]??/*:*:4.0:3.0
| 4400:*:4.0:3.0 | 4850:*:4.0:3.0 | SKA40:*:4.0:3.0 | SDS2:*:4.0:3.0 | SHG2:*:4.0:3.0 |
S7501*:*:4.0:3.0)
++ OS_REL=''
++ test -r /etc/.relid \
++ && OS_REL=.`sed -n 's/[^ ]* [^ ]* \([0-9][0-9]\).*/\1/p' <
/etc/.relid`
++ /bin/uname -p 2>/dev/null | grep 86 >/dev/null \
++ && { echo i486-ncr-sysv4.3${OS_REL}; exit; }
++ /bin/uname -p 2>/dev/null | /bin/grep entium >/dev/null \
++ && { echo i586-ncr-sysv4.3${OS_REL}; exit; } ;;
++ 3[34]??:*:4.0:* | 3[34]??,*:*:4.0:*)
++ /bin/uname -p 2>/dev/null | grep 86 >/dev/null \
++ && { echo i486-ncr-sysv4; exit; } ;;
++ NCR*:*:4.2:* | MPRAS*:*:4.2:*)
++ OS_REL='.3'
++ test -r /etc/.relid \
++ && OS_REL=.`sed -n 's/[^ ]* [^ ]* \([0-9][0-9]\).*/\1/p' <
/etc/.relid`
++ /bin/uname -p 2>/dev/null | grep 86 >/dev/null \
++ && { echo i486-ncr-sysv4.3${OS_REL}; exit; }
++ /bin/uname -p 2>/dev/null | /bin/grep entium >/dev/null \
++ && { echo i586-ncr-sysv4.3${OS_REL}; exit; }
++ /bin/uname -p 2>/dev/null | /bin/grep pteron >/dev/null \
++ && { echo i586-ncr-sysv4.3${OS_REL}; exit; } ;;
++ m68*:LynxOS:2.*:* | m68*:LynxOS:3.0*:*)
++ echo m68k-unknown-lynxos${UNAME_RELEASE}
++ exit ;;
++ mc68030:UNIX_System_V:4.*:*)
++ echo m68k-atari-sysv4
++ exit ;;
++ TSUNAMI:LynxOS:2.*:*)
++ echo sparc-unknown-lynxos${UNAME_RELEASE}
++ exit ;;
++ rs6000:LynxOS:2.*:*)
++ echo rs6000-unknown-lynxos${UNAME_RELEASE}
++ exit ;;
++ PowerPC:LynxOS:2.*:* | PowerPC:LynxOS:3.[01]*:* | PowerPC:LynxOS:4.[02]*:*)
++ echo powerpc-unknown-lynxos${UNAME_RELEASE}
++ exit ;;
++ SM[BE]S:UNIX_SV:*:*)
++ echo mips-dde-sysv${UNAME_RELEASE}
++ exit ;;
++ RM*:ReliantUNIX-*:*:*)
++ echo mips-sni-sysv4
++ exit ;;
++ RM*:SINIX-*:*:*)
++ echo mips-sni-sysv4
++ exit ;;
++ *:SINIX-*:*:*)
++ if uname -p 2>/dev/null >/dev/null ; then
++ UNAME_MACHINE=`(uname -p) 2>/dev/null`
++ echo ${UNAME_MACHINE}-sni-sysv4
++ else
++ echo ns32k-sni-sysv
++ fi
++ exit ;;
++ PENTIUM:*:4.0*:*) # Unisys `ClearPath HMP IX 4000' SVR4/MP effort
++ # says <Richard.M.Bartel(a)ccMail.Census.GOV>
++ echo i586-unisys-sysv4
++ exit ;;
++ *:UNIX_System_V:4*:FTX*)
++ # From Gerald Hewes <hewes(a)openmarket.com>.
++ # How about differentiating between stratus architectures? -djm
++ echo hppa1.1-stratus-sysv4
++ exit ;;
++ *:*:*:FTX*)
++ # From seanf(a)swdc.stratus.com.
++ echo i860-stratus-sysv4
++ exit ;;
++ i*86:VOS:*:*)
++ # From Paul.Green(a)stratus.com.
++ echo ${UNAME_MACHINE}-stratus-vos
++ exit ;;
++ *:VOS:*:*)
++ # From Paul.Green(a)stratus.com.
++ echo hppa1.1-stratus-vos
++ exit ;;
++ mc68*:A/UX:*:*)
++ echo m68k-apple-aux${UNAME_RELEASE}
++ exit ;;
++ news*:NEWS-OS:6*:*)
++ echo mips-sony-newsos6
++ exit ;;
++ R[34]000:*System_V*:*:* | R4000:UNIX_SYSV:*:* | R*000:UNIX_SV:*:*)
++ if [ -d /usr/nec ]; then
++ echo mips-nec-sysv${UNAME_RELEASE}
++ else
++ echo mips-unknown-sysv${UNAME_RELEASE}
++ fi
++ exit ;;
++ BeBox:BeOS:*:*) # BeOS running on hardware made by Be, PPC only.
++ echo powerpc-be-beos
++ exit ;;
++ BeMac:BeOS:*:*) # BeOS running on Mac or Mac clone, PPC only.
++ echo powerpc-apple-beos
++ exit ;;
++ BePC:BeOS:*:*) # BeOS running on Intel PC compatible.
++ echo i586-pc-beos
++ exit ;;
++ BePC:Haiku:*:*) # Haiku running on Intel PC compatible.
++ echo i586-pc-haiku
++ exit ;;
++ x86_64:Haiku:*:*)
++ echo x86_64-unknown-haiku
++ exit ;;
++ SX-4:SUPER-UX:*:*)
++ echo sx4-nec-superux${UNAME_RELEASE}
++ exit ;;
++ SX-5:SUPER-UX:*:*)
++ echo sx5-nec-superux${UNAME_RELEASE}
++ exit ;;
++ SX-6:SUPER-UX:*:*)
++ echo sx6-nec-superux${UNAME_RELEASE}
++ exit ;;
++ SX-7:SUPER-UX:*:*)
++ echo sx7-nec-superux${UNAME_RELEASE}
++ exit ;;
++ SX-8:SUPER-UX:*:*)
++ echo sx8-nec-superux${UNAME_RELEASE}
++ exit ;;
++ SX-8R:SUPER-UX:*:*)
++ echo sx8r-nec-superux${UNAME_RELEASE}
++ exit ;;
++ Power*:Rhapsody:*:*)
++ echo powerpc-apple-rhapsody${UNAME_RELEASE}
++ exit ;;
++ *:Rhapsody:*:*)
++ echo ${UNAME_MACHINE}-apple-rhapsody${UNAME_RELEASE}
++ exit ;;
++ *:Darwin:*:*)
++ UNAME_PROCESSOR=`uname -p` || UNAME_PROCESSOR=unknown
++ eval $set_cc_for_build
++ if test "$UNAME_PROCESSOR" = unknown ; then
++ UNAME_PROCESSOR=powerpc
++ fi
++ if test `echo "$UNAME_RELEASE" | sed -e 's/\..*//'` -le 10 ; then
++ if [ "$CC_FOR_BUILD" != 'no_compiler_found' ]; then
++ if (echo '#ifdef __LP64__'; echo IS_64BIT_ARCH; echo '#endif') | \
++ (CCOPTS= $CC_FOR_BUILD -E - 2>/dev/null) | \
++ grep IS_64BIT_ARCH >/dev/null
++ then
++ case $UNAME_PROCESSOR in
++ i386) UNAME_PROCESSOR=x86_64 ;;
++ powerpc) UNAME_PROCESSOR=powerpc64 ;;
++ esac
++ fi
++ fi
++ elif test "$UNAME_PROCESSOR" = i386 ; then
++ # Avoid executing cc on OS X 10.9, as it ships with a stub
++ # that puts up a graphical alert prompting to install
++ # developer tools. Any system running Mac OS X 10.7 or
++ # later (Darwin 11 and later) is required to have a 64-bit
++ # processor. This is not true of the ARM version of Darwin
++ # that Apple uses in portable devices.
++ UNAME_PROCESSOR=x86_64
++ fi
++ echo ${UNAME_PROCESSOR}-apple-darwin${UNAME_RELEASE}
++ exit ;;
++ *:procnto*:*:* | *:QNX:[0123456789]*:*)
++ UNAME_PROCESSOR=`uname -p`
++ if test "$UNAME_PROCESSOR" = "x86"; then
++ UNAME_PROCESSOR=i386
++ UNAME_MACHINE=pc
++ fi
++ echo ${UNAME_PROCESSOR}-${UNAME_MACHINE}-nto-qnx${UNAME_RELEASE}
++ exit ;;
++ *:QNX:*:4*)
++ echo i386-pc-qnx
++ exit ;;
++ NEO-?:NONSTOP_KERNEL:*:*)
++ echo neo-tandem-nsk${UNAME_RELEASE}
++ exit ;;
++ NSE-*:NONSTOP_KERNEL:*:*)
++ echo nse-tandem-nsk${UNAME_RELEASE}
++ exit ;;
++ NSR-?:NONSTOP_KERNEL:*:*)
++ echo nsr-tandem-nsk${UNAME_RELEASE}
++ exit ;;
++ *:NonStop-UX:*:*)
++ echo mips-compaq-nonstopux
++ exit ;;
++ BS2000:POSIX*:*:*)
++ echo bs2000-siemens-sysv
++ exit ;;
++ DS/*:UNIX_System_V:*:*)
++ echo ${UNAME_MACHINE}-${UNAME_SYSTEM}-${UNAME_RELEASE}
++ exit ;;
++ *:Plan9:*:*)
++ # "uname -m" is not consistent, so use $cputype instead. 386
++ # is converted to i386 for consistency with other x86
++ # operating systems.
++ if test "$cputype" = "386"; then
++ UNAME_MACHINE=i386
++ else
++ UNAME_MACHINE="$cputype"
++ fi
++ echo ${UNAME_MACHINE}-unknown-plan9
++ exit ;;
++ *:TOPS-10:*:*)
++ echo pdp10-unknown-tops10
++ exit ;;
++ *:TENEX:*:*)
++ echo pdp10-unknown-tenex
++ exit ;;
++ KS10:TOPS-20:*:* | KL10:TOPS-20:*:* | TYPE4:TOPS-20:*:*)
++ echo pdp10-dec-tops20
++ exit ;;
++ XKL-1:TOPS-20:*:* | TYPE5:TOPS-20:*:*)
++ echo pdp10-xkl-tops20
++ exit ;;
++ *:TOPS-20:*:*)
++ echo pdp10-unknown-tops20
++ exit ;;
++ *:ITS:*:*)
++ echo pdp10-unknown-its
++ exit ;;
++ SEI:*:*:SEIUX)
++ echo mips-sei-seiux${UNAME_RELEASE}
++ exit ;;
++ *:DragonFly:*:*)
++ echo ${UNAME_MACHINE}-unknown-dragonfly`echo ${UNAME_RELEASE}|sed -e
's/[-(].*//'`
++ exit ;;
++ *:*VMS:*:*)
++ UNAME_MACHINE=`(uname -p) 2>/dev/null`
++ case "${UNAME_MACHINE}" in
++ A*) echo alpha-dec-vms ; exit ;;
++ I*) echo ia64-dec-vms ; exit ;;
++ V*) echo vax-dec-vms ; exit ;;
++ esac ;;
++ *:XENIX:*:SysV)
++ echo i386-pc-xenix
++ exit ;;
++ i*86:skyos:*:*)
++ echo ${UNAME_MACHINE}-pc-skyos`echo ${UNAME_RELEASE}` | sed -e 's/ .*$//'
++ exit ;;
++ i*86:rdos:*:*)
++ echo ${UNAME_MACHINE}-pc-rdos
++ exit ;;
++ i*86:AROS:*:*)
++ echo ${UNAME_MACHINE}-pc-aros
++ exit ;;
++ x86_64:VMkernel:*:*)
++ echo ${UNAME_MACHINE}-unknown-esx
++ exit ;;
++esac
++
++cat >&2 <<EOF
++$0: unable to guess system type
++
++This script, last modified $timestamp, has failed to recognize
++the operating system you are using. It is advised that you
++download the most up to date version of the config scripts from
++
++
http://git.savannah.gnu.org/gitweb/?p=config.git;a=blob_plain;f=config.gu...
++and
++
http://git.savannah.gnu.org/gitweb/?p=config.git;a=blob_plain;f=config.su...
++
++If the version you run ($0) is already up to date, please
++send the following data and any information you think might be
++pertinent to <config-patches(a)gnu.org> in order to provide the needed
++information to handle your system.
++
++config.guess timestamp = $timestamp
++
++uname -m = `(uname -m) 2>/dev/null || echo unknown`
++uname -r = `(uname -r) 2>/dev/null || echo unknown`
++uname -s = `(uname -s) 2>/dev/null || echo unknown`
++uname -v = `(uname -v) 2>/dev/null || echo unknown`
++
++/usr/bin/uname -p = `(/usr/bin/uname -p) 2>/dev/null`
++/bin/uname -X = `(/bin/uname -X) 2>/dev/null`
++
++hostinfo = `(hostinfo) 2>/dev/null`
++/bin/universe = `(/bin/universe) 2>/dev/null`
++/usr/bin/arch -k = `(/usr/bin/arch -k) 2>/dev/null`
++/bin/arch = `(/bin/arch) 2>/dev/null`
++/usr/bin/oslevel = `(/usr/bin/oslevel) 2>/dev/null`
++/usr/convex/getsysinfo = `(/usr/convex/getsysinfo) 2>/dev/null`
++
++UNAME_MACHINE = ${UNAME_MACHINE}
++UNAME_RELEASE = ${UNAME_RELEASE}
++UNAME_SYSTEM = ${UNAME_SYSTEM}
++UNAME_VERSION = ${UNAME_VERSION}
++EOF
++
++exit 1
++
++# Local variables:
++# eval: (add-hook 'write-file-hooks 'time-stamp)
++# time-stamp-start: "timestamp='"
++# time-stamp-format: "%:y-%02m-%02d"
++# time-stamp-end: "'"
++# End:
+diff --git a/make/otp_default_release_path.mk b/make/otp_default_release_path.mk
+new file mode 100644
+index 0000000..bdaaca5
+--- /dev/null
++++ b/make/otp_default_release_path.mk
+@@ -0,0 +1,25 @@
++#
++# %CopyrightBegin%
++#
++# Copyright Ericsson AB 2014. All Rights Reserved.
++#
++# Licensed under the Apache License, Version 2.0 (the "License");
++# you may not use this file except in compliance with the License.
++# You may obtain a copy of the License at
++#
++#
http://www.apache.org/licenses/LICENSE-2.0
++#
++# Unless required by applicable law or agreed to in writing, software
++# distributed under the License is distributed on an "AS IS" BASIS,
++# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
++# See the License for the specific language governing permissions and
++# limitations under the License.
++#
++# %CopyrightEnd%
++#
++
++#
++# Where to release to by default
++#
++
++OTP_DEFAULT_RELEASE_PATH="$(ERL_TOP)/release/$(TARGET)"
+diff --git a/make/otp_release_targets.mk b/make/otp_release_targets.mk
+new file mode 100644
+index 0000000..23b4416
+--- /dev/null
++++ b/make/otp_release_targets.mk
+@@ -0,0 +1,184 @@
++#
++# %CopyrightBegin%
++#
++# Copyright Ericsson AB 1997-2013. All Rights Reserved.
++#
++# Licensed under the Apache License, Version 2.0 (the "License");
++# you may not use this file except in compliance with the License.
++# You may obtain a copy of the License at
++#
++#
http://www.apache.org/licenses/LICENSE-2.0
++#
++# Unless required by applicable law or agreed to in writing, software
++# distributed under the License is distributed on an "AS IS" BASIS,
++# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
++# See the License for the specific language governing permissions and
++# limitations under the License.
++#
++# %CopyrightEnd%
++#
++
++include $(ERL_TOP)/make/otp_default_release_path.mk
++
++# ----------------------------------------------------
++# Targets for the new documentation support
++# ----------------------------------------------------
++
++ifneq ($(TOP_SPECS_FILE),)
++TOP_SPECS_PARAM = --stringparam specs_file "`pwd`/$(TOP_SPECS_FILE)"
++endif
++
++MOD2APP = $(ERL_TOP)/make/$(TARGET)/mod2app.xml
++ifneq ($(wildcard $(MOD2APP)),)
++MOD2APP_PARAM = --stringparam mod2app_file "$(MOD2APP)"
++endif
++
++ifeq ($(TOPDOC),)
++$(HTMLDIR)/index.html: $(XML_FILES) $(SPECS_FILES)
++ date=`date +"%B %e, %Y"`; \
++ $(XSLTPROC) --noout \
++ --stringparam outdir $(HTMLDIR) \
++ --stringparam docgen "$(DOCGEN)" \
++ --stringparam topdocdir "$(TOPDOCDIR)" \
++ --stringparam pdfdir "$(PDFDIR)" \
++ --xinclude $(TOP_SPECS_PARAM) $(MOD2APP_PARAM) \
++ --stringparam gendate "$$date" \
++ --stringparam appname "$(APPLICATION)" \
++ --stringparam appver "$(VSN)" \
++ --stringparam extra_front_page_info "$(DOC_EXTRA_FRONT_PAGE_INFO)" \
++ --stringparam stylesheet "$(CSS_FILE)" \
++ --stringparam winprefix "$(WINPREFIX)" \
++ --stringparam logo "$(HTMLLOGO_FILE)" \
++ --stringparam pdfname "$(PDFNAME)" \
++ -path $(DOCGEN)/priv/dtd \
++ -path $(DOCGEN)/priv/dtd_html_entities \
++ $(DOCGEN)/priv/xsl/db_html.xsl book.xml
++
++endif
++
++$(HTMLDIR)/users_guide.html: $(XML_FILES)
++ date=`date +"%B %e, %Y"`; \
++ $(XSLTPROC) --noout \
++ --stringparam outdir $(HTMLDIR) \
++ --stringparam docgen "$(DOCGEN)" \
++ --stringparam topdocdir "$(TOPDOCDIR)" \
++ --stringparam pdfdir "$(PDFDIR)" \
++ --stringparam gendate "$$date" \
++ --stringparam appname "$(APPLICATION)" \
++ --stringparam appver "$(VSN)" \
++ --stringparam extra_front_page_info "$(DOC_EXTRA_FRONT_PAGE_INFO)" \
++ --stringparam stylesheet "$(CSS_FILE)" \
++ --stringparam winprefix "$(WINPREFIX)" \
++ --stringparam logo "$(HTMLLOGO_FILE)" \
++ --stringparam pdfname "$(PDFNAME)" \
++ --xinclude \
++ -path $(DOCGEN)/priv/dtd \
++ -path $(DOCGEN)/priv/dtd_html_entities \
++ $(DOCGEN)/priv/xsl/db_html.xsl book.xml
++
++%.fo: $(XML_FILES) $(SPECS_FILES)
++ date=`date +"%B %e, %Y"`; \
++ $(XSLTPROC) \
++ --stringparam docgen "$(DOCGEN)" \
++ --stringparam gendate "$$date" \
++ --stringparam appname "$(APPLICATION)" \
++ --stringparam appver "$(VSN)" \
++ --stringparam extra_front_page_info "$(DOC_EXTRA_FRONT_PAGE_INFO)" \
++ --stringparam logo "$(PDFLOGO_FILE)" \
++ --stringparam pdfcolor "$(PDFCOLOR)" \
++ --xinclude $(TOP_SPECS_PARAM) \
++ -path $(DOCGEN)/priv/dtd \
++ -path $(DOCGEN)/priv/dtd_html_entities \
++ $(DOCGEN)/priv/xsl/db_pdf.xsl book.xml > $@
++
++# ------------------------------------------------------------------------
++# The following targets just exist in the documentation directory
++# ------------------------------------------------------------------------
++.PHONY: xmllint
++
++ifneq ($(XML_FILES),)
++
++# ----------------------------------------------------
++# Generation of application index data
++# ----------------------------------------------------
++$(HTMLDIR)/$(APPLICATION).eix: $(XML_FILES) $(SPECS_FILES)
++ date=`date +"%B %e, %Y"`; \
++ $(XSLTPROC) --stringparam docgen "$(DOCGEN)" \
++ --stringparam gendate "$$date" \
++ --stringparam appname "$(APPLICATION)" \
++ --stringparam appver "$(VSN)" \
++ -xinclude $(TOP_SPECS_PARAM) \
++ -path $(DOCGEN)/priv/dtd \
++ -path $(DOCGEN)/priv/dtd_html_entities \
++ $(DOCGEN)/priv/xsl/db_eix.xsl book.xml > $@
++
++docs: $(HTMLDIR)/$(APPLICATION).eix
++
++## Here awk is used to find all xi:include files in $(BOOK_FILES)
++## Then we look into all those files check for xi:includes
++BOOK_XI_INC_FILES:=$(foreach file,$(BOOK_FILES),$(shell awk -F\" '/xi:include/
{print $$2}' $(file))) $(BOOK_FILES)
++ALL_XI_INC_FILES:=$(foreach file,$(BOOK_XI_INC_FILES),$(shell awk -F\"
'/xi:include/ {if ("$(dir $(file))" != "./") printf "$(dir
$(file))"; print $$2}' $(file))) $(BOOK_XI_INC_FILES)
++
++## These are the patterns of file names that xmllint cannot currently parse
++XI_INC_FILES:=%user_man.xml %usersguide.xml %refman.xml %ref_man.xml %part.xml
%book.xml
++
++## These are the files that we should run the xmllint on
++LINT_XI_INC_FILES := $(filter-out $(XI_INC_FILES), $(ALL_XI_INC_FILES))
++
++EMPTY :=
++SPACE := $(EMPTY) $(EMPTY)
++XMLLINT_SRCDIRS:=$(subst $(SPACE),:,$(sort $(foreach file,$(XML_FILES),$(dir
$(file)))))
++
++xmllint: $(ALL_XI_INC_FILES)
++## We verify that the $(XML_FILES) variable in the Makefile have exactly
++## the same files as we found out by following xi:include.
++ifneq ($(filter-out $(filter %.xml,$(XML_FILES)),$(ALL_XI_INC_FILES)),)
++ $(error "$(filter-out $(filter %.xml,$(XML_FILES)),$(ALL_XI_INC_FILES)) in
$$ALL_XI_INC_FILES but not in $$XML_FILES");
++endif
++ifneq ($(filter-out $(ALL_XI_INC_FILES),$(filter %.xml,$(XML_FILES))),)
++ $(error "$(filter-out $(ALL_XI_INC_FILES),$(filter %.xml,$(XML_FILES))) in
$$XML_FILES but not in $$ALL_XI_INC_FILES");
++endif
++ @echo "xmllint $(LINT_XI_INC_FILES)"
++ @xmllint --noout --valid --nodefdtd --loaddtd --path \
++ $(DOCGEN)/priv/dtd:$(DOCGEN)/priv/dtd_html_entities:$(XMLLINT_SRCDIRS) \
++ $(LINT_XI_INC_FILES)
++
++# ----------------------------------------------------
++# Local documentation target for testing
++# ----------------------------------------------------
++local_docs: TOPDOCDIR=.
++local_docs: local_copy_of_topdefs docs
++
++local_html: TOPDOCDIR=.
++local_html: local_copy_of_topdefs html
++
++local_copy_of_topdefs:
++ $(INSTALL) $(DOCGEN)/priv/css/otp_doc.css $(HTMLDIR)
++ $(INSTALL) $(DOCGEN)/priv/images/erlang-logo.png $(HTMLDIR)
++ $(INSTALL) $(DOCGEN)/priv/images/erlang-logo.gif $(HTMLDIR)
++ $(INSTALL_DIR) $(HTMLDIR)/js/flipmenu
++ $(INSTALL) $(DOCGEN)/priv/js/flipmenu/flip_closed.gif \
++ $(DOCGEN)/priv/js/flipmenu/flip_open.gif \
++ $(DOCGEN)/priv/js/flipmenu/flip_static.gif \
++ $(DOCGEN)/priv/js/flipmenu/flipmenu.js $(HTMLDIR)/js/flipmenu
++
++else
++xmllint:
++endif
++
++# ----------------------------------------------------
++# Standard release target
++# ----------------------------------------------------
++
++ifeq ($(TESTROOT),)
++
++release release_docs release_tests release_html:
++ $(MAKE) $(MFLAGS) RELEASE_PATH=$(OTP_DEFAULT_RELEASE_PATH) \
++ $(TARGET_MAKEFILE) $@_spec
++
++else
++
++release release_docs release_tests release_html:
++ $(MAKE) $(MFLAGS) RELEASE_PATH="$(TESTROOT)" $(TARGET_MAKEFILE) $@_spec
++
++endif
+diff --git a/make/otp_subdir.mk b/make/otp_subdir.mk
+new file mode 100644
+index 0000000..19c7449
+--- /dev/null
++++ b/make/otp_subdir.mk
+@@ -0,0 +1,58 @@
++#
++# %CopyrightBegin%
++#
++# Copyright Ericsson AB 1997-2011. All Rights Reserved.
++#
++# Licensed under the Apache License, Version 2.0 (the "License");
++# you may not use this file except in compliance with the License.
++# You may obtain a copy of the License at
++#
++#
http://www.apache.org/licenses/LICENSE-2.0
++#
++# Unless required by applicable law or agreed to in writing, software
++# distributed under the License is distributed on an "AS IS" BASIS,
++# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
++# See the License for the specific language governing permissions and
++# limitations under the License.
++#
++# %CopyrightEnd%
++#
++# Make include file for otp
++
++.PHONY: debug opt lcnt release docs release_docs tests release_tests \
++ clean depend valgrind static_lib
++
++#
++# Targets that don't affect documentation directories
++#
++opt debug lcnt release docs release_docs tests release_tests clean depend valgrind
static_lib xmllint:
++ @set -e ; \
++ app_pwd=`pwd` ; \
++ if test -f vsn.mk; then \
++ echo "=== Entering application" `basename $$app_pwd` ; \
++ fi ; \
++ for d in $(SUB_DIRECTORIES); do \
++ if test -f $$d/SKIP ; then \
++ echo "=== Skipping subdir $$d, reason:" ; \
++ cat $$d/SKIP ; \
++ echo "===" ; \
++ else \
++ if test ! -d $$d ; then \
++ echo "=== Skipping subdir $$d, it is missing" ; \
++ else \
++ (cd $$d && $(MAKE) $@) || exit $$? ; \
++ fi ; \
++ fi ; \
++ done ; \
++ if test -f vsn.mk; then \
++ if test release = $@ && test ! -f SKIP; then \
++ app=`basename $$app_pwd` ; \
++ app_vsn=`echo $$app | sed
"y|abcdefghijklmnopqrstuvwxyz|ABCDEFGHIJKLMNOPQRSTUVWXYZ|"` ; \
++ app_vsn=$${app_vsn}_VSN ; \
++ ( $(MAKE) -f "$(ERL_TOP)/make/otp_released_app.mk" \
++ APP_PWD="$$app_pwd" APP_VSN=$$app_vsn APP=$$app \
++ TESTROOT="$(TESTROOT)" update) \
++ || exit $$? ; \
++ fi ; \
++ echo "=== Leaving application" `basename $$app_pwd` ; \
++ fi
+diff --git a/make/output.mk b/make/output.mk
+new file mode 100644
+index 0000000..0496031
+--- /dev/null
++++ b/make/output.mk
+@@ -0,0 +1,141 @@
++#-*-makefile-*- ; force emacs to enter makefile-mode
++# ----------------------------------------------------
++# Make include file for otp
++#
++# %CopyrightBegin%
++#
++# Copyright Ericsson AB 1997-2013. All Rights Reserved.
++#
++# Licensed under the Apache License, Version 2.0 (the "License");
++# you may not use this file except in compliance with the License.
++# You may obtain a copy of the License at
++#
++#
http://www.apache.org/licenses/LICENSE-2.0
++#
++# Unless required by applicable law or agreed to in writing, software
++# distributed under the License is distributed on an "AS IS" BASIS,
++# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
++# See the License for the specific language governing permissions and
++# limitations under the License.
++#
++# %CopyrightEnd%
++#
++# Author: Anthony Ramine
++# ----------------------------------------------------
++
++# These variables are used to produce less output when running make with V=0 or
++# with the --enable-silent-rules flag.
++#
++# For each compiler kind of file generated by a command during the building of
++# Erlang/OTP, a variable named <command>_verbose should be defined and used as
++# a command prefix. The generic gen_verbose variable is offered for
++# miscellaneous operations like sed, cp or magical Perl incantations.
++#
++# A second variable V_<COMMAND> is also provided for major compilation tools
++# like CC, ERLC or JAVAC.
++
++# DEFAULT_VERBOSITY is set by the --enable-silent-rules configure flag.
++ifeq ($(V),)
++V = 0
++endif
++
++# v_p should be used with `test` to dynamically print things.
++ifeq ($(V),0)
++v_p = 0
++else
++v_p = 1
++endif
++
++# V_at is the @ prefix when silent rules are enabled.
++V_at_0 = @
++V_at = $(V_at_$(V))
++
++# V_colon makes the prefixed command into a no-op if silent rules are enabled,
++# useful to annihilate an `echo` command.
++V_colon_0 = @: ""
++V_colon = $(V_colon_$(V))
++
++ar_verbose_0 = @echo " AR "$@;
++ar_verbose = $(ar_verbose_$(V))
++V_AR = $(ar_verbose)$(AR)
++
++asn_verbose_0 = @echo " ASN "$@;
++asn_verbose = $(asn_verbose_$(V))
++
++cc_verbose_0 = @echo " CC "$@;
++cc_verbose = $(cc_verbose_$(V))
++V_CC = $(cc_verbose)$(CC)
++
++cxx_verbose_0 = @echo " CXX "$@;
++cxx_verbose = $(cxx_verbose_$(V))
++V_CXX = $(cxx_verbose)$(CXX)
++
++# For the diameter compiler.
++dia_verbose_0 = @echo " DIA "$@;
++dia_verbose = $(dia_verbose_$(V))
++
++dtrace_verbose_0 = @echo " DTRACE "$@;
++dtrace_verbose = $(dtrace_verbose_$(V))
++
++emacs_verbose_0 = @echo " EMACS "$@;
++emacs_verbose = $(emacs_verbose_$(V))
++
++emu_cc_verbose_0 = @echo " EMU_CC "$@;
++emu_cc_verbose = $(emu_cc_verbose_$(V))
++V_EMU_CC = $(emu_cc_verbose)$(EMU_CC)
++
++erlc_verbose_0 = @echo " ERLC "$@;
++erlc_verbose = $(erlc_verbose_$(V))
++V_ERLC = $(erlc_verbose)$(ERLC)
++
++gen_verbose_0 = @echo " GEN "$@;
++gen_verbose = $(gen_verbose_$(V))
++
++javac_verbose_0 = @echo " JAVAC "$@;
++javac_verbose = $(javac_verbose_$(V))
++V_JAVAC = $(javac_verbose)$(JAVAC)
++
++ld_verbose_0 = @echo " LD "$@;
++ld_verbose = $(ld_verbose_$(V))
++V_LD = $(ld_verbose)$(LD)
++
++leex_verbose_0 = @echo " LEEX "$@;
++leex_verbose = $(leex_verbose_$(V))
++
++lex_verbose_0 = @echo " LEX "$@;
++lex_verbose = $(lex_verbose_$(V))
++V_LEX = $(lex_verbose)$(LEX)
++
++m4_verbose_0 = @echo " M4 "$@;
++m4_verbose = $(m4_verbose_$(V))
++
++# V_MAKE isn't defined and shouldn't be to avoid breaking parallel building and
++# the following warning:
++#
++# warning: jobserver unavailable: using -j1. Add `+' to parent make rule.
++#
++make_verbose_0 = @echo " MAKE "$@;
++make_verbose = $(make_verbose_$(V))
++
++mc_verbose_0 = @echo " MC "$@;
++mc_verbose = $(mc_verbose_$(V))
++V_MC = $(mc_verbose)$(MC)
++
++ranlib_verbose_0 = @echo " RANLIB "$@;
++ranlib_verbose = $(ranlib_verbose_$(V))
++V_RANLIB = $(ranlib_verbose)$(RANLIB)
++
++rc_verbose_0 = @echo " RC "$@;
++rc_verbose = $(rc_verbose_$(V))
++V_RC = $(rc_verbose)$(RC)
++
++snmp_verbose_0 = @echo " SNMP "$@;
++snmp_verbose = $(snmp_verbose_$(V))
++
++# vsn_verbose should be used instead of gen_verbose when sed or another tool
++# is used to insert a version number into a file.
++vsn_verbose_0 = @echo " VSN "$@;
++vsn_verbose = $(vsn_verbose_$(V))
++
++yecc_verbose_0 = @echo " YECC "$@;
++yecc_verbose = $(yecc_verbose_$(V))
+diff --git a/make/target.mk b/make/target.mk
+new file mode 100644
+index 0000000..8917e1a
+--- /dev/null
++++ b/make/target.mk
+@@ -0,0 +1,70 @@
++#
++# %CopyrightBegin%
++#
++# Copyright Ericsson AB 1998-2011. All Rights Reserved.
++#
++# Licensed under the Apache License, Version 2.0 (the "License");
++# you may not use this file except in compliance with the License.
++# You may obtain a copy of the License at
++#
++#
http://www.apache.org/licenses/LICENSE-2.0
++#
++# Unless required by applicable law or agreed to in writing, software
++# distributed under the License is distributed on an "AS IS" BASIS,
++# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
++# See the License for the specific language governing permissions and
++# limitations under the License.
++#
++# %CopyrightEnd%
++
++# Ensure that the make variable TARGET is set
++#
++
++ifeq ($(OVERRIDE_TARGET),)
++
++ifeq ($(TARGET),)
++
++TARGET := $(shell $(ERL_TOP)/erts/autoconf/config.guess)
++
++else
++
++endif
++
++else
++
++ifneq ($(TARGET),)
++
++ifneq ($(TARGET), $(OVERRIDE_TARGET))
++$(warning overriding $$(TARGET) = \
++ "$(TARGET)" \
++ with \
++ $$(OVERRIDE_TARGET) = \
++ "$(OVERRIDE_TARGET)")
++else
++endif
++
++override TARGET := $(OVERRIDE_TARGET)
++
++else
++
++TARGET := $(OVERRIDE_TARGET)
++
++endif
++
++endif
++
++ifneq ($(TARGET),)
++ifneq ($(TARGET),win32)
++ifneq ($(findstring vxworks,$(TARGET)),vxworks)
++override TARGET := $(shell $(ERL_TOP)/erts/autoconf/config.sub $(TARGET))
++else
++endif
++else
++endif
++else
++endif
++
++ifeq ($(TARGET),)
++$(error Neither TARGET nor OVERRIDE_TARGET can be determined!)
++else
++endif
+diff --git a/make/target/otp.mk b/make/target/otp.mk
+new file mode 100644
+index 0000000..75a820f
+--- /dev/null
++++ b/make/target/otp.mk
+@@ -0,0 +1,329 @@
++#-*-makefile-*- ; force emacs to enter makefile-mode
++# ----------------------------------------------------
++# Make include file for otp
++#
++# %CopyrightBegin%
++#
++# Copyright Ericsson AB 1997-2016. All Rights Reserved.
++#
++# Licensed under the Apache License, Version 2.0 (the "License");
++# you may not use this file except in compliance with the License.
++# You may obtain a copy of the License at
++#
++#
http://www.apache.org/licenses/LICENSE-2.0
++#
++# Unless required by applicable law or agreed to in writing, software
++# distributed under the License is distributed on an "AS IS" BASIS,
++# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
++# See the License for the specific language governing permissions and
++# limitations under the License.
++#
++# %CopyrightEnd%
++#
++# Author: Lars Thorsen
++# ----------------------------------------------------
++.SUFFIXES: .erl .beam .yrl .xrl .bin .mib .hrl .sgml .xml .xmlsrc .html .ps \
++ .3 .1 .fig .dvi .tex .class .java .pdf .fo .psframe .pscrop .el .elc
++
++# ----------------------------------------------------
++# Output
++# ----------------------------------------------------
++include $(ERL_TOP)/make/output.mk
++
++# ----------------------------------------------------
++# Version
++# ----------------------------------------------------
++
++OTP_VERSION = 20.3.8.18
++SYSTEM_VSN = 20
++
++# ----------------------------------------------------
++# Cross Compiling
++# ----------------------------------------------------
++CROSS_COMPILING = no
++
++# ----------------------------------------------------
++# Common macros
++# ----------------------------------------------------
++DEFAULT_TARGETS = opt debug release release_docs clean docs
++
++DEFAULT_FLAVOR=smp
++FLAVORS= smp
++TYPES=opt
++
++# Slash separated list of return values from $(origin VAR)
++# that are untrusted - set default in this file instead.
++# The list is not space separated since some return values
++# contain space, and we want to use $(findstring ...) to
++# search the list.
++DUBIOUS_ORIGINS = /undefined/environment/
++
++# ----------------------------------------------------
++# HiPE
++# ----------------------------------------------------
++
++HIPE_ENABLED=yes
++NATIVE_LIBS_ENABLED=
++
++# ----------------------------------------------------
++# Command macros
++# ----------------------------------------------------
++INSTALL = /usr/bin/install -c
++INSTALL_DIR = /usr/bin/install -c -d
++INSTALL_PROGRAM = ${INSTALL}
++INSTALL_SCRIPT = ${INSTALL}
++INSTALL_DATA = ${INSTALL} -m 644
++
++CC = gcc
++GCC = yes
++HCC = $(CC)
++CC32 = gcc
++CFLAGS32 = -O2 -g -pipe -Wall -Werror=format-security -Wp,-D_FORTIFY_SOURCE=2
-fexceptions -fstack-protector-strong --param=ssp-buffer-size=4 -grecord-gcc-switches
-specs=/usr/lib/rpm/redhat/redhat-hardened-cc1 -m64 -mtune=generic
-I/home/petro/work/erlang/erts/x86_64-unknown-linux-gnu -fno-tree-copyrename
-D_GNU_SOURCE -m32
++BASIC_CFLAGS = -Werror=undef -Werror=implicit -Werror=return-type -O2 -g -pipe -Wall
-Werror=format-security -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector-strong
--param=ssp-buffer-size=4 -grecord-gcc-switches
-specs=/usr/lib/rpm/redhat/redhat-hardened-cc1 -m64 -mtune=generic
-I/home/petro/work/erlang/erts/x86_64-unknown-linux-gnu -fno-tree-copyrename
-D_GNU_SOURCE
++DEBUG_FLAGS = -g
++LD = $(CC)
++RANLIB = ranlib
++AR = ar
++PERL = /usr/bin/perl
++
++BITS64 = yes
++
++OTP_RELEASE =
++
++# ----------------------------------------------------
++# Erlang language section
++# ----------------------------------------------------
++EMULATOR = beam
++ifdef BOOTSTRAP
++ ERL_COMPILE_FLAGS += +slim
++else
++ ERL_COMPILE_FLAGS += +debug_info
++endif
++ERLC_WFLAGS = -W
++ERLC = erlc $(ERLC_WFLAGS) $(ERLC_FLAGS)
++ERL = erl -boot start_clean
++
++ifneq (,$(findstring $(origin EBIN),$(DUBIOUS_ORIGINS)))
++EBIN = ../ebin
++endif
++
++# Generated (non ebin) files...
++ifneq (,$(findstring $(origin EGEN),$(DUBIOUS_ORIGINS)))
++EGEN = .
++endif
++
++ifneq (,$(findstring $(origin ESRC),$(DUBIOUS_ORIGINS)))
++ESRC = .
++endif
++
++$(EBIN)/%.beam: $(EGEN)/%.erl
++ $(V_ERLC) $(ERL_COMPILE_FLAGS) -o$(EBIN) $<
++
++$(EBIN)/%.beam: $(ESRC)/%.erl
++ $(V_ERLC) $(ERL_COMPILE_FLAGS) -o$(EBIN) $<
++
++ifeq ($(NATIVE_LIBS_ENABLED),yes)
++# Special rule for the HIPE bootstrap w/ native libs
++../boot_ebin/%.beam: $(ESRC)/%.erl
++ $(V_ERLC) $(ERL_COMPILE_FLAGS) -o../boot_ebin $<
++endif
++
++.erl.beam:
++ $(V_ERLC) $(ERL_COMPILE_FLAGS) -o$(dir $@) $<
++
++#
++# When .erl files are automatically created GNU make removes them if
++# they were the result of a chain of implicit rules. To prevent this
++# we say that all .erl files are "precious".
++#
++.PRECIOUS: %.erl %.fo
++
++## Uncomment these lines and add .idl to suffixes above to have erlc
++## eat IDL files
++##$(EGEN)/%.erl: $(ESRC)/%.idl
++## $(ERLC) $(IDL_FLAGS) $<
++
++$(EGEN)/%.erl: $(ESRC)/%.yrl
++ $(yecc_verbose)$(ERLC) $(YRL_FLAGS) -o$(EGEN) $<
++
++$(EGEN)/%.erl: $(ESRC)/%.xrl
++ $(leex_verbose)$(ERLC) $(XRL_FLAGS) -o$(EGEN) $<
++
++# ----------------------------------------------------
++# SNMP language section
++# ----------------------------------------------------
++SNMP_TOOLKIT = $(ERL_TOP)/lib/snmp
++ifeq ($(SNMP_BIN_TARGET_DIR),)
++ SNMP_BIN_TARGET_DIR = ../priv/mibs
++endif
++ifeq ($(SNMP_HRL_TARGET_DIR),)
++ SNMP_HRL_TARGET_DIR = ../include
++endif
++
++
++$(SNMP_BIN_TARGET_DIR)/%.bin: %.mib
++ $(snmp_verbose)$(ERLC) -pa $(SNMP_TOOLKIT)/ebin -I $(SNMP_TOOLKIT)/priv/mibs
$(SNMP_FLAGS) -o $(SNMP_BIN_TARGET_DIR) $<
++
++$(SNMP_HRL_TARGET_DIR)/%.hrl: $(SNMP_BIN_TARGET_DIR)/%.bin
++ $(snmp_verbose)$(ERLC) -pa $(SNMP_TOOLKIT)/ebin -o $(SNMP_HRL_TARGET_DIR) $<
++
++.mib.bin:
++ $(snmp_verbose)$(ERLC) -pa $(SNMP_TOOLKIT)/ebin -I $(SNMP_TOOLKIT)/priv/mibs
$(SNMP_FLAGS) $<
++
++.bin.hrl:
++ $(snmp_verbose)$(ERLC) -pa $(SNMP_TOOLKIT)/ebin $<
++
++# ----------------------------------------------------
++# Java language section
++# ----------------------------------------------------
++JAVA= javac
++
++ifneq (,$(findstring $(origin JAVA_DEST_ROOT),$(DUBIOUS_ORIGINS)))
++JAVA_DEST_ROOT = ../priv/
++endif
++
++.java.class:
++ $(javac_verbose)CLASSPATH=$(CLASSPATH) $(JAVA) $(JAVA_OPTIONS) $<
++
++
++$(JAVA_DEST_ROOT)$(JAVA_CLASS_SUBDIR)%.class: %.java
++ $(javac_verbose)CLASSPATH=$(CLASSPATH) $(JAVA) $(JAVA_OPTIONS) -d $(JAVA_DEST_ROOT)
$<
++
++# ----------------------------------------------------
++# Emacs byte code compiling
++# ----------------------------------------------------
++EMACS_COMPILER=emacs-20
++EMACS_COMPILE_OPTIONS=-q --no-site-file -batch -f batch-byte-compile
++
++.el.elc:
++ $(emacs_verbose)$(EMACS_COMPILER) $(EMACS_COMPILE_OPTIONS) $<
++
++# ----------------------------------------------------
++# Documentation section
++# ----------------------------------------------------
++export VSN
++
++TOPDOCDIR=../../../../doc
++
++DOCDIR = ..
++
++PDFDIR=$(DOCDIR)/pdf
++
++HTMLDIR = $(DOCDIR)/html
++
++MAN1DIR = $(DOCDIR)/man1
++MAN2DIR = $(DOCDIR)/man2
++MAN3DIR = $(DOCDIR)/man3
++MAN4DIR = $(DOCDIR)/man4
++MAN6DIR = $(DOCDIR)/man6
++MAN9DIR = $(DOCDIR)/man9
++
++TEXDIR = .
++
++SPECDIR = $(DOCDIR)/specs
++
++ifeq ($(CSS_FILE),)
++CSS_FILE = otp_doc.css
++endif
++ifeq ($(WINPREFIX),)
++WINPREFIX = Erlang
++endif
++ifeq ($(HTMLLOGO),)
++HTMLLOGO_FILE = erlang-logo.png
++endif
++ifeq ($(PDFLOGO),)
++PDFLOGO_FILE = $(DOCGEN)/priv/images/erlang-logo.gif
++endif
++ifeq ($(PDFCOLOR),)
++PDFCOLOR = \#960003
++endif
++
++# HTML & GIF files that always are generated and must be delivered
++SGML_COLL_FILES = $(SGML_APPLICATION_FILES) $(SGML_PART_FILES)
++XML_COLL_FILES = $(XML_APPLICATION_FILES) $(XML_PART_FILES)
++DEFAULT_HTML_FILES = \
++ $(SGML_COLL_FILES:%.sgml=$(HTMLDIR)/%_frame.html) \
++ $(SGML_COLL_FILES:%.sgml=$(HTMLDIR)/%_first.html) \
++ $(SGML_COLL_FILES:%.sgml=$(HTMLDIR)/%_term.html) \
++ $(SGML_COLL_FILES:%.sgml=$(HTMLDIR)/%_cite.html) \
++ $(SGML_APPLICATION_FILES:%.sgml=$(HTMLDIR)/%_index.html) \
++ $(SGML_APPLICATION_FILES:%.sgml=$(HTMLDIR)/%.kwc) \
++ $(XML_COLL_FILES:%.xml=$(HTMLDIR)/%_frame.html) \
++ $(XML_COLL_FILES:%.xml=$(HTMLDIR)/%_first.html) \
++ $(XML_COLL_FILES:%.xml=$(HTMLDIR)/%_term.html) \
++ $(XML_COLL_FILES:%.xml=$(HTMLDIR)/%_cite.html) \
++ $(XML_APPLICATION_FILES:%.xml=$(HTMLDIR)/%_index.html) \
++ $(XML_APPLICATION_FILES:%.xml=$(HTMLDIR)/%.kwc) \
++ $(HTMLDIR)/index.html
++
++DEFAULT_GIF_FILES = $(HTMLDIR)/min_head.gif
++
++#
++# Flags & Commands
++#
++XSLTPROC = xsltproc
++FOP = fop
++XMLLINT = xmllint
++CP = /bin/cp
++
++DOCGEN=$(ERL_TOP)/lib/erl_docgen
++FOP_CONFIG = $(DOCGEN)/priv/fop.xconf
++
++ifneq (,$(findstring $(origin SPECS_ESRC),$(DUBIOUS_ORIGINS)))
++SPECS_ESRC = ../../src
++endif
++SPECS_EXTRACTOR=$(DOCGEN)/priv/bin/specs_gen.escript
++# Extract specifications and types from Erlang source files (-spec, -type)
++$(SPECDIR)/specs_%.xml: $(SPECS_ESRC)/%.erl
++ escript $(SPECS_EXTRACTOR) $(SPECS_FLAGS) -o$(dir $@) $<
++$(SPECDIR)/specs_%.xml: $(SPECS_ESRC)/gen/%.erl
++ escript $(SPECS_EXTRACTOR) $(SPECS_FLAGS) -o$(dir $@) $<
++
++
++$(MAN1DIR)/%.1: %.xml
++ date=`date +"%B %e, %Y"`; \
++ xsltproc --output "$@" --stringparam company "Ericsson AB"
--stringparam docgen "$(DOCGEN)" --stringparam gendate "$$date"
--stringparam appname "$(APPLICATION)" --stringparam appver "$(VSN)"
--xinclude -path $(DOCGEN)/priv/dtd -path $(DOCGEN)/priv/dtd_man_entities
$(DOCGEN)/priv/xsl/db_man.xsl $<
++
++$(MAN2DIR)/%.2: %.xml
++ date=`date +"%B %e, %Y"`; \
++ xsltproc --output "$@" --stringparam company "Ericsson AB"
--stringparam docgen "$(DOCGEN)" --stringparam gendate "$$date"
--stringparam appname "$(APPLICATION)" --stringparam appver "$(VSN)"
--xinclude -path $(DOCGEN)/priv/dtd -path $(DOCGEN)/priv/dtd_man_entities
$(DOCGEN)/priv/xsl/db_man.xsl $<
++
++ifneq ($(wildcard $(SPECDIR)),)
++$(MAN3DIR)/%.3: %.xml $(SPECDIR)/specs_%.xml
++ date=`date +"%B %e, %Y"`; \
++ specs_file=`pwd`/$(SPECDIR)/specs_$*.xml; \
++ xsltproc --output "$@" --stringparam company "Ericsson AB"
--stringparam docgen "$(DOCGEN)" --stringparam gendate "$$date"
--stringparam appname "$(APPLICATION)" --stringparam appver "$(VSN)"
--stringparam specs_file "$$specs_file" --xinclude -path $(DOCGEN)/priv/dtd
-path $(DOCGEN)/priv/dtd_man_entities $(DOCGEN)/priv/xsl/db_man.xsl $<
++else
++$(MAN3DIR)/%.3: %.xml
++ date=`date +"%B %e, %Y"`; \
++ xsltproc --output "$@" --stringparam company "Ericsson AB"
--stringparam docgen "$(DOCGEN)" --stringparam gendate "$$date"
--stringparam appname "$(APPLICATION)" --stringparam appver "$(VSN)"
--xinclude -path $(DOCGEN)/priv/dtd -path $(DOCGEN)/priv/dtd_man_entities
$(DOCGEN)/priv/xsl/db_man.xsl $<
++endif
++
++# left for compatibility
++$(MAN4DIR)/%.4: %.xml
++ date=`date +"%B %e, %Y"`; \
++ xsltproc --output "$@" --stringparam company "Ericsson AB"
--stringparam docgen "$(DOCGEN)" --stringparam gendate "$$date"
--stringparam appname "$(APPLICATION)" --stringparam appver "$(VSN)"
--xinclude -path $(DOCGEN)/priv/dtd -path $(DOCGEN)/priv/dtd_man_entities
$(DOCGEN)/priv/xsl/db_man.xsl $<
++
++$(MAN4DIR)/%.5: %.xml
++ date=`date +"%B %e, %Y"`; \
++ xsltproc --output "$@" --stringparam company "Ericsson AB"
--stringparam docgen "$(DOCGEN)" --stringparam gendate "$$date"
--stringparam appname "$(APPLICATION)" --stringparam appver "$(VSN)"
--xinclude -path $(DOCGEN)/priv/dtd -path $(DOCGEN)/priv/dtd_man_entities
$(DOCGEN)/priv/xsl/db_man.xsl $<
++
++# left for compatibility
++$(MAN6DIR)/%.6: %_app.xml
++ date=`date +"%B %e, %Y"`; \
++ xsltproc --output "$@" --stringparam company "Ericsson AB"
--stringparam docgen "$(DOCGEN)" --stringparam gendate "$$date"
--stringparam appname "$(APPLICATION)" --stringparam appver "$(VSN)"
--xinclude -path $(DOCGEN)/priv/dtd -path $(DOCGEN)/priv/dtd_man_entities
$(DOCGEN)/priv/xsl/db_man.xsl $<
++
++$(MAN6DIR)/%.7: %_app.xml
++ date=`date +"%B %e, %Y"`; \
++ xsltproc --output "$@" --stringparam company "Ericsson AB"
--stringparam docgen "$(DOCGEN)" --stringparam gendate "$$date"
--stringparam appname "$(APPLICATION)" --stringparam appver "$(VSN)"
--xinclude -path $(DOCGEN)/priv/dtd -path $(DOCGEN)/priv/dtd_man_entities
$(DOCGEN)/priv/xsl/db_man.xsl $<
++
++$(MAN9DIR)/%.9: %.xml
++ date=`date +"%B %e, %Y"`; \
++ xsltproc --output "$@" --stringparam company "Ericsson AB"
--stringparam docgen "$(DOCGEN)" --stringparam gendate "$$date"
--stringparam appname "$(APPLICATION)" --stringparam appver "$(VSN)"
--xinclude -path $(DOCGEN)/priv/dtd -path $(DOCGEN)/priv/dtd_man_entities
$(DOCGEN)/priv/xsl/db_man.xsl $<
++
++
++.xmlsrc.xml:
++ escript $(DOCGEN)/priv/bin/codeline_preprocessing.escript $< $@
++
++.fo.pdf:
++ $(FOP) -c $(FOP_CONFIG) -cache $(ERL_TOP)/make/$(TARGET)/fop-fonts.cache -fo $< -pdf
$@
+diff --git a/make/target/otp_ded.mk b/make/target/otp_ded.mk
+new file mode 100644
+index 0000000..abf68c8
+--- /dev/null
++++ b/make/target/otp_ded.mk
+@@ -0,0 +1,50 @@
++#-*-makefile-*- ; force emacs to enter makefile-mode
++# ----------------------------------------------------
++# %CopyrightBegin%
++#
++# Copyright Ericsson AB 2009-2013. All Rights Reserved.
++#
++# Licensed under the Apache License, Version 2.0 (the "License");
++# you may not use this file except in compliance with the License.
++# You may obtain a copy of the License at
++#
++#
http://www.apache.org/licenses/LICENSE-2.0
++#
++# Unless required by applicable law or agreed to in writing, software
++# distributed under the License is distributed on an "AS IS" BASIS,
++# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
++# See the License for the specific language governing permissions and
++# limitations under the License.
++#
++# %CopyrightEnd%
++
++# The version.
++#
++# Note that it is important that the version is
++# explicitly expressed here. Some applications need to
++# be able to check this value *before* configure has
++# been run and generated otp_ded.mk
++DED_MK_VSN = 1
++# ----------------------------------------------------
++# Variables needed for building Dynamic Erlang Drivers
++# ----------------------------------------------------
++DED_CC = gcc
++DED_GCC = yes
++DED_LD = gcc
++DED_LDFLAGS = -shared -Wl,-Bsymbolic
++DED__NOWARN_NOTHR_CFLAGS = -O2 -g -pipe -Wall -Werror=format-security
-Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector-strong --param=ssp-buffer-size=4
-grecord-gcc-switches -specs=/usr/lib/rpm/redhat/redhat-hardened-cc1 -m64 -mtune=generic
-I/home/petro/work/erlang/erts/x86_64-unknown-linux-gnu -fno-tree-copyrename
-D_GNU_SOURCE -fPIC
++DED__NOTHR_CFLAGS = -Wall -Wstrict-prototypes -Wmissing-prototypes
-Wdeclaration-after-statement -O2 -g -pipe -Wall -Werror=format-security
-Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector-strong --param=ssp-buffer-size=4
-grecord-gcc-switches -specs=/usr/lib/rpm/redhat/redhat-hardened-cc1 -m64 -mtune=generic
-I/home/petro/work/erlang/erts/x86_64-unknown-linux-gnu -fno-tree-copyrename
-D_GNU_SOURCE -fPIC
++DED__NOWARN_CFLAGS = -DUSE_THREADS -D_THREAD_SAFE -D_REENTRANT -DPOSIX_THREADS
-D_POSIX_THREAD_SAFE_FUNCTIONS -O2 -g -pipe -Wall -Werror=format-security
-Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector-strong --param=ssp-buffer-size=4
-grecord-gcc-switches -specs=/usr/lib/rpm/redhat/redhat-hardened-cc1 -m64 -mtune=generic
-I/home/petro/work/erlang/erts/x86_64-unknown-linux-gnu -fno-tree-copyrename
-D_GNU_SOURCE -fPIC
++DED_THR_DEFS = -DUSE_THREADS -D_THREAD_SAFE -D_REENTRANT -DPOSIX_THREADS
-D_POSIX_THREAD_SAFE_FUNCTIONS -D_GNU_SOURCE
++DED_EMU_THR_DEFS = -DUSE_THREADS -D_THREAD_SAFE -D_REENTRANT -DPOSIX_THREADS
-D_POSIX_THREAD_SAFE_FUNCTIONS
++DED_WARN_FLAGS = -Wall -Wstrict-prototypes -Wmissing-prototypes
-Wdeclaration-after-statement
++DED_CFLAGS = -Werror=undef -Werror=implicit -Werror=return-type -Wall
-Wstrict-prototypes -Wmissing-prototypes -Wdeclaration-after-statement -DUSE_THREADS
-D_THREAD_SAFE -D_REENTRANT -DPOSIX_THREADS -D_POSIX_THREAD_SAFE_FUNCTIONS -O2 -g -pipe
-Wall -Werror=format-security -Wp,-D_FORTIFY_SOURCE=2 -fexceptions
-fstack-protector-strong --param=ssp-buffer-size=4 -grecord-gcc-switches
-specs=/usr/lib/rpm/redhat/redhat-hardened-cc1 -m64 -mtune=generic
-I/home/petro/work/erlang/erts/x86_64-unknown-linux-gnu -fno-tree-copyrename
-D_GNU_SOURCE -fPIC
++DED_STATIC_CFLAGS = -Werror=undef -Werror=implicit -Werror=return-type -Wall
-Wstrict-prototypes -Wmissing-prototypes -Wdeclaration-after-statement -DUSE_THREADS
-D_THREAD_SAFE -D_REENTRANT -DPOSIX_THREADS -D_POSIX_THREAD_SAFE_FUNCTIONS -O2 -g -pipe
-Wall -Werror=format-security -Wp,-D_FORTIFY_SOURCE=2 -fexceptions
-fstack-protector-strong --param=ssp-buffer-size=4 -grecord-gcc-switches
-specs=/usr/lib/rpm/redhat/redhat-hardened-cc1 -m64 -mtune=generic
-I/home/petro/work/erlang/erts/x86_64-unknown-linux-gnu -fno-tree-copyrename
-D_GNU_SOURCE -DSTATIC_ERLANG_NIF -DSTATIC_ERLANG_DRIVER
++DED_LIBS = -lutil -ldl -lm
++DED_EXT = so
++ERLANG_OSTYPE = unix
++PRIVDIR = ../priv
++OBJDIR = $(PRIVDIR)/obj/$(TARGET)
++LIBDIR = $(PRIVDIR)/lib/$(TARGET)
++DED_SYS_INCLUDE = -I/home/petro/work/erlang/erts/emulator/beam
-I/home/petro/work/erlang/erts/include
-I/home/petro/work/erlang/erts/include/x86_64-unknown-linux-gnu
-I/home/petro/work/erlang/erts/include/internal
-I/home/petro/work/erlang/erts/include/internal/x86_64-unknown-linux-gnu
-I/home/petro/work/erlang/erts/emulator/sys/unix
-I/home/petro/work/erlang/erts/emulator/sys/common
++DED_INCLUDES = $(DED_SYS_INCLUDE)
diff --git a/erlang-corba-0002-Edit-OTP-files-to-allow-out-of-tree-build.patch
b/erlang-corba-0002-Edit-OTP-files-to-allow-out-of-tree-build.patch
new file mode 100644
index 0000000..df8fc52
--- /dev/null
+++ b/erlang-corba-0002-Edit-OTP-files-to-allow-out-of-tree-build.patch
@@ -0,0 +1,290 @@
+From: Peter Lemenkov <lemenkov(a)gmail.com>
+Date: Wed, 30 Jan 2019 12:37:31 +0300
+Subject: [PATCH] Edit OTP files to allow out-of-tree build
+
+
+diff --git a/doc/Makefile b/doc/Makefile
+index 8f00b17..4efe6f4 100644
+--- a/doc/Makefile
++++ b/doc/Makefile
+@@ -46,17 +46,17 @@ TOPDOCDIR=.
+ # ----------------------------------------------------
+ INDEX_FILE = index.html
+
+-CSS_PATH=$(ERL_TOP)/lib/erl_docgen/priv/css
++CSS_PATH=$(DOCGEN)/priv/css
+
+ CSS_FILES= \
+ $(CSS_PATH)/otp_doc.css \
+ $(CSS_PATH)/highlight.css
+
+-JS_PATH=$(ERL_TOP)/lib/erl_docgen/priv/js
++JS_PATH=$(DOCGEN)/priv/js
+
+ HIGHLIGHT_FILES= \
+- $(JS_PATH)/highlight.js \
+- $(JS_PATH)/highlight.pack.js
++ $(ERL_TOP)/make/highlight.js \
++ $(ERL_TOP)/make/highlight.pack.js
+
+ FLIPMENU_FILES= \
+ $(JS_PATH)/flipmenu/flipmenu.js \
+@@ -72,7 +72,7 @@ NOTES_GEN= $(NOTES_FILE:%.xml=%.html)
+
+ RELEASE_NOTES= release_notes.html
+
+-IMAGE_FILES=$(ERL_TOP)/lib/erl_docgen/priv/images/erlang-logo.png
++IMAGE_FILES=$(DOCGEN)/priv/images/erlang-logo.png
+
+ # ----------------------------------------------------
+ # FLAGS
+diff --git a/make/fop.xconf b/make/fop.xconf
+new file mode 100644
+index 0000000..ee48255
+--- /dev/null
++++ b/make/fop.xconf
+@@ -0,0 +1,46 @@
++<?xml version="1.0"?>
++<!--
++ #
++ # %CopyrightBegin%
++ #
++ # Copyright Ericsson AB 2009-2016. All Rights Reserved.
++ #
++ # Licensed under the Apache License, Version 2.0 (the "License");
++ # you may not use this file except in compliance with the License.
++ # You may obtain a copy of the License at
++ #
++ #
http://www.apache.org/licenses/LICENSE-2.0
++ #
++ # Unless required by applicable law or agreed to in writing, software
++ # distributed under the License is distributed on an "AS IS" BASIS,
++ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
++ # See the License for the specific language governing permissions and
++ # limitations under the License.
++ #
++ # %CopyrightEnd%
++
++ -->
++<!-- NOTE: This is the version of the configuration -->
++<fop version="1.0">
++ <!-- The substitutions of DejaVu 700 are there because FOP outputs
++ warnings about doing the substitutions otherwise -->
++ <fonts>
++ <substitutions>
++ <substitution>
++ <from font-family="DejaVuSans" font-weight="700"/>
++ <to font-family="DejaVuSans" font-weight="400"/>
++ </substitution>
++ <substitution>
++ <from font-family="DejaVuSansMono" font-weight="700"/>
++ <to font-family="DejaVuSansMono" font-weight="400"/>
++ </substitution>
++ </substitutions>
++ </fonts>
++ <renderers>
++ <renderer mime="application/pdf">
++ <fonts>
++ <auto-detect/>
++ </fonts>
++ </renderer>
++ </renderers>
++</fop>
+diff --git a/make/highlight.js b/make/highlight.js
+new file mode 100644
+index 0000000..0594b42
+--- /dev/null
++++ b/make/highlight.js
+@@ -0,0 +1,39 @@
++/*globals document, window*/
++window.addEventListener("load", function () {
++ "use strict";
++ var body = document.body,
++ base = window.__otpTopDocDir || "/doc/js/",
++ cssLink = document.createElement('link'),
++ script = document.createElement('script'),
++ intervalId, attempts = 0;
++
++ cssLink.rel = "stylesheet";
++ cssLink.href = base + "../highlight.css";
++ script.src = base + "highlight.pack.js";
++
++ body.appendChild(cssLink);
++ body.appendChild(script);
++
++ function doHighlight() {
++ attempts += 1;
++
++ if (attempts > 20) {
++ window.clearInterval(intervalId);
++ return;
++ }
++
++ if (!window.hljs) {
++ return;
++ }
++
++ window.clearInterval(intervalId);
++
++ var i, len, nodes = document.querySelectorAll('.example');
++ for (i = 0, len = nodes.length; i < len; i += 1) {
++ window.hljs.highlightBlock(nodes[i]);
++ }
++
++ }
++
++ intervalId = window.setInterval(doHighlight, 50);
++});
+diff --git a/make/highlight.pack.js b/make/highlight.pack.js
+new file mode 100644
+index 0000000..073d39e
+--- /dev/null
++++ b/make/highlight.pack.js
+@@ -0,0 +1,2 @@
++/*! highlight.js v9.7.0 | BSD3 License | git.io/hljslicense */
++!function(e){var n="object"==typeof
window&&window||"object"==typeof
self&&self;"undefined"!=typeof
exports?e(exports):n&&(n.hljs=e({}),"function"==typeof
define&&define.amd&&define([],function(){return
n.hljs}))}(function(e){function n(e){return
e.replace(/[&<>]/gm,function(e){return I[e]})}function t(e){return
e.nodeName.toLowerCase()}function r(e,n){var t=e&&e.exec(n);return
t&&0===t.index}function a(e){return k.test(e)}function i(e){var
n,t,r,i,o=e.className+"
";if(o+=e.parentNode?e.parentNode.className:"",t=B.exec(o))return
R(t[1])?t[1]:"no-highlight";for(o=o.split(/\s+/),n=0,r=o.length;r>n;n++)if(i=o[n],a(i)||R(i))return
i}function o(e,n){var t,r={};for(t in e)r[t]=e[t];if(n)for(t in n)r[t]=n[t];return
r}function u(e){var n=[];return function r(e,a){for(var
i=e.firstChild;i;i=i.nextSibling)3===i.nodeType?a+=i.nodeValue.length:1===i.nodeType&&(n.push({event:"start",offset:a,node:i}),a=r(i,a),t(i).match(/br|hr|img|input/)||n.push({event:"stop",offset:a,node:i}));return
a}(e,0),n}function c(e,r,a){function i(){return
e.length&&r.length?e[0].offset!==r[0].offset?e[0].offset<r[0].offset?e:r:"start"===r[0].event?e:r:e.length?e:r}function
o(e){function r(e){return"
"+e.nodeName+'="'+n(e.value)+'"'}l+="<"+t(e)+w.map.call(e.attributes,r).join("")+">"}function
u(e){l+="</"+t(e)+">"}function
c(e){("start"===e.event?o:u)(e.node)}for(var
s=0,l="",f=[];e.length||r.length;){var
g=i();if(l+=n(a.substr(s,g[0].offset-s)),s=g[0].offset,g===e){f.reverse().forEach(u);do
c(g.splice(0,1)[0]),g=i();while(g===e&&g.length&&g[0].offset===s);f.reverse().forEach(o)}else"start"===g[0].event?f.push(g[0].node):f.pop(),c(g.splice(0,1)[0])}return
l+n(a.substr(s))}function s(e){function n(e){return e&&e.source||e}function
t(t,r){return new
RegExp(n(t),"m"+(e.cI?"i":"")+(r?"g":""))}function
r(a,i){if(!a.compiled){if(a.compiled=!0,a.k=a.k||a.bK,a.k){var
u={},c=function(n,t){e.cI&&(t=t.toLowerCase()),t.split("
").forEach(function(e){var
t=e.split("|");u[t[0]]=[n,t[1]?Number(t[1]):1]})};"string"==typeof
a.k?c("keyword",a.k):E(a.k).forEach(function(e){c(e,a.k[e])}),a.k=u}a.lR=t(a.l||/\w+/,!0),i&&(a.bK&&(a.b="\\b("+a.bK.split("
").join("|")+")\\b"),a.b||(a.b=/\B|\b/),a.bR=t(a.b),a.e||a.eW||(a.e=/\B|\b/),a.e&&(a.eR=t(a.e)),a.tE=n(a.e)||"",a.eW&&i.tE&&(a.tE+=(a.e?"|":"")+i.tE)),a.i&&(a.iR=t(a.i)),null==a.r&&(a.r=1),a.c||(a.c=[]);var
s=[];a.c.forEach(function(e){e.v?e.v.forEach(function(n){s.push(o(e,n))}):s.push("self"===e?a:e)}),a.c=s,a.c.forEach(function(e){r(e,a)}),a.starts&&r(a.starts,i);var
l=a.c.map(function(e){return
e.bK?"\\.?("+e.b+")\\.?":e.b}).concat([a.tE,a.i]).map(n).filter(Boolean);a.t=l.length?t(l.join("|"),!0):{exec:function(){return
null}}}}r(e)}function l(e,t,a,i){function o(e,n){var
t,a;for(t=0,a=n.c.length;a>t;t++)if(r(n.c[t].bR,e))return n.c[t]}function
u(e,n){if(r(e.eR,n)){for(;e.endsParent&&e.parent;)e=e.parent;return e}return
e.eW?u(e.parent,n):void 0}function c(e,n){return!a&&r(n.iR,e)}function g(e,n){var
t=N.cI?n[0].toLowerCase():n[0];return e.k.hasOwnProperty(t)&&e.k[t]}function
h(e,n,t,r){var a=r?"":y.classPrefix,i='<span
class="'+a,o=t?"":C;return i+=e+'">',i+n+o}function
p(){var e,t,r,a;if(!E.k)return
n(B);for(a="",t=0,E.lR.lastIndex=0,r=E.lR.exec(B);r;)a+=n(B.substr(t,r.index-t)),e=g(E,r),e?(M+=e[1],a+=h(e[0],n(r[0]))):a+=n(r[0]),t=E.lR.lastIndex,r=E.lR.exec(B);return
a+n(B.substr(t))}function d(){var e="string"==typeof
E.sL;if(e&&!x[E.sL])return n(B);var
t=e?l(E.sL,B,!0,L[E.sL]):f(B,E.sL.length?E.sL:void 0);return
E.r>0&&(M+=t.r),e&&(L[E.sL]=t.top),h(t.language,t.value,!1,!0)}function
b(){k+=null!=E.sL?d():p(),B=""}function
v(e){k+=e.cN?h(e.cN,"",!0):"",E=Object.create(e,{parent:{value:E}})}function
m(e,n){if(B+=e,null==n)return b(),0;var t=o(n,E);if(t)return
t.skip?B+=n:(t.eB&&(B+=n),b(),t.rB||t.eB||(B=n)),v(t,n),t.rB?0:n.length;var
r=u(E,n);if(r){var a=E;a.skip?B+=n:(a.rE||a.eE||(B+=n),b(),a.eE&&(B=n));do
E.cN&&(k+=C),E.skip||(M+=E.r),E=E.parent;while(E!==r.parent);return
r.starts&&v(r.starts,""),a.rE?0:n.length}if(c(n,E))throw new
Error('Illegal lexeme "'+n+'" for mode
"'+(E.cN||"<unnamed>")+'"');return
B+=n,n.length||1}var N=R(e);if(!N)throw new Error('Unknown language:
"'+e+'"');s(N);var
w,E=i||N,L={},k="";for(w=E;w!==N;w=w.parent)w.cN&&(k=h(w.cN,"",!0)+k);var
B="",M=0;try{for(var
I,j,O=0;;){if(E.t.lastIndex=O,I=E.t.exec(t),!I)break;j=m(t.substr(O,I.index-O),I[0]),O=I.index+j}for(m(t.substr(O)),w=E;w.parent;w=w.parent)w.cN&&(k+=C);return{r:M,value:k,language:e,top:E}}catch(T){if(T.message&&-1!==T.message.indexOf("Illegal"))return{r:0,value:n(t)};throw
T}}function f(e,t){t=t||y.languages||E(x);var r={r:0,value:n(e)},a=r;return
t.filter(R).forEach(function(n){var
t=l(n,e,!1);t.language=n,t.r>a.r&&(a=t),t.r>r.r&&(a=r,r=t)}),a.language&&(r.second_best=a),r}function
g(e){return y.tabReplace||y.useBR?e.replace(M,function(e,n){return
y.useBR&&"\n"===e?"<br>":y.tabReplace?n.replace(/\t/g,y.tabReplace):void
0}):e}function h(e,n,t){var r=n?L[n]:t,a=[e.trim()];return
e.match(/\bhljs\b/)||a.push("hljs"),-1===e.indexOf(r)&&a.push(r),a.join("
").trim()}function p(e){var
n,t,r,o,s,p=i(e);a(p)||(y.useBR?(n=document.createElementNS("http://...
\/]*>/g,"\n")):n=e,s=n.textContent,r=p?l(p,s,!0):f(s),t=u(n),t.length&&(o=document.createElementNS("http://www.w3.org/1999/xhtml","div"),o.innerHTML=r.value,r.value=c(t,u(o),s)),r.value=g(r.value),e.innerHTML=r.value,e.className=h(e.className,p,r.language),e.result={language:r.language,re:r.r},r.second_best&&(e.second_best={language:r.second_best.language,re:r.second_best.r}))}function
d(e){y=o(y,e)}function b(){if(!b.called){b.called=!0;var
e=document.querySelectorAll("pre code");w.forEach.call(e,p)}}function
v(){addEventListener("DOMContentLoaded",b,!1),addEventListener("load",b,!1)}function
m(n,t){var r=x[n]=t(e);r.aliases&&r.aliases.forEach(function(e){L[e]=n})}function
N(){return E(x)}function R(e){return e=(e||"").toLowerCase(),x[e]||x[L[e]]}var
w=[],E=Object.keys,x={},L={},k=/^(no-?highlight|plain|text)$/i,B=/\blang(?:uage)?-([\w-]+)\b/i,M=/((^(<[^>]+>|\t|)+|(?:\n)))/gm,C="</span>",y={classPrefix:"hljs-",tabReplace:null,useBR:!1,languages:void
0},I={"&":"&","<":"<",">":">"};return
e.highlight=l,e.highlightAuto=f,e.fixMarkup=g,e.highlightBlock=p,e.configure=d,e.initHighlighting=b,e.initHighlightingOnLoad=v,e.registerLanguage=m,e.listLanguages=N,e.getLanguage=R,e.inherit=o,e.IR="[a-zA-Z]\\w*",e.UIR="[a-zA-Z_]\\w*",e.NR="\\b\\d+(\\.\\d+)?",e.CNR="(-?)(\\b0[xX][a-fA-F0-9]+|(\\b\\d+(\\.\\d*)?|\\.\\d+)([eE][-+]?\\d+)?)",e.BNR="\\b(0b[01]+)",e.RSR="!|!=|!==|%|%=|&|&&|&=|\\*|\\*=|\\+|\\+=|,|-|-=|/=|/|:|;|<<|<<=|<=|<|===|==|=|>>>=|>>=|>=|>>>|>>|>|\\?|\\[|\\{|\\(|\\^|\\^=|\\||\\|=|\\|\\||~",e.BE={b:"\\\\[\\s\\S]",r:0},e.ASM={cN:"string",b:"'",e:"'",i:"\\n",c:[e.BE]},e.QSM={cN:"string",b:'"',e:'"',i:"\\n",c:[e.BE]},e.PWM={b:/\b(a|an|the|are|I'm|isn't|don't|doesn't|won't|but|just|should|pretty|simply|enough|gonna|going|wtf|so|such|will|you|your|like)\b/},e.C=function(n,t,r){var
a=e.inherit({cN:"comment",b:n,e:t,c:[]},r||{});return
a.c.push(e.PWM),a.c.push({cN:"doctag",b:"(?:TODO|FIXME|NOTE|BUG|XXX):",r:0}),a},e.CLCM=e.C("//","$"),e.CBCM=e.C("/\\*","\\*/"),e.HCM=e.C("#","$"),e.NM={cN:"number",b:e.NR,r:0},e.CNM={cN:"number",b:e.CNR,r:0},e.BNM={cN:"number",b:e.BNR,r:0},e.CSSNM={cN:"number",b:e.NR+"(%|em|ex|ch|rem|vw|vh|vmin|vmax|cm|mm|in|pt|pc|px|deg|grad|rad|turn|s|ms|Hz|kHz|dpi|dpcm|dppx)?",r:0},e.RM={cN:"regexp",b:/\//,e:/\/[gimuy]*/,i:/\n/,c:[e.BE,{b:/\[/,e:/\]/,r:0,c:[e.BE]}]},e.TM={cN:"title",b:e.IR,r:0},e.UTM={cN:"title",b:e.UIR,r:0},e.METHOD_GUARD={b:"\\.\\s*"+e.UIR,r:0},e});hljs.registerLanguage("erlang",function(e){var
r="[a-z'][a-zA-Z0-9_']*",c="("+r+":"+r+"|"+r+")",b={keyword:"after
and andalso|10 band begin bnot bor bsl bzr bxor case catch cond div end fun if let not of
orelse|10 query receive rem try when xor",literal:"false
true"},i=e.C("%","$"),n={cN:"number",b:"\\b(\\d+#[a-fA-F0-9]+|\\d+(\\.\\d+)?([eE][-+]?\\d+)?)",r:0},a={b:"fun\\s+"+r+"/\\d+"},d={b:c+"\\(",e:"\\)",rB:!0,r:0,c:[{b:c,r:0},{b:"\\(",e:"\\)",eW:!0,rE:!0,r:0}]},o={b:"{",e:"}",r:0},t={b:"\\b_([A-Z][A-Za-z0-9_]*)?",r:0},f={b:"[A-Z][a-zA-Z0-9_]*",r:0},l={b:"#"+e.UIR,r:0,rB:!0,c:[{b:"#"+e.UIR,r:0},{b:"{",e:"}",r:0}]},s={bK:"fun
receive if try
case",e:"end",k:b};s.c=[i,a,e.inherit(e.ASM,{cN:""}),s,d,e.QSM,n,o,t,f,l];var
u=[i,a,s,d,e.QSM,n,o,t,f,l];d.c[1].c=u,o.c=u,l.c[1].c=u;var
h={cN:"params",b:"\\(",e:"\\)",c:u};return{aliases:["erl"],k:b,i:"(</|\\*=|\\+=|-=|/\\*|\\*/|\\(\\*|\\*\\))",c:[{cN:"function",b:"^"+r+"\\s*\\(",e:"->",rB:!0,i:"\\(|#|//|/\\*|\\\\|:|;",c:[h,e.inherit(e.TM,{b:r})],starts:{e:";|\\.",k:b,c:u}},i,{b:"^-",e:"\\.",r:0,eE:!0,rB:!0,l:"-"+e.IR,k:"-module
-record -undef -export -ifdef -ifndef -author -copyright -doc -vsn -import -include
-include_lib -compile -define -else -endif -file -behaviour -behavior
-spec",c:[h]},n,e.QSM,l,t,f,o,{b:/\.$/}]}});hljs.registerLanguage("erlang-repl",function(e){return{k:{built_in:"spawn
spawn_link self",keyword:"after and andalso|10 band begin bnot bor bsl bsr bxor
case catch cond div end fun if let not of or orelse|10 query receive rem try when
xor"},c:[{cN:"meta",b:"^[0-9]+>
",r:10},e.C("%","$"),{cN:"number",b:"\\b(\\d+#[a-fA-F0-9]+|\\d+(\\.\\d+)?([eE][-+]?\\d+)?)",r:0},e.ASM,e.QSM,{b:"\\?(::)?([A-Z]\\w*(::)?)+"},{b:"->"},{b:"ok"},{b:"!"},{b:"(\\b[a-z'][a-zA-Z0-9_']*:[a-z'][a-zA-Z0-9_']*)|(\\b[a-z'][a-zA-Z0-9_']*)",r:0},{b:"[A-Z][a-zA-Z0-9_']*",r:0}]}});hljs.registerLanguage("diff",function(e){return{aliases:["patch"],c:[{cN:"meta",r:10,v:[{b:/^@@
+\-\d+,\d+ +\+\d+,\d+ +@@$/},{b:/^\*\*\* +\d+,\d+ +\*\*\*\*$/},{b:/^\-\-\- +\d+,\d+
+\-\-\-\-$/}]},{cN:"comment",v:[{b:/Index:
/,e:/$/},{b:/={3,}/,e:/$/},{b:/^\-{3}/,e:/$/},{b:/^\*{3}
/,e:/$/},{b:/^\+{3}/,e:/$/},{b:/\*{5}/,e:/\*{5}$/}]},{cN:"addition",b:"^\\+",e:"$"},{cN:"deletion",b:"^\\-",e:"$"},{cN:"addition",b:"^\\!",e:"$"}]}});hljs.registerLanguage("bash",function(e){var
t={cN:"variable",v:[{b:/\$[\w\d#@][\w\d_]*/},{b:/\$\{(.*?)}/}]},s={cN:"string",b:/"/,e:/"/,c:[e.BE,t,{cN:"variable",b:/\$\(/,e:/\)/,c:[e.BE]}]},a={cN:"string",b:/'/,e:/'/};return{aliases:["sh","zsh"],l:/-?[a-z\._]+/,k:{keyword:"if
then else elif fi for while in do done case esac function",literal:"true
false",built_in:"break cd continue eval exec exit export getopts hash pwd
readonly return shift test times trap umask unset alias bind builtin caller command
declare echo enable help let local logout mapfile printf read readarray source type
typeset ulimit unalias set shopt autoload bg bindkey bye cap chdir clone comparguments
compcall compctl compdescribe compfiles compgroups compquote comptags comptry compvalues
dirs disable disown echotc echoti emulate fc fg float functions getcap getln history
integer jobs kill limit log noglob popd print pushd pushln rehash sched setcap setopt stat
suspend ttyctl unfunction unhash unlimit unsetopt vared wait whence where which zcompile
zformat zftp zle zmodload zparseopts zprof zpty zregexparse zsocket zstyle
ztcp",_:"-ne -eq -lt -gt -f -d -e -s -l
-a"},c:[{cN:"meta",b:/^#![^\n]+sh\s*$/,r:10},{cN:"function",b:/\w[\w\d_]*\s*\(\s*\)\s*\{/,rB:!0,c:[e.inherit(e.TM,{b:/\w[\w\d_]*/})],r:0},e.HCM,s,a,t]}});
+\ No newline at end of file
+diff --git a/make/target.mk b/make/target.mk
+index 8917e1a..c06be7d 100644
+--- a/make/target.mk
++++ b/make/target.mk
+@@ -1,70 +1 @@
+-#
+-# %CopyrightBegin%
+-#
+-# Copyright Ericsson AB 1998-2011. All Rights Reserved.
+-#
+-# Licensed under the Apache License, Version 2.0 (the "License");
+-# you may not use this file except in compliance with the License.
+-# You may obtain a copy of the License at
+-#
+-#
http://www.apache.org/licenses/LICENSE-2.0
+-#
+-# Unless required by applicable law or agreed to in writing, software
+-# distributed under the License is distributed on an "AS IS" BASIS,
+-# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+-# See the License for the specific language governing permissions and
+-# limitations under the License.
+-#
+-# %CopyrightEnd%
+-
+-# Ensure that the make variable TARGET is set
+-#
+-
+-ifeq ($(OVERRIDE_TARGET),)
+-
+-ifeq ($(TARGET),)
+-
+-TARGET := $(shell $(ERL_TOP)/erts/autoconf/config.guess)
+-
+-else
+-
+-endif
+-
+-else
+-
+-ifneq ($(TARGET),)
+-
+-ifneq ($(TARGET), $(OVERRIDE_TARGET))
+-$(warning overriding $$(TARGET) = \
+- "$(TARGET)" \
+- with \
+- $$(OVERRIDE_TARGET) = \
+- "$(OVERRIDE_TARGET)")
+-else
+-endif
+-
+-override TARGET := $(OVERRIDE_TARGET)
+-
+-else
+-
+-TARGET := $(OVERRIDE_TARGET)
+-
+-endif
+-
+-endif
+-
+-ifneq ($(TARGET),)
+-ifneq ($(TARGET),win32)
+-ifneq ($(findstring vxworks,$(TARGET)),vxworks)
+-override TARGET := $(shell $(ERL_TOP)/erts/autoconf/config.sub $(TARGET))
+-else
+-endif
+-else
+-endif
+-else
+-endif
+-
+-ifeq ($(TARGET),)
+-$(error Neither TARGET nor OVERRIDE_TARGET can be determined!)
+-else
+-endif
++TARGET := target
+diff --git a/make/target/otp.mk b/make/target/otp.mk
+index 75a820f..f5bd7a9 100644
+--- a/make/target/otp.mk
++++ b/make/target/otp.mk
+@@ -34,8 +34,8 @@ include $(ERL_TOP)/make/output.mk
+ # Version
+ # ----------------------------------------------------
+
+-OTP_VERSION = 20.3.8.18
+-SYSTEM_VSN = 20
++OTP_VERSION = $(shell rpm -q erlang-erts --qf "%{VERSION}")
++SYSTEM_VSN = $(shell erl -noshell -s init stop -eval "io:format(\"~s\",
[erlang:system_info(otp_release)]).")
+
+ # ----------------------------------------------------
+ # Cross Compiling
+@@ -77,9 +77,7 @@ INSTALL_DATA = ${INSTALL} -m 644
+ CC = gcc
+ GCC = yes
+ HCC = $(CC)
+-CC32 = gcc
+-CFLAGS32 = -O2 -g -pipe -Wall -Werror=format-security -Wp,-D_FORTIFY_SOURCE=2
-fexceptions -fstack-protector-strong --param=ssp-buffer-size=4 -grecord-gcc-switches
-specs=/usr/lib/rpm/redhat/redhat-hardened-cc1 -m64 -mtune=generic
-I/home/petro/work/erlang/erts/x86_64-unknown-linux-gnu -fno-tree-copyrename
-D_GNU_SOURCE -m32
+-BASIC_CFLAGS = -Werror=undef -Werror=implicit -Werror=return-type -O2 -g -pipe -Wall
-Werror=format-security -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector-strong
--param=ssp-buffer-size=4 -grecord-gcc-switches
-specs=/usr/lib/rpm/redhat/redhat-hardened-cc1 -m64 -mtune=generic
-I/home/petro/work/erlang/erts/x86_64-unknown-linux-gnu -fno-tree-copyrename
-D_GNU_SOURCE
++BASIC_CFLAGS = -Werror=undef -Werror=implicit -Werror=return-type $(CFLAGS)
-fno-tree-copyrename -D_GNU_SOURCE
+ DEBUG_FLAGS = -g
+ LD = $(CC)
+ RANLIB = ranlib
+@@ -266,8 +264,8 @@ FOP = fop
+ XMLLINT = xmllint
+ CP = /bin/cp
+
+-DOCGEN=$(ERL_TOP)/lib/erl_docgen
+-FOP_CONFIG = $(DOCGEN)/priv/fop.xconf
++DOCGEN=$(shell erl -noshell -s init stop -eval "io:format(\"~s\",
[code:lib_dir(erl_docgen)]).")
++FOP_CONFIG = $(ERL_TOP)/make/fop.xconf
+
+ ifneq (,$(findstring $(origin SPECS_ESRC),$(DUBIOUS_ORIGINS)))
+ SPECS_ESRC = ../../src
+diff --git a/make/target/otp_ded.mk b/make/target/otp_ded.mk
+index abf68c8..6ca064a 100644
+--- a/make/target/otp_ded.mk
++++ b/make/target/otp_ded.mk
+@@ -32,19 +32,19 @@ DED_CC = gcc
+ DED_GCC = yes
+ DED_LD = gcc
+ DED_LDFLAGS = -shared -Wl,-Bsymbolic
+-DED__NOWARN_NOTHR_CFLAGS = -O2 -g -pipe -Wall -Werror=format-security
-Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector-strong --param=ssp-buffer-size=4
-grecord-gcc-switches -specs=/usr/lib/rpm/redhat/redhat-hardened-cc1 -m64 -mtune=generic
-I/home/petro/work/erlang/erts/x86_64-unknown-linux-gnu -fno-tree-copyrename
-D_GNU_SOURCE -fPIC
+-DED__NOTHR_CFLAGS = -Wall -Wstrict-prototypes -Wmissing-prototypes
-Wdeclaration-after-statement -O2 -g -pipe -Wall -Werror=format-security
-Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector-strong --param=ssp-buffer-size=4
-grecord-gcc-switches -specs=/usr/lib/rpm/redhat/redhat-hardened-cc1 -m64 -mtune=generic
-I/home/petro/work/erlang/erts/x86_64-unknown-linux-gnu -fno-tree-copyrename
-D_GNU_SOURCE -fPIC
+-DED__NOWARN_CFLAGS = -DUSE_THREADS -D_THREAD_SAFE -D_REENTRANT -DPOSIX_THREADS
-D_POSIX_THREAD_SAFE_FUNCTIONS -O2 -g -pipe -Wall -Werror=format-security
-Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector-strong --param=ssp-buffer-size=4
-grecord-gcc-switches -specs=/usr/lib/rpm/redhat/redhat-hardened-cc1 -m64 -mtune=generic
-I/home/petro/work/erlang/erts/x86_64-unknown-linux-gnu -fno-tree-copyrename
-D_GNU_SOURCE -fPIC
++DED__NOWARN_NOTHR_CFLAGS = $(CFLAGS) -fno-tree-copyrename -D_GNU_SOURCE -fPIC
++DED__NOTHR_CFLAGS = -Wall -Wstrict-prototypes -Wmissing-prototypes
-Wdeclaration-after-statement $(CFLAGS) -fno-tree-copyrename -D_GNU_SOURCE -fPIC
++DED__NOWARN_CFLAGS = -DUSE_THREADS -D_THREAD_SAFE -D_REENTRANT -DPOSIX_THREADS
-D_POSIX_THREAD_SAFE_FUNCTIONS $(CFLAGS) -fno-tree-copyrename -D_GNU_SOURCE -fPIC
+ DED_THR_DEFS = -DUSE_THREADS -D_THREAD_SAFE -D_REENTRANT -DPOSIX_THREADS
-D_POSIX_THREAD_SAFE_FUNCTIONS -D_GNU_SOURCE
+ DED_EMU_THR_DEFS = -DUSE_THREADS -D_THREAD_SAFE -D_REENTRANT -DPOSIX_THREADS
-D_POSIX_THREAD_SAFE_FUNCTIONS
+ DED_WARN_FLAGS = -Wall -Wstrict-prototypes -Wmissing-prototypes
-Wdeclaration-after-statement
+-DED_CFLAGS = -Werror=undef -Werror=implicit -Werror=return-type -Wall
-Wstrict-prototypes -Wmissing-prototypes -Wdeclaration-after-statement -DUSE_THREADS
-D_THREAD_SAFE -D_REENTRANT -DPOSIX_THREADS -D_POSIX_THREAD_SAFE_FUNCTIONS -O2 -g -pipe
-Wall -Werror=format-security -Wp,-D_FORTIFY_SOURCE=2 -fexceptions
-fstack-protector-strong --param=ssp-buffer-size=4 -grecord-gcc-switches
-specs=/usr/lib/rpm/redhat/redhat-hardened-cc1 -m64 -mtune=generic
-I/home/petro/work/erlang/erts/x86_64-unknown-linux-gnu -fno-tree-copyrename
-D_GNU_SOURCE -fPIC
+-DED_STATIC_CFLAGS = -Werror=undef -Werror=implicit -Werror=return-type -Wall
-Wstrict-prototypes -Wmissing-prototypes -Wdeclaration-after-statement -DUSE_THREADS
-D_THREAD_SAFE -D_REENTRANT -DPOSIX_THREADS -D_POSIX_THREAD_SAFE_FUNCTIONS -O2 -g -pipe
-Wall -Werror=format-security -Wp,-D_FORTIFY_SOURCE=2 -fexceptions
-fstack-protector-strong --param=ssp-buffer-size=4 -grecord-gcc-switches
-specs=/usr/lib/rpm/redhat/redhat-hardened-cc1 -m64 -mtune=generic
-I/home/petro/work/erlang/erts/x86_64-unknown-linux-gnu -fno-tree-copyrename
-D_GNU_SOURCE -DSTATIC_ERLANG_NIF -DSTATIC_ERLANG_DRIVER
+-DED_LIBS = -lutil -ldl -lm
++DED_CFLAGS = -Werror=undef -Werror=implicit -Werror=return-type -Wall
-Wstrict-prototypes -Wmissing-prototypes -Wdeclaration-after-statement -DUSE_THREADS
-D_THREAD_SAFE -D_REENTRANT -DPOSIX_THREADS -D_POSIX_THREAD_SAFE_FUNCTIONS $(CFLAGS)
-fno-tree-copyrename -D_GNU_SOURCE -fPIC
++DED_STATIC_CFLAGS = -Werror=undef -Werror=implicit -Werror=return-type -Wall
-Wstrict-prototypes -Wmissing-prototypes -Wdeclaration-after-statement -DUSE_THREADS
-D_THREAD_SAFE -D_REENTRANT -DPOSIX_THREADS -D_POSIX_THREAD_SAFE_FUNCTIONS $(CFLAGS)
-fno-tree-copyrename -D_GNU_SOURCE -DSTATIC_ERLANG_NIF -DSTATIC_ERLANG_DRIVER
++DED_LIBS = -lutil -ldl -lm
+ DED_EXT = so
+ ERLANG_OSTYPE = unix
+ PRIVDIR = ../priv
+ OBJDIR = $(PRIVDIR)/obj/$(TARGET)
+ LIBDIR = $(PRIVDIR)/lib/$(TARGET)
+-DED_SYS_INCLUDE = -I/home/petro/work/erlang/erts/emulator/beam
-I/home/petro/work/erlang/erts/include
-I/home/petro/work/erlang/erts/include/x86_64-unknown-linux-gnu
-I/home/petro/work/erlang/erts/include/internal
-I/home/petro/work/erlang/erts/include/internal/x86_64-unknown-linux-gnu
-I/home/petro/work/erlang/erts/emulator/sys/unix
-I/home/petro/work/erlang/erts/emulator/sys/common
++DED_SYS_INCLUDE =
+ DED_INCLUDES = $(DED_SYS_INCLUDE)
diff --git a/erlang-corba-0003-Do-not-install-C-sources.patch
b/erlang-corba-0003-Do-not-install-C-sources.patch
new file mode 100644
index 0000000..d4340d9
--- /dev/null
+++ b/erlang-corba-0003-Do-not-install-C-sources.patch
@@ -0,0 +1,30 @@
+From: Peter Lemenkov <lemenkov(a)gmail.com>
+Date: Fri, 18 Jun 2010 23:41:33 +0400
+Subject: [PATCH] Do not install C sources
+
+Don't install *.c and *.o files.
+
+Excepts ones from the internal erl_interface. These
+API headers are necessary. See rhbz #818419 for the
+explanation why they're necessary for the low-level
+interaction with the Erlang nodes:
+
+https://bugzilla.redhat.com/818419
+
+Signed-off-by: Peter Lemenkov <lemenkov(a)gmail.com>
+
+diff --git a/lib/ic/c_src/Makefile b/lib/ic/c_src/Makefile
+index af48c04..7b2f67f 100644
+--- a/lib/ic/c_src/Makefile
++++ b/lib/ic/c_src/Makefile
+@@ -155,10 +155,8 @@ $(OBJDIR)/%.o: %.c
+ include $(ERL_TOP)/make/otp_release_targets.mk
+
+ release_spec: opt
+- $(INSTALL_DIR) "$(RELSYSDIR)/c_src"
+ $(INSTALL_DIR) "$(RELSYSDIR)/include"
+ $(INSTALL_DIR) "$(RELSYSDIR)/priv/lib"
+- $(INSTALL_DATA) ic.c ic_tmo.c "$(RELSYSDIR)/c_src"
+ $(INSTALL_DATA) $(IDL_FILES) $(H_FILES) "$(RELSYSDIR)/include"
+ $(INSTALL_DATA) $(LIBRARY) "$(RELSYSDIR)/priv/lib"
+ $(INSTALL_DIR) "$(RELEASE_PATH)/usr/include"
diff --git a/erlang-corba-0004-Do-not-install-Java-sources.patch
b/erlang-corba-0004-Do-not-install-Java-sources.patch
new file mode 100644
index 0000000..aa98e32
--- /dev/null
+++ b/erlang-corba-0004-Do-not-install-Java-sources.patch
@@ -0,0 +1,19 @@
+From: Peter Lemenkov <lemenkov(a)gmail.com>
+Date: Sat, 19 Jun 2010 09:25:18 +0400
+Subject: [PATCH] Do not install Java sources
+
+Signed-off-by: Peter Lemenkov <lemenkov(a)gmail.com>
+
+diff --git a/lib/ic/java_src/com/ericsson/otp/ic/Makefile
b/lib/ic/java_src/com/ericsson/otp/ic/Makefile
+index cf11d51..f228553 100644
+--- a/lib/ic/java_src/com/ericsson/otp/ic/Makefile
++++ b/lib/ic/java_src/com/ericsson/otp/ic/Makefile
+@@ -115,8 +115,6 @@ docs:
+ include $(ERL_TOP)/make/otp_release_targets.mk
+
+ release_spec: opt
+- $(INSTALL_DIR) "$(RELSYSDIR)/java_src/com/ericsson/otp/ic"
+- $(INSTALL_DATA) $(JAVA_FILES) "$(RELSYSDIR)/java_src/com/ericsson/otp/ic"
+ $(INSTALL_DIR) "$(RELSYSDIR)/priv"
+ $(INSTALL_DATA) $(JAVA_DEST_ROOT)$(JARFILE) "$(RELSYSDIR)/priv"
+
diff --git a/erlang-corba-0005-Do-not-install-erlang-sources.patch
b/erlang-corba-0005-Do-not-install-erlang-sources.patch
new file mode 100644
index 0000000..4a3f366
--- /dev/null
+++ b/erlang-corba-0005-Do-not-install-erlang-sources.patch
@@ -0,0 +1,146 @@
+From: Hans Ulrich Niedermann <hun(a)n-dimensional.de>
+Date: Mon, 21 Mar 2011 15:41:49 +0100
+Subject: [PATCH] Do not install erlang sources
+
+Don't install *.erl, *.xrl, *.yrl, and *.asn1 files at all.
+
+Signed-off-by: Peter Lemenkov <lemenkov(a)gmail.com>
+Signed-off-by: Hans Ulrich Niedermann <hun(a)n-dimensional.de>
+
+diff --git a/lib/cosEvent/src/Makefile b/lib/cosEvent/src/Makefile
+index 7eb0791..35e63c6 100644
+--- a/lib/cosEvent/src/Makefile
++++ b/lib/cosEvent/src/Makefile
+@@ -204,7 +204,7 @@ release_spec: opt
+ $(INSTALL_DIR) "$(RELSYSDIR)/ebin"
+ $(INSTALL_DATA) $(TARGET_FILES) $(APP_TARGET) $(APPUP_TARGET)
"$(RELSYSDIR)/ebin"
+ $(INSTALL_DIR) "$(RELSYSDIR)/src"
+- $(INSTALL_DATA) $(ERL_FILES) $(HRL_FILES) $(GEN_ERL_FILES) $(IDL_FILES)
"$(RELSYSDIR)/src"
++ $(INSTALL_DATA) $(HRL_FILES) $(IDL_FILES) "$(RELSYSDIR)/src"
+ $(INSTALL_DIR) "$(RELSYSDIR)/include"
+ $(INSTALL_DATA) $(GEN_HRL_FILES) "$(RELSYSDIR)/include"
+
+diff --git a/lib/cosEventDomain/src/Makefile b/lib/cosEventDomain/src/Makefile
+index 62a2a47..4f2cabd 100644
+--- a/lib/cosEventDomain/src/Makefile
++++ b/lib/cosEventDomain/src/Makefile
+@@ -173,7 +173,7 @@ release_spec: opt
+ $(INSTALL_DIR) "$(RELSYSDIR)/ebin"
+ $(INSTALL_DATA) $(TARGET_FILES) $(APP_TARGET) $(APPUP_TARGET)
"$(RELSYSDIR)/ebin"
+ $(INSTALL_DIR) "$(RELSYSDIR)/src"
+- $(INSTALL_DATA) $(ERL_FILES) $(HRL_FILES) $(GEN_ERL_FILES) $(IDL_FILES)
"$(RELSYSDIR)/src"
++ $(INSTALL_DATA) $(HRL_FILES) $(IDL_FILES) "$(RELSYSDIR)/src"
+ $(INSTALL_DIR) "$(RELSYSDIR)/include"
+ $(INSTALL_DATA) $(EXTERNAL_GEN_HRL_FILES) "$(RELSYSDIR)/include"
+
+diff --git a/lib/cosFileTransfer/src/Makefile b/lib/cosFileTransfer/src/Makefile
+index 35f2996..e27eb60 100644
+--- a/lib/cosFileTransfer/src/Makefile
++++ b/lib/cosFileTransfer/src/Makefile
+@@ -182,9 +182,7 @@ release_spec: opt
+ $(INSTALL_DIR) "$(RELSYSDIR)/ebin"
+ $(INSTALL_DATA) $(TARGET_FILES) $(APP_TARGET) $(APPUP_TARGET)
"$(RELSYSDIR)/ebin"
+ $(INSTALL_DIR) "$(RELSYSDIR)/src"
+- $(INSTALL_DATA) $(GEN_FILES) $(IDL_FILES) "$(RELSYSDIR)/src"
+- $(INSTALL_DATA) $(ERL_FILES) $(HRL_FILES) $(GEN_ERL_FILES) $(IDL_FILES)
"$(RELSYSDIR)/src"
++ $(INSTALL_DATA) $(HRL_FILES) $(GEN_HRL_FILES) $(IDL_FILES)
"$(RELSYSDIR)/src"
+ $(INSTALL_DIR) "$(RELSYSDIR)/include"
+- $(INSTALL_DATA) $(GEN_HRL_FILES) "$(RELSYSDIR)/include"
+
+ release_docs_spec:
+diff --git a/lib/cosNotification/src/Makefile b/lib/cosNotification/src/Makefile
+index 4064ec5..6ad9a2b 100644
+--- a/lib/cosNotification/src/Makefile
++++ b/lib/cosNotification/src/Makefile
+@@ -373,8 +373,7 @@ release_spec: opt
+ $(INSTALL_DIR) "$(RELSYSDIR)/ebin"
+ $(INSTALL_DATA) $(TARGET_FILES) $(APP_TARGET) $(APPUP_TARGET)
"$(RELSYSDIR)/ebin"
+ $(INSTALL_DIR) "$(RELSYSDIR)/src"
+- $(INSTALL_DATA) $(GEN_FILES) $(IDL_FILES) $(YECC_FILES) "$(RELSYSDIR)/src"
+- $(INSTALL_DATA) $(ERL_FILES) $(HRL_FILES) $(IDL_FILES) $(YECC_FILES)
"$(RELSYSDIR)/src"
++ $(INSTALL_DATA) $(GEN_HRL_FILES) $(HRL_FILES) $(IDL_FILES)
"$(RELSYSDIR)/src"
+ $(INSTALL_DIR) "$(RELSYSDIR)/include"
+ $(INSTALL_DATA) $(GEN_HRL_FILES) "$(RELSYSDIR)/include"
+
+diff --git a/lib/cosProperty/src/Makefile b/lib/cosProperty/src/Makefile
+index 0eb7ac5..b7f49f7 100644
+--- a/lib/cosProperty/src/Makefile
++++ b/lib/cosProperty/src/Makefile
+@@ -182,8 +182,7 @@ release_spec: opt
+ $(INSTALL_DIR) "$(RELSYSDIR)/ebin"
+ $(INSTALL_DATA) $(TARGET_FILES) $(APP_TARGET) $(APPUP_TARGET)
"$(RELSYSDIR)/ebin"
+ $(INSTALL_DIR) "$(RELSYSDIR)/src"
+- $(INSTALL_DATA) $(GEN_FILES) $(IDL_FILES) "$(RELSYSDIR)/src"
+- $(INSTALL_DATA) $(ERL_FILES) $(HRL_FILES) $(GEN_ERL_FILES) $(IDL_FILES)
"$(RELSYSDIR)/src"
++ $(INSTALL_DATA) $(GEN_HRL_FILES) $(HRL_FILES) $(IDL_FILES)
"$(RELSYSDIR)/src"
+ $(INSTALL_DIR) "$(RELSYSDIR)/include"
+ $(INSTALL_DATA) $(GEN_HRL_FILES) "$(RELSYSDIR)/include"
+
+diff --git a/lib/cosTime/src/Makefile b/lib/cosTime/src/Makefile
+index 1f55e5d..64453f0 100644
+--- a/lib/cosTime/src/Makefile
++++ b/lib/cosTime/src/Makefile
+@@ -201,8 +201,7 @@ release_spec: opt
+ $(INSTALL_DIR) "$(RELSYSDIR)/ebin"
+ $(INSTALL_DATA) $(TARGET_FILES) $(APP_TARGET) $(APPUP_TARGET)
"$(RELSYSDIR)/ebin"
+ $(INSTALL_DIR) "$(RELSYSDIR)/src"
+- $(INSTALL_DATA) $(GEN_FILES) $(IDL_FILES) "$(RELSYSDIR)/src"
+- $(INSTALL_DATA) $(ERL_FILES) $(HRL_FILES) $(GEN_ERL_FILES) $(IDL_FILES)
"$(RELSYSDIR)/src"
++ $(INSTALL_DATA) $(GEN_HRL_FILES) $(HRL_FILES) $(IDL_FILES)
"$(RELSYSDIR)/src"
+ $(INSTALL_DIR) "$(RELSYSDIR)/include"
+ $(INSTALL_DATA) $(GEN_HRL_FILES) "$(RELSYSDIR)/include"
+
+diff --git a/lib/cosTransactions/src/Makefile b/lib/cosTransactions/src/Makefile
+index 9f33b4f..93af63a 100644
+--- a/lib/cosTransactions/src/Makefile
++++ b/lib/cosTransactions/src/Makefile
+@@ -176,7 +176,7 @@ release_spec: opt
+ $(INSTALL_DIR) "$(RELSYSDIR)/ebin"
+ $(INSTALL_DATA) $(TARGET_FILES) $(APP_TARGET) $(APPUP_TARGET)
"$(RELSYSDIR)/ebin"
+ $(INSTALL_DIR) "$(RELSYSDIR)/src"
+- $(INSTALL_DATA) $(ERL_FILES) $(HRL_FILES) $(GEN_ERL_FILES) $(IDL_FILE)
"$(RELSYSDIR)/src"
++ $(INSTALL_DATA) $(HRL_FILES) $(IDL_FILE) "$(RELSYSDIR)/src"
+ $(INSTALL_DIR) "$(RELSYSDIR)/include"
+ $(INSTALL_DATA) $(EXTERNAL_GEN_HRL_FILES) "$(RELSYSDIR)/include"
+
+diff --git a/lib/ic/src/Makefile b/lib/ic/src/Makefile
+index 5f854b4..618330a 100644
+--- a/lib/ic/src/Makefile
++++ b/lib/ic/src/Makefile
+@@ -201,7 +201,7 @@ release_spec: opt
+ $(INSTALL_DIR) "$(RELSYSDIR)/ebin"
+ $(INSTALL_DATA) $(TARGET_FILES) $(APP_TARGET) "$(RELSYSDIR)/ebin"
+ $(INSTALL_DIR) "$(RELSYSDIR)/src"
+- $(INSTALL_DATA) $(ERL_FILES) $(YRL_FILE) $(INTERNAL_HRL_FILES)
"$(RELSYSDIR)/src"
++ $(INSTALL_DATA) $(INTERNAL_HRL_FILES) "$(RELSYSDIR)/src"
+ $(INSTALL_DIR) "$(RELSYSDIR)/examples"
+ $(INSTALL_DIR) "$(RELSYSDIR)/examples/c-client"
+ $(INSTALL_DATA) $(CCL_EX_FILES) "$(RELSYSDIR)/examples/c-client"
+diff --git a/lib/orber/COSS/CosNaming/Makefile b/lib/orber/COSS/CosNaming/Makefile
+index dfb05b2..0aec357 100644
+--- a/lib/orber/COSS/CosNaming/Makefile
++++ b/lib/orber/COSS/CosNaming/Makefile
+@@ -146,8 +146,8 @@ release_spec: opt
+ $(INSTALL_DIR) "$(RELSYSDIR)/ebin"
+ $(INSTALL_DATA) $(TARGET_FILES) $(APP_TARGET) "$(RELSYSDIR)/ebin"
+ $(INSTALL_DIR) "$(RELSYSDIR)/COSS/CosNaming"
+- $(INSTALL_DATA) $(ERL_FILES) $(HRL_FILES) $(IDL_FILE)
"$(RELSYSDIR)/COSS/CosNaming"
+- $(INSTALL_DATA) $(GEN_FILES) "$(RELSYSDIR)/COSS/CosNaming"
++ $(INSTALL_DATA) $(HRL_FILES) $(IDL_FILE) "$(RELSYSDIR)/COSS/CosNaming"
++ $(INSTALL_DATA) $(GEN_HRL_FILES) $(GEN_EXT_HRL_FILES)
"$(RELSYSDIR)/COSS/CosNaming"
+
+
+ release_docs_spec:
+diff --git a/lib/orber/src/Makefile b/lib/orber/src/Makefile
+index 958b6a5..c77881c 100644
+--- a/lib/orber/src/Makefile
++++ b/lib/orber/src/Makefile
+@@ -245,7 +245,7 @@ release_spec: opt
+ $(INSTALL_DIR) "$(RELSYSDIR)/ebin"
+ $(INSTALL_DATA) $(TARGET_FILES) $(APP_TARGET) $(APPUP_TARGET)
"$(RELSYSDIR)/ebin"
+ $(INSTALL_DIR) "$(RELSYSDIR)/src"
+- $(INSTALL_DATA) $(ERL_FILES) $(YRL_FILE) $(GEN_HRL_FILES_LOC) $(INTERNAL_HRL_FILES)
"$(RELSYSDIR)/src"
++ $(INSTALL_DATA) $(GEN_HRL_FILES_LOC) $(INTERNAL_HRL_FILES)
"$(RELSYSDIR)/src"
+ $(INSTALL_DIR) "$(RELSYSDIR)/include"
+ $(INSTALL_DATA) $(EXTERNAL_HRL_FILES) $(GEN_HRL_FILES_EXT)
"$(RELSYSDIR)/include"
+
diff --git a/erlang-corba-0006-Do-not-install-examples.patch
b/erlang-corba-0006-Do-not-install-examples.patch
new file mode 100644
index 0000000..cd637e4
--- /dev/null
+++ b/erlang-corba-0006-Do-not-install-examples.patch
@@ -0,0 +1,82 @@
+From: Peter Lemenkov <lemenkov(a)gmail.com>
+Date: Wed, 30 Jan 2019 13:01:08 +0300
+Subject: [PATCH] Do not install examples
+
+Signed-off-by: Peter Lemenkov <lemenkov(a)gmail.com>
+
+diff --git a/lib/ic/Makefile b/lib/ic/Makefile
+index 185b3a6..1b0fe61 100644
+--- a/lib/ic/Makefile
++++ b/lib/ic/Makefile
+@@ -33,7 +33,7 @@ VSN=$(CORBA_VSN)
+ # Common Macros
+ # ----------------------------------------------------
+
+-SUB_DIRECTORIES = src c_src java_src doc/src examples/pre_post_condition
++SUB_DIRECTORIES = src c_src java_src doc/src
+
+ SPECIAL_TARGETS =
+
+diff --git a/lib/ic/examples/pre_post_condition/Makefile
b/lib/ic/examples/pre_post_condition/Makefile
+index 25ce049..d86a5fe 100644
+--- a/lib/ic/examples/pre_post_condition/Makefile
++++ b/lib/ic/examples/pre_post_condition/Makefile
+@@ -126,8 +126,6 @@ include $(ERL_TOP)/make/otp_release_targets.mk
+
+
+ release_spec: opt
+- $(INSTALL_DIR) "$(RELSYSDIR)/examples/pre_post_condition"
+- $(INSTALL_DATA) $(ERL_FILES) $(IDL_FILES) $(TXT_FILES)
"$(RELSYSDIR)/examples/pre_post_condition"
+
+
+ release_docs_spec:
+diff --git a/lib/ic/src/Makefile b/lib/ic/src/Makefile
+index 618330a..490783d 100644
+--- a/lib/ic/src/Makefile
++++ b/lib/ic/src/Makefile
+@@ -202,19 +202,6 @@ release_spec: opt
+ $(INSTALL_DATA) $(TARGET_FILES) $(APP_TARGET) "$(RELSYSDIR)/ebin"
+ $(INSTALL_DIR) "$(RELSYSDIR)/src"
+ $(INSTALL_DATA) $(INTERNAL_HRL_FILES) "$(RELSYSDIR)/src"
+- $(INSTALL_DIR) "$(RELSYSDIR)/examples"
+- $(INSTALL_DIR) "$(RELSYSDIR)/examples/c-client"
+- $(INSTALL_DATA) $(CCL_EX_FILES) "$(RELSYSDIR)/examples/c-client"
+- $(INSTALL_DIR) "$(RELSYSDIR)/examples/c-server"
+- $(INSTALL_DATA) $(CSRV_EX_FILES) "$(RELSYSDIR)/examples/c-server"
+- $(INSTALL_DIR) "$(RELSYSDIR)/examples/erl-plain"
+- $(INSTALL_DATA) $(EPL_EX_FILES) "$(RELSYSDIR)/examples/erl-plain"
+- $(INSTALL_DIR) "$(RELSYSDIR)/examples/erl-genserv"
+- $(INSTALL_DATA) $(ESRV_EX_FILES) "$(RELSYSDIR)/examples/erl-genserv"
+- $(INSTALL_DIR) "$(RELSYSDIR)/examples/java-client-server"
+- $(INSTALL_DATA) $(JAVA_EX_FILES) "$(RELSYSDIR)/examples/java-client-server"
+- $(INSTALL_DIR) "$(RELSYSDIR)/examples/all-against-all"
+- $(INSTALL_DATA) $(MIXED_EX_FILES) "$(RELSYSDIR)/examples/all-against-all"
+
+ release_docs_spec:
+
+diff --git a/lib/orber/Makefile b/lib/orber/Makefile
+index f2911e6..b84991a 100644
+--- a/lib/orber/Makefile
++++ b/lib/orber/Makefile
+@@ -33,7 +33,7 @@ VSN=$(CORBA_VSN)
+ # Common Macros
+ # ----------------------------------------------------
+
+-SUB_DIRECTORIES = COSS/CosNaming src examples doc/src priv
++SUB_DIRECTORIES = COSS/CosNaming src doc/src priv
+
+ SPECIAL_TARGETS =
+
+diff --git a/lib/orber/examples/Stack/Makefile b/lib/orber/examples/Stack/Makefile
+index 8671db4..b55ed48 100644
+--- a/lib/orber/examples/Stack/Makefile
++++ b/lib/orber/examples/Stack/Makefile
+@@ -121,8 +121,6 @@ include $(ERL_TOP)/make/otp_release_targets.mk
+
+
+ release_spec: opt
+- $(INSTALL_DIR) "$(RELSYSDIR)/examples/Stack"
+- $(INSTALL_DATA) $(ERL_FILES) $(JAVA_FILES) $(CPP_FILES) $(IDL_FILES)
"$(RELSYSDIR)/examples/Stack"
+
+
+ release_docs_spec:
diff --git a/erlang-corba.spec b/erlang-corba.spec
new file mode 100644
index 0000000..8fd936e
--- /dev/null
+++ b/erlang-corba.spec
@@ -0,0 +1,382 @@
+%global realname corba
+%global upstream erlang
+# Technically, we're almost noarch (ic has some binary-specific files); but
+# erlang whose directories we install into is not.
+%global debug_package %{nil}
+
+
+%ifarch %{arm} %{mips} riscv64
+# MIPS does not have all dependencies for fop yet
+# For some reason, fop hangs on arm, so for now don't generate docs by
+# default
+%bcond_with doc
+%else
+%bcond_without doc
+%endif
+
+
+Name: erlang-%{realname}
+Version: 4.5.2
+Epoch: 1
+Release: 1%{?dist}
+Summary: Erlang CORBA libraries
+License: ASL 2.0
+URL:
https://github.com/%{upstream}/%{realname}
+VCS:
scm:git:https://github.com/%{upstream}/%{realname}.git
+Source0:
https://github.com/%{upstream}/%{realname}/archive/%{version}/%{realname}...
+Patch1: erlang-corba-0001-Add-files-from-OTP-tree.patch
+Patch2: erlang-corba-0002-Edit-OTP-files-to-allow-out-of-tree-build.patch
+Patch3: erlang-corba-0003-Do-not-install-C-sources.patch
+Patch4: erlang-corba-0004-Do-not-install-Java-sources.patch
+Patch5: erlang-corba-0005-Do-not-install-erlang-sources.patch
+Patch6: erlang-corba-0006-Do-not-install-examples.patch
+BuildRequires: erlang-erl_docgen
+BuildRequires: erlang-erl_interface
+BuildRequires: erlang-erts
+BuildRequires: erlang-jinterface
+BuildRequires: erlang-parsetools
+BuildRequires: erlang-rpm-macros
+BuildRequires: gcc
+BuildRequires: java-devel
+%if %{with doc}
+BuildRequires: fop
+BuildRequires: libxslt
+%endif
+# FIXME no autodetect yet
+BuildRequires: erlang-cosEvent
+BuildRequires: erlang-cosNotification
+BuildRequires: erlang-cosProperty
+BuildRequires: erlang-cosTime
+BuildRequires: erlang-orber
+
+
+%description
+A set of Erlang applications, that implements a CORBA compliant Object Request
+Broker (ORB) and a number of Object Managemnt Group (OMG) standard services.
+
+%if %{with doc}
+%package doc
+Summary: Erlang CORBA documentation
+BuildArch: noarch
+
+%description doc
+Documentation for Erlang.
+%endif
+
+%package -n erlang-cosEvent
+Summary: Orber OMG Event Service
+Requires: erlang-orber%{?_isa}
+
+%description -n erlang-cosEvent
+Orber OMG Event Service.
+
+%package -n erlang-cosEventDomain
+Summary: Orber OMG Event Domain Service
+Requires: erlang-cosNotification%{?_isa}
+Requires: erlang-orber%{?_isa}
+
+%description -n erlang-cosEventDomain
+Orber OMG Event Domain Service.
+
+%package -n erlang-cosFileTransfer
+Summary: Orber OMG File Transfer Service
+Requires: erlang-cosProperty%{?_isa}
+Requires: erlang-orber%{?_isa}
+
+%description -n erlang-cosFileTransfer
+Orber OMG File Transfer Service.
+
+%package -n erlang-cosNotification
+Summary: Orber OMG Notification Service
+Requires: erlang-cosEvent%{?_isa}
+Requires: erlang-cosTime%{?_isa}
+Requires: erlang-orber%{?_isa}
+
+%description -n erlang-cosNotification
+Orber OMG Notification Service.
+
+%package -n erlang-cosProperty
+Summary: Orber OMG Property Service
+Requires: erlang-orber%{?_isa}
+
+%description -n erlang-cosProperty
+Orber OMG Property Service.
+
+%package -n erlang-cosTime
+Summary: Orber OMG Timer and TimerEvent Service
+Requires: erlang-cosEvent%{?_isa}
+Requires: erlang-orber%{?_isa}
+
+%description -n erlang-cosTime
+Orber OMG Timer and TimerEvent Service.
+
+%package -n erlang-cosTransactions
+Summary: Orber OMG Transaction Service
+Requires: erlang-orber%{?_isa}
+
+%description -n erlang-cosTransactions
+Orber OMG Transaction Service.
+
+%package -n erlang-ic
+Summary: IDL compiler
+Requires: erlang-jinterface
+Requires: javapackages-tools
+
+%description -n erlang-ic
+IDL compiler.
+
+%package -n erlang-orber
+Summary: A CORBA Object Request Broker
+
+%description -n erlang-orber
+A CORBA Object Request Broker.
+
+
+%prep
+%autosetup -p1 -n %{realname}-%{version}
+
+
+%build
+CFLAGS="$RPM_OPT_FLAGS" ERL_TOP=`pwd` make %{?_smp_mflags} V=1
+%if %{with doc}
+CFLAGS="$RPM_OPT_FLAGS" ERL_TOP=`pwd` make docs V=1
+%endif
+
+
+%install
+ERL_TOP=`pwd` make install DESTDIR=%{buildroot}%{_erldir}
+%if %{with doc}
+ERL_TOP=`pwd` make install-docs DESTDIR=%{buildroot}%{_erldir}
+%endif
+
+# erlang-ic
+install -m 0755 -d "%{buildroot}%{_javadir}/erlang"
+ic_lib_dir="$(ls -d1 %{buildroot}%{_libdir}/erlang/lib/ic-*/ | sed
"s,^%{buildroot},,")"
+test -d "%{buildroot}$ic_lib_dir"
+ln -s "${ic_lib_dir}priv/ic.jar" "%{buildroot}%{_javadir}/erlang/"
+
+%if %{with doc}
+# Move man-pages to a system-wide directory - in the same way as Debian did
+# Erlang files from man 3 have too generic names
+for manpage in %{buildroot}%{_libdir}/erlang/man/man3/*
+do
+ mv ${manpage} ${manpage}erl
+done
+mkdir -p %{buildroot}%{_mandir}/
+mv %{buildroot}%{_libdir}/erlang/man/* %{buildroot}%{_mandir}/
+%endif
+
+# Relocate doc-files into the proper directory
+%if %{with doc}
+mkdir -p %{buildroot}%{_docdir}/%{name}-%{version}/lib
+pushd .
+cd %{buildroot}%{_libdir}/erlang
+mv -v doc %{buildroot}%{_docdir}/%{name}-%{version}
+cd %{buildroot}%{_libdir}/erlang/lib
+for i in * ; do mv -v $i/doc %{buildroot}%{_docdir}/%{name}-%{version}/lib/$i || true ;
done
+popd
+for i in ic orber ; do mv -v lib/$i/examples
%{buildroot}%{_docdir}/%{name}-%{version}/lib/$i-%{version}/examples || true ; done
+cp -av AUTHORS CONTRIBUTING.md README.md %{buildroot}%{_docdir}/%{name}-%{version}
+# We'll package it by marking it explicitly as doc - see below
+rm -f %{buildroot}%{_libdir}/erlang/README.md %{buildroot}%{_libdir}/erlang/COPYRIGHT
+%endif
+
+# Do not install info files - they are almost empty and useless
+find %{buildroot}%{_libdir}/erlang -type f -name info -exec rm -f {} \;
+
+
+%if %{with doc}
+%files doc
+%dir %{_docdir}/%{name}-%{version}/
+%doc %{_docdir}/%{name}-%{version}/AUTHORS
+%doc %{_docdir}/%{name}-%{version}/CONTRIBUTING.md
+%doc %{_docdir}/%{name}-%{version}/README.md
+%doc %{_docdir}/%{name}-%{version}/doc
+%doc %{_docdir}/%{name}-%{version}/lib/
+%license COPYRIGHT
+%license LICENSE.txt
+%endif
+
+%files -n erlang-cosEvent
+%license COPYRIGHT
+%license LICENSE.txt
+%{_libdir}/erlang/lib/cosEvent-*/
+%if %{with doc}
+%{_mandir}/man3/cosEventApp.*
+%{_mandir}/man3/CosEventChannelAdmin.*
+%{_mandir}/man3/CosEventChannelAdmin_ConsumerAdmin.*
+%{_mandir}/man3/CosEventChannelAdmin_EventChannel.*
+%{_mandir}/man3/CosEventChannelAdmin_ProxyPullConsumer.*
+%{_mandir}/man3/CosEventChannelAdmin_ProxyPullSupplier.*
+%{_mandir}/man3/CosEventChannelAdmin_ProxyPushConsumer.*
+%{_mandir}/man3/CosEventChannelAdmin_ProxyPushSupplier.*
+%{_mandir}/man3/CosEventChannelAdmin_SupplierAdmin.*
+%endif
+
+%files -n erlang-cosEventDomain
+%license COPYRIGHT
+%license LICENSE.txt
+%{_libdir}/erlang/lib/cosEventDomain-*/
+%if %{with doc}
+%{_mandir}/man3/CosEventDomainAdmin.*
+%{_mandir}/man3/CosEventDomainAdmin_EventDomain.*
+%{_mandir}/man3/CosEventDomainAdmin_EventDomainFactory.*
+%{_mandir}/man3/cosEventDomainApp.*
+%endif
+
+%files -n erlang-cosFileTransfer
+%license COPYRIGHT
+%license LICENSE.txt
+%dir %{_libdir}/erlang/lib/cosFileTransfer-*/
+%{_libdir}/erlang/lib/cosFileTransfer-*/ebin
+%{_libdir}/erlang/lib/cosFileTransfer-*/include
+%{_libdir}/erlang/lib/cosFileTransfer-*/src
+%if %{with doc}
+%{_mandir}/man3/cosFileTransferApp.*
+%{_mandir}/man3/CosFileTransfer_Directory.*
+%{_mandir}/man3/CosFileTransfer_File.*
+%{_mandir}/man3/CosFileTransfer_FileIterator.*
+%{_mandir}/man3/CosFileTransfer_FileTransferSession.*
+%{_mandir}/man3/CosFileTransfer_VirtualFileSystem.*
+%endif
+
+%files -n erlang-cosNotification
+%license COPYRIGHT
+%license LICENSE.txt
+%dir %{_libdir}/erlang/lib/cosNotification-*/
+%{_libdir}/erlang/lib/cosNotification-*/ebin
+%{_libdir}/erlang/lib/cosNotification-*/include
+%{_libdir}/erlang/lib/cosNotification-*/src
+%if %{with doc}
+%{_mandir}/man3/CosNotification.*
+%{_mandir}/man3/CosNotification_AdminPropertiesAdmin.*
+%{_mandir}/man3/cosNotificationApp.*
+%{_mandir}/man3/CosNotification_QoSAdmin.*
+%{_mandir}/man3/CosNotifyChannelAdmin_ConsumerAdmin.*
+%{_mandir}/man3/CosNotifyChannelAdmin_EventChannel.*
+%{_mandir}/man3/CosNotifyChannelAdmin_EventChannelFactory.*
+%{_mandir}/man3/CosNotifyChannelAdmin_ProxyConsumer.*
+%{_mandir}/man3/CosNotifyChannelAdmin_ProxyPullConsumer.*
+%{_mandir}/man3/CosNotifyChannelAdmin_ProxyPullSupplier.*
+%{_mandir}/man3/CosNotifyChannelAdmin_ProxyPushConsumer.*
+%{_mandir}/man3/CosNotifyChannelAdmin_ProxyPushSupplier.*
+%{_mandir}/man3/CosNotifyChannelAdmin_ProxySupplier.*
+%{_mandir}/man3/CosNotifyChannelAdmin_SequenceProxyPullConsumer.*
+%{_mandir}/man3/CosNotifyChannelAdmin_SequenceProxyPullSupplier.*
+%{_mandir}/man3/CosNotifyChannelAdmin_SequenceProxyPushConsumer.*
+%{_mandir}/man3/CosNotifyChannelAdmin_SequenceProxyPushSupplier.*
+%{_mandir}/man3/CosNotifyChannelAdmin_StructuredProxyPullConsumer.*
+%{_mandir}/man3/CosNotifyChannelAdmin_StructuredProxyPullSupplier.*
+%{_mandir}/man3/CosNotifyChannelAdmin_StructuredProxyPushConsumer.*
+%{_mandir}/man3/CosNotifyChannelAdmin_StructuredProxyPushSupplier.*
+%{_mandir}/man3/CosNotifyChannelAdmin_SupplierAdmin.*
+%{_mandir}/man3/CosNotifyComm_NotifyPublish.*
+%{_mandir}/man3/CosNotifyComm_NotifySubscribe.*
+%{_mandir}/man3/CosNotifyFilter_Filter.*
+%{_mandir}/man3/CosNotifyFilter_FilterAdmin.*
+%{_mandir}/man3/CosNotifyFilter_FilterFactory.*
+%{_mandir}/man3/CosNotifyFilter_MappingFilter.*
+%endif
+
+%files -n erlang-cosProperty
+%license COPYRIGHT
+%license LICENSE.txt
+%dir %{_libdir}/erlang/lib/cosProperty-*/
+%{_libdir}/erlang/lib/cosProperty-*/ebin
+%{_libdir}/erlang/lib/cosProperty-*/include
+%{_libdir}/erlang/lib/cosProperty-*/src
+%if %{with doc}
+%{_mandir}/man3/cosProperty.*
+%{_mandir}/man3/CosPropertyService_PropertiesIterator.*
+%{_mandir}/man3/CosPropertyService_PropertyNamesIterator.*
+%{_mandir}/man3/CosPropertyService_PropertySet.*
+%{_mandir}/man3/CosPropertyService_PropertySetDef.*
+%{_mandir}/man3/CosPropertyService_PropertySetDefFactory.*
+%{_mandir}/man3/CosPropertyService_PropertySetFactory.*
+%endif
+
+%files -n erlang-cosTime
+%license COPYRIGHT
+%license LICENSE.txt
+%dir %{_libdir}/erlang/lib/cosTime-*/
+%{_libdir}/erlang/lib/cosTime-*/ebin
+%{_libdir}/erlang/lib/cosTime-*/include
+%{_libdir}/erlang/lib/cosTime-*/src
+%if %{with doc}
+%{_mandir}/man3/cosTime.*
+%{_mandir}/man3/CosTimerEvent_TimerEventHandler.*
+%{_mandir}/man3/CosTimerEvent_TimerEventService.*
+%{_mandir}/man3/CosTime_TimeService.*
+%{_mandir}/man3/CosTime_TIO.*
+%{_mandir}/man3/CosTime_UTO.*
+%endif
+
+%files -n erlang-cosTransactions
+%license COPYRIGHT
+%license LICENSE.txt
+%dir %{_libdir}/erlang/lib/cosTransactions-*/
+%{_libdir}/erlang/lib/cosTransactions-*/ebin
+%{_libdir}/erlang/lib/cosTransactions-*/include
+%{_libdir}/erlang/lib/cosTransactions-*/src
+%if %{with doc}
+%{_mandir}/man3/cosTransactions.*
+%{_mandir}/man3/CosTransactions_Control.*
+%{_mandir}/man3/CosTransactions_Coordinator.*
+%{_mandir}/man3/CosTransactions_RecoveryCoordinator.*
+%{_mandir}/man3/CosTransactions_Resource.*
+%{_mandir}/man3/CosTransactions_SubtransactionAwareResource.*
+%{_mandir}/man3/CosTransactions_Terminator.*
+%{_mandir}/man3/CosTransactions_TransactionFactory.*
+%endif
+
+%files -n erlang-ic
+%license COPYRIGHT
+%license LICENSE.txt
+%dir %{_libdir}/erlang/lib/ic-*/
+%{_javadir}/erlang/ic.jar
+%{_libdir}/erlang/lib/ic-*/ebin
+%{_libdir}/erlang/lib/ic-*/include
+%{_libdir}/erlang/lib/ic-*/priv
+%{_libdir}/erlang/lib/ic-*/src
+%{_libdir}/erlang/usr/include/erlang.idl
+%{_libdir}/erlang/usr/include/ic.h
+%{_libdir}/erlang/usr/lib/libic.a
+%if %{with doc}
+%{_mandir}/man3/ic.*
+%{_mandir}/man3/ic_clib.*
+%{_mandir}/man3/ic_c_protocol.*
+%endif
+
+%files -n erlang-orber
+%license COPYRIGHT
+%license LICENSE.txt
+%dir %{_libdir}/erlang/lib/orber-*/
+%{_libdir}/erlang/lib/orber-*/COSS
+%{_libdir}/erlang/lib/orber-*/ebin
+%{_libdir}/erlang/lib/orber-*/include
+%{_libdir}/erlang/lib/orber-*/priv
+%{_libdir}/erlang/lib/orber-*/src
+%if %{with doc}
+%{_mandir}/man3/CosNaming.*
+%{_mandir}/man3/CosNaming_BindingIterator.*
+%{_mandir}/man3/CosNaming_NamingContext.*
+%{_mandir}/man3/CosNaming_NamingContextExt.*
+%{_mandir}/man3/Module_Interface.*
+%{_mandir}/man3/any.*
+%{_mandir}/man3/corba.*
+%{_mandir}/man3/corba_object.*
+%{_mandir}/man3/fixed.*
+%{_mandir}/man3/interceptors.*
+%{_mandir}/man3/lname.*
+%{_mandir}/man3/lname_component.*
+%{_mandir}/man3/orber.*
+%{_mandir}/man3/orber_acl.*
+%{_mandir}/man3/orber_diagnostics.*
+%{_mandir}/man3/orber_ifr.*
+%{_mandir}/man3/orber_tc.*
+%endif
+
+
+%changelog
+* Tue Jan 15 2019 Peter Lemenkov <lemenkov(a)gmail.com> - 4.5.2-1
+- Initial build as a separate set of packages splitted off from Erlang/OTP
diff --git a/sources b/sources
new file mode 100644
index 0000000..d5040da
--- /dev/null
+++ b/sources
@@ -0,0 +1 @@
+SHA512 (corba-4.5.2.tar.gz) =
882d8e3d4f847f731bf0ad605e33885ae8c7d31cd0c8109e5d4d5d2c232bd907dffed48416699ce35f6190e5025134132e6524cd0e64cfad4e3df9e12e1769fc