1 import org.apache.tools.ant.filters.ReplaceTokens
2 //import org.apache.tools.ant.filters.ReplaceRegexp
3 import org.gradle.internal.os.OperatingSystem
4 import org.gradle.plugins.ide.eclipse.model.*
7 import groovy.transform.ExternalizeMethods
11 classpath 'org.openclover:clover:4.3.1'
12 classpath 'org.apache.commons:commons-compress:1.18'
20 id 'com.github.johnrengelman.shadow' version '4.0.3'
21 id 'com.install4j.gradle' version '7.0.9'
33 mainClassName = launcherClass
34 def cloverInstrDir = file("$buildDir/$cloverSourcesInstrDir")
35 def classes = "$jalviewDir/$classesDir"
37 if (clover.equals("true")) {
39 classes = "$buildDir/$cloverClassesDir"
42 classes = "$jalviewDir/$classesDir"
45 // configure classpath/args for j8/j11 compilation
47 def jalviewDirAbsolutePath = file(jalviewDir).getAbsolutePath()
50 def compile_source_compatibility
51 def compile_target_compatibility
54 // where the getdown channel will be built.
55 // TODO: consider allowing this expression to be overridden by -P arg
56 getdownWebsiteDir = jalviewDir + '/' + getdown_website_dir + '/' + JAVA_VERSION
57 getdownAppDir = getdownWebsiteDir + '/' + getdown_app_dir
58 getdownJ11libDir = getdownWebsiteDir + '/' + getdown_j11lib_dir
59 getdownResourceDir = getdownWebsiteDir + '/' + getdown_resource_dir
60 getdownLauncher = jalviewDir + '/' + getdown_launcher
61 getdownFilesDir = jalviewDir + '/' + getdown_files_dir + '/' + JAVA_VERSION + '/'
62 getdown_app_base = getdown_channel_base+"/"+getdown_channel_name+"/"+JAVA_VERSION+"/"
63 modules_compileClasspath = fileTree(dir: "$jalviewDir/$j11modDir", include: ["*.jar"])
64 modules_runtimeClasspath = modules_compileClasspath
69 def JAVA_INTEGER_VERSION
70 def additional_compiler_args = []
71 // these are getdown.txt properties defined dependent on the JAVA_VERSION
72 def getdown_alt_java_min_version
73 // this property is assigned below and expanded to multiple lines in the getdown task
74 def getdown_alt_multi_java_location
75 if (JAVA_VERSION.equals("1.8")) {
76 JAVA_INTEGER_VERSION = "8"
79 compile_source_compatibility = 1.8
80 compile_target_compatibility = 1.8
81 getdown_alt_java_min_version = getdown_alt_java8_min_version
82 getdown_alt_multi_java_location = getdown_alt_java8_txt_multi_java_location
83 } else if (JAVA_VERSION.equals("11")) {
84 JAVA_INTEGER_VERSION = "11"
86 libDistDir = j11libDir
87 compile_source_compatibility = 11
88 compile_target_compatibility = 11
89 getdown_alt_java_min_version = getdown_alt_java11_min_version
90 getdown_alt_multi_java_location = getdown_alt_java11_txt_multi_java_location
91 additional_compiler_args += [
92 '--module-path', ext.modules_compileClasspath.asPath,
93 '--add-modules', j11modules
96 throw new GradleException("JAVA_VERSION=$JAVA_VERSION not currently supported by Jalview")
103 srcDirs "$jalviewDir/$sourceDir"
104 outputDir = file("$classes")
108 srcDirs "$jalviewDir/$resourceDir"
109 srcDirs "$jalviewDir/$libDistDir"
112 jar.destinationDir = file("$jalviewDir/$packageDir")
114 compileClasspath = files(sourceSets.main.java.outputDir)
115 compileClasspath += fileTree(dir: "$jalviewDir/$libDir", include: ["*.jar"])
117 runtimeClasspath = compileClasspath
121 srcDirs = [ cloverInstrDir ]
122 outputDir = file("${buildDir}/${cloverClassesDir}")
126 srcDirs = sourceSets.main.resources.srcDirs
128 compileClasspath = configurations.cloverRuntime + files( sourceSets.clover.java.outputDir )
129 compileClasspath += files(sourceSets.main.java.outputDir)
130 compileClasspath += sourceSets.main.compileClasspath
131 compileClasspath += fileTree(dir: "$jalviewDir/$utilsDir", include: ["**/*.jar"])
132 compileClasspath += fileTree(dir: "$jalviewDir/$libDir", include: ["*.jar"])
134 runtimeClasspath = compileClasspath
139 srcDirs "$jalviewDir/$testSourceDir"
140 outputDir = file("$jalviewDir/$testOutputDir")
144 srcDirs = sourceSets.main.resources.srcDirs
147 compileClasspath = files( sourceSets.test.java.outputDir )
150 compileClasspath += sourceSets.clover.compileClasspath
152 compileClasspath += files(sourceSets.main.java.outputDir)
154 //compileClasspath += sourceSets.main.compileClasspath
155 //compileClasspath += files( sourceSets.main.resources.srcDirs)
156 compileClasspath += fileTree(dir: "$jalviewDir/$utilsDir", include: ["**/*.jar"])
157 compileClasspath += fileTree(dir: "$jalviewDir/$libDir", include: ["*.jar"])
159 runtimeClasspath = compileClasspath
166 cloverCompile 'org.openclover:clover:4.3.1'
167 testCompile 'org.openclover:clover:4.3.1'
173 cloverRuntime.extendsFrom cloverCompile
178 name = "Jalview with gradle build"
180 natures 'org.eclipse.jdt.core.javanature',
181 'org.eclipse.jdt.groovy.core.groovyNature',
182 'org.eclipse.buildship.core.gradleprojectnature'
184 buildCommand 'org.eclipse.jdt.core.javabuilder'
185 buildCommand 'org.eclipse.buildship.core.gradleprojectbuilder'
189 //defaultOutputDir = sourceSets.main.java.outputDir
191 configurations.each{ if (it.isCanBeResolved()) {
196 minusConfigurations += removeThese
197 plusConfigurations = [ ]
201 def removeTheseToo = []
202 HashMap<String, Boolean> addedSrcPath = new HashMap<>();
203 cp.entries.each { entry ->
204 if (entry.kind == 'src') {
205 if (addedSrcPath.getAt(entry.path) || !(entry.path == "src" || entry.path == "test")) {
206 removeTheseToo += entry
208 addedSrcPath.putAt(entry.path, true)
212 cp.entries.removeAll(removeTheseToo)
214 cp.entries += new Output("bin/main")
215 cp.entries += new Library(fileReference(helpParentDir))
216 cp.entries += new Library(fileReference(resourceDir))
218 HashMap<String, Boolean> addedLibPath = new HashMap<>();
219 def allPaths = sourceSets.test.compileClasspath + sourceSets.main.compileClasspath
220 sourceSets.main.compileClasspath.each{
221 //if ((it.isDirectory() || ! it.exists()) && ! (it.equals(sourceSets.main.java.outputDir))) {
222 //no longer want to add outputDir as eclipse is using its own output dir in bin/main
223 if (it.isDirectory() || ! it.exists()) {
224 // don't add dirs to classpath
227 def itPath = it.toString()
228 if (itPath.startsWith(jalviewDirAbsolutePath+"/")) {
229 itPath = itPath.substring(jalviewDirAbsolutePath.length()+1)
231 if (addedLibPath.get(itPath)) {
232 //println("Not adding duplicate entry "+itPath)
234 //println("Adding entry "+itPath)
235 cp.entries += new Library(fileReference(itPath))
236 addedLibPath.put(itPath, true)
240 sourceSets.test.compileClasspath.each{
241 //if ((it.isDirectory() || ! it.exists()) && ! (it.equals(sourceSets.main.java.outputDir))) {
242 //no longer want to add outputDir as eclipse is using its own output dir in bin/main
243 if (it.isDirectory() || ! it.exists()) {
244 // don't add dirs to classpath
245 return false // groovy "break" in .each loop
247 def itPath = it.toString()
248 if (itPath.startsWith(jalviewDirAbsolutePath+"/")) {
249 itPath = itPath.substring(jalviewDirAbsolutePath.length()+1)
251 if (addedLibPath.get(itPath)) {
254 def lib = new Library(fileReference(itPath))
255 // this doesn't work... yet. Adding test=true attribute using withXml below
256 //def attrs = new Node(null, 'attributes', ["test":"true"])
257 //lib.appendNode(attrs) //
259 addedLibPath.put(itPath, true)
264 // withXml changes ignored by buildship, these add the "test=true" attribute
266 def node = it.asNode()
268 def srcTestAttributes
269 node.children().each{ cpe ->
270 def attributes = cpe.attributes()
271 if (attributes.get("kind") == "src" && attributes.get("path") == "test") {
272 srcTestAttributes = cpe.find { a -> a.name() == "attributes" }
276 def addTestAttribute = true
277 srcTestAttributes.each{a ->
278 if (a.name() == "attribute" && a.attributes().getAt("name") == "test") {
279 addTestAttribute = false
282 if (addTestAttribute) {
283 srcTestAttributes.append(new Node(null, "attribute", [name:"test", value:"true"]))
286 node.children().each{ cpe ->
287 def attributes = cpe.attributes()
288 if (attributes.get("kind") == "lib" && attributes.get("path").startsWith("utils/")) {
289 cpe.appendNode('attributes')
290 .appendNode('attribute', [name:"test", value:"true"])
296 containers 'org.eclipse.buildship.core.gradleclasspathcontainer'
300 // for the IDE, use java 11 compatibility
301 sourceCompatibility = 11
302 targetCompatibility = 11
303 javaRuntimeName = "JavaSE-11"
306 withProperties { props ->
307 def jalview_prefs = new Properties()
308 def ins = new FileInputStream(jalviewDirAbsolutePath+"/"+eclipse_extra_jdt_prefs_file)
309 jalview_prefs.load(ins)
311 jalview_prefs.forEach { t, v ->
312 if (props.getAt(t) == null) {
320 //synchronizationTasks eclipseClasspath
321 //autoBuildTasks eclipseClasspath
325 // only instrument source, we build test classes as normal
326 inputs.files files (sourceSets.main.allJava) // , fileTree(dir:"$jalviewDir/$testSourceDir", include: ["**/*.java"]))
327 outputs.dir cloverInstrDir
330 delete cloverInstrDir
331 def argsList = ["--initstring", "${buildDir}/clover/clover.db",
332 "-d", "${buildDir}/${cloverSourcesInstrDir}"]
333 argsList.addAll(inputs.files.files.collect({ file ->
336 String[] args = argsList.toArray()
337 println("About to instrument "+args.length +" files")
338 com.atlassian.clover.CloverInstr.mainImpl(args)
344 group = "Verification"
345 description = "Createst the Clover report"
346 inputs.dir "${buildDir}/clover"
347 outputs.dir "${reportsDir}/clover"
349 file("${buildDir}/clover/clover.db").exists()
352 def argsList = ["--initstring", "${buildDir}/clover/clover.db",
353 "-o", "${reportsDir}/clover"]
354 String[] args = argsList.toArray()
355 com.atlassian.clover.reporters.html.HtmlReporter.runReport(args)
357 // and generate ${reportsDir}/clover/clover.xml
358 args = ["--initstring", "${buildDir}/clover/clover.db",
359 "-o", "${reportsDir}/clover/clover.xml"].toArray()
360 com.atlassian.clover.reporters.xml.XMLReporter.runReport(args)
370 sourceCompatibility = compile_source_compatibility
371 targetCompatibility = compile_target_compatibility
372 options.compilerArgs = additional_compiler_args
373 print ("Setting target compatibility to "+targetCompatibility+"\n")
380 dependsOn compileCloverJava
381 classpath += configurations.cloverRuntime
383 classpath += sourceSets.main.runtimeClasspath
386 sourceCompatibility = compile_source_compatibility
387 targetCompatibility = compile_target_compatibility
388 options.compilerArgs = additional_compiler_args
389 print ("Setting target compatibility to "+targetCompatibility+"\n")
397 sourceCompatibility = compile_source_compatibility
398 targetCompatibility = compile_target_compatibility
399 options.compilerArgs += additional_compiler_args
400 print ("Setting target compatibility to "+targetCompatibility+"\n")
402 classpath += configurations.cloverRuntime
406 delete sourceSets.main.java.outputDir
410 delete sourceSets.test.java.outputDir
411 delete cloverInstrDir
414 def getDate(format) {
415 def date = new Date()
416 //return date.format("dd MMMM yyyy")
417 return date.format(format)
420 task setGitHash(type: Exec) {
421 workingDir = jalviewDir
422 commandLine "git", "rev-parse", "--short", "HEAD"
423 standardOutput = new ByteArrayOutputStream()
424 project.ext.gitHash = {
425 return standardOutput.toString().trim()
429 task setGitBranch(type: Exec) {
430 workingDir = jalviewDir
431 commandLine "git", "rev-parse", "--abbrev-ref", "HEAD"
432 standardOutput = new ByteArrayOutputStream()
433 project.ext.gitBranch = {
434 return standardOutput.toString().trim()
440 dependsOn setGitBranch
443 task createBuildProperties(type: WriteProperties) {
445 inputs.dir("$jalviewDir/$sourceDir")
446 inputs.dir("$jalviewDir/$resourceDir")
447 outputFile "$classes/$buildPropertiesFile"
448 // taking time specific comment out to allow better incremental builds
449 //comment "--Jalview Build Details--\n"+getDate("yyyy-MM-dd HH:mm:ss")
450 comment "--Jalview Build Details--\n"+getDate("yyyy-MM-dd")
451 property "BUILD_DATE", getDate("dd MMMM yyyy")
452 property "VERSION", JALVIEW_VERSION
453 property "INSTALLATION", INSTALLATION+" git-commit:"+project.ext.gitHash+" ["+project.ext.gitBranch+"]"
454 outputs.file(outputFile)
455 outputs.dir("$classes")
458 task syncDocs(type: Sync) {
459 def syncDir = "$classes/$docDir"
460 from fileTree("$jalviewDir/$docDir")
465 def helpFile = "$classes/$helpDir/help.jhm"
467 task copyHelp(type: Copy) {
468 def inputDir = "$jalviewDir/$helpParentDir/$helpDir"
469 def outputDir = "$classes/$helpDir"
474 filter(ReplaceTokens, beginToken: '$$', endToken: '$$', tokens: ['Version-Rel': JALVIEW_VERSION])
484 outputs.files(helpFile)
485 outputs.dir(outputDir)
488 task syncLib(type: Sync) {
489 def syncDir = "$classes/$libDistDir"
490 from fileTree("$jalviewDir/$libDistDir")
494 task syncResources(type: Sync) {
495 from "$jalviewDir/$resourceDir"
505 dependsOn syncResources
511 //testReportDirName = "test-reports" // note that test workingDir will be $jalviewDir
514 dependsOn compileJava
516 dependsOn cloverInstr
519 print("Running tests " + (use_clover?"WITH":"WITHOUT") + " clover [clover="+use_clover+"]\n")
522 includeGroups testngGroups
524 useDefaultListeners=true
527 workingDir = jalviewDir
528 //systemProperties 'clover.jar' System.properties.clover.jar
529 sourceCompatibility = compile_source_compatibility
530 targetCompatibility = compile_target_compatibility
531 jvmArgs += additional_compiler_args
532 print ("Setting target compatibility to "+targetCompatibility+"\n")
535 task buildIndices(type: JavaExec) {
537 classpath = sourceSets.main.compileClasspath
538 main = "com.sun.java.help.search.Indexer"
539 workingDir = "$classes/$helpDir"
542 inputs.dir("$workingDir/$argDir")
544 outputs.dir("$classes/doc")
545 outputs.dir("$classes/help")
546 outputs.file("$workingDir/JavaHelpSearch/DOCS")
547 outputs.file("$workingDir/JavaHelpSearch/DOCS.TAB")
548 outputs.file("$workingDir/JavaHelpSearch/OFFSETS")
549 outputs.file("$workingDir/JavaHelpSearch/POSITIONS")
550 outputs.file("$workingDir/JavaHelpSearch/SCHEMA")
551 outputs.file("$workingDir/JavaHelpSearch/TMAP")
554 task compileLinkCheck(type: JavaCompile) {
556 classpath = files("$jalviewDir/$utilsDir")
557 destinationDir = file("$jalviewDir/$utilsDir")
558 source = fileTree(dir: "$jalviewDir/$utilsDir", include: ["HelpLinksChecker.java", "BufferedLineReader.java"])
560 inputs.file("$jalviewDir/$utilsDir/HelpLinksChecker.java")
561 inputs.file("$jalviewDir/$utilsDir/HelpLinksChecker.java")
562 outputs.file("$jalviewDir/$utilsDir/HelpLinksChecker.class")
563 outputs.file("$jalviewDir/$utilsDir/BufferedLineReader.class")
566 def helplinkscheckeroutputfile = file("$jalviewDir/$utilsDir/HelpLinksChecker.out")
567 task linkCheck(type: JavaExec) {
568 dependsOn prepare, compileLinkCheck
569 classpath = files("$jalviewDir/$utilsDir")
570 main = "HelpLinksChecker"
571 workingDir = jalviewDir
572 def help = "$classes/$helpDir"
573 args = [ "$classes/$helpDir", "-nointernet" ]
576 helplinkscheckeroutputfile.createNewFile()
577 standardOutput new FileOutputStream(helplinkscheckeroutputfile, false)
580 outputs.file(helplinkscheckeroutputfile)
583 task cleanPackageDir(type: Delete) {
584 delete fileTree("$jalviewDir/$packageDir").include("*.jar")
589 dependsOn buildIndices
590 dependsOn createBuildProperties
593 attributes "Main-Class": mainClass,
594 "Permissions": "all-permissions",
595 "Application-Name": "Jalview Desktop",
596 "Codebase": application_codebase
599 destinationDir = file("$jalviewDir/$packageDir")
600 archiveName = rootProject.name+".jar"
608 inputs.dir("$classes")
609 outputs.file("$jalviewDir/$packageDir/$archiveName")
612 task copyJars(type: Copy) {
613 from fileTree("$classes").include("**/*.jar").include("*.jar").files
614 into "$jalviewDir/$packageDir"
617 // doing a Sync instead of Copy as Copy doesn't deal with "outputs" very well
618 task syncJars(type: Sync) {
619 from fileTree("$jalviewDir/$libDistDir").include("**/*.jar").include("*.jar").files
620 into "$jalviewDir/$packageDir"
622 include jar.archiveName
628 description = "Put all required libraries in dist"
629 // order of "cleanPackageDir", "copyJars", "jar" important!
630 jar.mustRunAfter cleanPackageDir
631 syncJars.mustRunAfter cleanPackageDir
632 dependsOn cleanPackageDir
635 outputs.dir("$jalviewDir/$packageDir")
639 dependsOn cleanPackageDir
646 from ("$jalviewDir/$libDistDir") {
649 mainClassName = shadowJarMainClass
651 classifier = "all-"+JAVA_VERSION
655 task getdownWebsite() {
656 group = "distribution"
657 description = "Create the getdown minimal app folder, and website folder for this version of jalview. Website folder also used for offline app installer"
659 def getdownWebsiteResourceFilenames = []
660 def getdownTextString = ""
661 def getdownResourceDir = project.ext.getdownResourceDir
662 def getdownAppDir = project.ext.getdownAppDir
663 def getdownResourceFilenames = []
665 // go through properties looking for getdown_txt_...
666 def props = project.properties.sort { it.key }
667 props.put("getdown_txt_java_min_version", getdown_alt_java_min_version)
668 props.put("getdown_txt_multi_java_location", getdown_alt_multi_java_location)
670 if (getdown_local == "true") {
671 getdown_app_base = file(getdownWebsiteDir).toURI().toString()
673 props.put("getdown_txt_appbase", getdown_app_base)
674 props.each{ prop, val ->
675 if (prop.startsWith("getdown_txt_") && val != null) {
676 if (prop.startsWith("getdown_txt_multi_")) {
677 def key = prop.substring(18)
678 val.split(",").each{ v ->
679 def line = key + " = " + v + "\n"
680 getdownTextString += line
683 // file values rationalised
684 if (val.indexOf('/') > -1) {
686 if (val.indexOf('/') == 0) {
689 } else if (val.indexOf('/') > 0) {
690 // relative path (relative to jalviewDir)
691 r = file( jalviewDir + '/' + val )
694 val = getdown_resource_dir + '/' + r.getName()
695 getdownWebsiteResourceFilenames += val
696 getdownResourceFilenames += r.getPath()
699 def line = prop.substring(12) + " = " + val + "\n"
700 getdownTextString += line
705 getdownWebsiteResourceFilenames.each{ filename ->
706 getdownTextString += "resource = "+filename+"\n"
708 getdownResourceFilenames.each{ filename ->
711 into project.ext.getdownResourceDir
716 makeDist.outputs.files.each{ f ->
717 if (f.isDirectory()) {
718 def files = fileTree(dir: f, include: ["*"]).getFiles()
720 } else if (f.exists()) {
724 codeFiles.sort().each{f ->
725 def line = "code = " + getdown_app_dir + '/' + f.getName() + "\n"
726 getdownTextString += line
729 into project.ext.getdownAppDir
733 // NOT USING MODULES YET, EVERYTHING SHOULD BE IN dist
735 if (JAVA_VERSION.equals("11")) {
736 def j11libFiles = fileTree(dir: "$jalviewDir/$j11libDir", include: ["*.jar"]).getFiles()
737 j11libFiles.sort().each{f ->
738 def line = "code = " + getdown_j11lib_dir + '/' + f.getName() + "\n"
739 getdownTextString += line
742 into project.ext.getdownJ11libDir
748 // getdown-launcher.jar should not be in main application class path so the main application can move it when updated. Listed as a resource so it gets updated.
749 //getdownTextString += "class = " + file(getdownLauncher).getName() + "\n"
750 getdownTextString += "resource = " + file(getdownLauncher).getName() + "\n"
751 getdownTextString += "class = " + mainClass + "\n"
753 def getdown_txt = file(project.ext.getdownWebsiteDir + "/getdown.txt")
754 getdown_txt.write(getdownTextString)
758 into project.ext.getdownFilesDir
763 into project.ext.getdownFilesDir
768 into project.ext.getdownWebsiteDir
772 from jalviewDir + '/' + project.getProperty('getdown_txt_ui.background_image')
773 from jalviewDir + '/' + project.getProperty('getdown_txt_ui.error_background')
774 from jalviewDir + '/' + project.getProperty('getdown_txt_ui.progress_image')
775 from jalviewDir + '/' + project.getProperty('getdown_txt_ui.icon')
776 from jalviewDir + '/' + project.getProperty('getdown_txt_ui.mac_dock_icon')
777 into project.ext.getdownFilesDir + '/' + getdown_resource_dir
781 inputs.dir(jalviewDir + '/' + packageDir)
782 outputs.dir(project.ext.getdownWebsiteDir)
783 outputs.dir(project.ext.getdownFilesDir)
786 task getdownDigest(type: JavaExec) {
787 group = "distribution"
788 description = "Digest the getdown website folder"
789 dependsOn getdownWebsite
790 classpath = files(jalviewDir + '/' + getdown_core, jalviewDir+'/'+getdown_launcher)
791 main = "com.threerings.getdown.tools.Digester"
792 args project.ext.getdownWebsiteDir
793 inputs.dir(project.ext.getdownWebsiteDir)
794 outputs.file(project.ext.getdownWebsiteDir + '/' + "digest2.txt")
798 group = "distribution"
799 description = "Create the minimal and full getdown app folder for installers and website and create digest file"
800 dependsOn getdownDigest
804 delete project.ext.getdownWebsiteDir
805 delete project.ext.getdownFilesDir
809 def install4jHomeDir = "/opt/install4j"
810 def hostname = "hostname".execute().text.trim()
811 if (hostname.equals("jv-bamboo")) {
812 install4jHomeDir = System.getProperty("user.home")+"/buildtools/install4j"
813 } else if (OperatingSystem.current().isMacOsX()) {
814 install4jHomeDir = '/Applications/install4j.app/Contents/Resources/app'
815 if (! file(install4jHomeDir).exists()) {
816 install4jHomeDir = System.getProperty("user.home")+install4jHomeDir
818 } else if (OperatingSystem.current().isLinux()) {
819 install4jHomeDir = System.getProperty("user.home")+"/buildtools/install4j"
821 installDir = file(install4jHomeDir)
822 mediaTypes = Arrays.asList(install4jMediaTypes.split(","))
823 if (install4jFaster.equals("true")) {
833 def install4jDir = "$jalviewDir/$install4jResourceDir"
834 def install4jConfFile = "jalview-installers-java"+JAVA_VERSION+".install4j"
835 install4jConf = "$install4jDir/$install4jConfFile"
837 task copyInstall4jTemplate(type: Copy) {
838 macosJavaVMDir = System.env.HOME+"/buildtools/jre/openjdk-java_vm/getdown/macos-jre"+JAVA_VERSION+"/jre"
839 macosJavaVMTgz = System.env.HOME+"/buildtools/jre/openjdk-java_vm/install4j/tgz/macos-jre"+JAVA_VERSION+".tar.gz"
840 windowsJavaVMDir = System.env.HOME+"/buildtools/jre/openjdk-java_vm/getdown/windows-jre"+JAVA_VERSION+"/jre"
841 windowsJavaVMTgz = System.env.HOME+"/buildtools/jre/openjdk-java_vm/install4j/tgz/windows-jre"+JAVA_VERSION+".tar.gz"
842 from (install4jDir) {
843 include install4jTemplate
844 rename (install4jTemplate, install4jConfFile)
845 filter(ReplaceTokens, beginToken: '', endToken: '', tokens: ['9999999999': JAVA_VERSION])
846 filter(ReplaceTokens, beginToken: '$$', endToken: '$$',
848 'JAVA_VERSION': JAVA_VERSION,
849 'JAVA_INTEGER_VERSION': JAVA_INTEGER_VERSION,
850 'VERSION': JALVIEW_VERSION,
851 'MACOS_JAVA_VM_DIR': macosJavaVMDir,
852 'MACOS_JAVA_VM_TGZ': macosJavaVMTgz,
853 'WINDOWS_JAVA_VM_DIR': windowsJavaVMDir,
854 'WINDOWS_JAVA_VM_TGZ': windowsJavaVMTgz,
855 'INSTALL4JINFOPLISTFILEASSOCIATIONS': install4jInfoPlistFileAssociations,
856 'COPYRIGHT_MESSAGE': install4jCopyrightMessage,
857 'MACOS_BUNDLE_ID': install4jMacOSBundleId
860 if (OSX_KEYPASS=="") {
861 filter(ReplaceTokens, beginToken: 'codeSigning macEnabled="', endToken: '"', tokens: ['true':'codeSigning macEnabled="false"'])
862 filter(ReplaceTokens, beginToken: 'runPostProcessor="true" ',endToken: 'Processor', tokens: ['post':'runPostProcessor="false" postProcessor'])
866 outputs.files(install4jConf)
869 // include file associations in installer
870 def installerFileAssociationsXml = file("$install4jDir/$install4jInstallerFileAssociations").text
874 match: '<action name="EXTENSIONS_REPLACED_BY_GRADLE".*?</action>',
875 replace: installerFileAssociationsXml,
879 // include uninstaller applescript app files in dmg
880 def installerDMGUninstallerXml = file("$install4jDir/$install4jDMGUninstallerAppFiles").text
884 match: '<file name="UNINSTALL_OLD_JALVIEW_APP_REPLACED_IN_GRADLE" file=.*?>',
885 replace: installerDMGUninstallerXml,
892 task installers(type: com.install4j.gradle.Install4jTask) {
893 group = "distribution"
894 description = "Create the install4j installers"
896 dependsOn copyInstall4jTemplate
897 projectFile = file(install4jConf)
898 println("Using projectFile "+projectFile)
899 variables = [majorVersion: version.substring(2, 11), build: 001, OSX_KEYSTORE: OSX_KEYSTORE, JSIGN_SH: JSIGN_SH]
900 destination = "$jalviewDir/$install4jBuildDir/$JAVA_VERSION"
904 macKeystorePassword=OSX_KEYPASS
908 inputs.dir(project.ext.getdownWebsiteDir)
909 inputs.file(install4jConf)
910 inputs.dir(macosJavaVMDir)
911 inputs.dir(windowsJavaVMDir)
912 outputs.dir("$jalviewDir/$install4jBuildDir/$JAVA_VERSION")