about summary refs log tree commit diff stats
path: root/src/js/console.nim
blob: 3b28df5e1ce767bb100b6e66145137ab3b7e1cd0 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
import io/dynstream
import js/javascript

type Console* = ref object
  err*: DynStream
  clearFun: proc()
  showFun: proc()
  hideFun: proc()

jsDestructor(Console)

proc newConsole*(err: DynStream; clearFun: proc() = nil; showFun: proc() = nil;
    hideFun: proc() = nil): Console =
  return Console(
    err: err,
    clearFun: clearFun,
    showFun: showFun,
    hideFun: hideFun
  )

proc log*(console: Console; ss: varargs[string]) {.jsfunc.} =
  for i, s in ss:
    console.err.write(s)
    if i != ss.high:
      console.err.write(' ')
  console.err.write('\n')
  console.err.sflush()

proc clear(console: Console) {.jsfunc.} =
  if console.clearFun != nil:
    console.clearFun()

# For now, these are the same as log().
proc debug(console: Console; ss: varargs[string]) {.jsfunc.} =
  console.log(ss)

proc error(console: Console; ss: varargs[string]) {.jsfunc.} =
  console.log(ss)

proc info(console: Console; ss: varargs[string]) {.jsfunc.} =
  console.log(ss)

proc warn(console: Console; ss: varargs[string]) {.jsfunc.} =
  console.log(ss)

proc show(console: Console; ss: varargs[string]) {.jsfunc.} =
  if console.showFun != nil:
    console.showFun()

proc hide(console: Console; ss: varargs[string]) {.jsfunc.} =
  if console.hideFun != nil:
    console.hideFun()

proc addConsoleModule*(ctx: JSContext) =
  #TODO console should not have a prototype
  # "For historical reasons, console is lowercased."
  ctx.registerType(Console, nointerface = true, name = "console")