module.go 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182
  1. package module
  2. import (
  3. "fw/cp"
  4. "fw/cp/constant/enter"
  5. "fw/cp/node"
  6. "fw/cp/object"
  7. "reflect"
  8. "strconv"
  9. "ypk/assert"
  10. "ypk/halt"
  11. )
  12. type Import struct {
  13. Name string
  14. Objects []object.Object
  15. Types []object.ComplexType
  16. }
  17. type Module struct {
  18. Name string
  19. Enter node.Node
  20. Objects map[node.Node][]object.Object
  21. Nodes []node.Node
  22. Types map[node.Node][]object.ComplexType
  23. Imports map[string]Import
  24. }
  25. type named interface {
  26. Name() string
  27. }
  28. func (m *Module) ObjectByName(scope node.Node, name string) (rl []object.Object) {
  29. assert.For(name != "", 20)
  30. find := func(v []object.Object) (ret []object.Object) {
  31. for _, o := range v {
  32. if o.Name() == name {
  33. ret = append(ret, o)
  34. }
  35. //fmt.Println(o.Name(), name, o.Name() == name)
  36. }
  37. return ret
  38. }
  39. if scope == nil {
  40. for _, v := range m.Objects {
  41. rl = append(rl, find(v)...)
  42. }
  43. } else {
  44. rl = find(m.Objects[scope])
  45. }
  46. return rl
  47. }
  48. func (m *Module) TypeByName(scope node.Node, name string) (ret object.ComplexType) {
  49. assert.For(name != "", 20)
  50. for _, typ := range m.Types[scope] {
  51. //fmt.Print(typ)
  52. if v, ok := typ.(named); ok && v.Name() == name {
  53. ret = typ
  54. break //стыд какой
  55. }
  56. }
  57. return ret
  58. }
  59. func (m *Module) ImportOf(obj object.Object) string {
  60. contains := func(v []object.Object) bool {
  61. for _, o := range v {
  62. if o == obj {
  63. return true
  64. }
  65. }
  66. return false
  67. }
  68. for _, v := range m.Imports {
  69. if contains(v.Objects) {
  70. return v.Name
  71. }
  72. }
  73. return ""
  74. }
  75. func (m *Module) ImportOfType(obj object.ComplexType) string {
  76. contains := func(v []object.ComplexType) bool {
  77. for _, o := range v {
  78. if o.Adr() == obj.Adr() {
  79. return true
  80. }
  81. }
  82. return false
  83. }
  84. for _, v := range m.Imports {
  85. if contains(v.Types) {
  86. return v.Name
  87. }
  88. }
  89. return ""
  90. }
  91. func (m *Module) NodeByObject(obj object.Object) (ret []node.Node) {
  92. assert.For(obj != nil, 20)
  93. for i := 0; (i < len(m.Nodes)) && (ret == nil); i++ {
  94. node := m.Nodes[i]
  95. if node.Object() != nil {
  96. if node.Object().Adr(0, 0) == obj.Adr() {
  97. ret = append(ret, node)
  98. }
  99. }
  100. }
  101. return ret
  102. }
  103. func (m *Module) Init(inittd ...func(t object.ComplexType)) {
  104. typeName := func(id cp.ID) string {
  105. for _, s := range m.Objects {
  106. for _, o := range s {
  107. switch t := o.(type) {
  108. case object.TypeObject:
  109. if o.Complex().Adr() == id {
  110. return t.Name()
  111. }
  112. }
  113. }
  114. }
  115. for _, i := range m.Imports {
  116. for _, o := range i.Objects {
  117. switch t := o.(type) {
  118. case object.TypeObject:
  119. if o.Complex().Adr() == id {
  120. return ">" + i.Name + "." + t.Name()
  121. }
  122. }
  123. }
  124. }
  125. return strconv.Itoa(int(id))
  126. }
  127. //fmt.Println("init", m.Name)
  128. for k, s := range m.Types {
  129. q := ""
  130. switch e := k.(type) {
  131. case node.EnterNode:
  132. switch e.Enter() {
  133. case enter.MODULE:
  134. q = m.Name
  135. case enter.PROCEDURE:
  136. q = m.Name + "..." + e.Object().Name()
  137. }
  138. default:
  139. halt.As(100, reflect.TypeOf(e))
  140. }
  141. for _, t := range s {
  142. t.Qualident(q + "." + typeName(t.Adr()))
  143. }
  144. }
  145. for _, s := range m.Imports {
  146. q := s.Name
  147. for _, t := range s.Types {
  148. t.Qualident(q + "." + typeName(t.Adr()))
  149. }
  150. for _, o := range s.Objects {
  151. o.Imp(s.Name)
  152. }
  153. }
  154. if len(inittd) > 0 {
  155. for _, s := range m.Types {
  156. for _, t := range s {
  157. inittd[0](t)
  158. switch rec := t.(type) {
  159. case object.RecordType:
  160. for x := rec.Link(); x != nil; x = x.Link() {
  161. switch f := x.(type) {
  162. case object.FieldObject:
  163. f.TypeOf(rec)
  164. }
  165. }
  166. }
  167. }
  168. }
  169. }
  170. }