X-Git-Url: http://ncurses.scripts.mit.edu/?p=ncurses.git;a=blobdiff_plain;f=mk-1st.awk;h=232a175cd1f9d1a36d925adc24593229a9831b5f;hp=cf7817d22993c9552b9b3d10d3ae6996ffab0d98;hb=614ef82f41eda084798068d715ef91b072014ca9;hpb=55ccd2b959766810cf7db8d1c4462f338ce0afc8 diff --git a/mk-1st.awk b/mk-1st.awk index cf7817d2..232a175c 100644 --- a/mk-1st.awk +++ b/mk-1st.awk @@ -1,6 +1,6 @@ -# $Id: mk-1st.awk,v 1.65 2005/06/18 19:15:57 tom Exp $ +# $Id: mk-1st.awk,v 1.71 2007/01/13 21:33:25 tom Exp $ ############################################################################## -# Copyright (c) 1998-2004,2005 Free Software Foundation, Inc. # +# Copyright (c) 1998-2006,2007 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"), # @@ -31,27 +31,85 @@ # # Generate list of objects for a given model library # Variables: -# 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) +# 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", etc.) +# 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) -# 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) +# 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 is_ticlib() { + return ( subset ~ /^ticlib$/ ); + } +function is_termlib() { + return ( subset ~ /^(ticlib\+)?termlib(\+ext_tinfo)?$/ ); + } +# see lib_name +function lib_name_of(a_name) { + return sprintf("%s%s%s", prefix, a_name, suffix) + } +# see imp_name +function imp_name_of(a_name) { + if (ShlibVerInfix == "cygdll") { + result = sprintf("%s%s%s.a", prefix, a_name, suffix); + } else { + result = ""; + } + return result; + } +# see abi_name +function abi_name_of(a_name) { + if (ShlibVerInfix == "cygdll") { + result = sprintf("%s%s$(ABI_VERSION)%s", "cyg", a_name, suffix); + } else if (ShlibVerInfix == "yes") { + result = sprintf("%s%s.$(ABI_VERSION)%s", prefix, a_name, suffix); + } else { + result = sprintf("%s.$(ABI_VERSION)", lib_name_of(a_name)); + } + return result; + } +# see rel_name +function rel_name_of(a_name) { + if (ShlibVerInfix == "cygdll") { + result = sprintf("%s%s$(REL_VERSION)%s", "cyg", a_name, suffix); + } else if (ShlibVerInfix == "yes") { + result = sprintf("%s%s.$(REL_VERSION)%s", prefix, a_name, suffix); + } else { + result = sprintf("%s.$(REL_VERSION)", lib_name_of(a_name)); + } + return result; + } +# see end_name +function end_name_of(a_name) { + if ( MODEL != "SHARED" ) { + result = lib_name_of(a_name); + } else if ( DoLinks == "reverse") { + result = lib_name_of(a_name); + } else { + if ( ShlibVer == "rel" ) { + result = rel_name_of(a_name); + } else if ( ShlibVer == "abi" || ShlibVer == "cygdll" ) { + result = abi_name_of(a_name); + } else { + result = lib_name_of(a_name); + } + } + return result + } function symlink(src,dst) { if ( src != dst ) { printf "rm -f %s; ", dst @@ -60,25 +118,28 @@ 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" ) { - if ( ShlibVer == "rel" ) { - rmlink(directory, abi_name); - rmlink(directory, rel_name); - } else if ( ShlibVer == "abi" ) { - rmlink(directory, abi_name); - } + if ( ShlibVer == "rel" ) { + rmlink(directory, abi_name); + rmlink(directory, rel_name); + } else if ( ShlibVer == "abi" ) { + rmlink(directory, abi_name); + } } else { - if ( ShlibVer == "rel" ) { - rmlink(directory, abi_name); - rmlink(directory, lib_name); - } else if ( ShlibVer == "abi" ) { - rmlink(directory, lib_name); - } + if ( ShlibVer == "rel" ) { + rmlink(directory, abi_name); + rmlink(directory, lib_name); + } else if ( ShlibVer == "abi" ) { + rmlink(directory, lib_name); + } } } +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 @@ -100,6 +161,44 @@ 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 : \\\n", dst_libs + printf "\t\t%s \\\n", directory + if (subset ~ /^base/ ) { + if (directory != "../lib") { + printf "\t\t%s/%s \\\n", "../lib", end_name_of("tinfo"); + } + printf "\t\t%s/%s \\\n", directory, end_name_of("tinfo"); + } + 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() ) { + 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 @@ -132,7 +231,9 @@ BEGIN { } using = 1 } - if ( subset == "termlib" || subset == "termlib+ext_tinfo" ) { + if ( is_ticlib() ) { + OBJS = MODEL "_P" + } else if ( is_termlib() ) { OBJS = MODEL "_T" } else { OBJS = MODEL @@ -174,77 +275,33 @@ END { if ( found == 1 ) { print "" - lib_name = sprintf("%s%s%s", prefix, name, suffix) + lib_name = lib_name_of(name); if ( MODEL == "SHARED" ) { - if (ShlibVerInfix == "cygdll") { - 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); - rel_name = sprintf("%s%s.$(REL_VERSION)%s", prefix, name, suffix); - } else { - abi_name = sprintf("%s.$(ABI_VERSION)", lib_name); - rel_name = sprintf("%s.$(REL_VERSION)", lib_name); - } - if ( DoLinks == "reverse") { - end_name = lib_name; - } else { - if ( ShlibVer == "rel" ) { - end_name = rel_name; - } else if ( ShlibVer == "abi" || ShlibVer == "cygdll" ) { - end_name = abi_name; - } else { - end_name = lib_name; - } - } + abi_name = abi_name_of(name); + rel_name = rel_name_of(name); + imp_name = imp_name_of(name); + end_name = end_name_of(name); - 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" || subset == "termlib+ext_tinfo" ) { - printf "\t$(MK_SHARED_LIB) $(%s_OBJS) $(TINFO_LIST) $(LDFLAGS)\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" ) @@ -259,7 +316,7 @@ END { 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 "" @@ -388,3 +445,4 @@ END { } } } +# vile:ts=4 sw=4