Skip to content

Commit 79a0eda

Browse files
authored
Merge pull request #11752 from JL0000/sort-dependencies
Sort dependencies in `libs.versions.toml`
2 parents e49156f + 172c3c9 commit 79a0eda

3 files changed

Lines changed: 57 additions & 7 deletions

File tree

app/build.gradle

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -160,11 +160,13 @@ tasks.register('formatKtlint', JavaExec) {
160160
jvmArgs("--add-opens", "java.base/java.lang=ALL-UNNAMED")
161161
}
162162

163+
apply from: 'check-dependencies.gradle'
164+
163165
afterEvaluate {
164166
if (!System.properties.containsKey('skipFormatKtlint')) {
165167
preDebugBuild.dependsOn formatKtlint
166168
}
167-
preDebugBuild.dependsOn runCheckstyle, runKtlint
169+
preDebugBuild.dependsOn runCheckstyle, runKtlint, checkDependenciesOrder
168170
}
169171

170172
sonar {

app/check-dependencies.gradle

Lines changed: 48 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,48 @@
1+
tasks.register('checkDependenciesOrder') {
2+
group = 'verification'
3+
description = 'Checks that each section in libs.versions.toml is sorted alphabetically'
4+
5+
def tomlFile = file('../gradle/libs.versions.toml')
6+
7+
doLast {
8+
if (!tomlFile.exists()) {
9+
throw new GradleException('TOML file not found')
10+
}
11+
12+
def lines = tomlFile.readLines()
13+
def nonSortedBlocks = []
14+
def currentBlock = []
15+
def prevLine = ''
16+
def prevIndex = 0
17+
18+
lines.eachWithIndex { line, lineIndex ->
19+
if (line.trim() && !line.startsWith('#')) {
20+
if (line.startsWith('[')) {
21+
prevLine = ''
22+
} else {
23+
def currIndex = lineIndex + 1
24+
if (prevLine > line) {
25+
if (currentBlock && currentBlock[-1] == "${prevIndex}: ${prevLine}") {
26+
currentBlock.add("${currIndex}: ${line}")
27+
} else {
28+
if (!currentBlock.isEmpty()) {
29+
nonSortedBlocks.add(currentBlock)
30+
currentBlock = []
31+
}
32+
currentBlock.add("${prevIndex}: ${prevLine}")
33+
currentBlock.add("${currIndex}: ${line}")
34+
}
35+
}
36+
prevLine = line
37+
prevIndex = lineIndex + 1
38+
}
39+
}
40+
}
41+
42+
if (!currentBlock.isEmpty()) {
43+
nonSortedBlocks.add(currentBlock)
44+
throw new GradleException("The following lines were not sorted:\n" +
45+
nonSortedBlocks.collect { it.join("\n") }.join("\n\n"))
46+
}
47+
}
48+
}

gradle/libs.versions.toml

Lines changed: 6 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -52,8 +52,8 @@ swiperefreshlayout = "1.1.0"
5252
# name and the commit hash with the commit hash of the (pushed) commit you want to test
5353
# This works thanks to JitPack: https://jitpack.io/
5454
teamnewpipe-filepicker = "5.0.0"
55-
teamnewpipe-newpipe-extractor = "d3d5f2b3f03a5f2b479b9f6fdf1c2555cbb9de0e"
5655
teamnewpipe-nanojson = "1d9e1aea9049fc9f85e68b43ba39fe7be1c1f751"
56+
teamnewpipe-newpipe-extractor = "d3d5f2b3f03a5f2b479b9f6fdf1c2555cbb9de0e"
5757
viewpager2 = "1.1.0-beta02"
5858
work = "2.8.1"
5959

@@ -86,20 +86,20 @@ androidx-constraintlayout = { group = "androidx.constraintlayout", name = "const
8686
androidx-core-ktx = { group = "androidx.core", name = "core-ktx", version.ref = "core-ktx" }
8787
androidx-documentfile = { group = "androidx.documentfile", name = "documentfile", version.ref = "documentFile" }
8888
androidx-fragment-compose = { group = "androidx.fragment", name = "fragment-compose", version.ref = "fragment-compose" }
89+
androidx-junit = { group = "androidx.test.ext", name = "junit", version.ref = "androidx-junit" }
8990
androidx-lifecycle-livedata = { group = "androidx.lifecycle", name = "lifecycle-livedata-ktx", version.ref = "lifecycle" }
9091
androidx-lifecycle-viewmodel = { group = "androidx.lifecycle", name = "lifecycle-viewmodel-ktx", version.ref = "lifecycle" }
9192
androidx-lifecycle-viewmodel-compose = { group = "androidx.lifecycle", name = "lifecycle-viewmodel-compose" }
9293
androidx-localbroadcastmanager = { group = "androidx.localbroadcastmanager", name = "localbroadcastmanager", version.ref = "localbroadcastmanager" }
9394
androidx-material = { group = "com.google.android.material", name = "material", version.ref = "material" }
9495
androidx-media = { group = "androidx.media", name = "media", version.ref = "media" }
9596
androidx-navigation-compose = { group = "androidx.navigation", name = "navigation-compose", version.ref = "navigationCompose" }
96-
androidx-junit = { group = "androidx.test.ext", name = "junit", version.ref = "androidx-junit" }
9797
androidx-paging-compose = { group = "androidx.paging", name = "paging-compose", version.ref = "pagingCompose" }
9898
androidx-preference = { group = "androidx.preference", name = "preference", version.ref = "preference" }
9999
androidx-recyclerview = { group = "androidx.recyclerview", name = "recyclerview", version.ref = "recyclerview" }
100+
androidx-room-compiler = { group = "androidx.room", name = "room-compiler", version.ref = "room" }
100101
androidx-room-runtime = { group = "androidx.room", name = "room-runtime", version.ref = "room" }
101102
androidx-room-rxjava3 = { group = "androidx.room", name = "room-rxjava3", version.ref = "room" }
102-
androidx-room-compiler = { group = "androidx.room", name = "room-compiler", version.ref = "room" }
103103
androidx-room-testing = { group = "androidx.room", name = "room-testing", version.ref = "room" }
104104
androidx-runner = { group = "androidx.test", name = "runner", version.ref = "runner" }
105105
androidx-swiperefreshlayout = { group = "androidx.swiperefreshlayout", name = "swiperefreshlayout", version.ref = "swiperefreshlayout" }
@@ -112,9 +112,9 @@ auto-service-kapt = { group = "com.google.auto.service", name = "auto-service",
112112
coil-compose = { group = "io.coil-kt.coil3", name = 'coil-compose', version.ref = "coil" }
113113
desugar-jdk-libs-nio = { group = "com.android.tools", name = "desugar_jdk_libs_nio", version.ref = "desugar-jdk-libs-nio" }
114114
exoplayer-core = { group = "com.google.android.exoplayer", name = "exoplayer-core", version.ref = "exoplayer" }
115+
exoplayer-dash = { module = "com.google.android.exoplayer:exoplayer-dash", version.ref = "exoplayer" }
115116
exoplayer-database = { group = "com.google.android.exoplayer", name = "exoplayer-database", version.ref = "exoplayer" }
116117
exoplayer-datasource = { group = "com.google.android.exoplayer", name = "exoplayer-datasource", version.ref = "exoplayer" }
117-
exoplayer-dash = { module = "com.google.android.exoplayer:exoplayer-dash", version.ref = "exoplayer" }
118118
exoplayer-hls = { group = "com.google.android.exoplayer", name = "exoplayer-hls", version.ref = "exoplayer" }
119119
exoplayer-smoothstreaming = { group = "com.google.android.exoplayer", name = "exoplayer-smoothstreaming", version.ref = "exoplayer" }
120120
exoplayer-ui = { group = "com.google.android.exoplayer", name = "exoplayer-ui", version.ref = "exoplayer" }
@@ -140,13 +140,13 @@ mockito-core = { group = "org.mockito", name = "mockito-core", version.ref = "mo
140140
okhttp = { group = "com.squareup.okhttp3", name = "okhttp", version.ref = "okhttp" }
141141
prettytime = { group = "org.ocpsoft.prettytime", name = "prettytime", version.ref = "prettytime" }
142142
process-phoenix = { group = "com.jakewharton", name = "process-phoenix", version.ref = "processPhoenix" }
143-
rxjava3-rxandroid = { group = "io.reactivex.rxjava3", name = "rxandroid", version.ref = "rxandroid" }
144143
rxbinding4-rxbinding = { group = "com.jakewharton.rxbinding4", name = "rxbinding", version.ref = "rxbinding" }
144+
rxjava3-rxandroid = { group = "io.reactivex.rxjava3", name = "rxandroid", version.ref = "rxandroid" }
145145
rxjava3-rxjava = { group = "io.reactivex.rxjava3", name = "rxjava", version.ref = "rxjava" }
146146
stetho = { group = "com.facebook.stetho", name = "stetho", version.ref = "stetho" }
147147
stetho-okhttp3 = { group = "com.facebook.stetho", name = "stetho-okhttp3", version.ref = "stetho" }
148+
teamnewpipe-nanojson = { group = "com.github.TeamNewPipe", name = "nanojson", version.ref = "teamnewpipe-nanojson" }
148149
teamnewpipe-newpipe-extractor = { group = "com.github.TeamNewPipe", name = "NewPipeExtractor", version.ref = "teamnewpipe-newpipe-extractor" }
149150
teamnewpipe-nononsense-filepicker = { group = "com.github.TeamNewPipe", name = "NoNonsense-FilePicker", version.ref = "teamnewpipe-filepicker" }
150-
teamnewpipe-nanojson = { group = "com.github.TeamNewPipe", name = "nanojson", version.ref = "teamnewpipe-nanojson" }
151151
tools-checkstyle = { group = "com.puppycrawl.tools", name = "checkstyle", version.ref = "checkstyle" }
152152
tools-ktlint = { group = "com.pinterest", name = "ktlint", version.ref = "ktlint" }

0 commit comments

Comments
 (0)