--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/jdk/make/java/jli/Makefile Sat Dec 01 00:00:00 2007 +0000
@@ -0,0 +1,165 @@
+#
+# Copyright 2005-2006 Sun Microsystems, Inc. All Rights Reserved.
+# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+#
+# This code is free software; you can redistribute it and/or modify it
+# under the terms of the GNU General Public License version 2 only, as
+# published by the Free Software Foundation. Sun designates this
+# particular file as subject to the "Classpath" exception as provided
+# by Sun in the LICENSE file that accompanied this code.
+#
+# This code is distributed in the hope that it will be useful, but WITHOUT
+# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
+# version 2 for more details (a copy is included in the LICENSE file that
+# accompanied this code).
+#
+# You should have received a copy of the GNU General Public License version
+# 2 along with this work; if not, write to the Free Software Foundation,
+# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+#
+# Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+# CA 95054 USA or visit www.sun.com if you need additional information or
+# have any questions.
+#
+
+#
+# Java Launcher Infrastructure Library (libjli)
+#
+# This library provides shared support for the Java launcher in all of
+# its manifestations (java, javaw, javac, ...).
+#
+BUILDDIR = ../..
+LIBRARY = jli
+PRODUCT = java
+
+#
+# Must be included before Defs.gmk to be functional.
+#
+# Note that for Windows, both a dynamic and static version are built.
+# Doing the compiles with the static library specified can be overridden
+# by the link step, but not the reverse.
+#
+MS_RUNTIME_STATIC = true
+
+include $(BUILDDIR)/common/Defs.gmk
+
+ZLIB_VERSION = 1.1.3
+ZIP_SRC = $(SHARE_SRC)/native/java/util/zip/zlib-$(ZLIB_VERSION)
+LAUNCHER_SHARE_SRC = $(SHARE_SRC)/bin
+LAUNCHER_PLATFORM_SRC = $(PLATFORM_SRC)/bin
+
+ifeq ($(ARCH_FAMILY), amd64)
+ERGO_FAMILY=i586
+else
+ERGO_FAMILY=$(ARCH_FAMILY)
+endif
+
+
+#
+# Files to compile.
+#
+FILES_c = \
+ java.c \
+ splashscreen_stubs.c \
+ java_md.c \
+ parse_manifest.c \
+ version_comp.c \
+ wildcard.c \
+ jli_util.c \
+ inflate.c \
+ infblock.c \
+ inftrees.c \
+ infcodes.c \
+ inffast.c \
+ infutil.c \
+ zadler32.c \
+ zutil.c
+
+ifneq ($(PLATFORM), windows)
+
+FILES_c += \
+ $(CTARGDIR)ergo.c \
+ $(CTARGDIR)ergo_$(ERGO_FAMILY).c
+endif
+
+
+# Names of arch directories
+LIBARCH_DEFINES = -DLIBARCHNAME='"$(LIBARCH)"'
+ifeq ($(PLATFORM), solaris)
+ LIBARCH_DEFINES += -DLIBARCH32NAME='"$(LIBARCH32)"'
+ LIBARCH_DEFINES += -DLIBARCH64NAME='"$(LIBARCH64)"'
+endif
+
+OTHER_CPPFLAGS += $(LIBARCH_DEFINES)
+
+
+ifneq ($(PLATFORM), windows) # UNIX systems
+ LIB_LOCATION = $(LIBDIR)/$(LIBARCH)/jli
+ # Note: its important to keep this order meaning -lc is the
+ # last library otherwise it could cause compatibility issues
+ # by pulling in SUNW_private symbols from libc
+ LDLIBS = -ldl -lc
+ifeq ($(USE_PTHREADS),true)
+ LDLIBS += -lpthread
+endif # USE_PTHREADS
+endif # PLATFORM
+
+ifeq ($(PLATFORM), windows)
+ EXTRA_LIBS = advapi32.lib \
+ user32.lib
+
+ JAVALIB =
+ OTHER_LCF = -export:JLI_Launch \
+ -export:JLI_ManifestIterate \
+ -export:JLI_SetTraceLauncher
+
+ # Files from zlib built here do not compile with warning level 3
+ # if warnings are fatal
+ COMPILER_WARNINGS_FATAL=false
+endif
+
+OTHER_INCLUDES += -I$(LAUNCHER_SHARE_SRC)
+OTHER_INCLUDES += -I$(LAUNCHER_PLATFORM_SRC)
+OTHER_INCLUDES += -I$(ZIP_SRC)
+
+#
+# Library to compile.
+#
+include $(BUILDDIR)/common/Mapfile-vers.gmk
+include $(BUILDDIR)/common/Library.gmk
+
+#
+# On Windows, some executable objects need to be statically linked against
+# the jli library. Hence, we need both a standard library (archive) and
+# an import library (associated with a dll). These both usually have the
+# extension .LIB, so they need to be placed in different directories. The
+# import library is build (as usual) in the $(OBJDIR) directory while the
+# standard library is built in a "static" subdirectory. The standard library
+# is not delivered as part of the product, but is only needed as part of
+# the build process. The import library is built by the standard rules
+# in Library.gmk. The additional rules which follow build the standard
+# library.
+#
+ifeq ($(PLATFORM), windows)
+
+STATIC_LIBRARY_DIR = $(OBJDIR)/static
+STATIC_LIBRARY_NAME = $(LIBPREFIX)$(LIBRARY).lib
+STATIC_LIBRARY = $(STATIC_LIBRARY_DIR)/$(STATIC_LIBRARY_NAME)
+
+$(STATIC_LIBRARY_DIR): $(OBJDIR)
+ @$(prep-target)
+ @$(MKDIR) $(STATIC_LIBRARY_DIR)
+
+$(STATIC_LIBRARY): $(STATIC_LIBRARY_DIR)
+ @$(prep-target)
+ $(LIBEXE) -nologo -out:$@ $(FILES_o)
+
+library:: $(STATIC_LIBRARY)
+
+endif # PLATFORM
+
+#
+# Add to ambient vpath so we pick up the library files
+#
+vpath %.c $(LAUNCHER_SHARE_SRC) $(ZIP_SRC) $(LAUNCHER_PLATFORM_SRC)