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

Side by Side Diff: pkg/analysis_server/lib/src/computer/computer_overrides.dart

Issue 479683005: Make more use of generated code in analysis server. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Created 6 years, 4 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
OLDNEW
1 // Copyright (c) 2014, the Dart project authors. Please see the AUTHORS file 1 // Copyright (c) 2014, 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 library computer.overrides; 5 library computer.overrides;
6 6
7 import 'package:analysis_server/src/computer/element.dart'; 7 import 'package:analysis_server/src/protocol2.dart';
8 import 'package:analysis_server/src/constants.dart';
9 import 'package:analysis_server/src/services/json.dart';
10 import 'package:analyzer/src/generated/ast.dart'; 8 import 'package:analyzer/src/generated/ast.dart';
11 import 'package:analyzer/src/generated/element.dart' as engine; 9 import 'package:analyzer/src/generated/element.dart' as engine;
12 10
13 11
14 /** 12 /**
15 * A computer for class member overrides in a Dart [CompilationUnit]. 13 * A computer for class member overrides in a Dart [CompilationUnit].
16 */ 14 */
17 class DartUnitOverridesComputer { 15 class DartUnitOverridesComputer {
18 final CompilationUnit _unit; 16 final CompilationUnit _unit;
19 17
(...skipping 41 matching lines...) Expand 10 before | Expand all | Expand 10 after
61 for (engine.InterfaceType interfaceType in _currentClass.interfaces) { 59 for (engine.InterfaceType interfaceType in _currentClass.interfaces) {
62 engine.ClassElement interfaceElement = interfaceType.element; 60 engine.ClassElement interfaceElement = interfaceType.element;
63 engine.Element interfaceMember = _lookupMember(interfaceElement, name); 61 engine.Element interfaceMember = _lookupMember(interfaceElement, name);
64 if (interfaceMember != null) { 62 if (interfaceMember != null) {
65 interfaceEngineElements.add(interfaceMember); 63 interfaceEngineElements.add(interfaceMember);
66 } 64 }
67 } 65 }
68 // is there any override? 66 // is there any override?
69 if (superEngineElement != null || interfaceEngineElements.isNotEmpty) { 67 if (superEngineElement != null || interfaceEngineElements.isNotEmpty) {
70 OverriddenMember superMember = superEngineElement != null ? 68 OverriddenMember superMember = superEngineElement != null ?
71 OverriddenMember.fromEngine(superEngineElement) : 69 new OverriddenMember.fromEngine(superEngineElement) :
72 null; 70 null;
73 List<OverriddenMember> interfaceMembers = 71 List<OverriddenMember> interfaceMembers =
74 interfaceEngineElements.map(OverriddenMember.fromEngine).toList(); 72 interfaceEngineElements.map((engine.Element member) =>
73 new OverriddenMember.fromEngine(member)).toList();
75 _overrides.add( 74 _overrides.add(
76 new Override(offset, length, superMember, interfaceMembers)); 75 new Override(offset, length, superclassMember: superMember,
76 interfaceMembers: interfaceMembers.isNotEmpty ?
77 interfaceMembers : null));
77 } 78 }
78 } 79 }
79 80
80 static engine.Element _lookupMember(engine.ClassElement classElement, 81 static engine.Element _lookupMember(engine.ClassElement classElement,
81 String name) { 82 String name) {
82 if (classElement == null) { 83 if (classElement == null) {
83 return null; 84 return null;
84 } 85 }
85 engine.LibraryElement library = classElement.library; 86 engine.LibraryElement library = classElement.library;
86 // method 87 // method
87 engine.Element member = classElement.lookUpMethod(name, library); 88 engine.Element member = classElement.lookUpMethod(name, library);
88 if (member != null) { 89 if (member != null) {
89 return member; 90 return member;
90 } 91 }
91 // getter 92 // getter
92 member = classElement.lookUpGetter(name, library); 93 member = classElement.lookUpGetter(name, library);
93 if (member != null) { 94 if (member != null) {
94 return member; 95 return member;
95 } 96 }
96 // setter 97 // setter
97 member = classElement.lookUpSetter(name + '=', library); 98 member = classElement.lookUpSetter(name + '=', library);
98 if (member != null) { 99 if (member != null) {
99 return member; 100 return member;
100 } 101 }
101 // not found 102 // not found
102 return null; 103 return null;
103 } 104 }
104 } 105 }
105
106
107 class OverriddenMember implements HasToJson {
108 final Element element;
109 final String className;
110
111 OverriddenMember(this.element, this.className);
112
113 Map<String, Object> toJson() {
114 return {
115 ELEMENT: element.toJson(),
116 CLASS_NAME: className
117 };
118 }
119
120 @override
121 String toString() => toJson().toString();
122
123 static OverriddenMember fromEngine(engine.Element member) {
124 Element element = new Element.fromEngine(member);
125 String className = member.enclosingElement.displayName;
126 return new OverriddenMember(element, className);
127 }
128
129 static OverriddenMember fromJson(Map<String, Object> json) {
130 Map<String, Object> elementJson = json[ELEMENT];
131 Element element = new Element.fromJson(elementJson);
132 String className = json[CLASS_NAME];
133 return new OverriddenMember(element, className);
134 }
135 }
136
137
138 class Override implements HasToJson {
139 final int offset;
140 final int length;
141 final OverriddenMember superclassMember;
142 final List<OverriddenMember> interfaceMembers;
143
144 Override(this.offset, this.length, this.superclassMember,
145 this.interfaceMembers);
146
147 Map<String, Object> toJson() {
148 Map<String, Object> json = <String, Object>{};
149 json[OFFSET] = offset;
150 json[LENGTH] = length;
151 if (superclassMember != null) {
152 json[SUPER_CLASS_MEMBER] = superclassMember.toJson();
153 }
154 if (interfaceMembers != null && interfaceMembers.isNotEmpty) {
155 json[INTERFACE_MEMBERS] = objectToJson(interfaceMembers);
156 }
157 return json;
158 }
159
160 @override
161 String toString() => toJson().toString();
162
163 static Override fromJson(Map<String, Object> map) {
164 int offset = map[OFFSET];
165 int length = map[LENGTH];
166 // super
167 OverriddenMember superclassMember = null;
168 {
169 Map<String, Object> superJson = map[SUPER_CLASS_MEMBER];
170 if (superJson != null) {
171 superclassMember = OverriddenMember.fromJson(superJson);
172 }
173 }
174 // interfaces
175 List<OverriddenMember> interfaceElements = null;
176 {
177 List<Map<String, Object>> jsonList = map[INTERFACE_MEMBERS];
178 if (jsonList != null) {
179 interfaceElements = jsonList.map(OverriddenMember.fromJson).toList();
180 }
181 }
182 // done
183 return new Override(offset, length, superclassMember, interfaceElements);
184 }
185 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698