summaryrefslogtreecommitdiff
path: root/app/src/main/java/org
diff options
context:
space:
mode:
authorJoel Klinghed <the_jk@spawned.biz>2024-07-15 00:46:18 +0200
committerJoel Klinghed <the_jk@spawned.biz>2024-07-15 00:46:18 +0200
commit427bb4c2ab0ce5cfb988789657c2de3761fec392 (patch)
tree8fe7f9f42c22284df2dc4f038cb04d3c8bc5234d /app/src/main/java/org
parentd351b94c9d81513b088572ae72ee8d114b08e1c6 (diff)
Add Utils for parsing path parts to a directory
Diffstat (limited to 'app/src/main/java/org')
-rw-r--r--app/src/main/java/org/the_jk/cleversync/StringUtils.kt32
-rw-r--r--app/src/main/java/org/the_jk/cleversync/io/Utils.kt25
2 files changed, 57 insertions, 0 deletions
diff --git a/app/src/main/java/org/the_jk/cleversync/StringUtils.kt b/app/src/main/java/org/the_jk/cleversync/StringUtils.kt
new file mode 100644
index 0000000..6adea24
--- /dev/null
+++ b/app/src/main/java/org/the_jk/cleversync/StringUtils.kt
@@ -0,0 +1,32 @@
+package org.the_jk.cleversync
+
+object StringUtils {
+ fun split(input: String, delimiter: Char, keepEmpty: Boolean = true, limit: Int = 0): List<String> {
+ return buildList {
+ var offset = 0
+ var count = 0
+ while (true) {
+ val next = input.indexOf(delimiter, offset)
+ if (next == -1) {
+ if (keepEmpty || offset < input.length) {
+ if (limit > 0 && count == limit) {
+ add("${removeLast()}${delimiter}${input.substring(offset)}")
+ break
+ }
+ add(input.substring(offset))
+ }
+ break
+ }
+ if (keepEmpty || offset < next) {
+ if (limit > 0 && count == limit) {
+ add("${removeLast()}${delimiter}${input.substring(offset)}")
+ break
+ }
+ add(input.substring(offset, next))
+ count++
+ }
+ offset = next + 1
+ }
+ }
+ }
+}
diff --git a/app/src/main/java/org/the_jk/cleversync/io/Utils.kt b/app/src/main/java/org/the_jk/cleversync/io/Utils.kt
new file mode 100644
index 0000000..0f9a2b7
--- /dev/null
+++ b/app/src/main/java/org/the_jk/cleversync/io/Utils.kt
@@ -0,0 +1,25 @@
+package org.the_jk.cleversync.io
+
+import org.the_jk.cleversync.StringUtils
+
+object Utils {
+ fun makeDirectories(directory: ModifiableDirectory, vararg names: String): ModifiableDirectory {
+ var current = directory
+ names.forEach { nameWithSlashes ->
+ StringUtils.split(nameWithSlashes, '/', keepEmpty = false).forEach { name ->
+ current = current.modifiableOpenDir(name) ?: current.createDirectory(name)
+ }
+ }
+ return current
+ }
+
+ fun openDirectory(directory: Directory, vararg names: String): Directory? {
+ var current = directory
+ names.forEach { nameWithSlashes ->
+ StringUtils.split(nameWithSlashes, '/', keepEmpty = false).forEach { name ->
+ current = current.openDir(name) ?: return null
+ }
+ }
+ return current
+ }
+}