Questo funziona per me.
La mia classe principale:
package com.curso.online.gradle;
import org.apache.commons.lang3.StringUtils;
import org.apache.log4j.Logger;
public class Main {
public static void main(String[] args) {
Logger logger = Logger.getLogger(Main.class);
logger.debug("Starting demo");
String s = "Some Value";
if (!StringUtils.isEmpty(s)) {
System.out.println("Welcome ");
}
logger.debug("End of demo");
}
}
Ed è il contenuto del mio file build.gradle:
apply plugin: 'java'
apply plugin: 'eclipse'
repositories {
mavenCentral()
}
dependencies {
compile group: 'commons-collections', name: 'commons-collections', version: '3.2'
testCompile group: 'junit', name: 'junit', version: '4.+'
compile 'org.apache.commons:commons-lang3:3.0'
compile 'log4j:log4j:1.2.16'
}
task fatJar(type: Jar) {
manifest {
attributes 'Main-Class': 'com.curso.online.gradle.Main'
}
baseName = project.name + '-all'
from { configurations.compile.collect { it.isDirectory() ? it : zipTree(it) } }
with jar
}
e scrivo quanto segue in mia console:
java -jar ProyectoEclipseTest-all.jar
E l'output è ottimo:
log4j:WARN No appenders could be found for logger (com.curso.online.gradle.Main)
.
log4j:WARN Please initialize the log4j system properly.
log4j:WARN See http://logging.apache.org/log4j/1.2/faq.html#noconfig for more in
fo.
Welcome
fonte
2014-08-10 19:42:00
ho dovuto modificare questo per configurations.runtime.collect per il mio progetto come ho dipendenze runtime pure. – vextorspace
Ho dovuto aggiungere 'def mainClassName' per far funzionare il codice ... Stavo ricevendo Impossibile impostare la proprietà sconosciuta 'mainClassName' per il progetto root – hanskoff
Come gestite le collisioni dei nomi dei file? I file sullo stesso percorso in JAR diversi verranno sovrascritti. – waste