You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
241 lines
8.8 KiB
241 lines
8.8 KiB
/*
|
|
* Copyright 2013 The Android Open Source Project
|
|
*
|
|
* 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.
|
|
*/
|
|
|
|
// The SampleGenPlugin source is in the buildSrc directory.
|
|
import com.example.android.samples.build.SampleGenPlugin
|
|
apply plugin: SampleGenPlugin
|
|
|
|
// Add a preflight task that depends on the "refresh" task that gets
|
|
// added by the SampleGenPlugin.
|
|
task preflight {
|
|
project.afterEvaluate({preflight.dependsOn(project.refresh)})
|
|
}
|
|
|
|
String outPath(String buildType) {
|
|
/*
|
|
def repoInfo = "repo info platform/developers/build".execute().text
|
|
def buildPath = (repoInfo =~ /Mount path: (.*)/)[0][1]
|
|
*/
|
|
return "${samplegen.pathToBuild}/out/${buildType}/${samplegen.targetSampleName()}";
|
|
}
|
|
|
|
/**
|
|
* Collapse a path "IntelliJ-style" by putting dots rather than slashes between
|
|
* path components that have only one child. So the two paths
|
|
*
|
|
* com/example/android/foo/bar.java
|
|
* com/example/android/bar/foo.java
|
|
*
|
|
* Become
|
|
* com.example.android/foo/bar.java
|
|
* com.example.android/bar/foo.java
|
|
*
|
|
* @param path
|
|
* @param roots
|
|
* @return
|
|
*/
|
|
Map<String,String> collapsePaths(FileTree path, List<String> roots) {
|
|
Map result = new HashMap<String,String>();
|
|
|
|
println ("******************** Collapse *************************")
|
|
|
|
path.visit { FileVisitDetails f ->
|
|
if (f.isDirectory()) return;
|
|
StringBuilder collapsedPath = new StringBuilder("${f.name}");
|
|
File current = f.file;
|
|
|
|
//
|
|
// Starting at this file, walk back to the root of the path and
|
|
// substitute dots for any directory that has only one child.
|
|
//
|
|
|
|
// Don't substitute a dot for the separator between the end of the
|
|
// path and the filename, even if there's only one file in the directory.
|
|
if (!f.isDirectory()) {
|
|
current = current.parentFile;
|
|
collapsedPath.insert(0, "${current.name}/")
|
|
}
|
|
|
|
// For everything else, use a dot if there's only one child and
|
|
// a slash otherwise. Filter out the root paths, too--we only want
|
|
// the relative path. But wait, Groovy/Gradle is capricious and
|
|
// won't return the proper value from a call to roots.contains(String)!
|
|
// I'm using roots.sum here instead of tracking down why a list of
|
|
// strings can't return true from contains() when given a string that
|
|
// it quite obviously does contain.
|
|
current = current.parentFile;
|
|
while((current != null)
|
|
&& (roots.sum {String r-> return r.equals(current.absolutePath) ? 1 : 0 } == 0)) {
|
|
|
|
char separator = current.list().length > 1 ? '/' : '.';
|
|
collapsedPath.insert(0, "${current.name}${separator}");
|
|
current = current.parentFile;
|
|
}
|
|
result.put(f.file.path, collapsedPath.toString());
|
|
}
|
|
|
|
println ("******************** Collapse results *********************")
|
|
|
|
result.each {entry -> println("- ${entry}");}
|
|
return result
|
|
}
|
|
|
|
|
|
task emitAnt(type:Copy) {
|
|
def outputPath = outPath("ant");
|
|
def inputPath = "${project.projectDir}/${samplegen.targetSampleModule()}"
|
|
into outputPath
|
|
includeEmptyDirs
|
|
["main", "common", "template"].each { input ->
|
|
[[ "java", "src"], ["res", "res"]].each { filetype ->
|
|
def srcPath = "${inputPath}/src/${input}/${filetype[0]}"
|
|
into("${filetype[1]}") {
|
|
from(srcPath)
|
|
}
|
|
}
|
|
}
|
|
from("${inputPath}/src/main") { include "AndroidManifest.xml" }
|
|
from("${inputPath}/src/template") { include "project.properties" }
|
|
}
|
|
|
|
task emitGradle(type:Copy) {
|
|
dependsOn(preflight)
|
|
def outputPath = outPath("gradle")
|
|
def inputPath = "${project.projectDir}"
|
|
// Copy entire sample into output -- since it's already in Gradle format, we'll explicitly exclude content that
|
|
// doesn't belong here.
|
|
into outputPath
|
|
from("${inputPath}") {
|
|
// Paths to exclude from output
|
|
exclude ".gradle"
|
|
exclude "_index.jd"
|
|
exclude "bin"
|
|
exclude "buildSrc"
|
|
exclude "local.properties"
|
|
exclude "template-params.xml"
|
|
exclude "*.iml"
|
|
exclude "**/.idea"
|
|
exclude "**/build"
|
|
exclude "**/proguard-project.txt"
|
|
exclude "${samplegen.targetSampleModule()}/**/README*.txt"
|
|
exclude "**/README-*.txt"
|
|
|
|
// src directory needs to be consolidated, will be done in next section
|
|
exclude "${samplegen.targetSampleModule()}/src/"
|
|
}
|
|
|
|
// Consolidate source directories
|
|
["main", "common", "template"].each { input ->
|
|
["java", "res", "assets", "rs"].each { filetype ->
|
|
def srcPath = "${inputPath}/${samplegen.targetSampleModule()}/src/${input}/${filetype}"
|
|
into("${samplegen.targetSampleModule()}/src/main/${filetype}") {
|
|
from(srcPath)
|
|
}
|
|
}
|
|
}
|
|
|
|
// Copy AndroidManifest.xml
|
|
into ("${samplegen.targetSampleModule()}/src/main") {
|
|
from("${inputPath}/${samplegen.targetSampleModule()}/src/main/AndroidManifest.xml")
|
|
}
|
|
|
|
// Remove BEGIN_EXCLUDE/END_EXCLUDE blocks from source files
|
|
eachFile { file ->
|
|
if (file.name.endsWith(".gradle") || file.name.endsWith(".java")) {
|
|
// TODO(trevorjohns): Outputs a blank newline for each filtered line. Replace with java.io.FilterReader impl.
|
|
boolean outputLines = true;
|
|
def removeExcludeBlocksFilter = { line ->
|
|
if (line ==~ /\/\/ BEGIN_EXCLUDE/) {
|
|
outputLines = false;
|
|
} else if (line ==~ /\/\/ END_EXCLUDE/) {
|
|
outputLines = true;
|
|
} else if (outputLines) {
|
|
return line;
|
|
}
|
|
return ""
|
|
}
|
|
filter(removeExcludeBlocksFilter)
|
|
}
|
|
}
|
|
}
|
|
|
|
task emitBrowseable(type:Copy) {
|
|
def outputPathRoot = outPath("browseable")
|
|
def modules = project.childProjects.keySet()
|
|
def hasMultipleModules = modules.size() > 1
|
|
println "---------------- modules found in sample: ${modules}"
|
|
into outputPathRoot
|
|
from("${project.projectDir}/_index.jd")
|
|
|
|
modules.each { moduleName ->
|
|
// For single module samples (default), we emit the module contents
|
|
// directly to the root of the browseable sample:
|
|
def outputPath = "."
|
|
if (hasMultipleModules) {
|
|
// For multi module samples, we need an extra directory level
|
|
// to separate modules:
|
|
outputPath = "${moduleName}"
|
|
}
|
|
println "\n---------------- processing MODULE ${moduleName} to outputPath ${outputPath}"
|
|
def inputPath = "${project.projectDir}/${moduleName}"
|
|
|
|
def srcDirs = ["main", "common", "template"].collect {input -> "${inputPath}/src/${input}" };
|
|
def javaDirs = srcDirs.collect { input -> "${input}/java"}
|
|
FileTree javaTree = null;
|
|
javaDirs.each { dir ->
|
|
FileTree tree = project.fileTree("${dir}")
|
|
javaTree = (javaTree == null) ? tree : javaTree.plus(tree)}
|
|
Map collapsedPaths = collapsePaths(javaTree, javaDirs)
|
|
|
|
srcDirs.each { srcPath ->
|
|
print "** Copying source ${srcPath}...";
|
|
duplicatesStrategy = 'fail'
|
|
into("${outputPath}/src") {
|
|
def javaPath = "${srcPath}/java";
|
|
from(javaPath)
|
|
include(["**/*.java", "**/*.xml"])
|
|
eachFile { FileCopyDetails fcd ->
|
|
if (fcd.file.isFile()) {
|
|
def filename = fcd.name;
|
|
String collapsed = collapsedPaths.get(fcd.file.path);
|
|
fcd.path = "${outputPath}/src/${collapsed}";
|
|
} else {fcd.exclude()}
|
|
}
|
|
println "done"
|
|
}
|
|
into("${outputPath}/res") {
|
|
from("${srcPath}/res")
|
|
}
|
|
into("${outputPath}/src/rs") {
|
|
from("${srcPath}/rs")
|
|
}
|
|
into("${outputPath}") {from("${srcPath}/AndroidManifest.xml")}
|
|
}
|
|
}
|
|
}
|
|
|
|
task emitGradleZip(dependsOn: [emitBrowseable, emitGradle], type:Zip) {
|
|
def outputPath = "${samplegen.pathToBuild}/out/browseable"
|
|
def folderName = "${samplegen.targetSampleName()}"
|
|
archiveName = "${samplegen.targetSampleName()}.zip"
|
|
def inputPath = outPath("gradle")
|
|
from inputPath
|
|
into folderName
|
|
include "**"
|
|
def outDir = project.file(outputPath)
|
|
destinationDir = outDir
|
|
}
|