pkgsrc-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[pkgsrc/trunk]: pkgsrc/mk/wrapper Add support of C++ crossbuild with g++, bas...



details:   https://anonhg.NetBSD.org/pkgsrc/rev/1adb13f5959c
branches:  trunk
changeset: 591089:1adb13f5959c
user:      obache <obache%pkgsrc.org@localhost>
date:      Thu Aug 04 13:32:05 2011 +0000

description:
Add support of C++ crossbuild with g++, based on CC with gcc.

diffstat:

 mk/wrapper/bsd.wrapper.mk     |    9 ++-
 mk/wrapper/cmd-sink-cross-gxx |  118 ++++++++++++++++++++++++++++++++++++++++++
 2 files changed, 125 insertions(+), 2 deletions(-)

diffs (152 lines):

diff -r b22d18424a7f -r 1adb13f5959c mk/wrapper/bsd.wrapper.mk
--- a/mk/wrapper/bsd.wrapper.mk Thu Aug 04 12:20:54 2011 +0000
+++ b/mk/wrapper/bsd.wrapper.mk Thu Aug 04 13:32:05 2011 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: bsd.wrapper.mk,v 1.85 2010/08/16 10:03:44 obache Exp $
+# $NetBSD: bsd.wrapper.mk,v 1.86 2011/08/04 13:32:05 obache Exp $
 #
 # Copyright (c) 2005 The NetBSD Foundation, Inc.
 # All rights reserved.
@@ -369,7 +369,7 @@
 .if !empty(USE_CROSS_COMPILE:M[yY][eE][sS])
 _WRAP_CMD_SINK.CC=     ${WRAPPER_TMPDIR}/cmd-sink-cross-gcc
 _WRAP_CMD_SINK.CPP=    ${WRAPPER_TMPDIR}/cmd-sink-cross-cpp
-_WRAP_CMD_SINK.CXX=    ${_WRAP_CMD_SINK.CC}
+_WRAP_CMD_SINK.CXX=    ${WRAPPER_TMPDIR}/cmd-sink-cross-gxx
 .endif
 
 .if ${OPSYS} == "SunOS" && !empty(PKGSRC_COMPILER:Mgcc)
@@ -554,6 +554,11 @@
        ${RUN} ${MKDIR} ${.TARGET:H}
        ${RUN} ${CAT} ${.ALLSRC} | ${_WRAP_CROSS_GCC_FILTER} |          \
        ${_WRAP_SH_CRUNCH_FILTER} > ${.TARGET}
+
+${WRAPPER_TMPDIR}/cmd-sink-cross-gxx: ${WRAPPER_SRCDIR}/cmd-sink-cross-gxx
+       ${RUN} ${MKDIR} ${.TARGET:H}
+       ${RUN} ${CAT} ${.ALLSRC} | ${_WRAP_CROSS_GCC_FILTER} |          \
+       ${_WRAP_SH_CRUNCH_FILTER} > ${.TARGET}
 .endif
 
 .if !target(${_WRAP_GEN_REORDER})
diff -r b22d18424a7f -r 1adb13f5959c mk/wrapper/cmd-sink-cross-gxx
--- /dev/null   Thu Jan 01 00:00:00 1970 +0000
+++ b/mk/wrapper/cmd-sink-cross-gxx     Thu Aug 04 13:32:05 2011 +0000
@@ -0,0 +1,118 @@
+# $NetBSD: cmd-sink-cross-gxx,v 1.1 2011/08/04 13:32:05 obache Exp $
+#
+# Copyright (c) 2007 Joerg Sonnenberger <joerg%NetBSD.org@localhost>.
+# All rights reserved.
+#
+# This code was developed as part of Google's Summer of Code 2007 program.
+#
+# Redistribution and use in source and binary forms, with or without
+# modification, are permitted provided that the following conditions
+# are met:
+#
+# 1. Redistributions of source code must retain the above copyright
+#    notice, this list of conditions and the following disclaimer.
+# 2. Redistributions in binary form must reproduce the above copyright
+#    notice, this list of conditions and the following disclaimer in
+#    the documentation and/or other materials provided with the
+#    distribution.
+#
+# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+# ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
+# FOR A PARTICULAR PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE
+# COPYRIGHT HOLDERS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
+# INCIDENTAL, SPECIAL, EXEMPLARY OR CONSEQUENTIAL DAMAGES (INCLUDING,
+# BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
+# LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
+# AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
+# OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
+# OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+# SUCH DAMAGE.
+
+if [ "${dont_link}" != yes ]; then
+       # Don't use standard search paths
+       arg="-Wl,-nostdlib"
+       $debug_log $wrapperlog "    (cmd-sink-native-cxx) pop: $arg"
+       . $buildcmd
+
+       # All normal library locations should be checked for
+       for libdir in /usr/lib @PREFIX@/lib; do
+               arg="-Wl,-rpath-link,@CROSS_DESTDIR@${libdir}"
+               $debug_log $wrapperlog "    (cmd-sink-native-cxx) pop: $arg"
+               . $buildcmd
+       done
+
+       # Compiler searches for libraries in /usr/lib, emulate.
+       arg="-L@CROSS_DESTDIR@/usr/lib"
+       $debug_log $wrapperlog "    (cmd-sink-native-cxx) pop: $arg"
+       . $buildcmd
+
+       # crt1.o and friends needs to be found as well.
+       arg="-B@CROSS_DESTDIR@/usr/lib"
+       $debug_log $wrapperlog "    (cmd-sink-native-cxx) pop: $arg"
+       . $buildcmd
+fi
+
+# Don't use standard include path.
+arg="-nostdinc"
+$debug_log $wrapperlog "    (cmd-sink-native-cxx) pop: $arg"
+. $buildcmd
+
+# Compiler searches for headers in /usr/include, emulate.
+arg="-isystem"
+$debug_log $wrapperlog "    (cmd-sink-native-cxx) pop: $arg"
+. $buildcmd
+
+arg="@CROSS_DESTDIR@/usr/include"
+$debug_log $wrapperlog "    (cmd-sink-native-cxx) pop: $arg"
+. $buildcmd
+
+# Don't use standard include path.
+arg="-nostdinc++"
+$debug_log $wrapperlog "    (cmd-sink-native-cxx) pop: $arg"
+. $buildcmd
+
+# Compiler searches for headers in /usr/include/g++, emulate.
+arg="-isystem"
+$debug_log $wrapperlog "    (cmd-sink-native-cxx) pop: $arg"
+. $buildcmd
+
+arg="@CROSS_DESTDIR@/usr/include/g++"
+$debug_log $wrapperlog "    (cmd-sink-native-cxx) pop: $arg"
+. $buildcmd
+
+arg="-isystem"
+$debug_log $wrapperlog "    (cmd-sink-native-cxx) pop: $arg"
+. $buildcmd
+
+arg="@CROSS_DESTDIR@/usr/include/g++/backward"
+$debug_log $wrapperlog "    (cmd-sink-native-cxx) pop: $arg"
+. $buildcmd
+
+while ! queue_is_empty cmdbuf; do
+       pop_queue cmdbuf arg
+       case $arg in
+       -R*|-Wl,-R*|-Wl,-rpath,*|-Wl,--rpath,*)
+               # First, push the option out again.
+               $debug_log $wrapperlog "    (cmd-sink-native-cxx) pop: $arg"
+               . $buildcmd
+
+               # Now translate the directory to be relative to the
+               # the target DESTDIR for the linker.
+               case $arg in
+               -R*)                    R="-R" ;;
+               -Wl,-R*)                R="-Wl,-R" ;;
+               -Wl,-rpath,*)           R="-Wl,-rpath," ;;
+               -Wl,--rpath,*)          R="-Wl,--rpath," ;;
+               esac
+               dir="${arg#$R}"
+               arg="-Wl,-rpath-link,@CROSS_DESTDIR@${dir}"
+               $debug_log $wrapperlog "    (cmd-sink-native-cxx) pop: $arg"
+               . $buildcmd
+               ;;
+       *)
+               $debug_log $wrapperlog "    (cmd-sink-native-cxx) pop:  $arg"
+               . $buildcmd
+               ;;
+       esac
+done



Home | Main Index | Thread Index | Old Index