mirror of
https://gitlab.com/mangadex-pub/mangadex_at_home.git
synced 2024-01-19 02:48:37 +00:00
108 lines
4.3 KiB
Kotlin
108 lines
4.3 KiB
Kotlin
/*
|
|
Mangadex@Home
|
|
Copyright (c) 2020, MangaDex Network
|
|
This file is part of MangaDex@Home.
|
|
|
|
MangaDex@Home is free software: you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation, either version 3 of the License, or
|
|
(at your option) any later version.
|
|
|
|
MangaDex@Home is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this MangaDex@Home. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
package mdnet
|
|
|
|
import ch.qos.logback.classic.LoggerContext
|
|
import mdnet.logging.error
|
|
import org.slf4j.LoggerFactory
|
|
import picocli.CommandLine
|
|
import java.io.File
|
|
import java.nio.file.Path
|
|
import java.nio.file.Paths
|
|
import kotlin.system.exitProcess
|
|
|
|
object Main {
|
|
private val LOGGER = LoggerFactory.getLogger(Main::class.java)
|
|
|
|
@JvmStatic
|
|
fun main(args: Array<String>) {
|
|
CommandLine(ClientArgs()).execute(*args)
|
|
}
|
|
|
|
fun dieWithError(e: Throwable): Nothing {
|
|
LOGGER.error(e) { "Critical Error" }
|
|
(LoggerFactory.getILoggerFactory() as LoggerContext).stop()
|
|
exitProcess(1)
|
|
}
|
|
|
|
fun dieWithError(error: String): Nothing {
|
|
LOGGER.error { "Critical Error: $error" }
|
|
|
|
(LoggerFactory.getILoggerFactory() as LoggerContext).stop()
|
|
exitProcess(1)
|
|
}
|
|
}
|
|
|
|
@CommandLine.Command(name = "java -jar <jar>", usageHelpWidth = 120, version = ["Client Version ${BuildInfo.VERSION} (Build ${Constants.CLIENT_BUILD})"])
|
|
class ClientArgs(
|
|
@field:CommandLine.Option(names = ["-s", "--settings"], defaultValue = "settings.yaml", paramLabel = "<settings>", description = ["the settings file (default: \${DEFAULT-VALUE})"])
|
|
var settingsFile: File = File("settings.yaml"),
|
|
@field:CommandLine.Option(names = ["-d", "--database"], defaultValue = ".\${sys:file.separator}metadata", paramLabel = "<settings>", description = ["the database file (default: \${DEFAULT-VALUE})"])
|
|
var databaseFile: File = File(".${File.separator}metadata"),
|
|
@field:CommandLine.Option(names = ["-c", "--cache"], defaultValue = "images", paramLabel = "<settings>", description = ["the cache folder (default: \${DEFAULT-VALUE})"])
|
|
var cacheFolder: Path = Paths.get("images"),
|
|
@field:CommandLine.Option(names = ["-h", "--help"], usageHelp = true, description = ["show this help message and exit"])
|
|
var helpRequested: Boolean = false,
|
|
@field:CommandLine.Option(names = ["-v", "--version"], versionHelp = true, description = ["show the version message and exit"])
|
|
var versionRequested: Boolean = false
|
|
) : Runnable {
|
|
override fun run() {
|
|
println(
|
|
"Mangadex@Home Client Version ${BuildInfo.VERSION} (Build ${Constants.CLIENT_BUILD}) initializing"
|
|
)
|
|
println()
|
|
println("Copyright (c) 2020, MangaDex Network")
|
|
println(
|
|
"""
|
|
Mangadex@Home is free software: you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation, either version 3 of the License, or
|
|
(at your option) any later version.
|
|
|
|
Mangadex@Home is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with Mangadex@Home. If not, see <https://www.gnu.org/licenses/>.
|
|
""".trimIndent()
|
|
)
|
|
|
|
val client = MangaDexClient(settingsFile, databaseFile, cacheFolder)
|
|
val hook = Thread {
|
|
client.shutdown()
|
|
(LoggerFactory.getILoggerFactory() as LoggerContext).stop()
|
|
}
|
|
Runtime.getRuntime().addShutdownHook(
|
|
hook
|
|
)
|
|
|
|
try {
|
|
client.runLoop()
|
|
} catch (e: Throwable) {
|
|
Runtime.getRuntime().removeShutdownHook(
|
|
hook
|
|
)
|
|
hook.run()
|
|
throw e
|
|
}
|
|
}
|
|
}
|