libtool-ldflags: New script.
* libtool-ldflags: New script. * src/Makefile.am (LTLDFLAGS): New variable. (CXXLINK): Use LTLDFLAGS. * src/Makefile.in: Regenerated. * libsupc++/Makefile.am (LTLDFLAGS): New variable. (CXXLINK): Use LTLDFLAGS. * libsupc++/Makefile.in: Regenerated. From-SVN: r109256
This commit is contained in:
parent
0ac6ae9a68
commit
d79e6356aa
@ -1,3 +1,7 @@
|
||||
2006-01-02 Mark Mitchell <mark@codesourcery.com>
|
||||
|
||||
* libtool-ldflags: New script.
|
||||
|
||||
2006-01-02 Andreas Schwab <schwab@suse.de>
|
||||
|
||||
* configure.in: When reconfiguring remove Makefile in
|
||||
|
@ -1,3 +1,12 @@
|
||||
2006-01-02 Mark Mitchell <mark@codesourcery.com>
|
||||
|
||||
* src/Makefile.am (LTLDFLAGS): New variable.
|
||||
(CXXLINK): Use LTLDFLAGS.
|
||||
* src/Makefile.in: Regenerated.
|
||||
* libsupc++/Makefile.am (LTLDFLAGS): New variable.
|
||||
(CXXLINK): Use LTLDFLAGS.
|
||||
* libsupc++/Makefile.in: Regenerated.
|
||||
|
||||
2006-01-02 Paolo Carlini <pcarlini@suse.de>
|
||||
|
||||
PR libstdc++/24645
|
||||
|
@ -139,6 +139,8 @@ LTCXXCOMPILE = $(LIBTOOL) --tag CXX --tag disable-shared \
|
||||
--mode=compile $(CXX) $(TOPLEVEL_INCLUDES) \
|
||||
$(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS)
|
||||
|
||||
LTLDFLAGS = $(shell $(SHELL) $(top_srcdir)/../libtool-ldflags $(LDFLAGS))
|
||||
|
||||
# 3) We'd have a problem when building the shared libstdc++ object if
|
||||
# the rules automake generates would be used. We cannot allow g++ to
|
||||
# be used since this would add -lstdc++ to the link line which of
|
||||
@ -147,7 +149,7 @@ LTCXXCOMPILE = $(LIBTOOL) --tag CXX --tag disable-shared \
|
||||
# compilation driver.
|
||||
CXXLINK = $(LIBTOOL) --tag CXX --tag disable-shared \
|
||||
--mode=link $(CXX) \
|
||||
$(OPT_LDFLAGS) $(SECTION_LDFLAGS) $(AM_CXXFLAGS) $(LDFLAGS) -o $@
|
||||
$(OPT_LDFLAGS) $(SECTION_LDFLAGS) $(AM_CXXFLAGS) $(LTLDFLAGS) -o $@
|
||||
|
||||
# We have to have rules modified from the default to counteract SUN make
|
||||
# prepending each of $(glibcxxinstall_HEADERS) with VPATH below.
|
||||
|
@ -402,6 +402,7 @@ LTCXXCOMPILE = $(LIBTOOL) --tag CXX --tag disable-shared \
|
||||
--mode=compile $(CXX) $(TOPLEVEL_INCLUDES) \
|
||||
$(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS)
|
||||
|
||||
LTLDFLAGS = $(shell $(SHELL) $(top_srcdir)/../libtool-ldflags $(LDFLAGS))
|
||||
|
||||
# 3) We'd have a problem when building the shared libstdc++ object if
|
||||
# the rules automake generates would be used. We cannot allow g++ to
|
||||
@ -411,7 +412,7 @@ LTCXXCOMPILE = $(LIBTOOL) --tag CXX --tag disable-shared \
|
||||
# compilation driver.
|
||||
CXXLINK = $(LIBTOOL) --tag CXX --tag disable-shared \
|
||||
--mode=link $(CXX) \
|
||||
$(OPT_LDFLAGS) $(SECTION_LDFLAGS) $(AM_CXXFLAGS) $(LDFLAGS) -o $@
|
||||
$(OPT_LDFLAGS) $(SECTION_LDFLAGS) $(AM_CXXFLAGS) $(LTLDFLAGS) -o $@
|
||||
|
||||
all: all-am
|
||||
|
||||
|
@ -226,6 +226,8 @@ AM_CXXFLAGS = \
|
||||
LTCXXCOMPILE = $(LIBTOOL) --tag CXX --mode=compile $(CXX) $(INCLUDES) \
|
||||
$(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS)
|
||||
|
||||
LTLDFLAGS = $(shell $(SHELL) $(top_srcdir)/../libtool-ldflags $(LDFLAGS))
|
||||
|
||||
# 3) We'd have a problem when building the shared libstdc++ object if
|
||||
# the rules automake generates would be used. We cannot allow g++ to
|
||||
# be used since this would add -lstdc++ to the link line which of
|
||||
@ -233,7 +235,7 @@ LTCXXCOMPILE = $(LIBTOOL) --tag CXX --mode=compile $(CXX) $(INCLUDES) \
|
||||
# directory to configure libstdc++-v3 to use gcc as the C++
|
||||
# compilation driver.
|
||||
CXXLINK = $(LIBTOOL) --tag CXX --mode=link $(CXX) \
|
||||
$(OPT_LDFLAGS) $(SECTION_LDFLAGS) $(AM_CXXFLAGS) $(LDFLAGS) -o $@
|
||||
$(OPT_LDFLAGS) $(SECTION_LDFLAGS) $(AM_CXXFLAGS) $(LTLDFLAGS) -o $@
|
||||
|
||||
|
||||
# Added bits to build debug library.
|
||||
|
@ -405,6 +405,7 @@ AM_CXXFLAGS = \
|
||||
LTCXXCOMPILE = $(LIBTOOL) --tag CXX --mode=compile $(CXX) $(INCLUDES) \
|
||||
$(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS)
|
||||
|
||||
LTLDFLAGS = $(shell $(SHELL) $(top_srcdir)/../libtool-ldflags $(LDFLAGS))
|
||||
|
||||
# 3) We'd have a problem when building the shared libstdc++ object if
|
||||
# the rules automake generates would be used. We cannot allow g++ to
|
||||
@ -413,7 +414,7 @@ LTCXXCOMPILE = $(LIBTOOL) --tag CXX --mode=compile $(CXX) $(INCLUDES) \
|
||||
# directory to configure libstdc++-v3 to use gcc as the C++
|
||||
# compilation driver.
|
||||
CXXLINK = $(LIBTOOL) --tag CXX --mode=link $(CXX) \
|
||||
$(OPT_LDFLAGS) $(SECTION_LDFLAGS) $(AM_CXXFLAGS) $(LDFLAGS) -o $@
|
||||
$(OPT_LDFLAGS) $(SECTION_LDFLAGS) $(AM_CXXFLAGS) $(LTLDFLAGS) -o $@
|
||||
|
||||
debugdir = debug
|
||||
all: all-am
|
||||
|
97
libtool-ldflags
Executable file
97
libtool-ldflags
Executable file
@ -0,0 +1,97 @@
|
||||
#! /bin/sh
|
||||
|
||||
# Script to translate LDFLAGS into a form suitable for use with libtool.
|
||||
|
||||
# Copyright (C) 2005 Free Software Foundation, Inc.
|
||||
#
|
||||
# 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 2 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, write to the Free Software
|
||||
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
|
||||
# MA 02110-1301, USA.
|
||||
|
||||
# Contributed by CodeSourcery, LLC.
|
||||
|
||||
# This script is designed to be used from a Makefile that uses libtool
|
||||
# to build libraries as follows:
|
||||
#
|
||||
# LTLDFLAGS = $(shell libtool-ldflags $(LDFLAGS))
|
||||
#
|
||||
# Then, use (LTLDFLAGS) in place of $(LDFLAGS) in your link line.
|
||||
|
||||
# The output of the script. This string is built up as we process the
|
||||
# arguments.
|
||||
result=
|
||||
|
||||
for arg
|
||||
do
|
||||
case $arg in
|
||||
-f*|--*)
|
||||
# Libtool does not ascribe any special meaning options
|
||||
# that begin with -f or with a double-dash. So, it will
|
||||
# think these options are linker options, and prefix them
|
||||
# with "-Wl,". Then, the compiler driver will ignore the
|
||||
# options. So, we prefix these options with -Xcompiler to
|
||||
# make clear to libtool that they are in fact compiler
|
||||
# options.
|
||||
result="$result -Xcompiler"
|
||||
;;
|
||||
*)
|
||||
# We do not want to add -Xcompiler to other options because
|
||||
# that would prevent libtool itself from recognizing them.
|
||||
;;
|
||||
esac
|
||||
|
||||
# If $(LDFLAGS) is (say):
|
||||
# a "b'c d" e
|
||||
# then the user expects that:
|
||||
# $(LD) $(LDFLAGS)
|
||||
# will pass three arguments to $(LD):
|
||||
# 1) a
|
||||
# 2) b'c d
|
||||
# 3) e
|
||||
# We must ensure, therefore, that the arguments are appropriately
|
||||
# quoted so that using:
|
||||
# libtool --mode=link ... $(LTLDFLAGS)
|
||||
# will result in the same number of arguments being passed to
|
||||
# libtool. In other words, when this script was invoked, the shell
|
||||
# removed one level of quoting, present in $(LDFLAGS); we have to put
|
||||
# it back.
|
||||
|
||||
# Quote any embedded single quotes.
|
||||
case $arg in
|
||||
*"'"*)
|
||||
# The following command creates the script:
|
||||
# 1s,^X,,;s|'|'"'"'|g
|
||||
# which removes a leading X, and then quotes and embedded single
|
||||
# quotes.
|
||||
sed_script="1s,^X,,;s|'|'\"'\"'|g"
|
||||
# Add a leading "X" so that if $arg starts with a dash,
|
||||
# the echo command will not try to interpret the argument
|
||||
# as a command-line option.
|
||||
arg="X$arg"
|
||||
# Generate the quoted string.
|
||||
quoted_arg=`echo "$arg" | sed -e "$sed_script"`
|
||||
;;
|
||||
*)
|
||||
quoted_arg=$arg
|
||||
;;
|
||||
esac
|
||||
# Surround the entire argument with single quotes.
|
||||
quoted_arg="'"$quoted_arg"'"
|
||||
|
||||
# Add it to the string.
|
||||
result="$result $quoted_arg"
|
||||
done
|
||||
|
||||
# Output the string we have built up.
|
||||
echo "$result"
|
Loading…
x
Reference in New Issue
Block a user