rinoux
4 years ago
commit
416064bdf5
11 changed files with 721 additions and 0 deletions
@ -0,0 +1,165 @@ |
|||||||
|
import org.gradle.plugins.ide.idea.model.IdeaLanguageLevel |
||||||
|
|
||||||
|
plugins { |
||||||
|
id 'java' |
||||||
|
id 'java-library' |
||||||
|
} |
||||||
|
|
||||||
|
def loadLocalProp() { |
||||||
|
Properties prop = new Properties(); |
||||||
|
File propFile = new File(projectDir.getAbsolutePath(), "local.properties") |
||||||
|
if (propFile.exists()) { |
||||||
|
prop.load(propFile.newDataInputStream()) |
||||||
|
} |
||||||
|
return prop |
||||||
|
} |
||||||
|
|
||||||
|
def getRootGradle() { |
||||||
|
def currentGradle = gradle |
||||||
|
while (currentGradle.parent) { |
||||||
|
currentGradle = currentGradle.parent |
||||||
|
} |
||||||
|
return currentGradle |
||||||
|
} |
||||||
|
|
||||||
|
def findOutputPath(Properties p) { |
||||||
|
def localEnv = p.getProperty("local.env") |
||||||
|
if (localEnv != null && localEnv.length() > 0) { |
||||||
|
return localEnv |
||||||
|
} |
||||||
|
def rootGradle = getRootGradle() |
||||||
|
def hookProject = rootGradle.getIncludedBuilds() |
||||||
|
.find({ build -> build.name == 'hook' }) |
||||||
|
if (hookProject) { |
||||||
|
def path = hookProject.projectDir.parentFile.parent + '/env/webroot/WEB-INF' |
||||||
|
return path |
||||||
|
} |
||||||
|
return projectDir.getAbsolutePath() + "/env/webroot/WEB-INF" |
||||||
|
} |
||||||
|
|
||||||
|
def getFRVersion(String name) { |
||||||
|
def v = localProp.getProperty("local.dev." + name) |
||||||
|
if ("true".equalsIgnoreCase(v)) { |
||||||
|
return "DEV" + frVersion |
||||||
|
} |
||||||
|
return frVersion |
||||||
|
} |
||||||
|
|
||||||
|
/* |
||||||
|
工程自定义配置说明 |
||||||
|
--------------- |
||||||
|
1. 工程env默认情况为build.gradle所在目录下的env/webroot/WEB-INF, |
||||||
|
如果本工程是导入FR主代码工程中,env路径是主代码工程finereport-maven所在目录下的env/webroot/WEB-INF |
||||||
|
2. 如果需要自定义env路径,则在build.gradle所在目录下创建一个local.properties文件(该文件不会进入git仓库) |
||||||
|
在里面添加: |
||||||
|
local.env=你的WEB-INF目录 |
||||||
|
3. 主jar依赖默认只依赖jar包,对于有代码的模块,也可以在local.properties文件中增加对应的配置来让其依赖代码 |
||||||
|
例如存在core和report-engine的代码,只需在local.properties中新增: |
||||||
|
local.dev.core=true |
||||||
|
local.dev.report-engine=true |
||||||
|
最终的依赖就是: |
||||||
|
com.fr.core:fine-core:DEV10.0-RELEASE-SNAPSHOT |
||||||
|
com.fr.report:fine-report-engine:DEV10.0-RELEASE-SNAPSHOT |
||||||
|
可以依赖代码的模块有以下几个: |
||||||
|
local.dev.third=true |
||||||
|
local.dev.core=true |
||||||
|
local.dev.activator=true |
||||||
|
local.dev.datasource=true |
||||||
|
local.dev.webui=true |
||||||
|
local.dev.decision=true |
||||||
|
local.dev.decision-report=true |
||||||
|
local.dev.schedule=true |
||||||
|
local.dev.schedule-report=true |
||||||
|
local.dev.report-engine=true |
||||||
|
local.dev.report-designer=true |
||||||
|
4. 完整local.properties内容示例,假设输出目录自定义为/Users/rinoux/envs/dev/webroot/WEB-INF, |
||||||
|
依赖代码的模块为core,activator,datasource,decision,decision-report,report-engine,report-designer, |
||||||
|
文件内容如下: |
||||||
|
local.env=/Users/rinoux/envs/dev/webroot/WEB-INF |
||||||
|
local.dev.core=true |
||||||
|
local.dev.activator=true |
||||||
|
local.dev.datasource=true |
||||||
|
local.dev.decision=true |
||||||
|
local.dev.decision-report=true |
||||||
|
local.dev.report-engine=true |
||||||
|
local.dev.report-designer=true |
||||||
|
*/ |
||||||
|
|
||||||
|
ext { |
||||||
|
localProp = loadLocalProp() |
||||||
|
env = findOutputPath(localProp) |
||||||
|
frVersion = "10.0-RELEASE-SNAPSHOT" |
||||||
|
|
||||||
|
def xmlParser = new XmlParser(); |
||||||
|
def plugin = xmlParser.parse("${project.projectDir}/plugin.xml") |
||||||
|
finePluginId = plugin.id[0].find() |
||||||
|
finePluginVersion = plugin.version[0].find() |
||||||
|
|
||||||
|
//插件编译目录 |
||||||
|
outputPath = "${env}/plugins/plugin-${finePluginId}-${finePluginVersion}" |
||||||
|
ignoreTestFailureSetting = true |
||||||
|
languageLevelSetting = 1.8 |
||||||
|
} |
||||||
|
|
||||||
|
dependencies { |
||||||
|
} |
||||||
|
|
||||||
|
allprojects { |
||||||
|
apply plugin: 'java' |
||||||
|
apply plugin: 'java-library' |
||||||
|
apply plugin: 'maven-publish' |
||||||
|
apply plugin: 'java-gradle-plugin' |
||||||
|
apply plugin: 'idea' |
||||||
|
|
||||||
|
group 'com.fr.plugin' |
||||||
|
version frVersion |
||||||
|
sourceCompatibility = languageLevelSetting |
||||||
|
targetCompatibility = languageLevelSetting |
||||||
|
|
||||||
|
tasks.withType(JavaCompile) { |
||||||
|
options.encoding = "UTF-8" |
||||||
|
} |
||||||
|
|
||||||
|
repositories { |
||||||
|
mavenLocal() |
||||||
|
} |
||||||
|
|
||||||
|
idea { |
||||||
|
module { |
||||||
|
inheritOutputDirs = false |
||||||
|
outputDir = file(outputPath + "/classes") |
||||||
|
testOutputDir = file(outputPath + "/test-classes") |
||||||
|
languageLevel = new IdeaLanguageLevel(sourceCompatibility) |
||||||
|
targetBytecodeVersion = targetCompatibility |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
task copyPluginXML(type: Copy) { |
||||||
|
//拷贝plugin.xml到插件安装目录 |
||||||
|
into outputPath |
||||||
|
from(projectDir.getAbsolutePath()) { |
||||||
|
include "plugin.xml" |
||||||
|
} |
||||||
|
} |
||||||
|
processResources.dependsOn copyPluginXML |
||||||
|
|
||||||
|
dependencies { |
||||||
|
implementation 'com.fr.third.server:servlet-api:3.0' |
||||||
|
implementation 'com.fr.third:fine-third:' + getFRVersion("third") |
||||||
|
implementation 'com.fr.core:fine-core:' + getFRVersion("core") |
||||||
|
implementation 'com.fr.activator:fine-activator:' + getFRVersion("activator") |
||||||
|
implementation 'com.fr.datasource:fine-datasource:' + getFRVersion("datasource") |
||||||
|
implementation 'com.fr.webui:fine-webui:' + getFRVersion("webui") |
||||||
|
implementation 'com.fr.decision:fine-decision:' + getFRVersion("decision") |
||||||
|
implementation 'com.fr.decision:fine-decision-report:' + getFRVersion("decision-report") |
||||||
|
implementation 'com.fr.schedule:fine-schedule:' + getFRVersion("schedule") |
||||||
|
implementation 'com.fr.schedule:fine-schedule-report:' + getFRVersion("schedule-report") |
||||||
|
implementation 'com.fr.report:fine-report-engine:' + getFRVersion("report-engine") |
||||||
|
implementation 'com.fr.report:fine-report-designer:' + getFRVersion("report-designer") |
||||||
|
testImplementation 'org.easymock:easymock:3.5.1' |
||||||
|
testImplementation 'org.powermock:powermock-module-junit4:1.7.1' |
||||||
|
testImplementation 'org.powermock:powermock-api-easymock:1.7.1' |
||||||
|
testImplementation 'junit:junit:4.12' |
||||||
|
} |
||||||
|
} |
@ -0,0 +1,142 @@ |
|||||||
|
<?xml version="1.0" encoding="UTF-8" standalone="no"?> |
||||||
|
<project basedir="." default="jar" name="plugin-report-tabledata-build-demo"> |
||||||
|
<property environment="env"/> |
||||||
|
<!-- JDK路径,根据自己机器上实际位置修改--> |
||||||
|
<property name="jdk.home" value="${env.JAVA_HOME}"/> |
||||||
|
|
||||||
|
<property name="libs" value="${basedir}/lib"/> |
||||||
|
<property name="publicLibs" value=""/> |
||||||
|
<property name="destLoc" value="."/> |
||||||
|
<property name="classes" value="classes"/> |
||||||
|
<xmlproperty file="${basedir}/plugin.xml"/> |
||||||
|
<property name="current-version" value="${plugin.version}"/> |
||||||
|
|
||||||
|
<!-- 插件版本--> |
||||||
|
<property name="plugin-version" value="${current-version}"/> |
||||||
|
<!-- 插件名字--> |
||||||
|
<property name="plugin-name" value="tabledata-build-demo"/> |
||||||
|
<property name="plugin-jar" value="fr-plugin-${plugin-name}-${plugin-version}.jar"/> |
||||||
|
|
||||||
|
<target name="prepare"> |
||||||
|
<delete dir="${classes}"/> |
||||||
|
<delete dir="fr-plugin-${plugin-name}-${plugin-version}"/> |
||||||
|
<xmlproperty file="${basedir}/plugin.xml"/> |
||||||
|
<delete dir="${destLoc}/${plugin-name}"/> |
||||||
|
</target> |
||||||
|
<path id="compile.classpath"> |
||||||
|
<fileset dir="${libs}"> |
||||||
|
<include name="**/*.jar"/> |
||||||
|
</fileset> |
||||||
|
<fileset dir="${publicLibs}"> |
||||||
|
<include name="**/*.jar"/> |
||||||
|
</fileset> |
||||||
|
</path> |
||||||
|
<patternset id="resources4Jar"> |
||||||
|
<exclude name="**/.settings/**"/> |
||||||
|
<exclude name=".classpath"/> |
||||||
|
<exclude name=".project"/> |
||||||
|
|
||||||
|
<exclude name="**/*.java"/> |
||||||
|
<exclude name="**/*.db"/> |
||||||
|
<exclude name="**/*.g"/> |
||||||
|
<exclude name="**/package.html"/> |
||||||
|
</patternset> |
||||||
|
<target name="copy_resources"> |
||||||
|
<echo message="从${resources_from}拷贝图片,JS,CSS等资源文件"/> |
||||||
|
<delete dir="tmp"/> |
||||||
|
<copy todir="tmp"> |
||||||
|
<fileset dir="${resources_from}/nx-esd/src/main/resources"> |
||||||
|
<patternset refid="resources4Jar"/> |
||||||
|
</fileset> |
||||||
|
<fileset dir="${resources_from}/nx-esd-i18n/src/main/resources"> |
||||||
|
<patternset refid="resources4Jar"/> |
||||||
|
</fileset> |
||||||
|
<fileset dir="${resources_from}/nx-esd-decision/src/main/resources"> |
||||||
|
<patternset refid="resources4Jar"/> |
||||||
|
</fileset> |
||||||
|
<fileset dir="${resources_from}/nx-esd-designer/src/main/resources"> |
||||||
|
<patternset refid="resources4Jar"/> |
||||||
|
</fileset> |
||||||
|
</copy> |
||||||
|
<copy todir="${classes}"> |
||||||
|
<fileset dir="tmp"/> |
||||||
|
</copy> |
||||||
|
<delete dir="tmp"/> |
||||||
|
</target> |
||||||
|
<target name="compile_javas"> |
||||||
|
<echo message="编译${compile_files}下的Java文件"/> |
||||||
|
<javac destdir="${classes}" debug="false" optimize="on" includeantruntime="false" source="${source_jdk_version}" |
||||||
|
target="${target_jdk_version}" |
||||||
|
fork="true" memoryMaximumSize="512m" listfiles="false" srcdir="${basedir}" |
||||||
|
executable="${compile_jdk_version}/bin/javac"> |
||||||
|
<src path="${basedir}/nx-esd/src/main/java"/> |
||||||
|
<src path="${basedir}/nx-esd-agent/src/main/java"/> |
||||||
|
<src path="${basedir}/nx-esd-core/src/main/java"/> |
||||||
|
<src path="${basedir}/nx-esd-decision/src/main/java"/> |
||||||
|
<src path="${basedir}/nx-esd-designer/src/main/java"/> |
||||||
|
<src path="${basedir}/nx-esd-engine/src/main/java"/> |
||||||
|
<src path="${basedir}/nx-esd-recommend/src/main/java"/> |
||||||
|
<exclude name="**/.svn/**"/> |
||||||
|
<exclude name="**/.git/**"/> |
||||||
|
<exclude name="**/package-info.java"/> |
||||||
|
<compilerarg line="-encoding UTF8 "/> |
||||||
|
<classpath refid="compile.classpath"/> |
||||||
|
</javac> |
||||||
|
<taskdef name="pretreatment" classname="com.fr.plugin.pack.PluginPretreatmentTask"> |
||||||
|
<classpath refid="compile.classpath"/> |
||||||
|
</taskdef> |
||||||
|
<pretreatment baseDir="${basedir}" encrypt="false"/> |
||||||
|
</target> |
||||||
|
|
||||||
|
<target name="jar_classes"> |
||||||
|
<echo message="打Jar包:${jar_name}"/> |
||||||
|
<delete file="${basedir}/${jar_name}"/> |
||||||
|
<jar jarfile="${basedir}/${jar_name}"> |
||||||
|
<fileset dir="${classes}"> |
||||||
|
<exclude name="**/com/fr/test/**"/> |
||||||
|
</fileset> |
||||||
|
</jar> |
||||||
|
</target> |
||||||
|
|
||||||
|
<target name="super_jar" depends="prepare"> |
||||||
|
<antcall target="copy_resources"> |
||||||
|
<param name="resources_from" value="${basedir}"/> |
||||||
|
</antcall> |
||||||
|
<antcall target="compile_javas"> |
||||||
|
<param name="source_jdk_version" value="1.8"/> |
||||||
|
<param name="target_jdk_version" value="1.8"/> |
||||||
|
<param name="compile_jdk_version" value="${jdk.home}"/> |
||||||
|
<param name="compile_files" value="${basedir}/src"/> |
||||||
|
</antcall> |
||||||
|
<echo message="compile plugin success!"/> |
||||||
|
|
||||||
|
<antcall target="jar_classes"> |
||||||
|
<param name="jar_name" value="${plugin-jar}"/> |
||||||
|
</antcall> |
||||||
|
<delete dir="${classes}"/> |
||||||
|
|
||||||
|
</target> |
||||||
|
<target name="jar" depends="super_jar"> |
||||||
|
<antcall target="zip"/> |
||||||
|
</target> |
||||||
|
|
||||||
|
<target name="zip"> |
||||||
|
<property name="plugin-folder" value="fr-plugin-${plugin-name}-${plugin-version}"/> |
||||||
|
<echo message="----------zip files----------"/> |
||||||
|
<mkdir dir="${plugin-folder}"/> |
||||||
|
<copy todir="${plugin-folder}"> |
||||||
|
<fileset dir="."> |
||||||
|
<include name="${plugin-jar}"/> |
||||||
|
<include name="plugin.xml"/> |
||||||
|
</fileset> |
||||||
|
</copy> |
||||||
|
<zip destfile="${basedir}/${plugin-folder}.zip" basedir="."> |
||||||
|
<include name="${plugin-folder}/*.jar"/> |
||||||
|
<include name="${plugin-folder}/plugin.xml"/> |
||||||
|
</zip> |
||||||
|
<move file="${plugin-folder}.zip" todir="${destLoc}/${plugin.name}"/> |
||||||
|
|
||||||
|
<delete dir="fr-plugin-${plugin-name}-${plugin-version}"/> |
||||||
|
<delete file="fr-plugin-${plugin-name}-${plugin-version}.jar"/> |
||||||
|
</target> |
||||||
|
</project> |
Binary file not shown.
@ -0,0 +1,5 @@ |
|||||||
|
distributionBase=GRADLE_USER_HOME |
||||||
|
distributionPath=wrapper/dists |
||||||
|
distributionUrl=https\://services.gradle.org/distributions/gradle-6.3-bin.zip |
||||||
|
zipStoreBase=GRADLE_USER_HOME |
||||||
|
zipStorePath=wrapper/dists |
@ -0,0 +1,185 @@ |
|||||||
|
#!/usr/bin/env sh |
||||||
|
|
||||||
|
# |
||||||
|
# Copyright 2015 the original author or authors. |
||||||
|
# |
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License"); |
||||||
|
# you may not use this file except in compliance with the License. |
||||||
|
# You may obtain a copy of the License at |
||||||
|
# |
||||||
|
# https://www.apache.org/licenses/LICENSE-2.0 |
||||||
|
# |
||||||
|
# Unless required by applicable law or agreed to in writing, software |
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS, |
||||||
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||||
|
# See the License for the specific language governing permissions and |
||||||
|
# limitations under the License. |
||||||
|
# |
||||||
|
|
||||||
|
############################################################################## |
||||||
|
## |
||||||
|
## Gradle start up script for UN*X |
||||||
|
## |
||||||
|
############################################################################## |
||||||
|
|
||||||
|
# Attempt to set APP_HOME |
||||||
|
# Resolve links: $0 may be a link |
||||||
|
PRG="$0" |
||||||
|
# Need this for relative symlinks. |
||||||
|
while [ -h "$PRG" ] ; do |
||||||
|
ls=`ls -ld "$PRG"` |
||||||
|
link=`expr "$ls" : '.*-> \(.*\)$'` |
||||||
|
if expr "$link" : '/.*' > /dev/null; then |
||||||
|
PRG="$link" |
||||||
|
else |
||||||
|
PRG=`dirname "$PRG"`"/$link" |
||||||
|
fi |
||||||
|
done |
||||||
|
SAVED="`pwd`" |
||||||
|
cd "`dirname \"$PRG\"`/" >/dev/null |
||||||
|
APP_HOME="`pwd -P`" |
||||||
|
cd "$SAVED" >/dev/null |
||||||
|
|
||||||
|
APP_NAME="Gradle" |
||||||
|
APP_BASE_NAME=`basename "$0"` |
||||||
|
|
||||||
|
# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. |
||||||
|
DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"' |
||||||
|
|
||||||
|
# Use the maximum available, or set MAX_FD != -1 to use that value. |
||||||
|
MAX_FD="maximum" |
||||||
|
|
||||||
|
warn () { |
||||||
|
echo "$*" |
||||||
|
} |
||||||
|
|
||||||
|
die () { |
||||||
|
echo |
||||||
|
echo "$*" |
||||||
|
echo |
||||||
|
exit 1 |
||||||
|
} |
||||||
|
|
||||||
|
# OS specific support (must be 'true' or 'false'). |
||||||
|
cygwin=false |
||||||
|
msys=false |
||||||
|
darwin=false |
||||||
|
nonstop=false |
||||||
|
case "`uname`" in |
||||||
|
CYGWIN* ) |
||||||
|
cygwin=true |
||||||
|
;; |
||||||
|
Darwin* ) |
||||||
|
darwin=true |
||||||
|
;; |
||||||
|
MINGW* ) |
||||||
|
msys=true |
||||||
|
;; |
||||||
|
NONSTOP* ) |
||||||
|
nonstop=true |
||||||
|
;; |
||||||
|
esac |
||||||
|
|
||||||
|
CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar |
||||||
|
|
||||||
|
|
||||||
|
# Determine the Java command to use to start the JVM. |
||||||
|
if [ -n "$JAVA_HOME" ] ; then |
||||||
|
if [ -x "$JAVA_HOME/jre/sh/java" ] ; then |
||||||
|
# IBM's JDK on AIX uses strange locations for the executables |
||||||
|
JAVACMD="$JAVA_HOME/jre/sh/java" |
||||||
|
else |
||||||
|
JAVACMD="$JAVA_HOME/bin/java" |
||||||
|
fi |
||||||
|
if [ ! -x "$JAVACMD" ] ; then |
||||||
|
die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME |
||||||
|
|
||||||
|
Please set the JAVA_HOME variable in your environment to match the |
||||||
|
location of your Java installation." |
||||||
|
fi |
||||||
|
else |
||||||
|
JAVACMD="java" |
||||||
|
which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. |
||||||
|
|
||||||
|
Please set the JAVA_HOME variable in your environment to match the |
||||||
|
location of your Java installation." |
||||||
|
fi |
||||||
|
|
||||||
|
# Increase the maximum file descriptors if we can. |
||||||
|
if [ "$cygwin" = "false" -a "$darwin" = "false" -a "$nonstop" = "false" ] ; then |
||||||
|
MAX_FD_LIMIT=`ulimit -H -n` |
||||||
|
if [ $? -eq 0 ] ; then |
||||||
|
if [ "$MAX_FD" = "maximum" -o "$MAX_FD" = "max" ] ; then |
||||||
|
MAX_FD="$MAX_FD_LIMIT" |
||||||
|
fi |
||||||
|
ulimit -n $MAX_FD |
||||||
|
if [ $? -ne 0 ] ; then |
||||||
|
warn "Could not set maximum file descriptor limit: $MAX_FD" |
||||||
|
fi |
||||||
|
else |
||||||
|
warn "Could not query maximum file descriptor limit: $MAX_FD_LIMIT" |
||||||
|
fi |
||||||
|
fi |
||||||
|
|
||||||
|
# For Darwin, add options to specify how the application appears in the dock |
||||||
|
if $darwin; then |
||||||
|
GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\"" |
||||||
|
fi |
||||||
|
|
||||||
|
# For Cygwin or MSYS, switch paths to Windows format before running java |
||||||
|
if [ "$cygwin" = "true" -o "$msys" = "true" ] ; then |
||||||
|
APP_HOME=`cygpath --path --mixed "$APP_HOME"` |
||||||
|
CLASSPATH=`cygpath --path --mixed "$CLASSPATH"` |
||||||
|
|
||||||
|
JAVACMD=`cygpath --unix "$JAVACMD"` |
||||||
|
|
||||||
|
# We build the pattern for arguments to be converted via cygpath |
||||||
|
ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null` |
||||||
|
SEP="" |
||||||
|
for dir in $ROOTDIRSRAW ; do |
||||||
|
ROOTDIRS="$ROOTDIRS$SEP$dir" |
||||||
|
SEP="|" |
||||||
|
done |
||||||
|
OURCYGPATTERN="(^($ROOTDIRS))" |
||||||
|
# Add a user-defined pattern to the cygpath arguments |
||||||
|
if [ "$GRADLE_CYGPATTERN" != "" ] ; then |
||||||
|
OURCYGPATTERN="$OURCYGPATTERN|($GRADLE_CYGPATTERN)" |
||||||
|
fi |
||||||
|
# Now convert the arguments - kludge to limit ourselves to /bin/sh |
||||||
|
i=0 |
||||||
|
for arg in "$@" ; do |
||||||
|
CHECK=`echo "$arg"|egrep -c "$OURCYGPATTERN" -` |
||||||
|
CHECK2=`echo "$arg"|egrep -c "^-"` ### Determine if an option |
||||||
|
|
||||||
|
if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ] ; then ### Added a condition |
||||||
|
eval `echo args$i`=`cygpath --path --ignore --mixed "$arg"` |
||||||
|
else |
||||||
|
eval `echo args$i`="\"$arg\"" |
||||||
|
fi |
||||||
|
i=`expr $i + 1` |
||||||
|
done |
||||||
|
case $i in |
||||||
|
0) set -- ;; |
||||||
|
1) set -- "$args0" ;; |
||||||
|
2) set -- "$args0" "$args1" ;; |
||||||
|
3) set -- "$args0" "$args1" "$args2" ;; |
||||||
|
4) set -- "$args0" "$args1" "$args2" "$args3" ;; |
||||||
|
5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;; |
||||||
|
6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;; |
||||||
|
7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;; |
||||||
|
8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;; |
||||||
|
9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;; |
||||||
|
esac |
||||||
|
fi |
||||||
|
|
||||||
|
# Escape application args |
||||||
|
save () { |
||||||
|
for i do printf %s\\n "$i" | sed "s/'/'\\\\''/g;1s/^/'/;\$s/\$/' \\\\/" ; done |
||||||
|
echo " " |
||||||
|
} |
||||||
|
APP_ARGS=`save "$@"` |
||||||
|
|
||||||
|
# Collect all arguments for the java command, following the shell quoting and substitution rules |
||||||
|
eval set -- $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS "\"-Dorg.gradle.appname=$APP_BASE_NAME\"" -classpath "\"$CLASSPATH\"" org.gradle.wrapper.GradleWrapperMain "$APP_ARGS" |
||||||
|
|
||||||
|
exec "$JAVACMD" "$@" |
@ -0,0 +1,104 @@ |
|||||||
|
@rem |
||||||
|
@rem Copyright 2015 the original author or authors. |
||||||
|
@rem |
||||||
|
@rem Licensed under the Apache License, Version 2.0 (the "License"); |
||||||
|
@rem you may not use this file except in compliance with the License. |
||||||
|
@rem You may obtain a copy of the License at |
||||||
|
@rem |
||||||
|
@rem https://www.apache.org/licenses/LICENSE-2.0 |
||||||
|
@rem |
||||||
|
@rem Unless required by applicable law or agreed to in writing, software |
||||||
|
@rem distributed under the License is distributed on an "AS IS" BASIS, |
||||||
|
@rem WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||||
|
@rem See the License for the specific language governing permissions and |
||||||
|
@rem limitations under the License. |
||||||
|
@rem |
||||||
|
|
||||||
|
@if "%DEBUG%" == "" @echo off |
||||||
|
@rem ########################################################################## |
||||||
|
@rem |
||||||
|
@rem Gradle startup script for Windows |
||||||
|
@rem |
||||||
|
@rem ########################################################################## |
||||||
|
|
||||||
|
@rem Set local scope for the variables with windows NT shell |
||||||
|
if "%OS%"=="Windows_NT" setlocal |
||||||
|
|
||||||
|
set DIRNAME=%~dp0 |
||||||
|
if "%DIRNAME%" == "" set DIRNAME=. |
||||||
|
set APP_BASE_NAME=%~n0 |
||||||
|
set APP_HOME=%DIRNAME% |
||||||
|
|
||||||
|
@rem Resolve any "." and ".." in APP_HOME to make it shorter. |
||||||
|
for %%i in ("%APP_HOME%") do set APP_HOME=%%~fi |
||||||
|
|
||||||
|
@rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. |
||||||
|
set DEFAULT_JVM_OPTS="-Xmx64m" "-Xms64m" |
||||||
|
|
||||||
|
@rem Find java.exe |
||||||
|
if defined JAVA_HOME goto findJavaFromJavaHome |
||||||
|
|
||||||
|
set JAVA_EXE=java.exe |
||||||
|
%JAVA_EXE% -version >NUL 2>&1 |
||||||
|
if "%ERRORLEVEL%" == "0" goto init |
||||||
|
|
||||||
|
echo. |
||||||
|
echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. |
||||||
|
echo. |
||||||
|
echo Please set the JAVA_HOME variable in your environment to match the |
||||||
|
echo location of your Java installation. |
||||||
|
|
||||||
|
goto fail |
||||||
|
|
||||||
|
:findJavaFromJavaHome |
||||||
|
set JAVA_HOME=%JAVA_HOME:"=% |
||||||
|
set JAVA_EXE=%JAVA_HOME%/bin/java.exe |
||||||
|
|
||||||
|
if exist "%JAVA_EXE%" goto init |
||||||
|
|
||||||
|
echo. |
||||||
|
echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME% |
||||||
|
echo. |
||||||
|
echo Please set the JAVA_HOME variable in your environment to match the |
||||||
|
echo location of your Java installation. |
||||||
|
|
||||||
|
goto fail |
||||||
|
|
||||||
|
:init |
||||||
|
@rem Get command-line arguments, handling Windows variants |
||||||
|
|
||||||
|
if not "%OS%" == "Windows_NT" goto win9xME_args |
||||||
|
|
||||||
|
:win9xME_args |
||||||
|
@rem Slurp the command line arguments. |
||||||
|
set CMD_LINE_ARGS= |
||||||
|
set _SKIP=2 |
||||||
|
|
||||||
|
:win9xME_args_slurp |
||||||
|
if "x%~1" == "x" goto execute |
||||||
|
|
||||||
|
set CMD_LINE_ARGS=%* |
||||||
|
|
||||||
|
:execute |
||||||
|
@rem Setup the command line |
||||||
|
|
||||||
|
set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar |
||||||
|
|
||||||
|
|
||||||
|
@rem Execute Gradle |
||||||
|
"%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %CMD_LINE_ARGS% |
||||||
|
|
||||||
|
:end |
||||||
|
@rem End local scope for the variables with windows NT shell |
||||||
|
if "%ERRORLEVEL%"=="0" goto mainEnd |
||||||
|
|
||||||
|
:fail |
||||||
|
rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of |
||||||
|
rem the _cmd.exe /c_ return code! |
||||||
|
if not "" == "%GRADLE_EXIT_CONSOLE%" exit 1 |
||||||
|
exit /b 1 |
||||||
|
|
||||||
|
:mainEnd |
||||||
|
if "%OS%"=="Windows_NT" endlocal |
||||||
|
|
||||||
|
:omega |
@ -0,0 +1,8 @@ |
|||||||
|
local.env=/Users/rinoux/envs/dev/webroot/WEB-INF |
||||||
|
local.dev.core=true |
||||||
|
local.dev.activator=true |
||||||
|
local.dev.datasource=true |
||||||
|
local.dev.decision=true |
||||||
|
local.dev.decision-report=true |
||||||
|
local.dev.report-engine=true |
||||||
|
local.dev.report-designer=true |
@ -0,0 +1,22 @@ |
|||||||
|
<?xml version="1.0" encoding="UTF-8" standalone="no"?> |
||||||
|
<plugin> |
||||||
|
<id>com.fr.plugin.tabledata.build.demo</id> |
||||||
|
<name><![CDATA[数据集TableData解析插件demo]]></name> |
||||||
|
<active>yes</active> |
||||||
|
<hidden>no</hidden> |
||||||
|
<version>1.0</version> |
||||||
|
<env-version>10.0</env-version> |
||||||
|
<jartime>2020-10-22</jartime> |
||||||
|
<vendor>finereport</vendor> |
||||||
|
<description><![CDATA[数据集TableData解析插件demo]]></description> |
||||||
|
<change-notes><![CDATA[ |
||||||
|
|
||||||
|
]]></change-notes> |
||||||
|
<!--主包--> |
||||||
|
<main-package>com.fr.plugin</main-package> |
||||||
|
<!--功能记录点类--> |
||||||
|
<function-recorder class="com.fr.plugin.tabledata.build.DemoTableDataBuilder"/> |
||||||
|
<extra-core> |
||||||
|
<TableDataBuildProvider class="com.fr.plugin.tabledata.build.DemoTableDataBuilder"/> |
||||||
|
</extra-core> |
||||||
|
</plugin> |
@ -0,0 +1,9 @@ |
|||||||
|
pluginManagement { |
||||||
|
repositories { |
||||||
|
maven { |
||||||
|
url 'http://mvn.finedevelop.com/repository/maven-public/' |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
rootProject.name = 'plugin-tabledata-build-demo' |
||||||
|
|
@ -0,0 +1,57 @@ |
|||||||
|
package com.fr.plugin.tabledata.build; |
||||||
|
|
||||||
|
import com.fr.data.impl.Connection; |
||||||
|
import com.fr.data.impl.DBTableData; |
||||||
|
import com.fr.stable.xml.XMLPrintWriter; |
||||||
|
import com.fr.stable.xml.XMLableReader; |
||||||
|
|
||||||
|
/** |
||||||
|
* @author rinoux |
||||||
|
* @version 10.0 |
||||||
|
* Created by rinoux on 2020/10/23 |
||||||
|
*/ |
||||||
|
public class DemoTableData extends DBTableData { |
||||||
|
|
||||||
|
private static final String DemoTag = "ExtraInfo"; |
||||||
|
|
||||||
|
|
||||||
|
private String extraInfo; |
||||||
|
|
||||||
|
public DemoTableData() { |
||||||
|
} |
||||||
|
|
||||||
|
public DemoTableData(String driver, String url, String user, String password, String query) { |
||||||
|
super(driver, url, user, password, query); |
||||||
|
} |
||||||
|
|
||||||
|
public DemoTableData(Connection database, String query) { |
||||||
|
super(database, query); |
||||||
|
} |
||||||
|
|
||||||
|
public String getExtraInfo() { |
||||||
|
return extraInfo; |
||||||
|
} |
||||||
|
|
||||||
|
public void setExtraInfo(String extraInfo) { |
||||||
|
this.extraInfo = extraInfo; |
||||||
|
} |
||||||
|
|
||||||
|
@Override |
||||||
|
public void readXML(XMLableReader reader) { |
||||||
|
super.readXML(reader); |
||||||
|
if (reader.isChildNode()) { |
||||||
|
String tagName = reader.getTagName(); |
||||||
|
if (DemoTag.equals(tagName)) { |
||||||
|
setExtraInfo(reader.getContent()); |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
@Override |
||||||
|
public void writeXML(XMLPrintWriter writer) { |
||||||
|
super.writeXML(writer); |
||||||
|
writer.startTAG(DemoTag); |
||||||
|
writer.textNode("some demo extra info"); |
||||||
|
writer.end(); |
||||||
|
} |
||||||
|
} |
@ -0,0 +1,24 @@ |
|||||||
|
package com.fr.plugin.tabledata.build; |
||||||
|
|
||||||
|
import com.fr.plugin.transform.ExecuteFunctionRecord; |
||||||
|
import com.fr.plugin.transform.FunctionRecorder; |
||||||
|
import com.fr.stable.fun.impl.AbstractTableDataBuildProvider; |
||||||
|
|
||||||
|
/** |
||||||
|
* @author rinoux |
||||||
|
* @version 10.0 |
||||||
|
* Created by rinoux on 2020/10/23 |
||||||
|
*/ |
||||||
|
@FunctionRecorder |
||||||
|
public class DemoTableDataBuilder extends AbstractTableDataBuildProvider<DemoTableData> { |
||||||
|
@Override |
||||||
|
public boolean matchPattern(String tdClassName) { |
||||||
|
return tdClassName.endsWith(".DBTableData"); |
||||||
|
} |
||||||
|
|
||||||
|
@Override |
||||||
|
@ExecuteFunctionRecord |
||||||
|
public DemoTableData newInstance() { |
||||||
|
return new DemoTableData(); |
||||||
|
} |
||||||
|
} |
Loading…
Reference in new issue