| 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 library dart2js.mirrors; | 5 library dart2js.mirrors; |
| 6 | 6 |
| 7 import 'dart:collection' show UnmodifiableListView, UnmodifiableMapView; | 7 import 'dart:collection' show UnmodifiableListView, UnmodifiableMapView; |
| 8 | 8 |
| 9 import '../common.dart'; | 9 import '../common.dart'; |
| 10 import '../compiler.dart' show | 10 import '../compiler.dart' show Compiler; |
| 11 Compiler; | |
| 12 import '../constants/expressions.dart'; | 11 import '../constants/expressions.dart'; |
| 13 import '../constants/values.dart'; | 12 import '../constants/values.dart'; |
| 14 import '../dart_types.dart'; | 13 import '../dart_types.dart'; |
| 15 import '../elements/elements.dart'; | 14 import '../elements/elements.dart'; |
| 16 import '../elements/modelx.dart' show | 15 import '../elements/modelx.dart' show LibraryElementX; |
| 17 LibraryElementX; | 16 import '../resolution/scope.dart' show Scope; |
| 18 import '../resolution/scope.dart' show | |
| 19 Scope; | |
| 20 import '../script.dart'; | 17 import '../script.dart'; |
| 21 import '../tokens/token.dart'; | 18 import '../tokens/token.dart'; |
| 22 import '../tokens/token_constants.dart' as Tokens; | 19 import '../tokens/token_constants.dart' as Tokens; |
| 23 import '../tree/tree.dart'; | 20 import '../tree/tree.dart'; |
| 24 import '../util/util.dart' | 21 import '../util/util.dart' show Link, LinkBuilder; |
| 25 show Link, | |
| 26 LinkBuilder; | |
| 27 import '../util/characters.dart' show $CR, $LF; | 22 import '../util/characters.dart' show $CR, $LF; |
| 28 | 23 |
| 29 import 'source_mirrors.dart'; | 24 import 'source_mirrors.dart'; |
| 30 import 'mirrors_util.dart'; | 25 import 'mirrors_util.dart'; |
| 31 | 26 |
| 32 part 'dart2js_library_mirror.dart'; | 27 part 'dart2js_library_mirror.dart'; |
| 33 part 'dart2js_type_mirrors.dart'; | 28 part 'dart2js_type_mirrors.dart'; |
| 34 part 'dart2js_member_mirrors.dart'; | 29 part 'dart2js_member_mirrors.dart'; |
| 35 part 'dart2js_instance_mirrors.dart'; | 30 part 'dart2js_instance_mirrors.dart'; |
| 36 | 31 |
| 37 //------------------------------------------------------------------------------ | 32 //------------------------------------------------------------------------------ |
| 38 // Utility types and functions for the dart2js mirror system | 33 // Utility types and functions for the dart2js mirror system |
| 39 //------------------------------------------------------------------------------ | 34 //------------------------------------------------------------------------------ |
| 40 | 35 |
| 41 bool _includeLibrary(Dart2JsLibraryMirror mirror) { | 36 bool _includeLibrary(Dart2JsLibraryMirror mirror) { |
| 42 return const bool.fromEnvironment("list_all_libraries") || | 37 return const bool.fromEnvironment("list_all_libraries") || |
| 43 !mirror._element.isInternalLibrary; | 38 !mirror._element.isInternalLibrary; |
| 44 } | 39 } |
| 45 | 40 |
| 46 bool _isPrivate(String name) { | 41 bool _isPrivate(String name) { |
| 47 return name.startsWith('_'); | 42 return name.startsWith('_'); |
| 48 } | 43 } |
| 49 | 44 |
| 50 List<ParameterMirror> _parametersFromFunctionSignature( | 45 List<ParameterMirror> _parametersFromFunctionSignature( |
| 51 Dart2JsDeclarationMirror owner, | 46 Dart2JsDeclarationMirror owner, FunctionSignature signature) { |
| 52 FunctionSignature signature) { | |
| 53 var parameters = <ParameterMirror>[]; | 47 var parameters = <ParameterMirror>[]; |
| 54 signature.requiredParameters.forEach((FormalElement parameter) { | 48 signature.requiredParameters.forEach((FormalElement parameter) { |
| 55 parameters.add(new Dart2JsParameterMirror( | 49 parameters.add(new Dart2JsParameterMirror(owner, parameter, |
| 56 owner, parameter, isOptional: false, isNamed: false)); | 50 isOptional: false, isNamed: false)); |
| 57 }); | 51 }); |
| 58 bool isNamed = signature.optionalParametersAreNamed; | 52 bool isNamed = signature.optionalParametersAreNamed; |
| 59 signature.optionalParameters.forEach((FormalElement parameter) { | 53 signature.optionalParameters.forEach((FormalElement parameter) { |
| 60 parameters.add(new Dart2JsParameterMirror( | 54 parameters.add(new Dart2JsParameterMirror(owner, parameter, |
| 61 owner, parameter, isOptional: true, isNamed: isNamed)); | 55 isOptional: true, isNamed: isNamed)); |
| 62 }); | 56 }); |
| 63 return parameters; | 57 return parameters; |
| 64 } | 58 } |
| 65 | 59 |
| 66 MethodMirror _convertElementMethodToMethodMirror( | 60 MethodMirror _convertElementMethodToMethodMirror( |
| 67 Dart2JsDeclarationMirror library, Element element) { | 61 Dart2JsDeclarationMirror library, Element element) { |
| 68 if (element is FunctionElement) { | 62 if (element is FunctionElement) { |
| 69 return new Dart2JsMethodMirror(library, element); | 63 return new Dart2JsMethodMirror(library, element); |
| 70 } else { | 64 } else { |
| 71 return null; | 65 return null; |
| 72 } | 66 } |
| 73 } | 67 } |
| 74 | 68 |
| 75 //------------------------------------------------------------------------------ | 69 //------------------------------------------------------------------------------ |
| 76 // Dart2Js specific extensions of mirror interfaces | 70 // Dart2Js specific extensions of mirror interfaces |
| 77 //------------------------------------------------------------------------------ | 71 //------------------------------------------------------------------------------ |
| 78 | 72 |
| 79 abstract class Dart2JsMirror implements Mirror { | 73 abstract class Dart2JsMirror implements Mirror { |
| 80 Dart2JsMirrorSystem get mirrorSystem; | 74 Dart2JsMirrorSystem get mirrorSystem; |
| 81 } | 75 } |
| 82 | 76 |
| 83 abstract class Dart2JsDeclarationMirror extends Dart2JsMirror | 77 abstract class Dart2JsDeclarationMirror extends Dart2JsMirror |
| 84 implements DeclarationSourceMirror { | 78 implements DeclarationSourceMirror { |
| 85 | |
| 86 bool get isTopLevel => owner != null && owner is LibraryMirror; | 79 bool get isTopLevel => owner != null && owner is LibraryMirror; |
| 87 | 80 |
| 88 bool get isPrivate => _isPrivate(_simpleNameString); | 81 bool get isPrivate => _isPrivate(_simpleNameString); |
| 89 | 82 |
| 90 String get _simpleNameString; | 83 String get _simpleNameString; |
| 91 | 84 |
| 92 String get _qualifiedNameString { | 85 String get _qualifiedNameString { |
| 93 var parent = owner; | 86 var parent = owner; |
| 94 if (parent is Dart2JsDeclarationMirror) { | 87 if (parent is Dart2JsDeclarationMirror) { |
| 95 return '${parent._qualifiedNameString}.${_simpleNameString}'; | 88 return '${parent._qualifiedNameString}.${_simpleNameString}'; |
| (...skipping 27 matching lines...) Expand all Loading... |
| 123 var members = <Dart2JsMemberMirror>[]; | 116 var members = <Dart2JsMemberMirror>[]; |
| 124 AbstractFieldElement field = element; | 117 AbstractFieldElement field = element; |
| 125 if (field.getter != null) { | 118 if (field.getter != null) { |
| 126 members.add(new Dart2JsMethodMirror(this, field.getter)); | 119 members.add(new Dart2JsMethodMirror(this, field.getter)); |
| 127 } | 120 } |
| 128 if (field.setter != null) { | 121 if (field.setter != null) { |
| 129 members.add(new Dart2JsMethodMirror(this, field.setter)); | 122 members.add(new Dart2JsMethodMirror(this, field.setter)); |
| 130 } | 123 } |
| 131 return members; | 124 return members; |
| 132 } | 125 } |
| 133 mirrorSystem.compiler.reporter.internalError(element, | 126 mirrorSystem.compiler.reporter.internalError( |
| 134 "Unexpected member type $element ${element.kind}."); | 127 element, "Unexpected member type $element ${element.kind}."); |
| 135 return null; | 128 return null; |
| 136 } | 129 } |
| 137 } | 130 } |
| 138 | 131 |
| 139 abstract class Dart2JsElementMirror extends Dart2JsDeclarationMirror { | 132 abstract class Dart2JsElementMirror extends Dart2JsDeclarationMirror { |
| 140 final Dart2JsMirrorSystem mirrorSystem; | 133 final Dart2JsMirrorSystem mirrorSystem; |
| 141 final Element _element; | 134 final Element _element; |
| 142 List<InstanceMirror> _metadata; | 135 List<InstanceMirror> _metadata; |
| 143 | 136 |
| 144 Dart2JsElementMirror(this.mirrorSystem, this._element) { | 137 Dart2JsElementMirror(this.mirrorSystem, this._element) { |
| 145 assert (mirrorSystem != null); | 138 assert(mirrorSystem != null); |
| 146 assert (_element != null); | 139 assert(_element != null); |
| 147 } | 140 } |
| 148 | 141 |
| 149 String get _simpleNameString => _element.name; | 142 String get _simpleNameString => _element.name; |
| 150 | 143 |
| 151 /** | 144 /** |
| 152 * Computes the first token for this declaration using the begin token of the | 145 * Computes the first token for this declaration using the begin token of the |
| 153 * element node or element position as indicator. | 146 * element node or element position as indicator. |
| 154 */ | 147 */ |
| 155 Token getBeginToken() { | 148 Token getBeginToken() { |
| 156 Element element = _element; | 149 Element element = _element; |
| (...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 196 Script getScript() => _element.compilationUnit.script; | 189 Script getScript() => _element.compilationUnit.script; |
| 197 | 190 |
| 198 SourceLocation get location { | 191 SourceLocation get location { |
| 199 Token beginToken = getFirstToken(); | 192 Token beginToken = getFirstToken(); |
| 200 Script script = getScript(); | 193 Script script = getScript(); |
| 201 SourceSpan span; | 194 SourceSpan span; |
| 202 if (beginToken == null) { | 195 if (beginToken == null) { |
| 203 span = new SourceSpan(script.resourceUri, 0, 0); | 196 span = new SourceSpan(script.resourceUri, 0, 0); |
| 204 } else { | 197 } else { |
| 205 Token endToken = getEndToken(); | 198 Token endToken = getEndToken(); |
| 206 span = new SourceSpan.fromTokens( | 199 span = |
| 207 script.resourceUri, beginToken, endToken); | 200 new SourceSpan.fromTokens(script.resourceUri, beginToken, endToken); |
| 208 } | 201 } |
| 209 return new Dart2JsSourceLocation(script, span); | 202 return new Dart2JsSourceLocation(script, span); |
| 210 } | 203 } |
| 211 | 204 |
| 212 String toString() => _element.toString(); | 205 String toString() => _element.toString(); |
| 213 | 206 |
| 214 void _appendCommentTokens(Token commentToken) { | 207 void _appendCommentTokens(Token commentToken) { |
| 215 while (commentToken != null && commentToken.kind == Tokens.COMMENT_TOKEN) { | 208 while (commentToken != null && commentToken.kind == Tokens.COMMENT_TOKEN) { |
| 216 _metadata.add(new Dart2JsCommentInstanceMirror( | 209 _metadata.add( |
| 217 mirrorSystem, commentToken.value)); | 210 new Dart2JsCommentInstanceMirror(mirrorSystem, commentToken.value)); |
| 218 commentToken = commentToken.next; | 211 commentToken = commentToken.next; |
| 219 } | 212 } |
| 220 } | 213 } |
| 221 | 214 |
| 222 List<InstanceMirror> get metadata { | 215 List<InstanceMirror> get metadata { |
| 223 if (_metadata == null) { | 216 if (_metadata == null) { |
| 224 _metadata = <InstanceMirror>[]; | 217 _metadata = <InstanceMirror>[]; |
| 225 for (MetadataAnnotation metadata in _element.metadata) { | 218 for (MetadataAnnotation metadata in _element.metadata) { |
| 226 _appendCommentTokens( | 219 _appendCommentTokens( |
| 227 mirrorSystem.compiler.commentMap[metadata.beginToken]); | 220 mirrorSystem.compiler.commentMap[metadata.beginToken]); |
| 228 metadata.ensureResolved(mirrorSystem.compiler.resolution); | 221 metadata.ensureResolved(mirrorSystem.compiler.resolution); |
| 229 _metadata.add(_convertConstantToInstanceMirror( | 222 _metadata.add(_convertConstantToInstanceMirror( |
| 230 mirrorSystem, metadata.constant, | 223 mirrorSystem, |
| 231 mirrorSystem.compiler.constants.getConstantValue( | 224 metadata.constant, |
| 232 metadata.constant))); | 225 mirrorSystem.compiler.constants |
| 226 .getConstantValue(metadata.constant))); |
| 233 } | 227 } |
| 234 _appendCommentTokens(mirrorSystem.compiler.commentMap[getBeginToken()]); | 228 _appendCommentTokens(mirrorSystem.compiler.commentMap[getBeginToken()]); |
| 235 } | 229 } |
| 236 // TODO(johnniwinther): Return an unmodifiable list instead. | 230 // TODO(johnniwinther): Return an unmodifiable list instead. |
| 237 return new List<InstanceMirror>.from(_metadata); | 231 return new List<InstanceMirror>.from(_metadata); |
| 238 } | 232 } |
| 239 | 233 |
| 240 DeclarationMirror lookupInScope(String name) { | 234 DeclarationMirror lookupInScope(String name) { |
| 241 // TODO(11653): Support lookup of constructors. | 235 // TODO(11653): Support lookup of constructors. |
| 242 Scope scope = _element.buildScope(); | 236 Scope scope = _element.buildScope(); |
| 243 Element result; | 237 Element result; |
| 244 int index = name.indexOf('.'); | 238 int index = name.indexOf('.'); |
| 245 if (index != -1) { | 239 if (index != -1) { |
| 246 // Lookup [: prefix.id :]. | 240 // Lookup [: prefix.id :]. |
| 247 String prefix = name.substring(0, index); | 241 String prefix = name.substring(0, index); |
| 248 String id = name.substring(index+1); | 242 String id = name.substring(index + 1); |
| 249 result = scope.lookup(prefix); | 243 result = scope.lookup(prefix); |
| 250 if (result != null && result.isPrefix) { | 244 if (result != null && result.isPrefix) { |
| 251 PrefixElement prefix = result; | 245 PrefixElement prefix = result; |
| 252 result = prefix.lookupLocalMember(id); | 246 result = prefix.lookupLocalMember(id); |
| 253 } else { | 247 } else { |
| 254 result = null; | 248 result = null; |
| 255 } | 249 } |
| 256 } else { | 250 } else { |
| 257 // Lookup [: id :]. | 251 // Lookup [: id :]. |
| 258 result = scope.lookup(name); | 252 result = scope.lookup(name); |
| 259 } | 253 } |
| 260 if (result == null || result.isPrefix) return null; | 254 if (result == null || result.isPrefix) return null; |
| 261 return _convertElementToDeclarationMirror(mirrorSystem, result); | 255 return _convertElementToDeclarationMirror(mirrorSystem, result); |
| 262 } | 256 } |
| 263 | 257 |
| 264 bool operator ==(var other) { | 258 bool operator ==(var other) { |
| 265 if (identical(this, other)) return true; | 259 if (identical(this, other)) return true; |
| 266 if (other == null) return false; | 260 if (other == null) return false; |
| 267 if (other is! Dart2JsElementMirror) return false; | 261 if (other is! Dart2JsElementMirror) return false; |
| 268 return _element == other._element && | 262 return _element == other._element && owner == other.owner; |
| 269 owner == other.owner; | |
| 270 } | 263 } |
| 271 | 264 |
| 272 int get hashCode { | 265 int get hashCode { |
| 273 return 13 * _element.hashCode + 17 * owner.hashCode; | 266 return 13 * _element.hashCode + 17 * owner.hashCode; |
| 274 } | 267 } |
| 275 } | 268 } |
| 276 | 269 |
| 277 //------------------------------------------------------------------------------ | 270 //------------------------------------------------------------------------------ |
| 278 // Mirror system implementation. | 271 // Mirror system implementation. |
| 279 //------------------------------------------------------------------------------ | 272 //------------------------------------------------------------------------------ |
| (...skipping 27 matching lines...) Expand all Loading... |
| 307 Map<Uri, LibraryMirror> get libraries { | 300 Map<Uri, LibraryMirror> get libraries { |
| 308 _ensureLibraries(); | 301 _ensureLibraries(); |
| 309 return _filteredLibraries; | 302 return _filteredLibraries; |
| 310 } | 303 } |
| 311 | 304 |
| 312 Dart2JsLibraryMirror _getLibrary(LibraryElement element) => | 305 Dart2JsLibraryMirror _getLibrary(LibraryElement element) => |
| 313 _libraryMap[element]; | 306 _libraryMap[element]; |
| 314 | 307 |
| 315 Dart2JsMirrorSystem get mirrorSystem => this; | 308 Dart2JsMirrorSystem get mirrorSystem => this; |
| 316 | 309 |
| 317 TypeMirror get dynamicType => | 310 TypeMirror get dynamicType => _convertTypeToTypeMirror(const DynamicType()); |
| 318 _convertTypeToTypeMirror(const DynamicType()); | |
| 319 | 311 |
| 320 TypeMirror get voidType => | 312 TypeMirror get voidType => _convertTypeToTypeMirror(const VoidType()); |
| 321 _convertTypeToTypeMirror(const VoidType()); | |
| 322 | 313 |
| 323 TypeMirror _convertTypeToTypeMirror(DartType type) { | 314 TypeMirror _convertTypeToTypeMirror(DartType type) { |
| 324 assert(type != null); | 315 assert(type != null); |
| 325 if (type.treatAsDynamic) { | 316 if (type.treatAsDynamic) { |
| 326 return new Dart2JsDynamicMirror(this, type); | 317 return new Dart2JsDynamicMirror(this, type); |
| 327 } else if (type is InterfaceType) { | 318 } else if (type is InterfaceType) { |
| 328 if (type.typeArguments.isEmpty) { | 319 if (type.typeArguments.isEmpty) { |
| 329 return _getTypeDeclarationMirror(type.element); | 320 return _getTypeDeclarationMirror(type.element); |
| 330 } else { | 321 } else { |
| 331 return new Dart2JsInterfaceTypeMirror(this, type); | 322 return new Dart2JsInterfaceTypeMirror(this, type); |
| 332 } | 323 } |
| 333 } else if (type is TypeVariableType) { | 324 } else if (type is TypeVariableType) { |
| 334 return new Dart2JsTypeVariableMirror(this, type); | 325 return new Dart2JsTypeVariableMirror(this, type); |
| 335 } else if (type is FunctionType) { | 326 } else if (type is FunctionType) { |
| 336 return new Dart2JsFunctionTypeMirror(this, type); | 327 return new Dart2JsFunctionTypeMirror(this, type); |
| 337 } else if (type is VoidType) { | 328 } else if (type is VoidType) { |
| 338 return new Dart2JsVoidMirror(this, type); | 329 return new Dart2JsVoidMirror(this, type); |
| 339 } else if (type is TypedefType) { | 330 } else if (type is TypedefType) { |
| 340 if (type.typeArguments.isEmpty) { | 331 if (type.typeArguments.isEmpty) { |
| 341 return _getTypeDeclarationMirror(type.element); | 332 return _getTypeDeclarationMirror(type.element); |
| 342 } else { | 333 } else { |
| 343 return new Dart2JsTypedefMirror(this, type); | 334 return new Dart2JsTypedefMirror(this, type); |
| 344 } | 335 } |
| 345 } | 336 } |
| 346 compiler.reporter.internalError(type.element, | 337 compiler.reporter.internalError( |
| 347 "Unexpected type $type of kind ${type.kind}."); | 338 type.element, "Unexpected type $type of kind ${type.kind}."); |
| 348 return null; | 339 return null; |
| 349 } | 340 } |
| 350 | 341 |
| 351 DeclarationMirror _getTypeDeclarationMirror(TypeDeclarationElement element) { | 342 DeclarationMirror _getTypeDeclarationMirror(TypeDeclarationElement element) { |
| 352 if (element.isClass) { | 343 if (element.isClass) { |
| 353 return new Dart2JsClassDeclarationMirror(this, element.thisType); | 344 return new Dart2JsClassDeclarationMirror(this, element.thisType); |
| 354 } else if (element.isTypedef) { | 345 } else if (element.isTypedef) { |
| 355 return new Dart2JsTypedefDeclarationMirror(this, element.thisType); | 346 return new Dart2JsTypedefDeclarationMirror(this, element.thisType); |
| 356 } | 347 } |
| 357 compiler.reporter.internalError(element, "Unexpected element $element."); | 348 compiler.reporter.internalError(element, "Unexpected element $element."); |
| 358 return null; | 349 return null; |
| 359 } | 350 } |
| 360 } | 351 } |
| 361 | 352 |
| 362 abstract class ContainerMixin { | 353 abstract class ContainerMixin { |
| 363 UnmodifiableMapView<Symbol, DeclarationMirror> _declarations; | 354 UnmodifiableMapView<Symbol, DeclarationMirror> _declarations; |
| 364 | 355 |
| 365 void _ensureDeclarations() { | 356 void _ensureDeclarations() { |
| 366 if (_declarations == null) { | 357 if (_declarations == null) { |
| 367 var declarations = <Symbol, DeclarationMirror>{}; | 358 var declarations = <Symbol, DeclarationMirror>{}; |
| 368 _forEachElement((Element element) { | 359 _forEachElement((Element element) { |
| 369 for (DeclarationMirror mirror in _getDeclarationMirrors(element)) { | 360 for (DeclarationMirror mirror in _getDeclarationMirrors(element)) { |
| 370 assert(invariant(_element, | 361 assert( |
| 371 !declarations.containsKey(mirror.simpleName), | 362 invariant(_element, !declarations.containsKey(mirror.simpleName), |
| 372 message: "Declaration name '${nameOf(mirror)}' " | 363 message: "Declaration name '${nameOf(mirror)}' " |
| 373 "is not unique in $_element.")); | 364 "is not unique in $_element.")); |
| 374 declarations[mirror.simpleName] = mirror; | 365 declarations[mirror.simpleName] = mirror; |
| 375 } | 366 } |
| 376 }); | 367 }); |
| 377 _declarations = | 368 _declarations = |
| 378 new UnmodifiableMapView<Symbol, DeclarationMirror>(declarations); | 369 new UnmodifiableMapView<Symbol, DeclarationMirror>(declarations); |
| 379 } | 370 } |
| 380 } | 371 } |
| 381 | 372 |
| 382 Element get _element; | 373 Element get _element; |
| 383 | 374 |
| 384 void _forEachElement(f(Element element)); | 375 void _forEachElement(f(Element element)); |
| 385 | 376 |
| 386 Iterable<Dart2JsMemberMirror> _getDeclarationMirrors(Element element); | 377 Iterable<Dart2JsMemberMirror> _getDeclarationMirrors(Element element); |
| 387 | 378 |
| 388 Map<Symbol, DeclarationMirror> get declarations { | 379 Map<Symbol, DeclarationMirror> get declarations { |
| 389 _ensureDeclarations(); | 380 _ensureDeclarations(); |
| 390 return _declarations; | 381 return _declarations; |
| 391 } | 382 } |
| 392 } | 383 } |
| 393 | 384 |
| 394 /** | 385 /** |
| 395 * Converts [element] into its corresponding [DeclarationMirror], if any. | 386 * Converts [element] into its corresponding [DeclarationMirror], if any. |
| 396 * | 387 * |
| 397 * If [element] is an [AbstractFieldElement] the mirror for its getter is | 388 * If [element] is an [AbstractFieldElement] the mirror for its getter is |
| 398 * returned or, if not present, the mirror for its setter. | 389 * returned or, if not present, the mirror for its setter. |
| 399 */ | 390 */ |
| 400 DeclarationMirror _convertElementToDeclarationMirror(Dart2JsMirrorSystem system, | 391 DeclarationMirror _convertElementToDeclarationMirror( |
| 401 Element element) { | 392 Dart2JsMirrorSystem system, Element element) { |
| 402 if (element.isTypeVariable) { | 393 if (element.isTypeVariable) { |
| 403 TypeVariableElement typeVariable = element; | 394 TypeVariableElement typeVariable = element; |
| 404 return new Dart2JsTypeVariableMirror(system, typeVariable.type); | 395 return new Dart2JsTypeVariableMirror(system, typeVariable.type); |
| 405 } | 396 } |
| 406 | 397 |
| 407 Dart2JsLibraryMirror library = system._libraryMap[element.library]; | 398 Dart2JsLibraryMirror library = system._libraryMap[element.library]; |
| 408 if (element.isLibrary) return library; | 399 if (element.isLibrary) return library; |
| 409 if (element.isTypedef) { | 400 if (element.isTypedef) { |
| 410 TypedefElement typedefElement = element; | 401 TypedefElement typedefElement = element; |
| 411 return new Dart2JsTypedefMirror.fromLibrary( | 402 return new Dart2JsTypedefMirror.fromLibrary( |
| 412 library, typedefElement.thisType); | 403 library, typedefElement.thisType); |
| 413 } | 404 } |
| 414 | 405 |
| 415 Dart2JsDeclarationMirror container = library; | 406 Dart2JsDeclarationMirror container = library; |
| 416 if (element.enclosingClass != null) { | 407 if (element.enclosingClass != null) { |
| 417 container = system._getTypeDeclarationMirror(element.enclosingClass); | 408 container = system._getTypeDeclarationMirror(element.enclosingClass); |
| 418 } | 409 } |
| 419 if (element.isClass) return container; | 410 if (element.isClass) return container; |
| 420 if (element.isParameter) { | 411 if (element.isParameter) { |
| 421 Dart2JsMethodMirror method = _convertElementMethodToMethodMirror( | 412 Dart2JsMethodMirror method = _convertElementMethodToMethodMirror( |
| 422 container, element.outermostEnclosingMemberOrTopLevel); | 413 container, element.outermostEnclosingMemberOrTopLevel); |
| 423 // TODO(johnniwinther): Find the right info for [isOptional] and [isNamed]. | 414 // TODO(johnniwinther): Find the right info for [isOptional] and [isNamed]. |
| 424 return new Dart2JsParameterMirror( | 415 return new Dart2JsParameterMirror(method, element, |
| 425 method, element, isOptional: false, isNamed: false); | 416 isOptional: false, isNamed: false); |
| 426 } | 417 } |
| 427 Iterable<DeclarationMirror> members = | 418 Iterable<DeclarationMirror> members = |
| 428 container._getDeclarationMirrors(element); | 419 container._getDeclarationMirrors(element); |
| 429 if (members.isEmpty) return null; | 420 if (members.isEmpty) return null; |
| 430 return members.first; | 421 return members.first; |
| 431 } | 422 } |
| 432 | 423 |
| 433 /** | 424 /** |
| 434 * Experimental API for accessing compilation units defined in a | 425 * Experimental API for accessing compilation units defined in a |
| 435 * library. | 426 * library. |
| (...skipping 19 matching lines...) Expand all Loading... |
| 455 | 446 |
| 456 /** | 447 /** |
| 457 * Transitional class that allows access to features that have not yet | 448 * Transitional class that allows access to features that have not yet |
| 458 * made it to the mirror API. | 449 * made it to the mirror API. |
| 459 * | 450 * |
| 460 * All API in this class is experimental. | 451 * All API in this class is experimental. |
| 461 */ | 452 */ |
| 462 class BackDoor { | 453 class BackDoor { |
| 463 /// Return the compilation units comprising [library]. | 454 /// Return the compilation units comprising [library]. |
| 464 static List<Mirror> compilationUnitsOf(Dart2JsLibraryMirror library) { | 455 static List<Mirror> compilationUnitsOf(Dart2JsLibraryMirror library) { |
| 465 return library._element.compilationUnits.mapToList( | 456 return library._element.compilationUnits |
| 466 (cu) => new Dart2JsCompilationUnitMirror(cu, library)); | 457 .mapToList((cu) => new Dart2JsCompilationUnitMirror(cu, library)); |
| 467 } | 458 } |
| 468 | 459 |
| 469 static Iterable<ConstantExpression> metadataSyntaxOf( | 460 static Iterable<ConstantExpression> metadataSyntaxOf( |
| 470 Dart2JsElementMirror declaration) { | 461 Dart2JsElementMirror declaration) { |
| 471 return declaration._element.metadata.map((metadata) => metadata.constant); | 462 return declaration._element.metadata.map((metadata) => metadata.constant); |
| 472 } | 463 } |
| 473 | 464 |
| 474 static ConstantExpression initializerSyntaxOf(Dart2JsFieldMirror variable) { | 465 static ConstantExpression initializerSyntaxOf(Dart2JsFieldMirror variable) { |
| 475 Compiler compiler = variable.mirrorSystem.compiler; | 466 Compiler compiler = variable.mirrorSystem.compiler; |
| 476 return compiler.constants.getConstantForVariable(variable._variable); | 467 return compiler.constants.getConstantForVariable(variable._variable); |
| 477 } | 468 } |
| 478 | 469 |
| 479 static ConstantExpression defaultValueSyntaxOf( | 470 static ConstantExpression defaultValueSyntaxOf( |
| 480 Dart2JsParameterMirror parameter) { | 471 Dart2JsParameterMirror parameter) { |
| 481 if (!parameter.hasDefaultValue) return null; | 472 if (!parameter.hasDefaultValue) return null; |
| 482 ParameterElement parameterElement = parameter._element; | 473 ParameterElement parameterElement = parameter._element; |
| 483 Compiler compiler = parameter.mirrorSystem.compiler; | 474 Compiler compiler = parameter.mirrorSystem.compiler; |
| 484 return compiler.constants.getConstantForVariable(parameterElement); | 475 return compiler.constants.getConstantForVariable(parameterElement); |
| 485 } | 476 } |
| 486 | 477 |
| 487 static Mirror getMirrorFromElement(Dart2JsMirror mirror, Element element) { | 478 static Mirror getMirrorFromElement(Dart2JsMirror mirror, Element element) { |
| 488 return _convertElementToDeclarationMirror(mirror.mirrorSystem, element); | 479 return _convertElementToDeclarationMirror(mirror.mirrorSystem, element); |
| 489 } | 480 } |
| 490 } | 481 } |
| OLD | NEW |