#
# 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)