stdScope.go 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180
  1. package scope
  2. import (
  3. "container/list"
  4. "fmt"
  5. "fw/cp/node"
  6. "fw/cp/object"
  7. "fw/rt2/context"
  8. rt_mod "fw/rt2/module"
  9. "reflect"
  10. "ypk/assert"
  11. )
  12. func This(i interface{}) Manager {
  13. assert.For(i != nil, 20)
  14. return i.(Manager)
  15. }
  16. func New() Manager {
  17. return new(manager).init()
  18. }
  19. type manager struct {
  20. d context.Domain
  21. areas *list.List
  22. }
  23. type area struct {
  24. heap map[object.Object]value
  25. root node.Node
  26. }
  27. type value interface {
  28. Set(x interface{})
  29. Get() interface{}
  30. }
  31. type direct struct {
  32. value
  33. data interface{}
  34. }
  35. type indirect struct {
  36. value
  37. ref object.Object
  38. mgr Manager
  39. }
  40. type dummy struct{}
  41. var def *dummy = &dummy{}
  42. func (v *direct) Set(x interface{}) {
  43. assert.For(x != nil, 20)
  44. v.data = x
  45. fmt.Println("set", x, reflect.TypeOf(x))
  46. }
  47. func (v *direct) Get() interface{} { return v.data }
  48. func (v *indirect) Set(x interface{}) {
  49. assert.For(x != nil, 20)
  50. assert.For(v.ref != nil, 21)
  51. v.mgr.Update(v.ref, func(old interface{}) interface{} {
  52. return x
  53. })
  54. }
  55. func (v *indirect) Get() interface{} {
  56. assert.For(v.ref != nil, 20)
  57. return v.mgr.Select(v.ref)
  58. }
  59. func (m *manager) init() *manager {
  60. m.areas = list.New()
  61. return m
  62. }
  63. func (m *manager) Allocate(n node.Node) {
  64. mod := rt_mod.DomainModule(m.Domain())
  65. h := new(area)
  66. h.heap = make(map[object.Object]value)
  67. h.root = n
  68. for _, o := range mod.Objects[n] {
  69. //fmt.Println(reflect.TypeOf(o))
  70. switch o.(type) {
  71. case object.VariableObject:
  72. h.heap[o] = &direct{data: def}
  73. case object.ParameterObject:
  74. h.heap[o] = &indirect{mgr: m}
  75. }
  76. }
  77. m.areas.PushFront(h)
  78. fmt.Println("allocate", len(h.heap), "obj")
  79. }
  80. func (m *manager) set(a *area, o object.Object, val node.Node) {
  81. switch val.(type) {
  82. case node.ConstantNode:
  83. m.Update(o, func(old interface{}) interface{} {
  84. return val.(node.ConstantNode).Data()
  85. })
  86. case node.VariableNode, node.ParameterNode:
  87. switch o.(type) {
  88. case object.VariableObject:
  89. m.Update(o, func(old interface{}) interface{} {
  90. return m.Select(val.Object())
  91. })
  92. case object.ParameterObject:
  93. a.heap[o].(*indirect).ref = val.Object()
  94. }
  95. default:
  96. panic("unknown value")
  97. }
  98. }
  99. func (m *manager) Initialize(n node.Node, o object.Object, _val node.Node) {
  100. e := m.areas.Front()
  101. assert.For(e != nil, 20)
  102. h := e.Value.(*area)
  103. assert.For(h.root == n, 21)
  104. val := _val
  105. fmt.Println("initialize")
  106. for next := o; next != nil; next = next.Link() {
  107. assert.For(val != nil, 40)
  108. fmt.Println(reflect.TypeOf(next), next.Name(), ":", next.Type())
  109. fmt.Println(reflect.TypeOf(val))
  110. m.set(h, next, val)
  111. val = val.Link()
  112. }
  113. }
  114. func (m *manager) Dispose(n node.Node) {
  115. e := m.areas.Front()
  116. assert.For(e != nil, 20)
  117. h := e.Value.(*area)
  118. assert.For(h.root == n, 21)
  119. m.areas.Remove(e)
  120. fmt.Println("dispose")
  121. }
  122. func (m *manager) Select(o object.Object) (ret interface{}) {
  123. assert.For(o != nil, 20)
  124. for e := m.areas.Front(); (e != nil) && (ret == nil); e = e.Next() {
  125. h := e.Value.(*area)
  126. ret = h.heap[o]
  127. }
  128. assert.For(ret != nil, 40)
  129. return ret.(value).Get()
  130. }
  131. func (m *manager) Update(o object.Object, val ValueFor) {
  132. assert.For(o != nil, 20)
  133. assert.For(val != nil, 21)
  134. var x *area
  135. for e := m.areas.Front(); (e != nil) && (x == nil); e = e.Next() {
  136. h := e.Value.(*area)
  137. if h.heap[o] != nil {
  138. x = h
  139. }
  140. }
  141. assert.For(x != nil, 40)
  142. old := x.heap[o].Get()
  143. if old == def {
  144. old = nil
  145. }
  146. tmp := val(old)
  147. assert.For(tmp != nil, 40) //если устанавливают значение NIL, значит делают что-то неверно
  148. x.heap[o].Set(tmp)
  149. }
  150. func (m *manager) Init(d context.Domain) {
  151. m.d = d
  152. }
  153. func (m *manager) Domain() context.Domain {
  154. return m.d
  155. }
  156. func (m *manager) Handle(msg interface{}) {}