jdk/make/java/jli/Makefile
changeset 2 90ce3da70b43
child 39 560da37936db
--- /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)