-# $Id: mk-1st.awk,v 1.71 2007/01/13 21:33:25 tom Exp $
+# $Id: mk-1st.awk,v 1.78 2007/03/24 22:10:55 tom Exp $
##############################################################################
# Copyright (c) 1998-2006,2007 Free Software Foundation, Inc. #
# #
# subset ("none", "base", "base+ext_funcs" or "termlib", etc.)
# ShlibVer ("rel", "abi" or "auto", to augment DoLinks variable)
# ShlibVerInfix ("yes" or "no", determines location of version #)
+# TermlibRoot ("tinfo" or other root for libterm.so)
+# TermlibSuffix (".so" or other suffix for libterm.so)
+# ReLink ("yes", or "no", flag to rebuild shared libs on install)
# DoLinks ("yes", "reverse" or "no", flag to add symbolic links)
# rmSoLocs ("yes" or "no", flag to add extra clean target)
# ldconfig (path for this tool, if used)
printf ")\n"
}
}
-function shlib_rule(directory) {
- if ( ShlibVer == "cygdll" ) {
- dst_libs = sprintf("%s/$(SHARED_LIB) %s/$(IMPORT_LIB)", directory, directory);
- } else {
- dst_libs = sprintf("%s/%s", directory, end_name);
- }
+# termlib may be named explicitly via "--with-termlib=XXX", which overrides
+# any suffix. Temporarily override "suffix" to account for this.
+function termlib_end_of() {
+ termlib_save_suffix = suffix;
+ suffix = TermlibSuffix;
+ termlib_temp_result = end_name_of(TermlibRoot);
+ suffix = termlib_save_suffix;
+ return termlib_temp_result;
+}
+function shlib_build(directory) {
+ dst_libs = sprintf("%s/%s", directory, end_name);
printf "%s : \\\n", dst_libs
printf "\t\t%s \\\n", directory
- if (subset ~ /^base/ ) {
+ if (subset ~ /^base/ || subset == "ticlib" ) {
+ save_suffix = suffix
+ sub(/^[^.]\./,".",suffix)
if (directory != "../lib") {
- printf "\t\t%s/%s \\\n", "../lib", end_name_of("tinfo");
+ printf "\t\t%s/%s \\\n", "../lib", termlib_end_of();
}
- printf "\t\t%s/%s \\\n", directory, end_name_of("tinfo");
+ printf "\t\t%s/%s \\\n", directory, termlib_end_of();
+ suffix = save_suffix
}
printf "\t\t$(%s_OBJS)\n", OBJS
printf "\t@echo linking $@\n"
- print "\t-@rm -f %s", dst_libs;
if ( is_ticlib() ) {
make_shlib(OBJS, "TICS_LIST")
} else if ( is_termlib() ) {
}
sharedlinks(directory)
}
+function shlib_install(directory) {
+ src_lib1 = sprintf("../lib/%s", end_name);
+ dst_lib1 = sprintf("%s/%s", directory, end_name);
+ printf "%s : \\\n", dst_lib1
+ printf "\t\t%s \\\n", directory
+ printf "\t\t%s\n", src_lib1
+ printf "\t@echo installing $@\n"
+ printf "\t$(INSTALL_LIB) %s %s\n", src_lib1, dst_lib1;
+ sharedlinks(directory)
+ }
function install_dll(directory,filename) {
src_name = sprintf("../lib/%s", filename);
dst_name = sprintf("$(DESTDIR)%s/%s", directory, filename);
printf "\t@echo installing %s as %s\n", src_name, dst_name
- printf "\t-@rm -f %s\n", dst_name
if ( directory == "$(bindir)" ) {
program = "$(INSTALL) -m 755";
} else {
printf "# subset: %s\n", subset
printf "# ShlibVer: %s\n", ShlibVer
printf "# ShlibVerInfix: %s\n", ShlibVerInfix
+ printf "# TermlibRoot: %s\n", TermlibRoot
+ printf "# TermlibSuffix: %s\n", TermlibSuffix
+ printf "# ReLink: %s\n", ReLink
printf "# DoLinks: %s\n", DoLinks
printf "# rmSoLocs: %s\n", rmSoLocs
printf "# ldconfig: %s\n", ldconfig
imp_name = imp_name_of(name);
end_name = end_name_of(name);
- shlib_rule("../lib")
+ shlib_build("../lib")
print ""
print "install \\"
lib_dir = "$(DESTDIR)$(libdir)";
printf "install.%s :: %s/%s\n", name, lib_dir, end_name
print ""
- shlib_rule(lib_dir)
+ if ( ReLink == "yes" ) {
+ shlib_build(lib_dir)
+ } else {
+ shlib_install(lib_dir)
+ }
}
if ( overwrite == "yes" && name == "ncurses" )