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
58
59
60
61
62
63
64
|
// +build js
package syscall
import (
"unsafe"
"github.com/gopherjs/gopherjs/js"
)
var warningPrinted = false
var lineBuffer []byte
func init() {
js.Global.Set("$flushConsole", js.InternalObject(func() {
if len(lineBuffer) != 0 {
js.Global.Get("console").Call("log", string(lineBuffer))
lineBuffer = nil
}
}))
}
func printWarning() {
if !warningPrinted {
js.Global.Get("console").Call("error", "warning: system calls not available, see https://github.com/gopherjs/gopherjs/blob/master/doc/syscalls.md")
}
warningPrinted = true
}
func printToConsole(b []byte) {
goPrintToConsole := js.Global.Get("goPrintToConsole")
if goPrintToConsole != js.Undefined {
goPrintToConsole.Invoke(js.InternalObject(b))
return
}
lineBuffer = append(lineBuffer, b...)
for {
i := indexByte(lineBuffer, '\n')
if i == -1 {
break
}
js.Global.Get("console").Call("log", string(lineBuffer[:i])) // don't use println, since it does not externalize multibyte characters
lineBuffer = lineBuffer[i+1:]
}
}
func use(p unsafe.Pointer) {
// no-op
}
func Exit(code int) {
Syscall(exitTrap, uintptr(code), 0, 0)
}
// indexByte is copied from bytes package to avoid importing it (since the real syscall package doesn't).
func indexByte(s []byte, c byte) int {
for i, b := range s {
if b == c {
return i
}
}
return -1
}
|