org.fusesource.scalate.tool.commands.Create.scala Maven / Gradle / Ivy
/**
* Copyright (C) 2009-2010 the original author or authors.
* See the notice.md file distributed with this work for additional
* information regarding copyright ownership.
*
* 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.fusesource.scalate.tool.commands
import java.{util => ju, lang => jl}
import java.util.zip.ZipInputStream
import java.io.{FileInputStream, FileWriter, File, ByteArrayOutputStream}
import java.lang.StringBuilder
import org.apache.felix.gogo.commands.{Action, Option => option, Argument => argument, Command => command, CompleterValues => completerValues}
import org.osgi.service.command.CommandSession
/**
* The 'scalate create' sub command.
*/
@command(scope = "scalate", name = "create", description = "Creates your Scalate project fast to get you scalate-ing!")
class Create extends Action {
@argument(index = 0, required = true, name = "archetype", description = "Archetype to create")
// TODO rename to archetype
var archetype: String = _
@argument(index = 1, required = true, name = "groupId", description = "Maven group Id of the new project")
var groupId = ""
@argument(index = 2, required = true, name = "artifactId", description = "Maven artifact Id of the new project")
var artifactId: String = _
@argument(index = 3, name = "version", description = "Maven Version of the new project")
var version = "1.0-SNAPSHOT"
@argument(index = 4, name = "package", description = "Package name of generated scala code (defaults to 'groupId.artifactId')")
var packageName: String = _
@option(name = "--outputDir", description = "Output directory")
var outputDir = userDir
@option(name = "--verbose", description = "Verbose output")
var verbose: Boolean = false
@option(name = "--home", description = "Scalate install directory")
var homeDir = System.getProperty("scalate.home", "")
val archetypes = Map("jersey" -> "scalate-archetype-jersey", "guice" -> "scalate-archetype-guice")
var archetypeGroupId = "org.fusesource.scalate.tooling"
val userDir = System.getProperty("user.dir", ".")
val zipEntryPrefix = "archetype-resources/"
var archetypeArtifactId = ""
var name = ""
/*
TODO
def usage(out: StringBuilder) = {
def info(v: String) = {
out.append(v + "\n");
}
info("")
info(" Archetypes:")
info(" empty Basic Scalate project")
info(" guice Guice based Scalate project")
}
*/
@completerValues(index = 0)
def archetypeNameArray = archetypes.keysIterator.toSeq.sortWith(_ < _).toArray
def archetypeNames = archetypes.keysIterator.toSeq.sortWith(_ < _).mkString("(", ", ", ")")
def execute(session: CommandSession): jl.Integer = {
def info(s: => String = "") = session.getConsole.println(s)
def debug(s: => String) = if (verbose) session.getConsole.println(s)
val optArchetype = archetypes.get(archetype)
if (optArchetype.isEmpty) {
info("No such archetype '" + archetype + "' possible values are " + archetypeNames)
return -1
}
this.archetypeArtifactId = optArchetype.get
// lets try find some files from the archetype...
val archetypesDir = new File(homeDir + "/archetypes")
val file = new File(archetypesDir, archetypeArtifactId + ".jar")
if (!file.exists) {
info("No such archetype '" + archetypeArtifactId + "' in directory " + archetypesDir)
return -2
}
else {
outputDir = userDir + "/" + artifactId
val outputFile = new File(outputDir)
if (outputFile.exists) {
info("Cannot create archetype as " + outputFile.getAbsolutePath + " already exists")
return -2
} else {
if (packageName==null || packageName.length == 0) {
packageName = groupId + "." + artifactId
}
info("Creating archetype " + archetypeArtifactId + " using maven groupId: " +
groupId + " artifactId: " + artifactId + " version: " + version
+ " in directory: " + outputDir)
val zip = new ZipInputStream(new FileInputStream(file))
try {
var ok = true
while (ok) {
val entry = zip.getNextEntry
if (entry == null) {
ok = false
}
else {
val fullName = entry.getName
if (!entry.isDirectory && fullName.startsWith(zipEntryPrefix)) {
name = fullName.substring(zipEntryPrefix.length)
val longSize = entry.getSize
val size = longSize.toInt
debug("processing resource: " + name)
val bos = new ByteArrayOutputStream()
val buffer = new Array[Byte](64 * 1024)
var bytes = 1
while (bytes > 0) {
bytes = zip.read(buffer)
if (bytes > 0) {
bos.write(buffer, 0, bytes)
}
}
val text = new String(bos.toByteArray)
processResource(text)
}
zip.closeEntry
}
}
info()
info("Done. To run the generated project type:")
info()
info(" cd " + artifactId)
info(" mvn jetty:run")
info()
} finally {
zip.close
}
return 0
}
}
}
protected val webInfResources = "src/main/webapp/WEB-INF/resources"
protected val sourcePathRegexPattern = "(src/(main|test)/(java|scala)/)(.*)".r.pattern
protected def processResource(fileContents: String): Unit = {
val idx = name.lastIndexOf('/')
val matcher = sourcePathRegexPattern.matcher(name)
val dirName = if (packageName.length > 0 && idx > 0 && matcher.matches) {
val prefix = matcher.group(1)
outputDir + "/" + prefix + packageName.replace('.', '/') + "/" + name.substring(prefix.length)
}
else if (packageName.length > 0 && name.startsWith(webInfResources)) {
outputDir + "/src/main/webapp/WEB-INF/" + packageName.replace('.', '/') + "/resources" + name.substring(webInfResources.length)
}
else {
outputDir + "/" + name
}
// lets replace properties...
val dir = new File(dirName)
dir.getParentFile.mkdirs
val out = new FileWriter(dir)
out.write(transformContents(fileContents))
out.close
}
protected def transformContents(fileContents: String): String = {
var answer = replaceVariable(fileContents, "package", packageName)
if (name == "pom.xml") {
// lets replace groupId and artifactId in pom.xml
answer = answer.replaceFirst(""".* """, """""" + groupId + """ """)
answer = answer.replaceFirst(""".* """, """""" + artifactId + """ """)
answer = answer.replaceFirst(""".* """, """""" + version + """ """)
}
answer
}
protected def replaceVariable(text: String, name: String, value: String): String = {
text.replaceAll("""([^\\])\$\{""" + name + """\}""", "$1" + value)
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy