X-Git-Url: https://git.argeo.org/?a=blobdiff_plain;f=Makefile;h=3f4dc3c67b3f0f3509d435cf5753ce7d0c7833d0;hb=440389217546979193b60acdf973a40abac50747;hp=1145dde26b1bc838c6e7235bf80dfed3843bed1e;hpb=cd9c92edd861a4af57713284ba796186a5505dd2;p=lgpl%2Fargeo-commons.git diff --git a/Makefile b/Makefile index 1145dde26..3f4dc3c67 100644 --- a/Makefile +++ b/Makefile @@ -1,48 +1,86 @@ include sdk.mk - -MAKEDIRS = org.argeo.api.uuid - -BUILD_BASE := generated - -BASE_BUNDLES := $(BUILD_BASE)/org.argeo.api.uuid.$(MAJOR).$(MINOR).jar - .PHONY: clean all build-base build-rcp -all: build-base - $(foreach dir, $(MAKEDIRS), $(MAKE) -C $(dir);) +#.PRECIOUS: $(SDK_BUILD_BASE)/%/bundle.jar + +all: osgi jni + +OLD_BASE_BUNDLES := \ +$(SDK_BUILD_BASE)/org.argeo.init.$(MAJOR).$(MINOR).jar \ +$(SDK_BUILD_BASE)/org.argeo.util.$(MAJOR).$(MINOR).jar \ +$(SDK_BUILD_BASE)/org.argeo.api.uuid.$(MAJOR).$(MINOR).jar \ +$(SDK_BUILD_BASE)/org.argeo.api.acr.$(MAJOR).$(MINOR).jar \ +$(SDK_BUILD_BASE)/org.argeo.api.cms.$(MAJOR).$(MINOR).jar \ +$(SDK_BUILD_BASE)/org.argeo.cms.tp.$(MAJOR).$(MINOR).jar \ +$(SDK_BUILD_BASE)/org.argeo.cms.$(MAJOR).$(MINOR).jar \ + +BASE_BUNDLES := \ +org.argeo.init \ +org.argeo.util \ +org.argeo.api.uuid \ +org.argeo.api.acr \ +org.argeo.api.cms \ +org.argeo.cms.tp \ +org.argeo.cms \ + +NATIVE_PROJECTS = org.argeo.api.uuid/jni + +A2_BASE_BUNDLES := $(BASE_BUNDLES:%=$(SDK_BUILD_BASE)/a2/org.argeo/%.$(MAJOR).$(MINOR).jar) + + +osgi : $(A2_BASE_BUNDLES) + +jni: + $(foreach dir, $(NATIVE_PROJECTS), $(MAKE) -C $(dir);) clean: - $(foreach dir, $(MAKEDIRS), $(MAKE) -C $(dir) clean;) - - - + rm -rf $(SDK_BUILD_BASE)/*-compiled + rm -rf $(SDK_BUILD_BASE)/{cnf,a2} + rm -rf $(SDK_BUILD_BASE)/org.argeo.* + $(foreach dir, $(NATIVE_PROJECTS), $(MAKE) -C $(dir) clean;) JVM := /usr/lib/jvm/jre-11/bin/java ECJ_JAR := /usr/share/java/ecj/ecj.jar BND_TOOL := /usr/bin/bnd -#osgi : $(BASE_BUNDLES) +WORKSPACE_BNDS := $(shell find cnf -name '*.bnd') +BUILD_WORKSPACE_BNDS := $(WORKSPACE_BNDS:%=$(SDK_BUILD_BASE)/%) -#$(BUILD_BASE)/%.$(MAJOR).$(MINOR).jar : $(SDK_SRC_BASE)/% -# $(BND_TOOL) build $< -# cp $ $(dir $@)/bundle.jar +# rm -rf $(dir $@)/generated + -BASE_CLASSPATH=\ +$(SDK_BUILD_BASE)/cnf/%.bnd: $(SDK_SRC_BASE)/cnf/%.bnd + mkdir -p $(dir $@) + cp $< $@ + +$(SDK_BUILD_BASE)/%.bnd: $(SDK_SRC_BASE)/%.bnd + mkdir -p $(dir $@) + cp $< $@ + + +BASE_CLASSPATH := \ /usr/share/java/osgi-core/osgi.core.jar:$\ /usr/share/java/osgi-compendium/osgi.cmpn.jar:$\ /usr/share/java/ecj/ecj.jar:$\ @@ -55,25 +93,25 @@ BASE_CLASSPATH=\ /usr/share/java/commons-httpclient3.jar:$\ /usr/share/java/postgresql-jdbc.jar -build-base: +$(SDK_BUILD_BASE)/base-java-compiled : $(JAVA_SRCS) $(JVM) -jar $(ECJ_JAR) -11 -nowarn -time -cp $(BASE_CLASSPATH) \ - $(SDK_SRC_BASE)/org.argeo.api.uuid/src[-d $(SDK_SRC_BASE)/org.argeo.api.uuid/bin] \ - $(SDK_SRC_BASE)/org.argeo.api.acr/src[-d $(SDK_SRC_BASE)/org.argeo.api.acr/bin] \ - $(SDK_SRC_BASE)/org.argeo.api.cms/src[-d $(SDK_SRC_BASE)/org.argeo.api.cms/bin] \ - $(SDK_SRC_BASE)/org.argeo.init/src[-d $(SDK_SRC_BASE)/org.argeo.init/bin] \ - $(SDK_SRC_BASE)/org.argeo.util/src[-d $(SDK_SRC_BASE)/org.argeo.util/bin] \ - $(SDK_SRC_BASE)/org.argeo.cms.tp/src[-d $(SDK_SRC_BASE)/org.argeo.cms.tp/bin] \ - $(SDK_SRC_BASE)/org.argeo.cms/src[-d $(SDK_SRC_BASE)/org.argeo.cms/bin] \ - $(SDK_SRC_BASE)/org.argeo.cms.pgsql/src[-d $(SDK_SRC_BASE)/org.argeo.cms.pgsql/bin] \ + $(SDK_SRC_BASE)/org.argeo.api.uuid/src[-d $(SDK_BUILD_BASE)/org.argeo.api.uuid/bin] \ + $(SDK_SRC_BASE)/org.argeo.api.acr/src[-d $(SDK_BUILD_BASE)/org.argeo.api.acr/bin] \ + $(SDK_SRC_BASE)/org.argeo.api.cms/src[-d $(SDK_BUILD_BASE)/org.argeo.api.cms/bin] \ + $(SDK_SRC_BASE)/org.argeo.init/src[-d $(SDK_BUILD_BASE)/org.argeo.init/bin] \ + $(SDK_SRC_BASE)/org.argeo.util/src[-d $(SDK_BUILD_BASE)/org.argeo.util/bin] \ + $(SDK_SRC_BASE)/org.argeo.cms.tp/src[-d $(SDK_BUILD_BASE)/org.argeo.cms.tp/bin] \ + $(SDK_SRC_BASE)/org.argeo.cms/src[-d $(SDK_BUILD_BASE)/org.argeo.cms/bin] \ + $(SDK_SRC_BASE)/org.argeo.cms.pgsql/src[-d $(SDK_BUILD_BASE)/org.argeo.cms.pgsql/bin] \ - $(BND_TOOL) build + touch $@ RCP_CLASSPATH=$(BASE_CLASSPATH):$\ -$(SDK_SRC_BASE)/org.argeo.api.uuid/bin:$\ -$(SDK_SRC_BASE)/org.argeo.api.acr/bin:$\ -$(SDK_SRC_BASE)/org.argeo.api.cms/bin:$\ -$(SDK_SRC_BASE)/org.argeo.util/bin:$\ -$(SDK_SRC_BASE)/org.argeo.cms/bin:$\ +$(SDK_BUILD_BASE)/org.argeo.api.uuid/bin:$\ +$(SDK_BUILD_BASE)/org.argeo.api.acr/bin:$\ +$(SDK_BUILD_BASE)/org.argeo.api.cms/bin:$\ +$(SDK_BUILD_BASE)/org.argeo.util/bin:$\ +$(SDK_BUILD_BASE)/org.argeo.cms/bin:$\ /usr/share/java/tomcat-servlet-api.jar:$\ /usr/share/java/eclipse/equinox.http.jetty.jar:$\ /usr/lib/java/swt.jar:$\ @@ -89,10 +127,26 @@ $(SDK_SRC_BASE)/org.argeo.cms/bin:$\ build-rcp: build-base $(JVM) -jar $(ECJ_JAR) -11 -nowarn -time -cp $(RCP_CLASSPATH) \ - $(SDK_SRC_BASE)/eclipse/org.argeo.cms.servlet/src[-d $(SDK_SRC_BASE)/eclipse/org.argeo.cms.servlet/bin] \ - $(SDK_SRC_BASE)/rcp/org.argeo.swt.minidesktop/src[-d $(SDK_SRC_BASE)/rcp/org.argeo.swt.minidesktop/bin] \ - $(SDK_SRC_BASE)/rcp/org.argeo.swt.specific.rcp/src[-d $(SDK_SRC_BASE)/rcp/org.argeo.swt.specific.rcp/bin] \ - $(SDK_SRC_BASE)/eclipse/org.argeo.cms.swt/src[-d $(SDK_SRC_BASE)/eclipse/org.argeo.cms.swt/bin] \ - $(SDK_SRC_BASE)/rcp/org.argeo.cms.ui.rcp/src[-d $(SDK_SRC_BASE)/rcp/org.argeo.cms.ui.rcp/bin] \ + $(SDK_SRC_BASE)/eclipse/org.argeo.cms.servlet/src[-d $(SDK_BUILD_BASE)/eclipse/org.argeo.cms.servlet/bin] \ + $(SDK_SRC_BASE)/rcp/org.argeo.swt.minidesktop/src[-d $(SDK_BUILD_BASE)/rcp/org.argeo.swt.minidesktop/bin] \ + $(SDK_SRC_BASE)/rcp/org.argeo.swt.specific.rcp/src[-d $(SDK_BUILD_BASE)/rcp/org.argeo.swt.specific.rcp/bin] \ + $(SDK_SRC_BASE)/eclipse/org.argeo.cms.swt/src[-d $(SDK_BUILD_BASE)/eclipse/org.argeo.cms.swt/bin] \ + $(SDK_SRC_BASE)/rcp/org.argeo.cms.ui.rcp/src[-d $(SDK_BUILD_BASE)/rcp/org.argeo.cms.ui.rcp/bin] \ + +#base-java-sources : $(shell find org.argeo.* -name '*.java') + +#base-java-classes : $(shell find org.argeo.* -name '*.class') + +# each dir depends on its package directories +#$(SDK_SRC_BASE)/% : $(shell find */src -type f | sed "s%/[^/]*$%%" | sort -u) + +# non empty package dirs +#$(SDK_SRC_BASE)/*/src/% : $(shell grep --no-filename ^import '%/*.java' | sed 's/import //g' | sed 's/static //g' | sed 's/\.[A-Za-z0-9_]*;//' | sed 's/\.[A-Z].*//' | sort | uniq) + +# convert dir to package +#$(shell find %/src -mindepth 1 -type d -printf '%P\n' | sed "s/\//\./g") + +# all packages +# grep --no-filename ^import src/org/argeo/api/uuid/*.java | sed "s/import //g" | sed "s/static //g" | sed "s/\.[A-Za-z0-9_]*;//" | sed "s/\.[A-Z].*//" | sort | uniq