Improve orx-olive to work nicer with host extensions.

Removed javax.script.ScriptEngineFactory as that is no longer needed from Kotlin 1.3.50
This commit is contained in:
Edwin Jakobs
2019-09-07 14:40:40 +02:00
parent 6c21f4417a
commit ab1a1b601d
2 changed files with 34 additions and 16 deletions

View File

@@ -3,9 +3,19 @@ package org.openrndr.extra.olive
import org.openrndr.Extension import org.openrndr.Extension
import org.openrndr.Program import org.openrndr.Program
import org.openrndr.draw.Session import org.openrndr.draw.Session
import org.openrndr.events.Event
import org.operndr.extras.filewatcher.watchFile import org.operndr.extras.filewatcher.watchFile
import java.io.File import java.io.File
fun <T> Event<T>.saveListeners(store: MutableMap<Event<*>, List<(Any) -> Unit>>) {
store[this] = listeners.map { it } as List<(Any) -> Unit>
}
fun <T> Event<T>.restoreListeners(store: Map<Event<*>, List<(Any) -> Unit>>) {
listeners.retainAll(store[this]?: emptyList<T>())
}
class Olive<P : Program> : Extension { class Olive<P : Program> : Extension {
override var enabled: Boolean = true override var enabled: Boolean = true
var session: Session? = null var session: Session? = null
@@ -16,6 +26,28 @@ class Olive<P : Program> : Extension {
System.setProperty("idea.io.use.fallback", "true") System.setProperty("idea.io.use.fallback", "true")
System.setProperty("org.openrndr.ignoreShadeStyleErrors", "true") System.setProperty("org.openrndr.ignoreShadeStyleErrors", "true")
val store = mutableMapOf<Event<*>,List<(Any)->Unit>>()
val originalExtensions = program.extensions.map { it }
val trackedListeners = listOf<Event<*>>(program.mouse.buttonDown,
program.mouse.buttonUp,
program.mouse.clicked,
program.mouse.dragged,
program.mouse.moved,
program.mouse.scrolled,
program.keyboard.keyUp,
program.keyboard.keyDown,
program.keyboard.keyRepeat,
program.window.drop,
program.window.focused,
program.window.minimized,
program.window.moved,
program.window.sized,
program.window.unfocused)
trackedListeners.forEach { it.saveListeners(store) }
val f = File(script) val f = File(script)
if (!f.exists()) { if (!f.exists()) {
@@ -46,22 +78,9 @@ class Olive<P : Program> : Extension {
val func = KtsObjectLoader().load<P.() -> Unit>(script) val func = KtsObjectLoader().load<P.() -> Unit>(script)
program.extensions.clear() program.extensions.clear()
program.extensions.addAll(originalExtensions)
program.keyboard.keyDown.listeners.clear() trackedListeners.forEach { it.restoreListeners(store) }
program.keyboard.keyUp.listeners.clear()
program.keyboard.character.listeners.clear()
program.keyboard.keyRepeat.listeners.clear()
program.mouse.clicked.listeners.clear()
program.mouse.buttonDown.listeners.clear()
program.mouse.dragged.listeners.clear()
program.mouse.buttonUp.listeners.clear()
program.mouse.moved.listeners.clear()
program.window.drop.listeners.clear()
program.window.focused.listeners.clear()
program.window.minimized.listeners.clear()
program.window.unfocused.listeners.clear()
program.window.restored.listeners.clear()
program.window.sized.listeners.clear()
session?.end() session?.end()
session = Session() session = Session()

View File

@@ -1 +0,0 @@
org.jetbrains.kotlin.script.jsr223.KotlinJsr223JvmLocalScriptEngineFactory