Makefile 5.2 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25
#
# Copyright 2009 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.
#

26 27 28
BUILDDIR = ..
include $(BUILDDIR)/common/Defs.gmk

29 30
#
# Modularizing the JDK
31 32 33
# - Post jdk build process until the source tree is restructured
#   for modules build
# - <outputdir>/modules/<module> will be created for each module.
34
#
35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73
# Steps:
# 0. During jdk build before this makefile is invoked, classes, 
#    resource files, and other non-class files such as native libraries,
#    properties file, images, etc are created.
#
#    Non-class files are copied to <outputdir>/tmp/modules/<MODULE>
#    directory in this step to prepare for the post-build modularization. 
#
#    The MODULE variable defined in other makefiles specifies 
#    the lowest-level module that the non-class files belong to.
#    The name might or might not be the same as the name of the modules 
#    in the resulting <outputdir>/modules directory.
#    
# 1. Unpack all jars in the <builddir>/lib directory to a temporary 
#    location (<outputdir>/tmp/modules/classes) to prepare for modules
#    creation.
#
# 2. Run ClassAnalyzer tool to analyze all jdk classes and generate
#    class list for all modules and also perform dependency analysis. 
#
#    Input configuration files :-
#
#    modules.config : defines the low-level modules and specifies 
#       what classes and resource files each module includes.
#    modules.group  : defines the module groups and its members.
#    jdk7.depconfig : lists the dynamic dependencies including
#       use of reflection Class.forName and JNI FindClass and
#       service provider.
#    optional.depconfig : lists the optional dependencies
#
# 3. Create one directory for each module (<outputdir>/modules/<module>)
#    based on the output files from (2).
#       
#    modules.list lists the modules to be created for the modules
#    build and its members. For each module (m) in modules.list,
#    a. create $m/lib/$m.jar with all classes and resource files
#       listed in $m.classlist and $m.resources respectively.
#    b. copy all non-class files from its members to 
#       <outputdir>/modules/$m.
74 75 76 77 78


MAINMANIFEST=$(JDK_TOPDIR)/make/tools/manifest.mf
MODULE_JAR_MANIFEST_FILE=$(ABS_TEMPDIR)/manifest.tmp

79 80 81
TMP = $(ABS_MODULES_TEMPDIR)
MODULE_CLASSLIST = $(ABS_MODULES_TEMPDIR)/classlist
MODULE_CLASSES = $(ABS_MODULES_TEMPDIR)/classes
82
MODULES_LIST = $(MODULE_CLASSLIST)/modules.list
83 84 85

all:: unpack-jars gen-classlist modularize

86
JAR_LIST := $(shell $(FIND) $(ABS_OUTPUTDIR)/lib -name \*.jar -print) 
87
unpack-jars:
88
	@$(ECHO) ">>>Making "$@" @ `$(DATE)` ..."
89 90 91
	$(RM) -rf $(MODULE_CLASSES)
	$(MKDIR) -p $(MODULE_CLASSES)
	$(CP) -rf $(CLASSBINDIR)/* $(MODULE_CLASSES)
92
	@for jf in  $(JAR_LIST) ; do \
93 94 95 96
	   $(CD) $(MODULE_CLASSES) && $(BOOT_JAR_CMD) xf $$jf $(BOOT_JAR_JFLAGS);\
	done
	@$(ECHO) ">>>Finished making "$@" @ `$(DATE)` ..."

97 98 99
gen-classlist:
	$(CD) tools && $(MAKE) all

100 101
modularize: $(MODULE_JAR_MANIFEST_FILE)
	@$(ECHO) ">>>Making "$@" @ `$(DATE)` ..."
102
	@$(RM) -rf $(MODULES_DIR)
103

104 105 106
	@# create jar file for modules and
	@# copy other files from all members of this module 
	for m in `$(NAWK) '{print $$1}' $(MODULES_LIST)` ; do \
107 108 109 110 111
   	   $(ECHO) "Creating module $$m" ; \
   	   $(SED) -e 's%\\%\/%g' < $(MODULE_CLASSLIST)/$$m.classlist > $(TMP)/tmp.cf ; \
	   if [ -f $(MODULE_CLASSLIST)/$$m.resources ] ; then \
   	       $(SED) -e 's%\\%\/%g' < $(MODULE_CLASSLIST)/$$m.resources >> $(TMP)/tmp.cf ; \
           fi ; \
112
           $(MKDIR) -p $(ABS_MODULES_DIR)/$$m/lib; \
113 114
	   $(CD) $(MODULE_CLASSES) && \
               $(BOOT_JAR_CMD) c0mf $(MODULE_JAR_MANIFEST_FILE) \
115
		   $(ABS_MODULES_DIR)/$$m/lib/$$m.jar \
116 117 118 119
	           @$(TMP)/tmp.cf \
                   $(BOOT_JAR_JFLAGS); \
	   for s in `$(GREP) "^$$m" $(MODULES_LIST)` ; do \
               if [ -d $(TMP)/$$s ] ; then \
120 121
               	   $(CP) -rf $(TMP)/$$s/*  $(ABS_MODULES_DIR)/$$m; \
		   $(RM) -rf $(ABS_MODULES_DIR)/$$m/classes; \
122 123 124
	       fi \
	   done \
        done
125 126 127 128 129 130 131 132
	@$(CD) $(MODULE_CLASSES) && $(java-vm-cleanup)
	@$(ECHO) ">>>Finished making "$@" @ `$(DATE)` ..."

$(MODULE_JAR_MANIFEST_FILE):
	$(SED) -e "s/@@RELEASE@@/$(RELEASE)/" $(MAINMANIFEST) > $@

clean clobber::
	$(RM) -rf $(MODULE_CLASSLIST)
133
	$(RM) -rf $(MODULES_DIR)
134
	$(RM) $(MODULE_JAR_MANIFEST_FILE)