Introduce Makefile for Java build
authorMathieu Baudier <mbaudier@argeo.org>
Fri, 28 Jan 2022 10:00:58 +0000 (11:00 +0100)
committerMathieu Baudier <mbaudier@argeo.org>
Fri, 28 Jan 2022 10:00:58 +0000 (11:00 +0100)
Makefile
org.argeo.api.uuid/jni/org_argeo_api_uuid/.gitignore [new file with mode: 0644]
org.argeo.api.uuid/jni/org_argeo_api_uuid/Makefile
sdk/dnf-tp.sh [new file with mode: 0644]
sdk/fedora-tp-rcp.target [new file with mode: 0644]
sdk/includes.mk
sdk/jni.mk

index 649560c5ae33bc0866a268daa55001483551b54d..21af0b9d0cc5334ca8f3dcd42e50f82314623329 100644 (file)
--- a/Makefile
+++ b/Makefile
@@ -1,11 +1,70 @@
+include sdk.mk
+
 MAKEDIRS = org.argeo.api.uuid
 
 BUILD_BASE=generated
 
-.PHONY: clean all
-all:
+.PHONY: clean all base rcp
+all: base
        $(foreach dir, $(MAKEDIRS), $(MAKE) -C $(dir);)
        
 clean:
        $(foreach dir, $(MAKEDIRS), $(MAKE) -C $(dir) clean;)
 
+
+JVM := /usr/lib/jvm/jre-11/bin/java
+ECJ_JAR := /usr/share/java/ecj/ecj.jar
+
+BASE_CLASSPATH=\
+/usr/share/java/osgi-core/osgi.core.jar:$\
+/usr/share/java/osgi-compendium/osgi.cmpn.jar:$\
+/usr/share/java/ecj/ecj.jar:$\
+/usr/share/java/aqute-bnd/biz.aQute.bndlib.jar:$\
+/usr/share/java/slf4j/api.jar:$\
+/usr/share/java/commons-io.jar:$\
+/usr/share/java/commons-cli.jar:$\
+/usr/share/java/bcprov.jar:$\
+/usr/share/java/bcpkix.jar:$\
+/usr/share/java/commons-httpclient3.jar:$\
+/usr/share/java/postgresql-jdbc.jar
+
+base: 
+       $(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] \
+
+
+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:$\
+/usr/share/java/tomcat-servlet-api.jar:$\
+/usr/share/java/eclipse/equinox.http.jetty.jar:$\
+/usr/lib/java/swt.jar:$\
+/usr/lib/eclipse/plugins/org.eclipse.swt.gtk.linux.x86_64_3.116.0.v20210304-1735:$\
+/usr/lib/eclipse/plugins/org.eclipse.e4.ui.css.core_0.13.0.v20210304-1735.jar:$\
+/usr/lib/eclipse/plugins/org.eclipse.e4.ui.css.swt_0.14.100.v20210304-1735.jar:$\
+/usr/lib/eclipse/plugins/org.eclipse.e4.ui.css.swt.theme_0.13.0.v20210304-1735.jar:$\
+/usr/lib/eclipse/plugins/org.eclipse.jface_3.22.100.v20210304-1735.jar:$\
+/usr/lib/eclipse/plugins/org.eclipse.core.commands_3.9.800.v20210304-1735.jar:$\
+/usr/share/java/eclipse/equinox.common.jar:$\
+/usr/share/java/sac.jar
+
+
+rcp: base
+       $(JVM) -jar $(ECJ_JAR) -11 -nowarn -time -cp $(RCP_CLASSPATH) \
+       $(SDK_SRC_BASE)/org.argeo.cms.servlet/src[-d $(SDK_SRC_BASE)/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)/org.argeo.cms.swt/src[-d $(SDK_SRC_BASE)/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] \
+
+
diff --git a/org.argeo.api.uuid/jni/org_argeo_api_uuid/.gitignore b/org.argeo.api.uuid/jni/org_argeo_api_uuid/.gitignore
new file mode 100644 (file)
index 0000000..84c048a
--- /dev/null
@@ -0,0 +1 @@
+/build/
index 1c45b52a9acf5932e7c91067ed7cf3dd1f816ef8..336a38fac8db2438cfc9c52b5b65ca4a9de4c6f9 100644 (file)
@@ -1,5 +1,5 @@
 NATIVE_PACKAGE := org_argeo_api_uuid
 
-#include ../../../branch.mk
 include ../../../sdk.mk
+include $(SDK_SRC_BASE)/sdk/jni.mk
 
diff --git a/sdk/dnf-tp.sh b/sdk/dnf-tp.sh
new file mode 100644 (file)
index 0000000..1005f8c
--- /dev/null
@@ -0,0 +1 @@
+sudo dnf install osgi-core osgi-compendium ecj aqute-bnd eclipse-equinox-osgi apache-commons-io apache-commons-cli apache-commons-exec bouncycastle bouncycastle-pkix tomcat-servlet-4.0-api jakarta-commons-httpclient eclipse-platform slf4j postgresql-jdbc
\ No newline at end of file
diff --git a/sdk/fedora-tp-rcp.target b/sdk/fedora-tp-rcp.target
new file mode 100644 (file)
index 0000000..08540f7
--- /dev/null
@@ -0,0 +1,24 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<?pde version="3.8"?>
+<target name="fedora-tp-rcp">
+       <locations>
+               <location path="/usr/share/java/eclipse" type="Directory"/>
+               <location path="/usr/share/java/ecj" type="Directory"/>
+               <location path="/usr/share/java/" type="Directory"/>
+               <location path="/usr/share/java/slf4j" type="Directory"/>
+               <location path="/usr/share/java/jetty" type="Directory"/>
+       </locations>
+       <includeBundles>
+               <plugin id="bcprov"/>
+               <plugin id="bcpkix"/>
+               <plugin id="org.apache.commons.cli" version="1.5.0"/>
+               <plugin id="org.apache.commons.httpclient" version="3.1.0.v20080605-1935"/>
+               <plugin id="org.apache.commons.io" version="2.8.0"/>
+               <plugin id="org.eclipse.equinox.http.jetty"/>
+               <plugin id="org.eclipse.osgi"/>
+               <plugin id="org.eclipse.osgi.services"/>
+               <plugin id="slf4j.api" version="1.7.30"/>
+               <plugin id="org.eclipse.osgi.util"/>
+               <plugin id="jakarta.servlet-api"/>
+       </includeBundles>
+</target>
\ No newline at end of file
index 8f1aedaebcbc23bdf7f2ee915a71c35497b4a980..e69de29bb2d1d6434b8b29ae775ad8c2e48c5391 100644 (file)
@@ -1 +0,0 @@
-include $(SDK_SRC_BASE)/sdk/jni.mk
index e22460dc30bc218a0079751922a1cfc89e6c3add..b13ceaf00cb55fb772cb42561672b0a3682c689f 100644 (file)
@@ -18,7 +18,8 @@ LDFLAGS=-shared -fPIC -Wl,-soname,$(TARGET_EXEC).$(MAJOR).$(MINOR)
 #
 # Generic Argeo
 #
-BUILD_DIR := $(SDK_BUILD_BASE)/$(NATIVE_PACKAGE)
+#BUILD_DIR := $(SDK_BUILD_BASE)/$(NATIVE_PACKAGE)
+BUILD_DIR := ./build
 #META_INF_DIR := ./../META-INF
 ARCH := $(shell uname -p)