org.codehaus.groovy.tools.GrapeMain.groovy Maven / Gradle / Ivy
/*
* Copyright 2003-2013 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
*
* http://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.
*/
package org.codehaus.groovy.tools
import groovy.grape.Grape
import org.apache.ivy.util.DefaultMessageLogger
import org.apache.ivy.util.Message
import org.apache.commons.cli.*
//commands
install = {arg, cmd ->
if (arg.size() > 5 || arg.size() < 3) {
println 'install requires two to four arguments: [] []'
return
}
def ver = '*'
if (arg.size() >= 4) {
ver = arg[3]
}
def classifier = null
if (arg.size() >= 5) {
classifier = arg[4]
}
// set the instance so we can re-set the logger
Grape.getInstance()
setupLogging()
cmd.getOptionValues('r')?.each { String url ->
Grape.addResolver(name:url, root:url)
}
try {
Grape.grab(autoDownload: true, group: arg[1], module: arg[2], version: ver, classifier: classifier, noExceptions: true)
} catch (Exception e) {
println "An error occured : $ex"
}
}
uninstall = {arg, cmd ->
if (arg.size() != 4) {
println 'uninstall requires three arguments: '
// TODO make version optional? support classifier?
// println 'uninstall requires two to four arguments, [] []'
return
}
String group = arg[1]
String module = arg[2]
String ver = arg[3]
// def classifier = null
// set the instance so we can re-set the logger
Grape.getInstance()
setupLogging()
if (!Grape.enumerateGrapes().find {String groupName, Map g ->
g.any {String moduleName, List versions ->
group == groupName && module == moduleName && ver in versions
}
}) {
println "uninstall did not find grape matching: $group $module $ver"
def fuzzyMatches = Grape.enumerateGrapes().findAll { String groupName, Map g ->
g.any {String moduleName, List versions ->
groupName.contains(group) || moduleName.contains(module) ||
group.contains(groupName) || module.contains(moduleName)
}
}
if (fuzzyMatches) {
println 'possible matches:'
fuzzyMatches.each { String groupName, Map g -> println " $groupName: $g" }
}
return
}
Grape.instance.uninstallArtifact(group, module, ver)
}
list = {arg, cmd ->
println ""
int moduleCount = 0
int versionCount = 0
// set the instance so we can re-set the logger
Grape.getInstance()
setupLogging()
Grape.enumerateGrapes().each {String groupName, Map group ->
group.each {String moduleName, List versions ->
println "$groupName $moduleName $versions"
moduleCount++
versionCount += versions.size()
}
}
println ""
println "$moduleCount Grape modules cached"
println "$versionCount Grape module versions cached"
}
resolve = {arg, cmd ->
Options options = new Options();
options.addOption(
OptionBuilder.hasArg(false)
.withLongOpt("ant")
.create('a')
);
options.addOption(
OptionBuilder.hasArg(false)
.withLongOpt("dos")
.create('d')
);
options.addOption(
OptionBuilder.hasArg(false)
.withLongOpt("shell")
.create('s')
);
options.addOption(
OptionBuilder.hasArg(false)
.withLongOpt("ivy")
.create('i')
);
CommandLine cmd2 = new GroovyInternalPosixParser().parse(options, arg[1..-1] as String[], true);
arg = cmd2.args
// set the instance so we can re-set the logger
Grape.getInstance()
setupLogging(Message.MSG_ERR)
if ((arg.size() % 3) != 0) {
println 'There needs to be a multiple of three arguments: (group module version)+'
return
}
if (args.size() < 3) {
println 'At least one Grape reference is required'
return
}
def before, between, after
def ivyFormatRequested = false
if (cmd2.hasOption('a')) {
before = '\n'
} else if (cmd2.hasOption('d')) {
before = 'set CLASSPATH='
between = ';'
after = ''
} else if (cmd2.hasOption('s')) {
before = 'export CLASSPATH='
between = ':'
after = ''
} else if (cmd2.hasOption('i')) {
ivyFormatRequested = true
before = '
results += ('org="' + dep.group + '" name="' + dep.module + '" revision="' + dep.revision)
}
}
if (results) {
println "${before}${results.join(between)}${after}"
} else {
println 'Nothing was resolved'
}
} catch (Exception e) {
println "Error in resolve:\n\t$e.message"
if (e.message =~ /unresolved dependency/) println "Perhaps the grape is not installed?"
}
}
def commands = [
'install': [closure: install,
shortHelp: 'Installs a particular grape'],
'uninstall': [closure: uninstall,
shortHelp: 'Uninstalls a particular grape (non-transitively removes the respective jar file from the grape cache)'],
'list': [closure: list,
shortHelp: 'Lists all installed grapes'],
'resolve': [closure: resolve,
shortHelp: 'Enumerates the jars used by a grape']
]
// command line parsing
Options options = new Options();
options.addOption(
OptionBuilder.withLongOpt("define")
.withDescription("define a system property")
.hasArg(true)
.withArgName("name=value")
.create('D')
);
options.addOption(
OptionBuilder.withLongOpt("resolver")
.withDescription("define a grab resolver (for install)")
.hasArg(true)
.withArgName("url")
.create('r')
);
options.addOption(
OptionBuilder.hasArg(false)
.withDescription("usage information")
.withLongOpt("help")
.create('h')
);
// Logging Level Options
options.addOptionGroup(
new OptionGroup().addOption(
OptionBuilder.hasArg(false)
.withDescription("Log level 0 - only errors")
.withLongOpt("quiet")
.create('q'))
.addOption(
OptionBuilder.hasArg(false)
.withDescription("Log level 1 - errors and warnings")
.withLongOpt("warn")
.create('w'))
.addOption(
OptionBuilder.hasArg(false)
.withDescription("Log level 2 - info")
.withLongOpt("info")
.create('i'))
.addOption(
OptionBuilder.hasArg(false)
.withDescription("Log level 3 - verbose")
.withLongOpt("verbose")
.create('V'))
.addOption(
OptionBuilder.hasArg(false)
.withDescription("Log level 4 - debug")
.withLongOpt("debug")
.create('d'))
)
options.addOption(
OptionBuilder.hasArg(false)
.withDescription("display the Groovy and JVM versions")
.withLongOpt("version")
.create('v')
);
CommandLine cmd = new GroovyInternalPosixParser().parse(options, args, true);
grapeHelp = {
int spacesLen = commands.keySet().max {it.length()}.length() + 3
String spaces = ' ' * spacesLen
PrintWriter pw = new PrintWriter(binding.variables.out ?: System.out)
new HelpFormatter().printHelp(
pw,
80,
"grape [options] [args]\n",
"options:",
options,
2,
4,
null, // footer
true);
pw.flush()
println ""
println "commands:"
commands.each {String k, v ->
println " ${(k + spaces).substring(0, spacesLen)} $v.shortHelp"
}
println ""
}
setupLogging = {int defaultLevel = 2 -> // = Message.MSG_INFO -> some parsing error :(
if (cmd.hasOption('q')) {
Message.setDefaultLogger(new DefaultMessageLogger(Message.MSG_ERR))
} else if (cmd.hasOption('w')) {
Message.setDefaultLogger(new DefaultMessageLogger(Message.MSG_WARN))
} else if (cmd.hasOption('i')) {
Message.setDefaultLogger(new DefaultMessageLogger(Message.MSG_INFO))
} else if (cmd.hasOption('V')) {
Message.setDefaultLogger(new DefaultMessageLogger(Message.MSG_VERBOSE))
} else if (cmd.hasOption('d')) {
Message.setDefaultLogger(new DefaultMessageLogger(Message.MSG_DEBUG))
} else {
Message.setDefaultLogger(new DefaultMessageLogger(defaultLevel))
}
}
if (cmd.hasOption('h')) {
grapeHelp()
return
}
if (cmd.hasOption('v')) {
String version = GroovySystem.getVersion();
println "Groovy Version: $version JVM: ${System.getProperty('java.version')}"
return
}
cmd.getOptionValues('D')?.each {String prop ->
def (k, v) = prop.split ('=', 2) as List // array multiple assignment quirk
System.setProperty(k, v ?: "")
}
String[] arg = cmd.args
if (arg?.length == 0) {
grapeHelp()
} else if (commands.containsKey(arg[0])) {
commands[arg[0]].closure(arg, cmd)
} else {
println "grape: '${arg[0]}' is not a grape command. See 'grape --help'"
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy