@edadma/logo 0.2.0 → 0.2.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@edadma/logo",
3
- "version": "0.2.0",
3
+ "version": "0.2.2",
4
4
  "description": "Logo programming language interpreter with React component",
5
5
  "main": "dist/main.js",
6
6
  "module": "dist/main.js",
package/src/Logo.d.ts CHANGED
@@ -55,6 +55,15 @@ export declare class Logo {
55
55
  /** Set a callback for print output */
56
56
  setOutputHandler(handler: (text: string) => void): void
57
57
 
58
+ /** Clear the output handler (print goes to console) */
59
+ clearOutputHandler(): void
60
+
61
+ /** Set a callback for turtle events (called after each drawing command) */
62
+ setEventHandler(handler: () => void): void
63
+
64
+ /** Clear the event handler (use default auto-render behavior) */
65
+ clearEventHandler(): void
66
+
58
67
  /** Get the current drawing data */
59
68
  getDrawing(): LogoDrawing
60
69
 
@@ -7,6 +7,10 @@ import org.scalajs.dom.html
7
7
 
8
8
  import scala.math.Pi
9
9
 
10
+ /** Singleton representing "no value" from commands like print, fd, etc. */
11
+ @JSExportTopLevel("LogoUnit")
12
+ object LogoUnitJS extends js.Object
13
+
10
14
  @js.native
11
15
  trait LogoDrawing extends js.Object:
12
16
  val lines: js.Array[LineData] = js.native
@@ -53,9 +57,14 @@ class LogoJS(canvas: html.Canvas) extends js.Object:
53
57
  private var autoRender: Boolean = true
54
58
  private var initialized: Boolean = false
55
59
  private var backgroundColor: String = "white"
60
+ private var eventHandler: Option[js.Function0[Unit]] = None
56
61
 
57
62
  private val logo = new Logo:
58
- def event(): Unit = if initialized && autoRender then render()
63
+ def event(): Unit =
64
+ if initialized then
65
+ eventHandler match
66
+ case Some(handler) => handler()
67
+ case None => if autoRender then render()
59
68
 
60
69
  initialized = true
61
70
 
@@ -64,10 +73,13 @@ class LogoJS(canvas: html.Canvas) extends js.Object:
64
73
  logo.interp(program)
65
74
  if !autoRender then render()
66
75
 
67
- /** Execute a single command */
68
- def execute(command: String): Unit =
69
- logo.interp(command)
76
+ /** Execute a single command, returns result (undefined for commands with no output) */
77
+ def execute(command: String): js.UndefOr[String] =
78
+ val result = logo.interp(command)
70
79
  if !autoRender then render()
80
+ result match
81
+ case LogoUnit => js.undefined
82
+ case v => v.toString
71
83
 
72
84
  /** Clear the screen and reset turtle */
73
85
  def clear(): Unit =
@@ -117,6 +129,14 @@ class LogoJS(canvas: html.Canvas) extends js.Object:
117
129
  def clearOutputHandler(): Unit =
118
130
  logo.clearOutputHandler()
119
131
 
132
+ /** Set a callback for turtle events (called after each drawing command) */
133
+ def setEventHandler(handler: js.Function0[Unit]): Unit =
134
+ eventHandler = Some(handler)
135
+
136
+ /** Clear the event handler (use default auto-render behavior) */
137
+ def clearEventHandler(): Unit =
138
+ eventHandler = None
139
+
120
140
  /** Force a render */
121
141
  def render(): Unit =
122
142
  val width = canvas.width