aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorthedarkcolour <30441001+thedarkcolour@users.noreply.github.com>2020-06-20 17:47:55 -0700
committerthedarkcolour <30441001+thedarkcolour@users.noreply.github.com>2020-06-20 17:47:55 -0700
commit98458685ef50708edb3aebc4d72366d4bc41d71a (patch)
tree71623afce49865f09312af034df6d39bd4f3c058
parent7afdd597f4eb82de491fe37bd9b802f44d13d650 (diff)
downloadKotlinForForge-98458685ef50708edb3aebc4d72366d4bc41d71a.tar.gz
KotlinForForge-98458685ef50708edb3aebc4d72366d4bc41d71a.tar.bz2
KotlinForForge-98458685ef50708edb3aebc4d72366d4bc41d71a.zip
Update Kotlin for Forge 1.3.0
-rw-r--r--README.md17
-rw-r--r--build.gradle18
-rw-r--r--changelog.md (renamed from changelog.txt)15
-rw-r--r--gradle.properties4
-rw-r--r--src/example/kotlin/thedarkcolour/kotlinforforge/ExampleMod.kt80
-rw-r--r--src/example/kotlin/thedarkcolour/kotlinforforge/package.md7
-rw-r--r--src/example/kotlin/thedarkcolour/kotlinforforge/proxy/Proxies.kt20
-rw-r--r--src/example/kotlin/thedarkcolour/kotlinforforge/proxy/package.md12
-rw-r--r--src/main/kotlin/thedarkcolour/kotlinforforge/AutoKotlinEventBusSubscriber.kt18
-rw-r--r--src/main/kotlin/thedarkcolour/kotlinforforge/KotlinForForge.kt11
-rw-r--r--src/main/kotlin/thedarkcolour/kotlinforforge/KotlinLanguageProvider.kt7
-rw-r--r--src/main/kotlin/thedarkcolour/kotlinforforge/KotlinModContainer.kt50
-rw-r--r--src/main/kotlin/thedarkcolour/kotlinforforge/KotlinModLoadingContext.kt10
-rw-r--r--src/main/kotlin/thedarkcolour/kotlinforforge/eventbus/KotlinEventBus.kt41
-rw-r--r--src/main/kotlin/thedarkcolour/kotlinforforge/eventbus/KotlinEventBusWrapper.kt18
-rw-r--r--src/main/kotlin/thedarkcolour/kotlinforforge/forge/Forge.kt83
-rw-r--r--src/main/kotlin/thedarkcolour/kotlinforforge/kotlin/Kotlin.kt20
-rw-r--r--src/main/kotlin/thedarkcolour/kotlinforforge/kotlin/package.md2
-rw-r--r--src/main/resources/META-INF/mods.toml4
-rw-r--r--thedarkcolour/kotlinforforge/1.3.0/kotlinforforge-1.3.0-sources.jarbin0 -> 31884 bytes
-rw-r--r--thedarkcolour/kotlinforforge/1.3.0/kotlinforforge-1.3.0-sources.jar.md51
-rw-r--r--thedarkcolour/kotlinforforge/1.3.0/kotlinforforge-1.3.0-sources.jar.sha11
-rw-r--r--thedarkcolour/kotlinforforge/1.3.0/kotlinforforge-1.3.0.jarbin0 -> 89549 bytes
-rw-r--r--thedarkcolour/kotlinforforge/1.3.0/kotlinforforge-1.3.0.jar.md51
-rw-r--r--thedarkcolour/kotlinforforge/1.3.0/kotlinforforge-1.3.0.jar.sha11
-rw-r--r--thedarkcolour/kotlinforforge/1.3.0/kotlinforforge-1.3.0.pom60
-rw-r--r--thedarkcolour/kotlinforforge/1.3.0/kotlinforforge-1.3.0.pom.md51
-rw-r--r--thedarkcolour/kotlinforforge/1.3.0/kotlinforforge-1.3.0.pom.sha11
-rw-r--r--thedarkcolour/kotlinforforge/1.3.0/web.html20
-rw-r--r--thedarkcolour/kotlinforforge/maven-metadata.xml4
-rw-r--r--thedarkcolour/kotlinforforge/web.html1
31 files changed, 313 insertions, 215 deletions
diff --git a/README.md b/README.md
index ef3807f..8a00d7d 100644
--- a/README.md
+++ b/README.md
@@ -4,6 +4,14 @@ Makes Kotlin forge-friendly by doing the following:
- Provides `KotlinLanguageProvider` to allow usage of object declarations as @Mod targets.
- Provides `AutoKotlinEventBusSubscriber` to allow usage of object declarations as @Mod.EventBusSubscriber targets.
- Provides useful utility functions and constants
+- Provides its own implementation of the Forge eventbus to work with KCallables and reified type parameters
+- Provides sided property delegates and object holder property delegates
+
+An example mod is provided at the [KotlinModdingSkeleton repository](https://github.com/thedarkcolour/KotlinModdingSkeleton).
+If you aren't sure where to start, make a fork of the KotlinModdingSkeleton repository.
+```git
+git clone https://github.com/thedarkcolour/KotlinModdingSkeleton.git
+```
To implement in your project, paste the following into your build.gradle:
```groovy
@@ -14,7 +22,7 @@ buildscript {
}
dependencies {
// Make sure to use the correct version
- classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:1.4-M1"
+ classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:1.4-M2"
}
}
@@ -33,7 +41,7 @@ repositories {
dependencies {
// Use the latest version of KotlinForForge
- implementation 'thedarkcolour:kotlinforforge:1.2.2'
+ implementation 'thedarkcolour:kotlinforforge:1.2.3'
}
compileKotlin {
@@ -44,11 +52,6 @@ compileKotlin {
languageVersion = '1.4'
apiVersion = '1.4'
}
-
- // Required to run in dev environment
- copy {
- from "$buildDir/classes/kotlin/main" into "$buildDir/classes/java/main"
- }
}
```
Then, change the following to your mods.toml file:
diff --git a/build.gradle b/build.gradle
index d9b563e..0722f28 100644
--- a/build.gradle
+++ b/build.gradle
@@ -20,7 +20,7 @@ apply plugin: 'net.minecraftforge.gradle'
apply plugin: 'kotlin'
apply plugin: 'org.jetbrains.dokka'
-version = "1.2.2"
+version = "1.3.0"
group = 'thedarkcolour.kotlinforforge'
archivesBaseName = 'kotlinforforge'
@@ -120,15 +120,19 @@ jar {
compileKotlin {
kotlinOptions {
jvmTarget = '1.8'
+ freeCompilerArgs = ["-Xexplicit-api=warning"]
}
- // Required to run in dev environment
- copy {
- from "$buildDir/classes/kotlin/main" into "$buildDir/classes/java/main"
- }
+}
+
+sourceSets.test {
+ kotlin.srcDirs 'src/example/kotlin'
+ resources.srcDirs 'src/example/resources'
}
kotlinSourcesJar {
- from(sourceSets.main.kotlin.srcDirs)
+ from(sourceSets.main.kotlin.srcDirs).eachFile { file ->
+ println(file.name)
+ }
}
dokka {
@@ -138,6 +142,6 @@ dokka {
configuration {
reportUndocumented = true
- samples = ["$rootDir/src/test/kotlin/thedarkcolour/kotlinforforge/ExampleMod.kt".toString()]
+ samples = ["$rootDir/src/test/kotlin/thedarkcolour/example/ExampleMod.kt".toString()]
}
} \ No newline at end of file
diff --git a/changelog.txt b/changelog.md
index 3f38229..d4fdf03 100644
--- a/changelog.txt
+++ b/changelog.md
@@ -1,8 +1,15 @@
+Kotlin for Forge 1.3.0
+- Added a modding skeleton repository as an alternative to editing the build.gradle the Forge MDK ships with.
+- Added two more reified generic functions to the KotlinEventBus for `priority` and `receivedCancelled` parameters.
+- Fixed the ObjectHolderDelegate not allowing subtypes of classes that implement IForgeRegistryEntry
+- Updated to Kotlin 1.4-M2, Updated to coroutines 1.3.7
+- **KFF 1.3.x is not compatible with versions earlier than 1.2.3 due to Kotlin Reflection changes in 1.4-M2**
+
Kotlin for Forge 1.2.2
-- Added a sided delegate class that returns a "client value" on the client side and a "server value" on the server side.
+- Added a sided delegate class which returns a "client value" on the client side and a "server value" on the server side.
- Added a new utility file called "Kotlin.kt" that provides a few utility functions not related to Minecraft Forge.
- Added an example mod. I will make a template GitHub repository for Kotlin for Forge soon.
-- Adjusted mod construction to accurately report exceptions in @Mod object initializers
+- Adjusted mod construction to accurately report exceptions in @Mod object constructors
- Restructured Kotlin for Forge code to use Kotlin APIs whenever possible
- Added styling to the maven repo
@@ -12,11 +19,11 @@ Kotlin for Forge 1.2.1
Kotlin for Forge 1.2.0
- Added a Kotlin implementation of the Forge EventBus that has working addListener and addGenericListener functions
- Added an overload of addGenericListener that uses a reified type parameter instead of a class parameter.
-- Updated to Kotlin 1.4M1
+- Updated to Kotlin 1.4-M1
Kotlin for Forge 1.1.0
- Events now properly fire through KotlinModContainer
-- Updated to Kotlin 1.3.70 Updated to coroutines 1.3.4 Updated to Jetbrains annotation 19.0.0
+- Updated to Kotlin 1.3.70, Updated to coroutines 1.3.4, Updated to JetBrains annotations 19.0.0
Kotlin for Forge 1.0.1
- Fixed an issue with language extensions
diff --git a/gradle.properties b/gradle.properties
index c4f4ba4..8ee44fd 100644
--- a/gradle.properties
+++ b/gradle.properties
@@ -2,6 +2,6 @@
# This is required to provide enough memory for the Minecraft decompilation process.
org.gradle.jvmargs=-Xmx3G
org.gradle.daemon=false
-kotlin_version=1.4-M1
-coroutines_version = 1.3.4
+kotlin_version=1.4-M2
+coroutines_version = 1.3.7
annotations_version = 19.0.0 \ No newline at end of file
diff --git a/src/example/kotlin/thedarkcolour/kotlinforforge/ExampleMod.kt b/src/example/kotlin/thedarkcolour/kotlinforforge/ExampleMod.kt
deleted file mode 100644
index af01493..0000000
--- a/src/example/kotlin/thedarkcolour/kotlinforforge/ExampleMod.kt
+++ /dev/null
@@ -1,80 +0,0 @@
-package thedarkcolour.kotlinforforge
-
-import net.minecraft.block.Block
-import net.minecraftforge.event.RegistryEvent
-import net.minecraftforge.eventbus.api.SubscribeEvent
-import net.minecraftforge.fml.common.Mod
-import net.minecraftforge.fml.event.server.FMLServerStartingEvent
-import thedarkcolour.kotlinforforge.forge.MOD_BUS
-import thedarkcolour.kotlinforforge.forge.lazySidedDelegate
-import thedarkcolour.kotlinforforge.proxy.ClientProxy
-import thedarkcolour.kotlinforforge.proxy.IProxy
-import thedarkcolour.kotlinforforge.proxy.ServerProxy
-
-/**
- * Example mod for anyone who'd like to see
- * how a mod would be made with Kotlin for Forge.
- *
- * This mod has a modid of "examplemod", listens
- * for the ``RegistryEvent.Register<Block>`` and
- * for the ``FMLServerStartingEvent``.
- *
- * It registers event listeners by adding event listeners
- * directly to the event buses KFF provides and
- * by using the ``@EventBusSubscriber`` annotation.
- */
-@Mod(ExampleMod.ID)
-object ExampleMod {
- /**
- * Your mod's ID
- */
- const val ID = "examplemod"
-
- /**
- * The sided proxy. Since we use a lazy sided delegate,
- * the supplier parameters are invoked only once.
- */
- private val proxy by lazySidedDelegate(::ClientProxy, ::ServerProxy)
-
- /**
- * Example of using the KotlinEventBus
- * to register a function reference.
- *
- * Event classes with a generic type
- * should be registered using ``addGenericListener``
- * instead of ``addListener``.
- */
- init {
- MOD_BUS.addGenericListener(::registerBlocks)
-
- proxy.modConstruction()
- }
-
- /**
- * Handle block registry here.
- */
- private fun registerBlocks(event: RegistryEvent.Register<Block>) {
- // ...
- }
-
- /**
- * Example of an object class using the
- * ``@Mod.EventBusSubscriber`` annotation
- * to automatically subscribe functions
- * to the forge event bus.
- *
- * Even though the ``Bus.FORGE`` event bus
- * is default, I think that it's still
- * a good practice to specify the bus explicitly.
- */
- @Mod.EventBusSubscriber(modid = ExampleMod.ID, bus = Mod.EventBusSubscriber.Bus.FORGE)
- object EventHandler {
- /**
- * Handles things like registering commands.
- */
- @SubscribeEvent
- fun onServerStarting(event: FMLServerStartingEvent) {
- // ...
- }
- }
-} \ No newline at end of file
diff --git a/src/example/kotlin/thedarkcolour/kotlinforforge/package.md b/src/example/kotlin/thedarkcolour/kotlinforforge/package.md
deleted file mode 100644
index c9c1caa..0000000
--- a/src/example/kotlin/thedarkcolour/kotlinforforge/package.md
+++ /dev/null
@@ -1,7 +0,0 @@
-# thedarkcolour.kotlinforforge
-This package contains an example main mod class
-for a mod using Kotlin for Forge.
-
-## ExampleMod
-Your main mod class should be an object declaration.
-It must be annotated with the @Mod annotation. \ No newline at end of file
diff --git a/src/example/kotlin/thedarkcolour/kotlinforforge/proxy/Proxies.kt b/src/example/kotlin/thedarkcolour/kotlinforforge/proxy/Proxies.kt
deleted file mode 100644
index 24c51b7..0000000
--- a/src/example/kotlin/thedarkcolour/kotlinforforge/proxy/Proxies.kt
+++ /dev/null
@@ -1,20 +0,0 @@
-package thedarkcolour.kotlinforforge.proxy
-
-/**
- * Common inheritor of both proxies.
- */
-interface IProxy {
- fun modConstruction()
-}
-
-class ClientProxy : IProxy {
- override fun modConstruction() {
- // run client code
- }
-}
-
-class ServerProxy : IProxy {
- override fun modConstruction() {
- // run server code
- }
-} \ No newline at end of file
diff --git a/src/example/kotlin/thedarkcolour/kotlinforforge/proxy/package.md b/src/example/kotlin/thedarkcolour/kotlinforforge/proxy/package.md
deleted file mode 100644
index bb57203..0000000
--- a/src/example/kotlin/thedarkcolour/kotlinforforge/proxy/package.md
+++ /dev/null
@@ -1,12 +0,0 @@
-# thedarkcolour.kotlinforforge.proxy
-This package has example proxy classes.
-Proxies are used to provide common declarations with sided implementations.
-
-Forge no longer supports the proxy pattern.
-The ``@SidedProxy`` annotation was removed in 1.13+.
-This example shows a use case for the ``lazySidedDelegate``.
-It is recommended to use the ``runWhenOn`` and ``callWhenOn`` functions
-instead of proxies whenever possible.
-
-In this example, a proxy is instantiated lazily in the ``ExampleMod`` class.
-Proxies are not the only use for sided delegates. \ No newline at end of file
diff --git a/src/main/kotlin/thedarkcolour/kotlinforforge/AutoKotlinEventBusSubscriber.kt b/src/main/kotlin/thedarkcolour/kotlinforforge/AutoKotlinEventBusSubscriber.kt
index 01a10c0..78325ee 100644
--- a/src/main/kotlin/thedarkcolour/kotlinforforge/AutoKotlinEventBusSubscriber.kt
+++ b/src/main/kotlin/thedarkcolour/kotlinforforge/AutoKotlinEventBusSubscriber.kt
@@ -19,26 +19,28 @@ import thedarkcolour.kotlinforforge.kotlin.enumSet
* @see MOD_BUS
* @see FORGE_BUS
*/
-object AutoKotlinEventBusSubscriber {
+public object AutoKotlinEventBusSubscriber {
+ /** The [Mod.EventBusSubscriber] java type. */
private val EVENT_BUS_SUBSCRIBER: Type = Type.getType(Mod.EventBusSubscriber::class.java)
+ /** The default (client & server) list of [Dist] enum holders. */
private val DIST_ENUM_HOLDERS = listOf(
ModAnnotation.EnumHolder(null, "CLIENT"),
ModAnnotation.EnumHolder(null, "DEDICATED_SERVER")
)
/**
- * Allows the Mod.EventBusSubscriber annotation
+ * Allows the [Mod.EventBusSubscriber] annotation
* to target member functions of an `object` class.
*
* You **must** be using an `object` class, or the
- * EventBusSubscriber annotation will ignore it.
+ * `Mod.EventBusSubscriber` annotation will ignore it.
*
- * Personally, I am against using [Mod.EventBusSubscriber]
- * because it makes
- *
- * @sample thedarkcolour.kotlinforforge.ExampleMod
+ * I am against using `Mod.EventBusSubscriber`
+ * because it makes it difficult to follow where event
+ * listeners are registered. Instead, prefer to directly
+ * register event listeners to the [FORGE_BUS] or [MOD_BUS].
*/
- fun inject(mod: ModContainer, scanData: ModFileScanData, classLoader: ClassLoader) {
+ public fun inject(mod: ModContainer, scanData: ModFileScanData, classLoader: ClassLoader) {
LOGGER.debug(Logging.LOADING, "Attempting to inject @EventBusSubscriber kotlin objects in to the event bus for ${mod.modId}")
val data = scanData.annotations.filter { annotationData ->
diff --git a/src/main/kotlin/thedarkcolour/kotlinforforge/KotlinForForge.kt b/src/main/kotlin/thedarkcolour/kotlinforforge/KotlinForForge.kt
index 6a60e4b..eeaaef4 100644
--- a/src/main/kotlin/thedarkcolour/kotlinforforge/KotlinForForge.kt
+++ b/src/main/kotlin/thedarkcolour/kotlinforforge/KotlinForForge.kt
@@ -4,9 +4,14 @@ import net.minecraftforge.fml.common.Mod
import net.minecraftforge.fml.javafmlmod.FMLJavaModLoadingContext
/**
- * Set 'modLoader' in mods.toml to "kotlinforforge" and loaderVersion to "[1,)".
+ * Set `modLoader` in mods.toml to
+ * `"kotlinforforge"` and loaderVersion to `"[1.3,1.4)"`.
*
- * Make sure to use [KotlinModLoadingContext] instead of [FMLJavaModLoadingContext].
+ * Make sure to use [KotlinModLoadingContext]
+ * instead of [FMLJavaModLoadingContext].
+ *
+ * For a more thorough example mod,
+ * check out the [KotlinModdingSkeleton repository](https://github.com/thedarkcolour/KotlinModdingSkeleton).
*/
@Mod("kotlinforforge")
-object KotlinForForge \ No newline at end of file
+public object KotlinForForge \ No newline at end of file
diff --git a/src/main/kotlin/thedarkcolour/kotlinforforge/KotlinLanguageProvider.kt b/src/main/kotlin/thedarkcolour/kotlinforforge/KotlinLanguageProvider.kt
index a06c9a3..e2ee9ff 100644
--- a/src/main/kotlin/thedarkcolour/kotlinforforge/KotlinLanguageProvider.kt
+++ b/src/main/kotlin/thedarkcolour/kotlinforforge/KotlinLanguageProvider.kt
@@ -10,8 +10,8 @@ import java.util.function.Consumer
/**
* Reuse a bit of code from FMLJavaModLanguageProvider
*/
-class KotlinLanguageProvider : FMLJavaModLanguageProvider() {
- override fun name() = "kotlinforforge"
+public class KotlinLanguageProvider : FMLJavaModLanguageProvider() {
+ override fun name(): String = "kotlinforforge"
override fun getFileVisitor(): Consumer<ModFileScanData> {
return Consumer { scanData ->
@@ -20,6 +20,7 @@ class KotlinLanguageProvider : FMLJavaModLanguageProvider() {
}.map { data ->
val modid = data.annotationData["value"] as String
val modClass = data.classType.className
+
LOGGER.debug(Logging.SCAN, "Found @Mod class $modClass with mod id $modid")
modid to KotlinModTarget(modClass)
}.toMap()
@@ -28,7 +29,7 @@ class KotlinLanguageProvider : FMLJavaModLanguageProvider() {
}
}
- class KotlinModTarget constructor(private val className: String) : IModLanguageProvider.IModLanguageLoader {
+ public class KotlinModTarget constructor(private val className: String) : IModLanguageProvider.IModLanguageLoader {
override fun <T> loadMod(info: IModInfo, modClassLoader: ClassLoader, modFileScanResults: ModFileScanData): T {
val ktContainer = Class.forName("thedarkcolour.kotlinforforge.KotlinModContainer", true, Thread.currentThread().contextClassLoader)
val constructor = ktContainer.declaredConstructors[0]
diff --git a/src/main/kotlin/thedarkcolour/kotlinforforge/KotlinModContainer.kt b/src/main/kotlin/thedarkcolour/kotlinforforge/KotlinModContainer.kt
index e86f66a..9a7c308 100644
--- a/src/main/kotlin/thedarkcolour/kotlinforforge/KotlinModContainer.kt
+++ b/src/main/kotlin/thedarkcolour/kotlinforforge/KotlinModContainer.kt
@@ -17,14 +17,28 @@ import thedarkcolour.kotlinforforge.eventbus.KotlinEventBus
import thedarkcolour.kotlinforforge.kotlin.supply
import java.util.function.Consumer
-typealias LifeCycleEventListener = (LifecycleEvent) -> Unit
+public typealias LifecycleEventListener = (LifecycleEvent) -> Unit
/**
- * Functions as [net.minecraftforge.fml.javafmlmod.FMLModContainer] for Kotlin
+ * The Kotlin for Forge `ModContainer`.
*/
-class KotlinModContainer(private val info: IModInfo, private val className: String, private val classLoader: ClassLoader, private val scanData: ModFileScanData) : ModContainer(info) {
+public class KotlinModContainer(
+ private val info: IModInfo,
+ private val className: String,
+ private val classLoader: ClassLoader,
+ private val scanData: ModFileScanData,
+) : ModContainer(info) {
+
+ /**
+ * The `@Mod` object or instance of the `@Mod` class.
+ */
private lateinit var modInstance: Any
- val eventBus: KotlinEventBus
+
+ /**
+ * The `IEventBus` for Kotlin for Forge mods
+ * that supports `KCallable` event listeners.
+ */
+ public val eventBus: KotlinEventBus
init {
LOGGER.debug(Logging.LOADING, "Creating KotlinModContainer instance for {} with classLoader {} & {}", className, classLoader, javaClass.classLoader)
@@ -41,9 +55,13 @@ class KotlinModContainer(private val info: IModInfo, private val className: Stri
contextExtension = supply(KotlinModLoadingContext(this))
}
- private inline fun createTrigger(
- crossinline consumerA: LifeCycleEventListener,
- crossinline consumerB: LifeCycleEventListener,
+ /**
+ * Creates a single `Consumer` that calls
+ * both [consumerA] and [consumerB].
+ */
+ private fun createTrigger(
+ consumerA: LifecycleEventListener,
+ consumerB: LifecycleEventListener,
): Consumer<LifecycleEvent> {
return Consumer { event ->
consumerA(event)
@@ -51,12 +69,20 @@ class KotlinModContainer(private val info: IModInfo, private val className: Stri
}
}
+ /**
+ * The `IEventExceptionHandler` that logs
+ * errors in events as errors.
+ */
private fun onEventFailed(iEventBus: IEventBus, event: Event, iEventListeners: Array<IEventListener>, i: Int, throwable: Throwable) {
LOGGER.error(EventBusErrorMessage(event, i, iEventListeners, throwable))
}
+ /**
+ * Fires a `LifecycleEvent` on the mod [eventBus].
+ */
private fun fireEvent(lifecycleEvent: LifecycleEvent) {
val event = lifecycleEvent.getOrBuildEvent(this)
+
LOGGER.debug(Logging.LOADING, "Firing event for modid $modId : $event")
try {
@@ -68,14 +94,22 @@ class KotlinModContainer(private val info: IModInfo, private val className: Stri
}
}
+ /**
+ * If an error was thrown during the event,
+ * log it to the console as an error.
+ */
private fun afterEvent(lifecycleEvent: LifecycleEvent) {
if (currentState == ModLoadingStage.ERROR) {
LOGGER.error(Logging.LOADING, "An error occurred while dispatching event ${lifecycleEvent.fromStage()} to $modId")
}
}
+ /**
+ * Initializes [modInstance] and calls the mod constructor
+ */
private fun constructMod(lifecycleEvent: LifecycleEvent) {
val modClass: Class<*>
+
try {
modClass = Class.forName(className, false, classLoader)
LOGGER.debug(Logging.LOADING, "Loaded kotlin modclass ${modClass.name} with ${modClass.classLoader}")
@@ -112,7 +146,7 @@ class KotlinModContainer(private val info: IModInfo, private val className: Stri
return mod == modInstance
}
- override fun getMod() = modInstance
+ override fun getMod(): Any = modInstance
override fun acceptEvent(e: Event) {
eventBus.post(e)
diff --git a/src/main/kotlin/thedarkcolour/kotlinforforge/KotlinModLoadingContext.kt b/src/main/kotlin/thedarkcolour/kotlinforforge/KotlinModLoadingContext.kt
index 8d0029f..128b399 100644
--- a/src/main/kotlin/thedarkcolour/kotlinforforge/KotlinModLoadingContext.kt
+++ b/src/main/kotlin/thedarkcolour/kotlinforforge/KotlinModLoadingContext.kt
@@ -7,11 +7,11 @@ import thedarkcolour.kotlinforforge.forge.LOADING_CONTEXT
/**
* Mod loading context for mods made with Kotlin for Forge.
*/
-class KotlinModLoadingContext constructor(private val container: KotlinModContainer) {
+public class KotlinModLoadingContext constructor(private val container: KotlinModContainer) {
/** @since 1.2.1
* @see thedarkcolour.kotlinforforge.forge.MOD_BUS
*/
- fun getKEventBus(): KotlinEventBus {
+ public fun getKEventBus(): KotlinEventBus {
return container.eventBus
}
@@ -25,15 +25,15 @@ class KotlinModLoadingContext constructor(private val container: KotlinModContai
replaceWith = ReplaceWith("getKEventBus()"),
level = DeprecationLevel.WARNING,
)
- fun getEventBus(): IEventBus {
+ public fun getEventBus(): IEventBus {
return container.eventBus
}
- companion object {
+ public companion object {
/**
* Returns the [KotlinModLoadingContext] for the current mod
*/
- fun get(): KotlinModLoadingContext {
+ public fun get(): KotlinModLoadingContext {
return LOADING_CONTEXT.extension()
}
}
diff --git a/src/main/kotlin/thedarkcolour/kotlinforforge/eventbus/KotlinEventBus.kt b/src/main/kotlin/thedarkcolour/kotlinforforge/eventbus/KotlinEventBus.kt
index 7bf575e..c35c4e9 100644
--- a/src/main/kotlin/thedarkcolour/kotlinforforge/eventbus/KotlinEventBus.kt
+++ b/src/main/kotlin/thedarkcolour/kotlinforforge/eventbus/KotlinEventBus.kt
@@ -19,14 +19,14 @@ import java.util.function.Consumer
/** @since 1.2.0
* Fixes [addListener] and [addGenericListener] for Kotlin KCallable.
*/
-open class KotlinEventBus(builder: BusBuilder, synthetic: Boolean = false) : IEventBus, IEventExceptionHandler {
+public open class KotlinEventBus(builder: BusBuilder, synthetic: Boolean = false) : IEventBus, IEventExceptionHandler {
@Suppress("LeakingThis")
private val exceptionHandler = builder.exceptionHandler ?: this
private val trackPhases = builder.trackPhases
@Volatile
private var shutdown = builder.isStartingShutdown
- protected open val busID = MAX_ID.getAndIncrement()
- protected open val listeners = ConcurrentHashMap<Any, MutableList<IEventListener>>()
+ protected open val busID: Int = MAX_ID.getAndIncrement()
+ protected open val listeners: ConcurrentHashMap<Any, MutableList<IEventListener>> = ConcurrentHashMap()
init {
// see companion object
@@ -201,11 +201,42 @@ open class KotlinEventBus(builder: BusBuilder, synthetic: Boolean = false) : IEv
* @param T The [GenericEvent] subclass to listen for
* @param F The [Class] to filter the [GenericEvent] for
*/
- inline fun <T : GenericEvent<out F>, reified F> addGenericListener(consumer: Consumer<T>) {
+ public inline fun <T : GenericEvent<out F>, reified F> addGenericListener(consumer: Consumer<T>) {
addGenericListener(F::class.java, consumer)
}
/**
+ * Add a consumer listener with the specified [EventPriority] and not receiving cancelled events,
+ * for a [GenericEvent] subclass, filtered to only be called for the specified
+ * filter [Class].
+ *
+ * @param genericClassFilter A [Class] which the [GenericEvent] should be filtered for
+ * @param priority [EventPriority] for this listener
+ * @param consumer Callback to invoke when a matching event is received
+ * @param T The [GenericEvent] subclass to listen for
+ * @param F The [Class] to filter the [GenericEvent] for
+ */
+ public inline fun <T : GenericEvent<out F>, reified F> addGenericListener(priority: EventPriority, consumer: Consumer<T>) {
+ addGenericListener(F::class.java, priority, false, consumer)
+ }
+
+ /**
+ * Add a consumer listener with the specified [EventPriority] and potentially cancelled events,
+ * for a [GenericEvent] subclass, filtered to only be called for the specified
+ * filter [Class].
+ *
+ * @param genericClassFilter A [Class] which the [GenericEvent] should be filtered for
+ * @param priority [EventPriority] for this listener
+ * @param receiveCancelled Indicate if this listener should receive events that have been [Cancelable] cancelled
+ * @param consumer Callback to invoke when a matching event is received
+ * @param T The [GenericEvent] subclass to listen for
+ * @param F The [Class] to filter the [GenericEvent] for
+ */
+ public inline fun <T : GenericEvent<out F>, reified F> addGenericListener(priority: EventPriority, receiveCancelled: Boolean, consumer: Consumer<T>) {
+ addGenericListener(F::class.java, priority, receiveCancelled, consumer)
+ }
+
+ /**
* Add a consumer listener for a [GenericEvent] subclass, filtered to only be called for the specified
* filter [Class].
*
@@ -365,7 +396,7 @@ open class KotlinEventBus(builder: BusBuilder, synthetic: Boolean = false) : IEv
shutdown = false
}
- companion object {
+ private companion object {
private val LOGGER = LogManager.getLogger()
private val EVENT_BUS = MarkerManager.getMarker("EVENTBUS")
private val MAX_ID: AtomicInteger
diff --git a/src/main/kotlin/thedarkcolour/kotlinforforge/eventbus/KotlinEventBusWrapper.kt b/src/main/kotlin/thedarkcolour/kotlinforforge/eventbus/KotlinEventBusWrapper.kt
index b3cb9d5..ac12b1b 100644
--- a/src/main/kotlin/thedarkcolour/kotlinforforge/eventbus/KotlinEventBusWrapper.kt
+++ b/src/main/kotlin/thedarkcolour/kotlinforforge/eventbus/KotlinEventBusWrapper.kt
@@ -12,40 +12,40 @@ import java.util.concurrent.ConcurrentHashMap
* Fixes [IEventBus.addListener] for Kotlin SAM interfaces
* when using [FORGE_BUS].
*/
-class KotlinEventBusWrapper(private val parent: EventBus) : KotlinEventBus(BusBuilder()
+public class KotlinEventBusWrapper(private val parent: EventBus) : KotlinEventBus(BusBuilder()
.setExceptionHandler(getExceptionHandler(parent))
.setTrackPhases(getTrackPhases(parent))
.also { if (getShutdown(parent)) it.startShutdown() }
) {
- override val busID = getBusID(parent)
- override val listeners = getListeners(parent)
+ override val busID: Int = getBusID(parent)
+ override val listeners: ConcurrentHashMap<Any, MutableList<IEventListener>> = getListeners(parent)
// reflection stuff
- companion object {
+ private companion object {
private val GET_BUS_ID = EventBus::class.java.getDeclaredField("busID").also { it.isAccessible = true }
private val GET_LISTENERS = EventBus::class.java.getDeclaredField("listeners").also { it.isAccessible = true }
private val GET_EXCEPTION_HANDLER = EventBus::class.java.getDeclaredField("exceptionHandler").also { it.isAccessible = true }
private val GET_TRACK_PHASES = EventBus::class.java.getDeclaredField("trackPhases").also { it.isAccessible = true }
private val GET_SHUTDOWN = EventBus::class.java.getDeclaredField("shutdown").also { it.isAccessible = true }
- fun getBusID(eventBus: EventBus): Int {
+ private fun getBusID(eventBus: EventBus): Int {
return GET_BUS_ID[eventBus] as Int
}
@Suppress("UNCHECKED_CAST")
- fun getListeners(eventBus: EventBus): ConcurrentHashMap<Any, MutableList<IEventListener>> {