ncurses 5.9 - patch 20120218
[ncurses.git] / mk-1st.awk
index e2f54ea4cbec94e6b7720a5ec37960795e6091f5..e48584c8dc803829d1eb80edd667b399eb79e92a 100644 (file)
@@ -1,6 +1,6 @@
-# $Id: mk-1st.awk,v 1.78 2007/03/24 22:10:55 tom Exp $
+# $Id: mk-1st.awk,v 1.87 2011/12/17 20:27:27 tom Exp $
 ##############################################################################
-# Copyright (c) 1998-2006,2007 Free Software Foundation, Inc.                #
+# Copyright (c) 1998-2010,2011 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"), #
 #      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.)
+#      driver            ("yes" or "no", depends on --enable-term-driver)
 #      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)
+#      SymLink           ("ln -s", etc)
+#      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)
@@ -49,6 +51,7 @@
 #      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)
+#      libtool_version (libtool "-version-info" or "-version-number")
 #
 # Notes:
 #      CLIXs nawk does not like underscores in command-line variable names.
@@ -59,7 +62,7 @@ function is_ticlib() {
                return ( subset ~ /^ticlib$/ );
        }
 function is_termlib() {
-               return ( subset ~ /^(ticlib\+)?termlib(\+ext_tinfo)?$/ );
+               return ( subset ~ /^(ticlib\+)?termlib((\+[^+ ]+)*\+[a-z_]+_tinfo)?$/ );
        }
 # see lib_name
 function lib_name_of(a_name) {
@@ -115,7 +118,9 @@ function end_name_of(a_name) {
        }
 function symlink(src,dst) {
                if ( src != dst ) {
-                       printf "rm -f %s; ", dst
+                       if ( SymLink !~ /.*-f.*/ ) {
+                               printf "rm -f %s; ", dst
+                       }
                        printf "$(LN_S) %s %s; ", src, dst
                }
        }
@@ -177,6 +182,11 @@ 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 == "ticlib" && driver == "yes" ) {
+                       base = name;
+                       sub(/^tic/, "ncurses", base); # workaround for "w"
+                       printf "\t\t%s/%s \\\n", directory, end_name_of(base);
+               }
                if (subset ~ /^base/ || subset == "ticlib" ) {
                        save_suffix = suffix
                        sub(/^[^.]\./,".",suffix)
@@ -238,8 +248,10 @@ BEGIN      {
                                        printf "#  prefix:        %s\n", prefix 
                                        printf "#  suffix:        %s\n", suffix 
                                        printf "#  subset:        %s\n", subset 
+                                       printf "#  driver:        %s\n", driver 
                                        printf "#  ShlibVer:      %s\n", ShlibVer 
                                        printf "#  ShlibVerInfix: %s\n", ShlibVerInfix 
+                                       printf "#  SymLink:       %s\n", SymLink 
                                        printf "#  TermlibRoot:   %s\n", TermlibRoot 
                                        printf "#  TermlibSuffix: %s\n", TermlibSuffix 
                                        printf "#  ReLink:        %s\n", ReLink 
@@ -335,11 +347,15 @@ END       {
                                        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
+                                               printf "\tcd $(DESTDIR)$(libdir) && ("
+                                               symlink(imp_name, ovr_name)
+                                               printf ")\n"
                                        } 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
+                                               printf "\tcd $(DESTDIR)$(libdir) && ("
+                                               symlink(end_name, ovr_name)
+                                               printf ")\n"
                                        }
                                }
                                if ( ldconfig != "" && ldconfig != ":" ) {
@@ -386,7 +402,14 @@ END        {
                                }
                                end_name = lib_name;
                                printf "../lib/%s : $(%s_OBJS)\n", 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
+                               if ( is_ticlib() ) {
+                                       which_list = "TICS_LIST";
+                               } else if ( is_termlib() ) {
+                                       which_list = "TINFO_LIST";
+                               } else {
+                                       which_list = "SHLIB_LIST";
+                               }
+                               printf "\tcd ../lib && $(LIBTOOL_LINK) $(%s) -o %s $(%s_OBJS:$o=.lo) -rpath $(DESTDIR)$(libdir) %s $(NCURSES_MAJOR):$(NCURSES_MINOR) $(LT_UNDEF) $(%s) $(LDFLAGS)\n", compile, lib_name, OBJS, libtool_version, which_list
                                print  ""
                                print  "install \\"
                                print  "install.libs \\"
@@ -404,7 +427,7 @@ END {
                        {
                                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"
                                if ( host == "vxworks" )
                                {
@@ -420,7 +443,9 @@ END {
                                {
                                        printf "\t@echo linking libcurses.a to libncurses.a\n"
                                        printf "\t-@rm -f $(DESTDIR)$(libdir)/libcurses.a\n"
-                                       printf "\t(cd $(DESTDIR)$(libdir) && $(LN_S) libncurses.a libcurses.a)\n"
+                                       printf "\t(cd $(DESTDIR)$(libdir) && "
+                                       symlink("libncurses.a", "libcurses.a")
+                                       printf ")\n"
                                }
                                printf "\t$(RANLIB) $(DESTDIR)$(libdir)/%s\n", lib_name
                                if ( host == "vxworks" )