stdScope.go 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  1. package scope
  2. import (
  3. "container/list"
  4. "cp/node"
  5. "cp/object"
  6. "fmt"
  7. "reflect"
  8. "rt2/context"
  9. rt_mod "rt2/module"
  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 heapObj struct {
  24. heap map[object.Object]interface{}
  25. root node.Node
  26. }
  27. type undefined struct{}
  28. var undef *undefined = new(undefined)
  29. func (m *manager) init() *manager {
  30. m.areas = list.New()
  31. return m
  32. }
  33. func (m *manager) Allocate(n node.Node) {
  34. mod := rt_mod.DomainModule(m.Domain())
  35. h := new(heapObj)
  36. h.heap = make(map[object.Object]interface{})
  37. h.root = n
  38. for _, o := range mod.Objects[n] {
  39. fmt.Println(reflect.TypeOf(o))
  40. switch o.(type) {
  41. case object.VariableObject:
  42. h.heap[o] = undef
  43. }
  44. }
  45. m.areas.PushFront(h)
  46. fmt.Println("allocate", len(h.heap), "obj")
  47. }
  48. func (m *manager) Dispose(n node.Node) {
  49. e := m.areas.Front()
  50. assert.For(e != nil, 20)
  51. h := e.Value.(*heapObj)
  52. assert.For(h.root == n, 21)
  53. m.areas.Remove(e)
  54. fmt.Println("dispose")
  55. }
  56. func (m *manager) Select(o object.Object) (ret interface{}) {
  57. assert.For(o != nil, 20)
  58. for e := m.areas.Front(); (e != nil) && (ret == nil); e = e.Next() {
  59. h := e.Value.(*heapObj)
  60. ret = h.heap[o]
  61. }
  62. assert.For(ret != nil, 40)
  63. if ret == undef {
  64. ret = nil
  65. }
  66. return ret
  67. }
  68. func (m *manager) Update(o object.Object, val Value) {
  69. assert.For(o != nil, 20)
  70. assert.For(val != nil, 21)
  71. var x *heapObj
  72. for e := m.areas.Front(); (e != nil) && (x == nil); e = e.Next() {
  73. h := e.Value.(*heapObj)
  74. if h.heap[o] != nil {
  75. x = h
  76. }
  77. }
  78. assert.For(x != nil, 40)
  79. tmp := x.heap[o]
  80. if tmp == undef {
  81. tmp = val(nil)
  82. } else {
  83. tmp = val(tmp)
  84. }
  85. if tmp == nil {
  86. tmp = undef
  87. }
  88. x.heap[o] = tmp
  89. fmt.Println("set", x.heap[o], reflect.TypeOf(x.heap[o]))
  90. }
  91. func (m *manager) Init(d context.Domain) {
  92. m.d = d
  93. }
  94. func (m *manager) Domain() context.Domain {
  95. return m.d
  96. }
  97. func (m *manager) Handle(msg interface{}) {}