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

Unified Diff: third_party/pkg/di/lib/static_injector.dart

Issue 257423008: Update all Angular libs (run update_all.sh). (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Created 6 years, 8 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « third_party/pkg/di/lib/src/provider.dart ('k') | third_party/pkg/di/lib/transformer.dart » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: third_party/pkg/di/lib/static_injector.dart
diff --git a/third_party/pkg/di/lib/static_injector.dart b/third_party/pkg/di/lib/static_injector.dart
index f7bf51f7e1c05a1672ac75e64f7de28cd7345844..747bcd45bea6eaae15bb99b21049eba01eb76471 100644
--- a/third_party/pkg/di/lib/static_injector.dart
+++ b/third_party/pkg/di/lib/static_injector.dart
@@ -1,11 +1,17 @@
library di.static_injector;
import 'di.dart';
+import 'src/error_helper.dart';
+import 'src/base_injector.dart';
+import 'src/provider.dart';
+
+export 'annotations.dart';
+export 'di.dart';
/**
* Static implementation of [Injector] that uses type factories
*/
-class StaticInjector extends Injector {
+class StaticInjector extends BaseInjector {
Map<Type, TypeFactory> typeFactories;
StaticInjector({List<Module> modules, String name,
@@ -20,24 +26,26 @@ class StaticInjector extends Injector {
this.typeFactories = _extractTypeFactories(modules);
}
- newFromParent(List<Module> modules, String name) {
- return new StaticInjector._fromParent(modules, this, name: name);
- }
+ newFromParent(List<Module> modules, String name) =>
+ new StaticInjector._fromParent(modules, this, name: name);
- Object newInstanceOf(Type type, ObjectFactory getInstanceByType,
- Injector requestor, error) {
+ Object newInstanceOf(Type type, ObjectFactory objFactory,
+ Injector requestor, resolving) {
TypeFactory typeFactory = _getFactory(type);
if (typeFactory == null) {
- throw new NoProviderError(error('No type factory provided for $type!'));
+ throw new NoProviderError(
+ error(resolving, 'No type factory provided for $type!'));
}
- return typeFactory((type) => getInstanceByType(type, requestor));
+ return typeFactory((type, [annotation]) =>
+ objFactory.getInstanceByKey(
+ new Key(type, annotation), requestor, resolving));
}
- TypeFactory _getFactory(Type type) {
+ TypeFactory _getFactory(Type key) {
var cursor = this;
while (cursor != null) {
- if (cursor.typeFactories.containsKey(type)) {
- return cursor.typeFactories[type];
+ if (cursor.typeFactories.containsKey(key)) {
+ return cursor.typeFactories[key];
}
cursor = cursor.parent;
}
@@ -48,11 +56,9 @@ class StaticInjector extends Injector {
Map<Type, TypeFactory> _extractTypeFactories(List<Module> modules,
[Map<Type, TypeFactory> initial = const {}]) {
if (modules == null || modules.isEmpty) return initial;
- var tmp = new Map.from(initial == null ? {} : initial);
- modules.forEach((module) {
- module.typeFactories.forEach((type, factory) {
- tmp[type] = factory;
- });
+ var factories = new Map.from(initial == null ? {} : initial);
+ modules.forEach((m) {
+ factories.addAll(m.typeFactories);
});
- return tmp;
+ return factories;
}
« no previous file with comments | « third_party/pkg/di/lib/src/provider.dart ('k') | third_party/pkg/di/lib/transformer.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698