# # CDDL HEADER START # # The contents of this file are subject to the terms of the # Common Development and Distribution License (the "License"). # You may not use this file except in compliance with the License. # # You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE # or http://www.opensolaris.org/os/licensing. # See the License for the specific language governing permissions # and limitations under the License. # # When distributing Covered Code, include this CDDL HEADER in each # file and include the License file at usr/src/OPENSOLARIS.LICENSE. # If applicable, add the following below this CDDL HEADER, with the # fields enclosed by brackets "[]" replaced with your own identifying # information: Portions Copyright [yyyy] [name of copyright owner] # # CDDL HEADER END # # # Copyright 2008 Sun Microsystems, Inc. All rights reserved. # Use is subject to license terms. # # Copyright 2020 Peter Tribble # include $(SRC)/Makefile.master # The Java DTrace API package PKGPATH=org/opensolaris/os/dtrace PKGNAME=org.opensolaris.os.dtrace # The Java DTrace API directories APIDIR=$(SRC)/lib/libdtrace_jni/java CLASSES=$(APIDIR)/classes JARS=$(APIDIR)/lib # the files in the docs directory go with the api javadoc # which can be generated using the doc target # the documentation is not built or packaged by default DOCS=$(APIDIR)/docs DOCAPI=$(DOCS)/api DOCEXAMPLES=$(DOCS)/examples DOCHTML=$(DOCS)/html DOCIMAGES=$(DOCS)/images MANIFEST=$(APIDIR)/manifest APIJAVASRC=$(APIDIR)/src # Java DTrace API jar file, its ultimate destination, and packaging details APIJAR=dtrace.jar JARDESTDIR=$(ROOT)/usr/share/lib/java INSJARS=$(JARDESTDIR)/$(APIJAR) $(JARDESTDIR)/%: $(JARS)/% $(INS.file) # Manifest files APIMANI= $(MANIFEST)/dtrace.mf MANIFESTS= $(APIMANI) # Controlled CLASSPATH for making APICLASSPATH=$(CLASSES):$(APIJAVASRC) # javac flags JFLAGS= -g -d $(CLASSES) -sourcepath $(APICLASSPATH) JFLAGS += -source 7 -target 7 JFLAGS += -Xlint:all,-deprecation,-rawtypes,-options # The default make rule for Java files COMPILE.java=$(JAVAC) $(JFLAGS) $(CLASSES)/$(PKGPATH)/%.class: $(APIJAVASRC)/$(PKGPATH)/%.java $(COMPILE.java) $< # All API classes API_CLASSNAMES=\ AbstractAggregationValue \ Aggregate \ AggregateSpec \ Aggregation \ AggregationRecord \ AggregationValue \ AvgValue \ Consumer \ ConsumerAdapter \ ConsumerEvent \ ConsumerException \ ConsumerListener \ CountValue \ DTraceException \ DataEvent \ Distribution \ Drop \ DropEvent \ Error \ ErrorEvent \ ExceptionHandler \ ExitRecord \ Flow \ InterfaceAttributes \ KernelStackRecord \ KernelSymbolRecord \ LinearDistribution \ LocalConsumer \ LogDistribution \ LogLinearDistribution \ MaxValue \ MinValue \ NativeException \ Option \ PrintaRecord \ PrintfRecord \ Probe \ ProbeData \ ProbeDescription \ ProbeInfo \ ProcessEvent \ ProcessState \ Program \ ProgramInfo \ Record \ ResourceLimitException \ ScalarRecord \ StackFrame \ StackValueRecord \ StddevValue \ SumValue \ SymbolValueRecord \ Tuple \ UserStackRecord \ UserSymbolRecord \ Utility \ ValueRecord API_CLASSES=${API_CLASSNAMES:%=%.class} DTRACE_API_CLASSES=${API_CLASSES:%=$(CLASSES)/$(PKGPATH)/%} all: $(CLASSES) $(DTRACE_API_CLASSES) clean: -$(RM) $(CLASSES)/$(PKGPATH)/*.class -$(RM) -r $(DOCAPI) clobber: clean -$(RM) $(JARS)/*.jar # Make the class dir, if it doesn't exist $(CLASSES): -@mkdir -p $@ $(CLASSES)/$(PKGPATH): $(INS.dir) $(JARS)/$(APIJAR): $(DTRACE_API_CLASSES) $(APIMANI) -@mkdir -p $(JARS) $(JAR) cfm $@ $(APIMANI) -C $(CLASSES) . $(JARDESTDIR): $(INS.dir) install: all $(JARDESTDIR) $(INSJARS) # empty targets for top-level building compatability install_h: # create API javadoc doc: -@mkdir -p $(DOCAPI) cd $(APIJAVASRC); umask 022; \ $(JAVADOC) -protected -use -notimestamp \ -classpath $(APICLASSPATH) -d $(DOCAPI) \ $(PKGNAME)