✨ Add debug flags to Core
[Sone.git] / src / main / kotlin / net / pterodactylus / sone / main / SoneModule.kt
index a3fe9be..07ec56e 100644 (file)
@@ -6,6 +6,8 @@ import com.google.inject.*
 import com.google.inject.matcher.*
 import com.google.inject.name.Names.*
 import com.google.inject.spi.*
+import freenet.l10n.*
+import net.pterodactylus.sone.core.*
 import net.pterodactylus.sone.database.*
 import net.pterodactylus.sone.database.memory.*
 import net.pterodactylus.sone.freenet.wot.*
@@ -44,11 +46,12 @@ class SoneModule(private val sonePlugin: SonePlugin) : AbstractModule() {
                bind(Context::class.java).toInstance(context)
                bind(object : TypeLiteral<Optional<Context>>() {}).toInstance(Optional.of(context))
                bind(SonePlugin::class.java).toInstance(sonePlugin)
-               bind(Version::class.java).toInstance(sonePlugin.version.parseVersion())
+               bind(Version::class.java).toInstance(sonePlugin.version.drop(1).parseVersion())
                bind(PluginVersion::class.java).toInstance(PluginVersion(sonePlugin.version))
                bind(PluginYear::class.java).toInstance(PluginYear(sonePlugin.year))
                bind(PluginHomepage::class.java).toInstance(PluginHomepage(sonePlugin.homepage))
                bind(Database::class.java).to(MemoryDatabase::class.java).`in`(Singleton::class.java)
+               bind(BaseL10n::class.java).toInstance(sonePlugin.l10n().base)
                loaders?.let { bind(Loaders::class.java).toInstance(it) }
 
                bindListener(Matchers.any(), object : TypeListener {
@@ -58,6 +61,12 @@ class SoneModule(private val sonePlugin: SonePlugin) : AbstractModule() {
                })
        }
 
+       @Provides
+       fun getCore(configuration: Configuration, freenetInterface: FreenetInterface, identityManager: IdentityManager, soneDownloader: SoneDownloader, imageInserter: ImageInserter, updateChecker: UpdateChecker, webOfTrustUpdater: WebOfTrustUpdater, eventBus: EventBus, database: Database) =
+                       Core(configuration, freenetInterface, identityManager, soneDownloader, imageInserter, updateChecker, webOfTrustUpdater, eventBus, database).apply {
+                               debugInformation.showVersionInformation = configuration.getBooleanValue("Debug/ShowVersionInformation").getValue(false)
+                       }
+
 }
 
 private fun String.parseVersion(): Version = Version.parse(this)