call.go 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. package eval
  2. import (
  3. "encoding/json"
  4. "fmt"
  5. "fw/cp"
  6. "fw/cp/constant"
  7. "fw/cp/node"
  8. "fw/cp/object"
  9. "fw/rt2"
  10. "fw/rt2/frame"
  11. rtm "fw/rt2/module"
  12. "fw/rt2/scope"
  13. "math"
  14. "reflect"
  15. "ypk/assert"
  16. "ypk/halt"
  17. "ypk/mathe"
  18. )
  19. var sys map[string]func(IN, node.Node) OUT
  20. type Msg struct {
  21. Type string
  22. Command string
  23. Data string
  24. }
  25. func callHandler(f frame.Frame, obj object.Object, data interface{}) {
  26. //n := rt2.Utils.NodeOf(f)
  27. //fmt.Println("call handler", obj)
  28. if obj == nil {
  29. return
  30. }
  31. m := rtm.DomainModule(f.Domain())
  32. cn := node.New(constant.CALL, cp.Some())
  33. ol := m.NodeByObject(obj)
  34. assert.For(len(ol) <= 1, 40)
  35. cn.SetLeft(ol[0])
  36. cc := node.New(constant.CONSTANT, cp.Some()).(node.ConstantNode)
  37. cc.SetData(data)
  38. cc.SetType(object.SHORTSTRING)
  39. cn.SetRight(cc)
  40. rt2.Push(rt2.New(cn), f)
  41. }
  42. func go_process(in IN, par node.Node) OUT {
  43. assert.For(par != nil, 20)
  44. sm := rt2.ThisScope(in.Frame)
  45. do := func(val string) {
  46. if val != "" {
  47. msg := &Msg{}
  48. if err := json.Unmarshal([]byte(val), msg); err == nil {
  49. switch msg.Type {
  50. case "log":
  51. fmt.Print(msg.Data)
  52. callHandler(in.Frame, scope.FindObjByName(sm, "go_handler"), `{"type":"log"}`)
  53. case "core":
  54. switch msg.Command {
  55. case "load":
  56. LoadMod(in.Frame, msg.Data)
  57. default:
  58. halt.As(100, msg.Command)
  59. }
  60. default:
  61. panic(40)
  62. }
  63. } else {
  64. fmt.Println(val, "not a json")
  65. }
  66. }
  67. }
  68. const left = "sys:left"
  69. return GetExpression(in, left, par, func(IN) OUT {
  70. val := rt2.ValueOf(in.Frame)[KeyOf(in, left)]
  71. assert.For(val != nil, 20)
  72. do(scope.GoTypeFrom(val).(string))
  73. return Later(Tail(STOP))
  74. })
  75. }
  76. func go_math(in IN, par node.Node) OUT {
  77. const (
  78. LN = 1.0
  79. MANT = 2.0
  80. EXP = 3.0
  81. )
  82. assert.For(par != nil, 20)
  83. sm := rt2.ThisScope(in.Frame)
  84. res := math.NaN()
  85. switch p := par.(type) {
  86. case node.VariableNode:
  87. sm.Select(p.Object().Adr(), func(val scope.Value) {
  88. rv, ok := scope.GoTypeFrom(val).([]float64)
  89. assert.For(ok && (len(rv) > 1), 100, rv)
  90. switch rv[0] {
  91. case LN:
  92. res = math.Log(rv[1])
  93. case MANT:
  94. res, _ = mathe.Me(rv[1])
  95. case EXP:
  96. _, res = mathe.Me(rv[1])
  97. default:
  98. halt.As(100, rv[0])
  99. }
  100. })
  101. default:
  102. halt.As(100, reflect.TypeOf(p))
  103. }
  104. id := cp.ID(cp.Some())
  105. rt2.RegOf(in.Parent)[in.Key] = id
  106. rt2.ValueOf(in.Parent)[id] = scope.TypeFromGo(res)
  107. return End()
  108. }
  109. func init() {
  110. sys = make(map[string]func(IN, node.Node) OUT)
  111. sys["go_process"] = go_process
  112. sys["go_math"] = go_math
  113. }
  114. var LoadMod func(frame.Frame, string)
  115. func syscall(in IN) OUT {
  116. n := in.IR
  117. name := n.Left().Object().Name()
  118. return sys[name](in, n.Right())
  119. }