X-Git-Url: http://ncurses.scripts.mit.edu/?p=ncurses.git;a=blobdiff_plain;f=mk-1st.awk;h=371042ccce99dc7e0d22caf9e8b06212e64c4fac;hp=bbd7c40efa561d55ad7580a8d0ffe0e974d442aa;hb=027ae42953e3186daed8f3882da73de48291b606;hpb=46722468f47c2b77b3987729b4bcf2321cccfd01 diff --git a/mk-1st.awk b/mk-1st.awk index bbd7c40e..371042cc 100644 --- a/mk-1st.awk +++ b/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 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 } } }