dart-sdk/runtime/lib/mirrors_patch.dart
Peter von der Ahé 0023f99019 Changes to runtime patches so Fasta can understand them.
Change-Id: I7f8d6b110f2f0c90b131a2538240c1b81bfa1578
Reviewed-on: https://dart-review.googlesource.com/17162
Commit-Queue: Peter von der Ahé <ahe@google.com>
Reviewed-by: Vyacheslav Egorov <vegorov@google.com>
2017-11-01 15:16:04 +00:00

93 lines
2.7 KiB
Dart

// 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";
}