ncurses 5.9 - patch 20120825
[ncurses.git] / mk-1st.awk
index 7d9390522895ac349826f866d602bf04506b5b14..b2203c39214f2f87345f8e42bcadfc8eee97b72c 100644 (file)
@@ -1,6 +1,6 @@
-# $Id: mk-1st.awk,v 1.83 2010/05/15 19:14:44 tom Exp $
+# $Id: mk-1st.awk,v 1.88 2012/02/25 20:22:09 tom Exp $
 ##############################################################################
-# Copyright (c) 1998-2009,2010 Free Software Foundation, Inc.                #
+# Copyright (c) 1998-2011,2012 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)
@@ -68,7 +70,7 @@ function lib_name_of(a_name) {
        }
 # see imp_name
 function imp_name_of(a_name) {
-               if (ShlibVerInfix == "cygdll") {
+               if (ShlibVerInfix == "cygdll" || ShlibVerInfix == "mingw") {
                        result = sprintf("%s%s%s.a", prefix, a_name, suffix);
                } else {
                        result = "";
@@ -79,6 +81,8 @@ function imp_name_of(a_name) {
 function abi_name_of(a_name) {
                if (ShlibVerInfix == "cygdll") {
                        result = sprintf("%s%s$(ABI_VERSION)%s", "cyg", a_name, suffix);
+               } else if (ShlibVerInfix == "mingw") {
+                       result = sprintf("%s%s$(ABI_VERSION)%s", prefix, a_name, suffix);
                } else if (ShlibVerInfix == "yes") {
                        result = sprintf("%s%s.$(ABI_VERSION)%s", prefix, a_name, suffix);
                } else {
@@ -90,6 +94,8 @@ function abi_name_of(a_name) {
 function rel_name_of(a_name) {
                if (ShlibVerInfix == "cygdll") {
                        result = sprintf("%s%s$(REL_VERSION)%s", "cyg", a_name, suffix);
+               } else if (ShlibVerInfix == "mingw") {
+                       result = sprintf("%s%s$(REL_VERSION)%s", prefix, a_name, suffix);
                } else if (ShlibVerInfix == "yes") {
                        result = sprintf("%s%s.$(REL_VERSION)%s", prefix, a_name, suffix);
                } else {
@@ -106,7 +112,7 @@ function end_name_of(a_name) {
                } else {
                        if ( ShlibVer == "rel" ) {
                                result = rel_name_of(a_name);
-                       } else if ( ShlibVer == "abi" || ShlibVer == "cygdll" ) {
+                       } else if ( ShlibVer == "abi" || ShlibVer == "cygdll" || ShlibVer == "mingw" ) {
                                result = abi_name_of(a_name);
                        } else {
                                result = lib_name_of(a_name);
@@ -116,7 +122,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
                }
        }
@@ -145,7 +153,7 @@ 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" ) {
+               if ( ShlibVer != "auto" && ShlibVer != "cygdll" && ShlibVer != "mingw" ) {
                        printf "\tcd %s && (", directory
                        if ( DoLinks == "reverse" ) {
                                if ( ShlibVer == "rel" ) {
@@ -178,6 +186,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)
@@ -239,8 +252,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 
@@ -312,7 +327,7 @@ END {
                                print  "install \\"
                                print  "install.libs \\"
 
-                               if ( ShlibVer == "cygdll" ) {
+                               if ( ShlibVer == "cygdll" || ShlibVer == "mingw") {
 
                                        dst_dirs = "$(DESTDIR)$(bindir) $(DESTDIR)$(libdir)";
                                        printf "install.%s :: %s $(LIBRARIES)\n", name, dst_dirs
@@ -333,14 +348,18 @@ END       {
 
                                if ( overwrite == "yes" && name == "ncurses" )
                                {
-                                       if ( ShlibVer == "cygdll" ) {
+                                       if ( ShlibVer == "cygdll" || ShlibVer == "mingw") {
                                                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 != ":" ) {
@@ -350,7 +369,7 @@ END {
                                print  "uninstall \\"
                                print  "uninstall.libs \\"
                                printf "uninstall.%s ::\n", name
-                               if ( ShlibVer == "cygdll" ) {
+                               if ( ShlibVer == "cygdll" || ShlibVer == "mingw") {
 
                                        printf "\t@echo uninstalling $(DESTDIR)$(bindir)/%s\n", end_name
                                        printf "\t-@rm -f $(DESTDIR)$(bindir)/%s\n", end_name
@@ -363,11 +382,7 @@ END        {
                                        removelinks("$(DESTDIR)$(libdir)")
                                        if ( overwrite == "yes" && name == "ncurses" )
                                        {
-                                               if ( ShlibVer == "cygdll" ) {
-                                                       ovr_name = sprintf("libcurses%s.a", suffix)
-                                               } else {
-                                                       ovr_name = sprintf("libcurses%s", suffix)
-                                               }
+                                               ovr_name = sprintf("libcurses%s", suffix)
                                                printf "\t-@rm -f $(DESTDIR)$(libdir)/%s\n", ovr_name
                                        }
                                }
@@ -388,12 +403,13 @@ END       {
                                end_name = lib_name;
                                printf "../lib/%s : $(%s_OBJS)\n", lib_name, OBJS
                                if ( is_ticlib() ) {
-                                       printf "\tcd ../lib && $(LIBTOOL_LINK) $(%s) -o %s $(%s_OBJS:$o=.lo) -rpath $(DESTDIR)$(libdir) %s $(NCURSES_MAJOR):$(NCURSES_MINOR) $(LT_UNDEF) $(TICS_LIST)\n", compile, lib_name, OBJS, libtool_version
+                                       which_list = "TICS_LIST";
                                } else if ( is_termlib() ) {
-                                       printf "\tcd ../lib && $(LIBTOOL_LINK) $(%s) -o %s $(%s_OBJS:$o=.lo) -rpath $(DESTDIR)$(libdir) %s $(NCURSES_MAJOR):$(NCURSES_MINOR) $(LT_UNDEF) $(TINFO_LIST)\n", compile, lib_name, OBJS, libtool_version
+                                       which_list = "TINFO_LIST";
                                } else {
-                                       printf "\tcd ../lib && $(LIBTOOL_LINK) $(%s) -o %s $(%s_OBJS:$o=.lo) -rpath $(DESTDIR)$(libdir) %s $(NCURSES_MAJOR):$(NCURSES_MINOR) $(LT_UNDEF) $(SHLIB_LIST)\n", compile, lib_name, OBJS, libtool_version
+                                       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 \\"
@@ -427,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" )