This repository was archived by the owner on Dec 18, 2023. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 88
/
Copy pathConfigPOJO.kt
167 lines (120 loc) · 5.61 KB
/
ConfigPOJO.kt
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
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
/*
* Copyright 2017 Google Inc.
*
* 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 com.google.androidstudiopoet.input
import com.google.androidstudiopoet.models.FromToDependencyConfig
import com.google.androidstudiopoet.models.Topologies
import com.google.gson.Gson
import java.security.InvalidParameterException
import java.util.Locale
class ConfigPOJO {
// name of the new project
lateinit var projectName: String
// directory where generator should put generated project
lateinit var root: String
// how many modules
var numModules: Int = 0
// how many methods should be generated all together (!!!)
var allMethods: String? = null
// how many java methods should be generated all together
var javaMethodCount: String? = null
// how many java packages should be generated
var javaPackageCount: String? = null
// how many kotlin packages should be generated
var kotlinPackageCount: String? = null
// how many classes should be generated in each Java packages
var javaClassCount: String? = null
// how many classes should be generated in each Kotlin packages
var kotlinClassCount: String? = null
val javaMethodsPerClass: Int
get() {
val totalJavaClasses = (Integer.parseInt(javaClassCount!!) * Integer.parseInt(javaPackageCount!!))
return if (totalJavaClasses > 0) Integer.parseInt(javaMethodCount!!) / totalJavaClasses else 0
}
private val allKotlinMethods: Int
get() = Integer.parseInt(allMethods!!) - Integer.parseInt(javaMethodCount!!)
val kotlinMethodsPerClass: Int
get() {
val totalKotlinClasses = Integer.parseInt(kotlinClassCount!!) * Integer.parseInt(kotlinPackageCount!!)
return if (totalKotlinClasses > 0) allKotlinMethods / totalKotlinClasses else 0
}
var dependencies: List<FromToDependencyConfig>? = null
var androidModules: Int = 0
var numActivitiesPerAndroidModule: String? = null
val productFlavors: List<Int>? = null
val buildTypes: Int? = null
var gradleVersion: String? = ""
var kotlinVersion: String? = null
var androidGradlePluginVersion: String? = null
var gradleProperties: Map<String, String>? = null
private val topologies: List<Map<String, String>>? = null
var libraries: List<DependencyConfig.LibraryDependencyConfig>? = null
var localJarLibsDependency: List<DependencyConfig.LocalJarLibsDependencyConfig>? = null
var extraBuildFileLines: List<String>? = null
var extraAndroidBuildFileLines: List<String>? = null
var generateTests: Boolean = false
var generateBazelFiles: Boolean = false
// Will use same data binding configuration for all android modules
var dataBindingConfig: DataBindingConfig? = null
var composeConfig: ComposeConfig? = null
var viewBinding: Boolean = false
override fun toString(): String = toJson()
private fun toJson(): String {
val gson = Gson()
return gson.toJson(this)
}
val useKotlin: Boolean
get() = kotlinPackageCount?.toInt()?.let { it > 0 } == true
val resolvedDependencies: Map<String, Set<FromToDependencyConfig>> by lazy {
val allDependencies: MutableMap<String, MutableSet<FromToDependencyConfig>> = mutableMapOf()
// Add dependencies generated by topologies
val givenTopologies = topologies
if (givenTopologies != null) {
for (parameters in givenTopologies) {
val type = parameters["type"] ?: throw InvalidParameterException("No type specified in topology $parameters")
val topology: Topologies = Topologies.valueOf(type.uppercase(Locale.getDefault()))
val currentDependencies = topology.generateDependencies(parameters, allModuleNames)
addDependencies(allDependencies, currentDependencies)
}
}
// Add explicit dependencies
val explicitDependencies = dependencies
if (explicitDependencies != null) {
addDependencies(allDependencies, explicitDependencies)
}
allDependencies
}
val resolvedLocalJarLibsDependencies: Map<String, DependencyConfig.LocalJarLibsDependencyConfig> by lazy {
val givenDependency = localJarLibsDependency
givenDependency?.associateBy({it.moduleName}, {it}) ?: emptyMap()
}
private val allModuleNames: List<String> by lazy {
val moduleNames = mutableListOf<String>()
(0 until androidModules).mapTo(moduleNames) {getAndroidModuleName(it)}
(0 until numModules).mapTo(moduleNames) {getModuleName(it)}
moduleNames
}
private fun addDependencies(to: MutableMap<String, MutableSet<FromToDependencyConfig>>, from: List<FromToDependencyConfig>) {
for (dependency in from) {
val key = dependency.from
if ((!to.containsKey(key)) || to[key] == null) {
to[key] = hashSetOf(dependency)
}
else {
to[key]?.add(dependency)
}
}
}
fun getAndroidModuleName(index: Int) = "androidAppModule$index"
fun getModuleName(index: Int) = "module$index"
}