summaryrefslogtreecommitdiffstats
path: root/contrib/ncurses/mk-1st.awk
diff options
context:
space:
mode:
Diffstat (limited to 'contrib/ncurses/mk-1st.awk')
-rw-r--r--contrib/ncurses/mk-1st.awk185
1 files changed, 108 insertions, 77 deletions
diff --git a/contrib/ncurses/mk-1st.awk b/contrib/ncurses/mk-1st.awk
index bbd7c40..371042c 100644
--- a/contrib/ncurses/mk-1st.awk
+++ b/contrib/ncurses/mk-1st.awk
@@ -1,6 +1,6 @@
-# $Id: mk-1st.awk,v 1.55 2002/04/20 17:32:47 tom Exp $
+# $Id: mk-1st.awk,v 1.68 2006/10/08 00:14:08 tom Exp $
##############################################################################
-# Copyright (c) 1998,2000,2002 Free Software Foundation, Inc. #
+# Copyright (c) 1998-2005,2006 Free Software Foundation, Inc. #
# #
# Permission is hereby granted, free of charge, to any person obtaining a #
# copy of this software and associated documentation files (the "Software"), #
@@ -27,27 +27,29 @@
# authorization. #
##############################################################################
#
-# Author: Thomas E. Dickey <dickey@clark.net> 1996,1997,2000
+# Author: Thomas E. Dickey
#
# Generate list of objects for a given model library
# Variables:
-# name (library name, e.g., "ncurses", "panel", "forms", "menus")
-# model (directory into which we compile, e.g., "obj")
-# prefix (e.g., "lib", for Unix-style libraries)
-# suffix (e.g., "_g.a", for debug libraries)
-# MODEL (e.g., "DEBUG", uppercase; toupper is not portable)
-# depend (optional dependencies for all objects, e.g, ncurses_cfg.h)
-# subset ("none", "base", "base+ext_funcs" or "termlib")
-# target (cross-compile target, if any)
-# ShlibVer ("rel", "abi" or "auto", to augment DoLinks variable)
+# name (library name, e.g., "ncurses", "panel", "forms", "menus")
+# traces ("all" or "DEBUG", to control whether tracing is compiled in)
+# MODEL (e.g., "DEBUG", uppercase; toupper is not portable)
+# model (directory into which we compile, e.g., "obj")
+# prefix (e.g., "lib", for Unix-style libraries)
+# suffix (e.g., "_g.a", for debug libraries)
+# subset ("none", "base", "base+ext_funcs" or "termlib")
+# ShlibVer ("rel", "abi" or "auto", to augment DoLinks variable)
# ShlibVerInfix ("yes" or "no", determines location of version #)
-# DoLinks ("yes", "reverse" or "no", flag to add symbolic links)
-# rmSoLocs ("yes" or "no", flag to add extra clean target)
-# overwrite ("yes" or "no", flag to add link to libcurses.a
+# 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)
+# overwrite ("yes" or "no", flag to add link to libcurses.a
+# depend (optional dependencies for all objects, e.g, ncurses_cfg.h)
+# host (cross-compile host, if any)
#
# Notes:
# CLIXs nawk does not like underscores in command-line variable names.
-# Mixed-case is ok.
+# Mixed-case variable names are ok.
# HP/UX requires shared libraries to have executable permissions.
#
function symlink(src,dst) {
@@ -58,7 +60,7 @@ function symlink(src,dst) {
}
function rmlink(directory, dst) {
printf "\t-rm -f %s/%s\n", directory, dst
-}
+ }
function removelinks(directory) {
rmlink(directory, end_name);
if ( DoLinks == "reverse" ) {
@@ -77,6 +79,9 @@ function removelinks(directory) {
}
}
}
+function make_shlib(objs, shlib_list) {
+ printf "\t$(MK_SHARED_LIB) $(%s_OBJS) $(%s) $(LDFLAGS)\n", objs, shlib_list
+ }
function sharedlinks(directory) {
if ( ShlibVer != "auto" && ShlibVer != "cygdll" ) {
printf "\tcd %s && (", directory
@@ -98,6 +103,34 @@ function sharedlinks(directory) {
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);
+ }
+ printf "%s : %s $(%s_OBJS)\n", dst_libs, directory, OBJS
+ printf "\t@echo linking $@\n"
+ print "\t-@rm -f %s", dst_libs;
+ if ( subset == "termlib" || subset == "termlib+ext_tinfo" ) {
+ make_shlib(OBJS, "TINFO_LIST")
+ } else {
+ make_shlib(OBJS, "SHLIB_LIST")
+ }
+ 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 {
+ program = "$(INSTALL_LIB)";
+ }
+ printf "\t%s %s %s\n", program, src_name, dst_name
+ }
BEGIN {
found = 0
using = 0
@@ -110,13 +143,27 @@ BEGIN {
if (using == 0) {
if (found == 0) {
print ""
- print "# generated by mk-1st.awk"
+ printf "# generated by mk-1st.awk (subset=%s)\n", subset
+ printf "# name: %s\n", name
+ printf "# traces: %s\n", traces
+ printf "# MODEL: %s\n", MODEL
+ printf "# model: %s\n", model
+ printf "# prefix: %s\n", prefix
+ printf "# suffix: %s\n", suffix
+ printf "# subset: %s\n", subset
+ printf "# ShlibVer: %s\n", ShlibVer
+ printf "# ShlibVerInfix: %s\n", ShlibVerInfix
+ printf "# DoLinks: %s\n", DoLinks
+ printf "# rmSoLocs: %s\n", rmSoLocs
+ printf "# ldconfig: %s\n", ldconfig
+ printf "# overwrite: %s\n", overwrite
+ printf "# depend: %s\n", depend
+ printf "# host: %s\n", host
print ""
}
using = 1
}
- if ( subset == "termlib") {
- name = "tinfo"
+ if ( subset == "termlib" || subset == "termlib+ext_tinfo" ) {
OBJS = MODEL "_T"
} else {
OBJS = MODEL
@@ -146,7 +193,7 @@ BEGIN {
else
found = 2
}
- printf " \\\n\t../%s/%s.o", model, $1
+ printf " \\\n\t../%s/%s$o", model, $1
}
}
END {
@@ -162,8 +209,8 @@ END {
if ( MODEL == "SHARED" )
{
if (ShlibVerInfix == "cygdll") {
- abi_name = sprintf("%s%s$(ABI_VERSION)%s", prefix, name, suffix);
- rel_name = sprintf("%s%s$(REL_VERSION)%s", prefix, name, suffix);
+ abi_name = sprintf("%s%s$(ABI_VERSION)%s", "cyg", name, suffix);
+ rel_name = sprintf("%s%s$(REL_VERSION)%s", "cyg", name, suffix);
imp_name = sprintf("%s%s%s.a", prefix, name, suffix);
} else if (ShlibVerInfix == "yes") {
abi_name = sprintf("%s%s.$(ABI_VERSION)%s", prefix, name, suffix);
@@ -184,60 +231,40 @@ END {
}
}
- if ( ShlibVer == "cygdll" ) {
- dst_dirs = "$(DESTDIR)$(bindir) $(DESTDIR)$(libdir)";
- printf "$(SHARED_LIB) $(IMPORT_LIB) : $(%s_OBJS)\n", OBJS;
- print "\t-@rm -f $(SHARED_LIB) $(IMPORT_LIB)";
- } else {
- dst_dirs = "$(DESTDIR)$(libdir)";
- printf "../lib/%s : $(%s_OBJS)\n", end_name, OBJS
- print "\t-@rm -f $@";
- }
- if ( subset == "termlib") {
- printf "\t$(MK_SHARED_LIB) $(%s_OBJS) $(TINFO_LIST)\n", OBJS
- } else {
- printf "\t$(MK_SHARED_LIB) $(%s_OBJS) $(SHLIB_LIST) $(LDFLAGS)\n", OBJS
- }
- sharedlinks("../lib")
+ shlib_rule("../lib")
print ""
print "install \\"
print "install.libs \\"
- printf "install.%s :: %s $(LIBRARIES)\n", name, dst_dirs
if ( ShlibVer == "cygdll" ) {
- src_name = sprintf("../lib/%s", end_name);
- dst_name = sprintf("$(DESTDIR)$(bindir)/%s", end_name);
- printf "\t@echo installing %s as %s\n", src_name, dst_name
- printf "\t-@rm -f %s\n", dst_name
- printf "\t$(INSTALL_LIB) %s %s\n", src_name, dst_name
-
- src_name = sprintf("../lib/%s", imp_name);
- dst_name = sprintf("$(DESTDIR)$(libdir)/%s", imp_name);
- printf "\t@echo installing %s as %s\n", src_name, dst_name
- printf "\t-@rm -f %s\n", dst_name
- printf "\t$(INSTALL_LIB) %s %s\n", src_name, dst_name
+ dst_dirs = "$(DESTDIR)$(bindir) $(DESTDIR)$(libdir)";
+ printf "install.%s :: %s $(LIBRARIES)\n", name, dst_dirs
+ install_dll("$(bindir)",end_name);
+ install_dll("$(libdir)",imp_name);
} else {
- src_name = sprintf("../lib/%s", end_name);
- dst_name = sprintf("$(DESTDIR)$(libdir)/%s", end_name);
- printf "\t@echo installing %s as %s\n", src_name, dst_name
- printf "\t-@rm -f %s\n", dst_name
- printf "\t$(INSTALL_LIB) %s %s\n", src_name, dst_name
-
- sharedlinks("$(DESTDIR)$(libdir)")
-
+ lib_dir = "$(DESTDIR)$(libdir)";
+ printf "install.%s :: %s/%s\n", name, lib_dir, end_name
+ print ""
+ shlib_rule(lib_dir)
}
if ( overwrite == "yes" && name == "ncurses" )
{
- ovr_name = sprintf("libcurses%s", suffix)
- printf "\t@echo linking %s to %s\n", end_name, ovr_name
- printf "\tcd $(DESTDIR)$(libdir) && (rm -f %s; $(LN_S) %s %s; )\n", ovr_name, end_name, ovr_name
+ if ( ShlibVer == "cygdll" ) {
+ ovr_name = sprintf("libcurses%s.a", suffix)
+ printf "\t@echo linking %s to %s\n", imp_name, ovr_name
+ printf "\tcd $(DESTDIR)$(libdir) && (rm -f %s; $(LN_S) %s %s; )\n", ovr_name, imp_name, ovr_name
+ } else {
+ ovr_name = sprintf("libcurses%s", suffix)
+ printf "\t@echo linking %s to %s\n", end_name, ovr_name
+ printf "\tcd $(DESTDIR)$(libdir) && (rm -f %s; $(LN_S) %s %s; )\n", ovr_name, end_name, ovr_name
+ }
}
- if ( ldconfig != "" ) {
+ if ( ldconfig != "" && ldconfig != ":" ) {
printf "\t- test -z \"$(DESTDIR)\" && %s\n", ldconfig
}
print ""
@@ -257,7 +284,11 @@ END {
removelinks("$(DESTDIR)$(libdir)")
if ( overwrite == "yes" && name == "ncurses" )
{
- ovr_name = sprintf("libcurses%s", suffix)
+ if ( ShlibVer == "cygdll" ) {
+ ovr_name = sprintf("libcurses%s.a", suffix)
+ } else {
+ ovr_name = sprintf("libcurses%s", suffix)
+ }
printf "\t-@rm -f $(DESTDIR)$(libdir)/%s\n", ovr_name
}
}
@@ -277,19 +308,19 @@ END {
}
end_name = lib_name;
printf "../lib/%s : $(%s_OBJS)\n", lib_name, OBJS
- printf "\tcd ../lib && $(LIBTOOL) $(%s) -o %s $(%s_OBJS:.o=.lo) -rpath $(DESTDIR)$(libdir) -version-info $(NCURSES_MAJOR):$(NCURSES_MINOR)\n", compile, lib_name, OBJS
+ printf "\tcd ../lib && $(LIBTOOL_LINK) $(%s) -o %s $(%s_OBJS:$o=.lo) -rpath $(DESTDIR)$(libdir) -version-info $(NCURSES_MAJOR):$(NCURSES_MINOR) $(SHLIB_LIST)\n", compile, lib_name, OBJS
print ""
print "install \\"
print "install.libs \\"
printf "install.%s :: $(DESTDIR)$(libdir) ../lib/%s\n", name, lib_name
printf "\t@echo installing ../lib/%s as $(DESTDIR)$(libdir)/%s\n", lib_name, lib_name
- printf "\tcd ../lib; $(LIBTOOL) $(INSTALL_DATA) %s $(DESTDIR)$(libdir)\n", lib_name
+ printf "\tcd ../lib; $(LIBTOOL_INSTALL) $(INSTALL) %s $(DESTDIR)$(libdir)\n", lib_name
print ""
print "uninstall \\"
print "uninstall.libs \\"
printf "uninstall.%s ::\n", name
printf "\t@echo uninstalling $(DESTDIR)$(libdir)/%s\n", lib_name
- printf "\t-@$(LIBTOOL) rm -f $(DESTDIR)$(libdir)/%s\n", lib_name
+ printf "\t-@$(LIBTOOL_UNINSTALL) rm -f $(DESTDIR)$(libdir)/%s\n", lib_name
}
else
{
@@ -297,9 +328,9 @@ END {
printf "../lib/%s : $(%s_OBJS)\n", lib_name, OBJS
printf "\t$(AR) $(AR_OPTS) $@ $?\n"
printf "\t$(RANLIB) $@\n"
- if ( target == "vxworks" )
+ if ( host == "vxworks" )
{
- printf "\t$(LD) $(LD_OPTS) $? -o $(@:.a=.o)\n"
+ printf "\t$(LD) $(LD_OPTS) $? -o $(@:.a=$o)\n"
}
print ""
print "install \\"
@@ -314,10 +345,10 @@ END {
printf "\t(cd $(DESTDIR)$(libdir) && $(LN_S) libncurses.a libcurses.a)\n"
}
printf "\t$(RANLIB) $(DESTDIR)$(libdir)/%s\n", lib_name
- if ( target == "vxworks" )
+ if ( host == "vxworks" )
{
- printf "\t@echo installing ../lib/lib%s.o as $(DESTDIR)$(libdir)/lib%s.o\n", name, name
- printf "\t$(INSTALL_DATA) ../lib/lib%s.o $(DESTDIR)$(libdir)/lib%s.o\n", name, name
+ printf "\t@echo installing ../lib/lib%s$o as $(DESTDIR)$(libdir)/lib%s$o\n", name, name
+ printf "\t$(INSTALL_DATA) ../lib/lib%s$o $(DESTDIR)$(libdir)/lib%s$o\n", name, name
}
print ""
print "uninstall \\"
@@ -330,10 +361,10 @@ END {
printf "\t@echo linking libcurses.a to libncurses.a\n"
printf "\t-@rm -f $(DESTDIR)$(libdir)/libcurses.a\n"
}
- if ( target == "vxworks" )
+ if ( host == "vxworks" )
{
- printf "\t@echo uninstalling $(DESTDIR)$(libdir)/lib%s.o\n", name
- printf "\t-@rm -f $(DESTDIR)$(libdir)/lib%s.o\n", name
+ printf "\t@echo uninstalling $(DESTDIR)$(libdir)/lib%s$o\n", name
+ printf "\t-@rm -f $(DESTDIR)$(libdir)/lib%s$o\n", name
}
}
print ""
@@ -343,7 +374,7 @@ END {
print "mostlyclean::"
printf "\t-rm -f $(%s_OBJS)\n", OBJS
if ( MODEL == "LIBTOOL" ) {
- printf "\t-rm -f $(%s_OBJS:.o=.lo)\n", OBJS
+ printf "\t-$(LIBTOOL_CLEAN) rm -f $(%s_OBJS:$o=.lo)\n", OBJS
}
}
else if ( found == 2 )
@@ -352,13 +383,13 @@ END {
print "mostlyclean::"
printf "\t-rm -f $(%s_OBJS)\n", OBJS
if ( MODEL == "LIBTOOL" ) {
- printf "\t-rm -f $(%s_OBJS:.o=.lo)\n", OBJS
+ printf "\t-$(LIBTOOL_CLEAN) rm -f $(%s_OBJS:$o=.lo)\n", OBJS
}
print ""
print "clean ::"
printf "\t-rm -f $(%s_OBJS)\n", OBJS
if ( MODEL == "LIBTOOL" ) {
- printf "\t-rm -f $(%s_OBJS:.o=.lo)\n", OBJS
+ printf "\t-$(LIBTOOL_CLEAN) rm -f $(%s_OBJS:$o=.lo)\n", OBJS
}
}
}
OpenPOWER on IntegriCloud