summaryrefslogtreecommitdiff
path: root/ace-config.in
diff options
context:
space:
mode:
authorOssama Othman <ossama-othman@users.noreply.github.com>1999-02-14 21:38:09 +0000
committerOssama Othman <ossama-othman@users.noreply.github.com>1999-02-14 21:38:09 +0000
commite5747ef9b163e177b59db2809763555d64750af0 (patch)
tree100e46ca99f69257ecbe700c6a090c55b15b3a40 /ace-config.in
parent02df907cfeb38b914753da7678593528a3e63ffc (diff)
downloadATCD-e5747ef9b163e177b59db2809763555d64750af0.tar.gz
Started to introduce the work done by the ACE Configuration
Project into the official ACE distribution.
Diffstat (limited to 'ace-config.in')
-rw-r--r--ace-config.in207
1 files changed, 207 insertions, 0 deletions
diff --git a/ace-config.in b/ace-config.in
new file mode 100644
index 00000000000..110e452c943
--- /dev/null
+++ b/ace-config.in
@@ -0,0 +1,207 @@
+#!/bin/sh
+
+set -e
+
+prefix=@prefix@
+exec_prefix=@exec_prefix@
+
+bindir=@bindir@
+sbindir=@sbindir@
+libexecdir=@libexecdir@
+datadir=@datadir@
+sysconfdir=@sysconfdir@
+sharedstatedir=@sharedstatedir@
+localstatedir=@localstatedir@
+libdir=@libdir@
+infodir=@infodir@
+mandir=@mandir@
+includedir=@includedir@
+
+pkgdatadir=${datadir}/@PACKAGE@
+pkglibdir=${libdir}/@PACKAGE@
+pkgincludedir=${includedir}/@PACKAGE@
+
+usage()
+{
+ cat <<EOF
+Usage: ace-config [OPTIONS]... [LIBRARY]...
+
+Generic options
+ --version output ACE version information
+ --help display this help and exit
+
+Compilation support options
+ --cxx print C++ compiler used for compiling
+ --cxxflags print C++ pre-processor and compiler flags
+ --libs print library linking information
+ --libs-only-L only print the -L/-R part of --libs
+ --libs-only-l only print the -l part of --libs
+
+Install directories ace-libs was configured to
+ --prefix --exec-prefix --bindir --sbindir --libexecdir --datadir
+ --sysconfdir --sharedstatedir --localstatedir --libdir --infodir
+ --mandir --includedir
+
+Known values for LIBRARY are:
+
+ ace
+ netsvcs
+ tao (calls tao-config)
+
+If LIBRARY is none of these,
+
+ ${libdir}/<LIBRARY>Conf.sh
+
+is looked in for the necessary information.
+EOF
+
+ exit $1
+}
+
+if test $# -eq 0; then
+ usage 1
+fi
+
+cxx=false
+cxxflags=false
+libs_L=false
+libs_l=false
+
+while test $# -gt 0; do
+ case "$1" in
+ -*=*) optarg=`echo "$1" | sed 's/[-_a-zA-Z0-9]*=//'` ;;
+ *) optarg= ;;
+ esac
+
+ case $1 in
+ --version)
+ echo @PACKAGE@ @VERSION@
+ exit 0
+ ;;
+ --exec-prefix)
+ echo $exec_prefix
+ exit 0
+ ;;
+ --prefix)
+ echo $prefix
+ exit 0
+ ;;
+ --*dir)
+ dirname=\$`echo $1 | sed -e 's,^--,,'`
+ dirname=`eval echo $dirname`
+ test -z "$dirname" && exit 1
+ echo $dirname
+ exit 0
+ ;;
+ --help)
+ usage 0
+ ;;
+ --cxx)
+ cxx=true
+ ;;
+ --cxxflags)
+ cxxflags=true
+ ;;
+ --libs)
+ libs_L=true
+ libs_l=true
+ ;;
+ --libs-only-L)
+ libs_L=true
+ ;;
+ --libs-only-l)
+ libs_l=true
+ ;;
+ --*)
+ usage 1
+ ;;
+ ace)
+ the_compiler="@CXX@"
+ the_libs="$the_libs @ACE_LIBDIR@ @ACE_LIBS@"
+ the_flags="$the_flags @ACE_INCLUDEDIR@ @CXXFLAGS@"
+ ;;
+ netsvcs)
+ echo "Currently unsupported."
+ exit 1
+# the_libs="$the_libs @ACE_LIBDIR@ @NETSVCS_LIBS@"
+# the_flags="$the_flags @ACE_INCLUDEDIR@ @CXXFLAGS@"
+ ;;
+ tao)
+ # The TAO compiler should be the same as ACE's compiler!
+ the_compiler="`tao-config --cxx tao`"
+ the_libs="$the_libs `tao-config --libs tao`"
+ the_flags="$the_flags `tao-config --cxxflags tao`"
+ ;;
+ *)
+ cnf_sh=${libdir}/${1}Conf.sh
+ if test -f ${cnf_sh}; then
+ . ${cnf_sh}
+ up_name=`echo $1 | tr a-z A-Z`
+ cnf_compiler=\$${up_name}_COMPILER
+ cnf_libdir=\$${up_name}_LIBDIR
+ cnf_libs=\$${up_name}_LIBS
+ cnf_flags=\$${up_name}_INCLUDEDIR
+ the_compiler="`eval echo $cnf_compiler`"
+ the_libs="$the_libs `eval echo $cnf_libdir` `eval echo $cnf_libs`"
+ the_flags="$the_flags `eval echo $cnf_flags`"
+ else
+ echo Unknown library \`$1\' 1>&2
+ fi
+ ;;
+ esac
+ shift
+done
+
+if $cxx; then
+ all_flags="$the_compiler"
+fi
+
+if $cxxflags; then
+ all_flags="$all_flags $the_flags"
+fi
+
+if $libs_L || $libs_l; then
+ all_flags="$all_flags $the_libs"
+fi
+
+if test -z "$all_flags" || test "x$all_flags" = "x "; then
+ exit 1
+fi
+
+# Straight out any possible duplicates, but be careful to
+# get `-lfoo -lbar -lbaz' for `-lfoo -lbaz -lbar -lbaz'
+other_flags=
+lib_L_flags=
+rev_libs=
+for i in $all_flags; do
+ case "$i" in
+ # a library, save it for later, in reverse order
+ -l*) rev_libs="$i $rev_libs" ;;
+ -L*|-R*)
+ if $libs_L; then
+ case " $lib_L_flags " in
+ *\ $i\ *) ;; # already there
+ *) lib_L_flags="$lib_L_flags $i" ;; # add it to output
+ esac
+ fi;;
+ *)
+ case " $other_flags " in
+ *\ $i\ *) ;; # already there
+ *) other_flags="$other_flags $i" ;; # add it to output
+ esac ;;
+ esac
+done
+
+ord_libs=
+if $libs_l; then
+ for i in $rev_libs; do
+ case " $ord_libs " in
+ *\ $i\ *) ;; # already there
+ *) ord_libs="$i $ord_libs" ;; # add it to output in reverse order
+ esac
+ done
+fi
+
+echo $other_flags $lib_L_flags $ord_libs
+
+exit 0