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

Side by Side Diff: dart/pkg/serialization/lib/src/serialization_rule.dart

Issue 23455028: Mirrors overhaul. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge
Patch Set: Merged with r29550. Created 7 years, 1 month 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) 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 part of serialization; 5 part of serialization;
6 6
7 // TODO(alanknight): We should have an example and tests for subclassing 7 // TODO(alanknight): We should have an example and tests for subclassing
8 // serialization rule rather than using the hard-coded ClosureToMap rule. And 8 // serialization rule rather than using the hard-coded ClosureToMap rule. And
9 // possibly an abstract superclass that's designed to be subclassed that way. 9 // possibly an abstract superclass that's designed to be subclassed that way.
10 /** 10 /**
(...skipping 396 matching lines...) Expand 10 before | Expand all | Expand 10 after
407 // That can't be constructed as a Symbol, so we can't use findLibrary. 407 // That can't be constructed as a Symbol, so we can't use findLibrary.
408 // So follow one or the other path depending if it has a colon, which we 408 // So follow one or the other path depending if it has a colon, which we
409 // assume is in any URI and can't be in a Symbol. 409 // assume is in any URI and can't be in a Symbol.
410 if (name.contains(":")) { 410 if (name.contains(":")) {
411 var uri = Uri.parse(name); 411 var uri = Uri.parse(name);
412 var libMirror = currentMirrorSystem().libraries[uri]; 412 var libMirror = currentMirrorSystem().libraries[uri];
413 return libMirror.classes[new Symbol(type)]; 413 return libMirror.classes[new Symbol(type)];
414 } else { 414 } else {
415 var symbol = new Symbol(name); 415 var symbol = new Symbol(name);
416 var typeSymbol = new Symbol(type); 416 var typeSymbol = new Symbol(type);
417 var libMirror = currentMirrorSystem().findLibrary(symbol).firstWhere( 417 var libMirror = currentMirrorSystem().libraries.values.firstWhere(
418 (lib) => lib.classes[typeSymbol] != null); 418 (lib) => lib.simpleName == symbol && lib.classes[typeSymbol] != null);
419 return libMirror.classes[typeSymbol]; 419 return libMirror.classes[typeSymbol];
420 } 420 }
421 } 421 }
422 } 422 }
423 423
424 /** 424 /**
425 * This provides an abstract superclass for writing your own rules specific to 425 * This provides an abstract superclass for writing your own rules specific to
426 * a class. It makes some assumptions about behaviour, and so can have a 426 * a class. It makes some assumptions about behaviour, and so can have a
427 * simpler set of methods that need to be implemented in order to subclass it. 427 * simpler set of methods that need to be implemented in order to subclass it.
428 * 428 *
(...skipping 139 matching lines...) Expand 10 before | Expand all | Expand 10 after
568 int get length => _raw.length; 568 int get length => _raw.length;
569 569
570 void set length(int value) => _throw(); 570 void set length(int value) => _throw();
571 571
572 void operator []=(int index, value) => _throw(); 572 void operator []=(int index, value) => _throw();
573 573
574 void _throw() { 574 void _throw() {
575 throw new UnsupportedError("Not modifiable"); 575 throw new UnsupportedError("Not modifiable");
576 } 576 }
577 } 577 }
OLDNEW
« no previous file with comments | « dart/pkg/serialization/lib/src/mirrors_helpers.dart ('k') | dart/pkg/serialization/test/serialization_test.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698