]> ncurses.scripts.mit.edu Git - ncurses.git/blobdiff - mk-1st.awk
ncurses 5.7 - patch 20100206
[ncurses.git] / mk-1st.awk
index bbd7c40efa561d55ad7580a8d0ffe0e974d442aa..c5defc8fa72d066424366f22c4e5f06a5889cc20 100644 (file)
@@ -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.82 2009/11/28 20:09:38 tom Exp $
 ##############################################################################
 ##############################################################################
-# Copyright (c) 1998,2000,2002 Free Software Foundation, Inc.                #
+# Copyright (c) 1998-2008,2009 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"), #
 #                                                                            #
 # Permission is hereby granted, free of charge, to any person obtaining a    #
 # copy of this software and associated documentation files (the "Software"), #
 # authorization.                                                             #
 ##############################################################################
 #
 # 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:
 #
 # 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", etc.)
+#      ShlibVer          ("rel", "abi" or "auto", to augment DoLinks variable)
 #      ShlibVerInfix ("yes" or "no", determines location of version #)
 #      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
+#   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)
+#      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.
 #
 # 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.
 #
 #      HP/UX requires shared libraries to have executable permissions.
 #
+function is_ticlib() {
+               return ( subset ~ /^ticlib$/ );
+       }
+function is_termlib() {
+               return ( subset ~ /^(ticlib\+)?termlib((\+[^+ ]+)*\+[a-z_]+_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
 function symlink(src,dst) {
                if ( src != dst ) {
                        printf "rm -f %s; ", dst
@@ -58,25 +121,28 @@ function symlink(src,dst) {
        }
 function rmlink(directory, dst) {
                printf "\t-rm -f %s/%s\n", directory, dst
        }
 function rmlink(directory, dst) {
                printf "\t-rm -f %s/%s\n", directory, dst
-}
+       }
 function removelinks(directory) {
                rmlink(directory, end_name);
                if ( DoLinks == "reverse" ) {
 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 {
                } 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
 function sharedlinks(directory) {
                if ( ShlibVer != "auto" && ShlibVer != "cygdll" ) {
                        printf "\tcd %s && (", directory
@@ -98,6 +164,60 @@ function sharedlinks(directory) {
                        printf ")\n"
                }
        }
                        printf ")\n"
                }
        }
+# 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/ || subset == "ticlib" ) {
+                       save_suffix = suffix
+                       sub(/^[^.]\./,".",suffix)
+                       if (directory != "../lib") {
+                               printf "\t\t%s/%s \\\n", "../lib", termlib_end_of();
+                       }
+                       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"
+               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 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
+               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
 BEGIN  {
                found = 0
                using = 0
@@ -110,13 +230,32 @@ BEGIN     {
                        if (using == 0) {
                                if (found == 0) {
                                        print  ""
                        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 "#  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 
+                                       printf "#  overwrite:     %s\n", overwrite 
+                                       printf "#  depend:        %s\n", depend 
+                                       printf "#  host:          %s\n", host 
                                        print  ""
                                }
                                using = 1
                        }
                                        print  ""
                                }
                                using = 1
                        }
-                       if ( subset == "termlib") {
-                               name  = "tinfo"
+                       if ( is_ticlib() ) {
+                               OBJS  = MODEL "_P"
+                       } else if ( is_termlib() ) {
                                OBJS  = MODEL "_T"
                        } else {
                                OBJS  = MODEL
                                OBJS  = MODEL "_T"
                        } else {
                                OBJS  = MODEL
@@ -146,7 +285,7 @@ BEGIN       {
                                else
                                        found = 2
                        }
                                else
                                        found = 2
                        }
-                       printf " \\\n\t../%s/%s.o", model, $1
+                       printf " \\\n\t../%s/%s$o", model, $1
                }
        }
 END    {
                }
        }
 END    {
@@ -158,86 +297,52 @@ END       {
                if ( found == 1 )
                {
                        print  ""
                if ( found == 1 )
                {
                        print  ""
-                       lib_name = sprintf("%s%s%s", prefix, name, suffix)
+                       lib_name = lib_name_of(name);
                        if ( MODEL == "SHARED" )
                        {
                        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);
-                                       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") {
-                                       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_build("../lib")
 
                                print  ""
                                print  "install \\"
                                print  "install.libs \\"
 
                                print  ""
                                print  "install \\"
                                print  "install.libs \\"
-                               printf "install.%s :: %s $(LIBRARIES)\n", name, dst_dirs
 
                                if ( ShlibVer == "cygdll" ) {
 
 
                                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 {
 
 
                                } 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 ""
+                                       if ( ReLink == "yes" ) {
+                                               shlib_build(lib_dir)
+                                       } else {
+                                               shlib_install(lib_dir)
+                                       }
                                }
 
                                if ( overwrite == "yes" && name == "ncurses" )
                                {
                                }
 
                                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  ""
                                        printf "\t- test -z \"$(DESTDIR)\" && %s\n", ldconfig
                                }
                                print  ""
@@ -257,7 +362,11 @@ END        {
                                        removelinks("$(DESTDIR)$(libdir)")
                                        if ( overwrite == "yes" && name == "ncurses" )
                                        {
                                        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
                                        }
                                }
                                                printf "\t-@rm -f $(DESTDIR)$(libdir)/%s\n", ovr_name
                                        }
                                }
@@ -277,29 +386,35 @@ END       {
                                }
                                end_name = lib_name;
                                printf "../lib/%s : $(%s_OBJS)\n", lib_name, OBJS
                                }
                                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
+                               if ( is_ticlib() ) {
+                                       printf "\tcd ../lib && $(LIBTOOL_LINK) $(%s) -o %s $(%s_OBJS:$o=.lo) -rpath $(DESTDIR)$(libdir) -version-info $(NCURSES_MAJOR):$(NCURSES_MINOR) $(LT_UNDEF) $(TICS_LIST)\n", compile, lib_name, OBJS
+                               } else if ( is_termlib() ) {
+                                       printf "\tcd ../lib && $(LIBTOOL_LINK) $(%s) -o %s $(%s_OBJS:$o=.lo) -rpath $(DESTDIR)$(libdir) -version-info $(NCURSES_MAJOR):$(NCURSES_MINOR) $(LT_UNDEF) $(TINFO_LIST)\n", compile, lib_name, OBJS
+                               } else {
+                                       printf "\tcd ../lib && $(LIBTOOL_LINK) $(%s) -o %s $(%s_OBJS:$o=.lo) -rpath $(DESTDIR)$(libdir) -version-info $(NCURSES_MAJOR):$(NCURSES_MINOR) $(LT_UNDEF) $(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
                                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
                                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
                        {
                                end_name = lib_name;
                                printf "../lib/%s : $(%s_OBJS)\n", lib_name, OBJS
                        }
                        else
                        {
                                end_name = lib_name;
                                printf "../lib/%s : $(%s_OBJS)\n", lib_name, OBJS
-                               printf "\t$(AR) $(AR_OPTS) $@ $?\n"
+                               printf "\t$(AR) $(ARFLAGS) $@ $?\n"
                                printf "\t$(RANLIB) $@\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 \\"
                                }
                                print  ""
                                print  "install \\"
@@ -314,10 +429,10 @@ END       {
                                        printf "\t(cd $(DESTDIR)$(libdir) && $(LN_S) libncurses.a libcurses.a)\n"
                                }
                                printf "\t$(RANLIB) $(DESTDIR)$(libdir)/%s\n", lib_name
                                        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 \\"
                                }
                                print  ""
                                print  "uninstall \\"
@@ -330,10 +445,10 @@ END       {
                                        printf "\t@echo linking libcurses.a to libncurses.a\n"
                                        printf "\t-@rm -f $(DESTDIR)$(libdir)/libcurses.a\n"
                                }
                                        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 ""
                                }
                        }
                        print ""
@@ -343,7 +458,7 @@ END {
                        print "mostlyclean::"
                        printf "\t-rm -f $(%s_OBJS)\n", OBJS
                        if ( MODEL == "LIBTOOL" ) {
                        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 )
                        }
                }
                else if ( found == 2 )
@@ -352,13 +467,14 @@ END       {
                        print "mostlyclean::"
                        printf "\t-rm -f $(%s_OBJS)\n", OBJS
                        if ( MODEL == "LIBTOOL" ) {
                        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" ) {
                        }
                        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
                        }
                }
        }
                        }
                }
        }
+# vile:ts=4 sw=4