OLD | NEW |
1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file |
2 // for details. All rights reserved. Use of this source code is governed by a | 2 // for details. All rights reserved. Use of this source code is governed by a |
3 // BSD-style license that can be found in the LICENSE file. | 3 // BSD-style license that can be found in the LICENSE file. |
4 | 4 |
5 class LibraryImport { | 5 class LibraryImport { |
6 final String prefix; | 6 final String prefix; |
7 final Library library; | 7 final Library library; |
8 final SourceSpan span; | 8 final SourceSpan span; |
9 LibraryImport(this.library, [this.prefix, this.span]); | 9 LibraryImport(this.library, [this.prefix, this.span]); |
10 } | 10 } |
(...skipping 76 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
87 return world._members[name]; | 87 return world._members[name]; |
88 } | 88 } |
89 } | 89 } |
90 | 90 |
91 _addMember(Member member) { | 91 _addMember(Member member) { |
92 if (member.isPrivate) { | 92 if (member.isPrivate) { |
93 if (member.isStatic) { | 93 if (member.isStatic) { |
94 if (member.declaringType.isTop) { | 94 if (member.declaringType.isTop) { |
95 world._addTopName(member); | 95 world._addTopName(member); |
96 } | 96 } |
97 return; | 97 } else { |
98 } | 98 var members = _privateMembers[member.name]; |
99 | 99 if (members == null) { |
100 var mset = _privateMembers[member.name]; | 100 members = new MemberSet(member, isVar: true); |
101 if (mset == null) { | 101 _privateMembers[member.name] = members; |
102 // TODO(jimhug): Make this lazier! | 102 } else { |
103 for (var lib in world.libraries.getValues()) { | 103 members.add(member); |
104 if (lib._privateMembers.containsKey(member.jsname)) { | |
105 member._jsname = '_$jsname${member.jsname}'; | |
106 break; | |
107 } | |
108 } | 104 } |
109 | 105 _makePrivateMembersUnique(member, members); |
110 mset = new MemberSet(member, isVar:true); | |
111 _privateMembers[member.name] = mset; | |
112 } else { | |
113 mset.members.add(member); | |
114 } | 106 } |
115 } else { | 107 } else { |
116 world._addMember(member); | 108 world._addMember(member); |
117 } | 109 } |
118 } | 110 } |
119 | 111 |
| 112 void _makePrivateMembersUnique(Member member, MemberSet members) { |
| 113 // If the JS name in the member set is already unique, we simply |
| 114 // copy the name to the new member. |
| 115 if (members.jsnameUnique) { |
| 116 member._jsname = members.jsname; |
| 117 return; |
| 118 } |
| 119 |
| 120 // Run through the other libraries in the world and check if any |
| 121 // of them has a clashing private member. If so, we rewrite this |
| 122 // one and all other members in the set. |
| 123 String name = members.name; |
| 124 for (var lib in world.libraries.getValues()) { |
| 125 if (lib !== this && lib._privateMembers.containsKey(name)) { |
| 126 String uniqueName = '_${this.jsname}${members.jsname}'; |
| 127 members.jsname = uniqueName; |
| 128 members.jsnameUnique = true; |
| 129 members.members.forEach((each) { each._jsname = uniqueName; }); |
| 130 assert(member.jsname == members.jsname); |
| 131 return; |
| 132 } |
| 133 } |
| 134 } |
| 135 |
120 // TODO(jimhug): Cache and share the types as interfaces! | 136 // TODO(jimhug): Cache and share the types as interfaces! |
121 Type getOrAddFunctionType(Element enclosingElement, String name, | 137 Type getOrAddFunctionType(Element enclosingElement, String name, |
122 FunctionDefinition func, MethodData data) { | 138 FunctionDefinition func, MethodData data) { |
123 // TODO(jimhug): This is redundant now that FunctionDef has type params. | 139 // TODO(jimhug): This is redundant now that FunctionDef has type params. |
124 final def = new FunctionTypeDefinition(func, null, func.span); | 140 final def = new FunctionTypeDefinition(func, null, func.span); |
125 final type = new DefinedType(name, this, def, false); | 141 final type = new DefinedType(name, this, def, false); |
126 type.addMethod(':call', func); | 142 type.addMethod(':call', func); |
127 var m = type.members[':call']; | 143 var m = type.members[':call']; |
128 m.enclosingElement = enclosingElement; | 144 m.enclosingElement = enclosingElement; |
129 m.resolve(); | 145 m.resolve(); |
(...skipping 382 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
512 | 528 |
513 void visitFunctionDefinition(FunctionDefinition node) { | 529 void visitFunctionDefinition(FunctionDefinition node) { |
514 currentType.addMethod(node.name.name, node); | 530 currentType.addMethod(node.name.name, node); |
515 } | 531 } |
516 | 532 |
517 void visitFunctionTypeDefinition(FunctionTypeDefinition node) { | 533 void visitFunctionTypeDefinition(FunctionTypeDefinition node) { |
518 var type = library.addType(node.func.name.name, node, false); | 534 var type = library.addType(node.func.name.name, node, false); |
519 type.addMethod(':call', node.func); | 535 type.addMethod(':call', node.func); |
520 } | 536 } |
521 } | 537 } |
OLD | NEW |