Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(283)

Side by Side Diff: frog/library.dart

Issue 9621001: Fix private member name mangling. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Improve private names. Created 8 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « no previous file | frog/member_set.dart » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
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
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
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 }
OLDNEW
« no previous file with comments | « no previous file | frog/member_set.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698