generated from WilderForge/ExampleMod
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathreplaceTokenScript.gradle
More file actions
148 lines (126 loc) · 5.16 KB
/
replaceTokenScript.gradle
File metadata and controls
148 lines (126 loc) · 5.16 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
/*
* This Gradle build script preprocesses source and resource files by replacing placeholders
* (e.g., `@modVersion@`) in your source code with actual values at compile time.
* It also organizes the build process to use these modified files.
*
* Key Features:
* 1. **Token Replacement**:
* - Replaces placeholders in `.java` and `.json` files with project-specific values.
*
* 2. **Custom Tasks**:
* - `replaceTokensInResources`: Processes resource files and outputs them to `build/processedResources`.
* - `replaceTokensInSource`: Processes Java source files and outputs them to `build/processedSrc`.
*
* 3. **Source Set Updates**:
* - Uses a `processed` source set for token-replaced files, ensuring the build uses the updated files.
*
* 4. **Build Integration**:
* - Ensures token replacement happens before resource processing, compilation, and packaging.
* - Creates a `sourceJar` containing the processed files.
*
* How to Use:
* 1. Define the token and its value in gradle.properties, which is located in the project's root directory.
(see the `replacementTokens` variable declaration in this script)
* 2. Add the token to the replacementTokens map in this buildscript.
* 3. Add placeholders (e.g., `@modVersion@`) in your source or resource files.
* 4. Run `./gradlew build` to generate the processed files and build the project.
*
* Outputs:
* - Processed resource files in `build/processedResources`.
* - Processed source files in `build/processedSrc`.
* - A source JAR containing processed files in `build/libs`.
* - A Compiled JAR binary which uses the processed files. Located in `build/libs`
*/
import org.apache.tools.ant.filters.ReplaceTokens
// Define file extensions for token replacement. You can add additional file types to replace tokens in.
def tokenReplaceExtensions = ['.java', '.json']
// Define all tokens and their replacements as a map
def replacementTokens = [
modVersion: project.modVersion, //defines the token @modVersion@, which is replaced with the `modVersion` value located in gradle.properties (project root)
buildDate: new Date().format('yyyy-MM-dd HH:mm:ss'), //defines the token @buildDate@, which is replaced by the current system time.
builtBy: System.getProperty("user.name")
]
task replaceTokensInResources(type: Copy) {
doFirst {
delete "$buildDir/processedResources"
}
from(sourceSets.main.resources.srcDirs) {
// Only include files matching the defined extensions
include { file -> tokenReplaceExtensions.any { file.name.endsWith(it) } }
// Apply token replacement using the predefined variable
filter(ReplaceTokens, tokens: replacementTokens)
}
from(sourceSets.main.resources.srcDirs) {
// Ensure non-text files are passed through untouched
exclude { file -> tokenReplaceExtensions.any { file.name.endsWith(it) } }
}
into("$buildDir/processedResources")
outputs.upToDateWhen { false }
outputs.cacheIf { false }
inputs.files(sourceSets.main.resources.srcDirs)
outputs.dir("$buildDir/processedResources")
}
task replaceTokensInSource(type: Copy) {
def processedDir = "$buildDir/processedSrc"
doFirst {
delete processedDir
project.logger.lifecycle("Starting file iteration in source files")
project.logger.lifecycle("Source directories being used: ${sourceSets.main.java.srcDirs}")
}
from(sourceSets.main.java.srcDirs) {
include '**/*'
eachFile { file ->
def matchesExtension = tokenReplaceExtensions.any { file.name.endsWith(it) }
project.logger.lifecycle("found file " + file)
}
filter(ReplaceTokens, tokens: replacementTokens)
}
into(processedDir)
// Properly set inputs and outputs
inputs.files(sourceSets.main.java.srcDirs)
outputs.dir(processedDir)
// Ensure Gradle sees the task as out-of-date by overriding the up-to-date check
outputs.upToDateWhen { false }
outputs.cacheIf { false }
doLast {
project.logger.lifecycle("File iteration and token replacement complete")
}
}
sourceSets {
processed {
resources.srcDirs = ["$buildDir/processedResources"]
java.srcDirs = ["$buildDir/processedSrc"]
}
build {
java.srcDirs = sourceSets.main.java.srcDirs + sourceSets.processed.java.srcDirs
resources.srcDirs = sourceSets.main.resources.srcDirs + sourceSets.processed.resources.srcDirs
}
}
configurations {
resolvedCompileOnly {
extendsFrom compileOnly
}
}
processResources {
dependsOn replaceTokensInResources
from(sourceSets.processed.resources)
duplicatesStrategy = DuplicatesStrategy.INCLUDE
}
compileJava {
dependsOn replaceTokensInResources
source = replaceTokensInSource.outputs
classpath -= sourceSets.main.resources
classpath += sourceSets.processed.resources
}
task sourceJar(type: Jar) {
from sourceSets.processed.allSource
archiveClassifier.set('sources')
destinationDirectory.set(file("$buildDir/libs"))
dependsOn replaceTokensInSource, replaceTokensInResources
}
build.dependsOn(sourceJar)
eclipse {
classpath {
sourceSets -= [sourceSets.processed, sourceSets.build]
}
}