buildcraft/build.gradle

232 lines
7.1 KiB
Groovy
Raw Normal View History

// DON'T TOUCH THE BUILDSCRIPT[] BLOCK
// its special, and it is only there to make ForgeGradle work correctly.
2014-02-17 01:24:19 -06:00
buildscript {
repositories {
mavenCentral()
maven {
name = "forge"
url = "http://files.minecraftforge.net/maven"
}
maven {
name = "sonatype"
url = "https://oss.sonatype.org/content/repositories/snapshots/"
}
}
dependencies {
2014-04-26 13:12:28 +02:00
classpath 'net.minecraftforge.gradle:ForgeGradle:1.2-SNAPSHOT'
2014-02-17 01:24:19 -06:00
}
}
apply plugin: 'forge' // adds the forge dependency
apply plugin: 'maven' // for uploading to a maven repo
2014-05-04 12:06:32 +08:00
apply plugin: 'checkstyle'
2014-02-17 01:24:19 -06:00
2014-05-31 18:16:42 +02:00
version = "6.0.16"
2014-02-17 01:24:19 -06:00
group= "com.mod-buildcraft"
archivesBaseName = "buildcraft" // the name that all artifacts will use as a base. artifacts names follow this pattern: [baseName]-[appendix]-[version]-[classifier].[extension]
minecraft {
version = "1.7.2-10.12.2.1121" // McVersion-ForgeVersion this variable is later changed to contain only the MC version, while the apiVersion variable is used for the forge version. Yeah its stupid, and will be changed eventually.
2014-02-17 01:24:19 -06:00
assetDir = "run/assets" // the place for ForgeGradle to download the assets. The assets that the launcher gets and stuff
2014-02-17 01:24:19 -06:00
// replacing stuff in the source
replace '@VERSION@', project.version
replace '@MC_VERSION@', version
}
// configure the source folders
sourceSets {
main {
java {
srcDir 'common'
2014-02-17 01:24:19 -06:00
// exclude 'some exclusion'
// include 'some inclusion'
}
resources {
srcDir 'buildcraft_resources'
def l10n = file('../BuildCraft-Localization')
if(l10n.exists())
srcDir l10n
exclude '**/.md' // exclude readme from localization repo
2014-02-17 01:24:19 -06:00
// exclude 'some exclusion'
// include 'some inclusion'
}
}
api {
java {
srcDir 'api'
}
}
2014-02-17 01:24:19 -06:00
}
processResources
{
// replace stuff in mcmod.info, nothing else
from(sourceSets.main.resources.srcDirs) {
include 'mcmod.info'
// replace version and mcversion
// ${version} and ${mcversion} are the exact strings being replaced
expand 'version':project.version, 'mcversion':project.minecraft.version
2014-02-17 01:24:19 -06:00
}
// copy everything else, that's not the mcmod.info
2014-02-17 01:24:19 -06:00
from(sourceSets.main.resources.srcDirs) {
exclude 'mcmod.info'
}
}
// --------------------
// extra jar section
// -------------------
// add a source jar
task sourceJar(type: Jar) {
from sourceSets.main.allSource
from sourceSets.api.allSource
2014-02-17 01:24:19 -06:00
classifier = 'sources'
}
// add api classes to javadoc
javadoc {
source += sourceSets.api.allSource
}
2014-02-17 01:24:19 -06:00
// add a javadoc jar
task javadocJar(type: Jar, dependsOn: javadoc) {
classifier = 'javadoc'
from 'build/docs/javadoc'
}
// because the normal output has been made to be obfuscated
task deobfJar(type: Jar) {
from sourceSets.main.output
from sourceSets.api.output
2014-02-17 01:24:19 -06:00
classifier = 'dev'
}
task apiJar(type: Jar) {
from sourceSets.api.output
classifier = 'api'
}
// add api classes to main package
jar {
from sourceSets.api.output
}
2014-05-04 18:16:45 +02:00
checkstyle {
2014-05-04 12:06:32 +08:00
configFile = file('guidelines/buildcraft.checkstyle')
}
2014-02-17 01:24:19 -06:00
// make sure all of these happen when we run build
build.dependsOn sourceJar, javadocJar, deobfJar, apiJar
2014-02-17 01:24:19 -06:00
// --------------------
// maven section
// -------------------
// create the deployerJars dependency configuration
configurations {
deployerJars
}
dependencies {
// dependency in deployerJars, for maven deployment. see definition in mavenDeployer{} below
deployerJars "org.apache.maven.wagon:wagon-ssh:2.2"
}
// specify artifacts to be uploaded
artifacts {
// the default jar is already here by default
2014-02-17 01:24:19 -06:00
archives sourceJar
archives javadocJar
archives deobfJar
archives apiJar
2014-02-17 01:24:19 -06:00
}
uploadArchives {
// make sure this happens after reobfuscation
dependsOn 'reobf'
repositories {
if (project.hasProperty("filesmaven")) { // if this is the Forge server, and this stuff is defined...
logger.info('Publishing to files server')
mavenDeployer {
// specify the jars that maven needs to deploy here
configuration = configurations.deployerJars
// authentication, again, specially set in the forge server environment
repository(url: project.filesmaven.url) {
authentication(userName: project.filesmaven.username, privateKey: project.filesmaven.key)
}
// here you specify all your metadata
// this is the definition of the maven pom.xml. This is simply a DSL to define the XML. Not actual fields or things to set.
pom {
groupId = project.group
2014-03-18 16:08:36 -05:00
version = project.version
2014-02-17 01:24:19 -06:00
artifactId = project.archivesBaseName
project {
name project.archivesBaseName
packaging 'jar'
description 'A Minecraft mod adding all sorts of machinery'
2014-02-17 01:24:19 -06:00
url 'http://www.mod-buildcraft.com/'
scm {
url 'https://github.com/BuildCraft/BuildCraft'
connection 'scm:git:git://github.com/BuildCraft/BuildCraft.git'
developerConnection 'scm:git:git@github.com:BuildCraft/BuildCraft.git'
}
issueManagement {
system 'github'
url 'https://github.com/BuildCraft/BuildCraft/issues'
}
licenses {
license {
name 'Minecraft Mod Public License'
url 'http://www.mod-buildcraft.com/MMPL-1.0.txt'
distribution 'repo'
}
}
developers {
developer {
id 'SpaceToad'
name 'SpaceToad'
roles { role 'developer' }
}
developer {
id 'CovertJaguar'
name 'CovertJaguar'
roles { role 'developer' }
}
developer {
id 'SirSngir'
name 'SirSengir'
roles { role 'developer' }
}
developer {
id 'Krapht'
name 'Krapht'
roles { role 'developer' }
}
}
}
}
}
}
else
{
// otherwise publishing to the local repo in ~/.m2 is fine...
add project.repositories.mavenLocal()
}
}
}