| // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file |
| // for details. All rights reserved. Use of this source code is governed by a |
| // BSD-style license that can be found in the LICENSE file. |
| |
| /// Note: the VM concatenates all patch files into a single patch file. This |
| /// file is the first patch in "dart:_internal" which contains all the imports |
| /// used by patches of that library. We plan to change this when we have a |
| /// shared front end and simply use parts. |
| |
| import "dart:_internal" as internal; |
| |
| import "dart:_internal" show patch; |
| |
| import "dart:async" show Future; |
| |
| import "dart:collection" show UnmodifiableListView, UnmodifiableMapView; |
| |
| /// These are the additional parts of this patch library: |
| // part "mirrors_impl.dart"; |
| // part "mirror_reference.dart"; |
| |
| /** |
| * Returns a [MirrorSystem] for the current isolate. |
| */ |
| @patch |
| MirrorSystem currentMirrorSystem() { |
| return _Mirrors.currentMirrorSystem(); |
| } |
| |
| /** |
| * Returns an [InstanceMirror] for some Dart language object. |
| * |
| * This only works if this mirror system is associated with the |
| * current running isolate. |
| */ |
| @patch |
| InstanceMirror reflect(Object reflectee) { |
| return _Mirrors.reflect(reflectee); |
| } |
| |
| /** |
| * Returns a [ClassMirror] for the class represented by a Dart |
| * Type object. |
| * |
| * This only works with objects local to the current isolate. |
| */ |
| @patch |
| ClassMirror reflectClass(Type key) { |
| return _Mirrors.reflectClass(key); |
| } |
| |
| @patch |
| TypeMirror reflectType(Type key, [List<Type> typeArguments]) { |
| return _Mirrors.reflectType(key, typeArguments); |
| } |
| |
| @patch |
| class MirrorSystem { |
| @patch |
| LibraryMirror findLibrary(Symbol libraryName) { |
| var candidates = |
| libraries.values.where((lib) => lib.simpleName == libraryName); |
| if (candidates.length == 1) { |
| return candidates.single; |
| } |
| if (candidates.length > 1) { |
| var uris = candidates.map((lib) => lib.uri.toString()).toList(); |
| throw new Exception("There are multiple libraries named " |
| "'${getName(libraryName)}': $uris"); |
| } |
| throw new Exception("There is no library named '${getName(libraryName)}'"); |
| } |
| |
| @patch |
| static String getName(Symbol symbol) { |
| return internal.Symbol.computeUnmangledName(symbol); |
| } |
| |
| @patch |
| static Symbol getSymbol(String name, [LibraryMirror library]) { |
| if ((library != null && library is! _LocalLibraryMirror) || |
| ((name.length > 0) && (name[0] == '_') && (library == null))) { |
| throw new ArgumentError(library); |
| } |
| if (library != null) { |
| name = _mangleName(name, (library as _LocalLibraryMirror)._reflectee); |
| } |
| return new internal.Symbol.unvalidated(name); |
| } |
| |
| static _mangleName(String name, _MirrorReference lib) |
| native "Mirrors_mangleName"; |
| } |