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

Unified Diff: lib/compiler/implementation/compiler.dart

Issue 10702204: Revert "Allow patch files to add top-level declarations to the patched library." (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Created 8 years, 5 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 | « corelib/unified/math/random.dart ('k') | lib/compiler/implementation/elements/elements.dart » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: lib/compiler/implementation/compiler.dart
diff --git a/lib/compiler/implementation/compiler.dart b/lib/compiler/implementation/compiler.dart
index c6270196c73694e99e7d94e15336debfb9a84e8b..79e936668248c2a67fd6ecb0cc9d506efd0254fd 100644
--- a/lib/compiler/implementation/compiler.dart
+++ b/lib/compiler/implementation/compiler.dart
@@ -534,7 +534,7 @@ class Compiler implements DiagnosticListener {
Uri resolved = patchBase.resolve(argument.dartString.slowToString());
LibraryElement importedLibrary =
scanner.loadLibrary(resolved, argument);
- scanner.importLibrary(original, importedLibrary, tag, patch.script);
+ scanner.importLibrary(original, importedLibrary, tag, patch);
if (resolved.scheme == "dart") {
delayedPatches[resolved.path] = importedLibrary;
}
@@ -556,34 +556,43 @@ class Compiler implements DiagnosticListener {
while (!patches.isEmpty()) {
Element patchElement = patches.head;
Element originalElement = lookup(patchElement.name);
- assert(patchElement.kind !== ElementKind.ABSTRACT_FIELD);
- if (originalElement !== null &&
- originalElement.kind === ElementKind.ABSTRACT_FIELD) {
+ // Getters and setters are kept inside a synthetic field.
+ if (patchElement.kind === ElementKind.ABSTRACT_FIELD) {
+ if (originalElement !== null &&
+ originalElement.kind !== ElementKind.ABSTRACT_FIELD) {
+ internalError("Cannot patch non-getter/setter with getter/setter",
+ element: originalElement);
+ }
+ AbstractFieldElement patchField = patchElement;
AbstractFieldElement originalField = originalElement;
- if (patchElement.kind === ElementKind.GETTER) {
- originalElement = originalField.getter;
- } else if (patchElement.kind === ElementKind.SETTER) {
- originalElement = originalField.setter;
- } else {
- internalError("Cannot patch a getter/setter field with a "
- "non-getter/setter patch", element: originalElement);
+ if (patchField.getter !== null) {
+ if (originalField === null || originalField.getter === null) {
+ original.addGetterOrSetter(clonePatch(patchField.getter),
+ originalField,
+ this);
+ if (originalField === null && patchField.setter !== null) {
+ // It exists now, so find it for the setter patching.
+ originalField = lookup(patchElement.name);
+ }
+ } else {
+ patchMember(originalField.getter, patchField.getter);
+ }
}
- }
- if (originalElement === null) {
- // The original library does not have an element with the same name
- // as the patch library element.
- // In this case, the patch library element must not be marked as
- // "patch", and its name must make it private.
+ if (patchField.setter !== null) {
+ if (originalField === null || originalField.setter === null) {
+ original.addGetterOrSetter(clonePatch(patchField.setter),
+ originalField,
+ this);
+ } else {
+ patchMember(originalField.setter, patchField.setter);
+ }
+ }
+ } else if (originalElement === null) {
if (isPatchElement(patchElement)) {
internalError("Cannot patch non-existing member '"
"${patchElement.name.slowToString()}'.");
}
- if (!patchElement.name.isPrivate()) {
- internalError("Cannot add non-private member '"
- "${patchElement.name.slowToString()}' from patch.");
- }
- Element cloneElement = patchElement.cloneTo(original, this);
- original.addMember(cloneElement, this);
+ original.addMember(clonePatch(patchElement), this);
} else {
patchMember(originalElement, patchElement);
}
@@ -597,6 +606,20 @@ class Compiler implements DiagnosticListener {
return !element.metadata.isEmpty();
}
+ Element clonePatch(Element patchElement) {
+ // The original library does not have an element with the same name
+ // as the patch library element.
+ // In this case, the patch library element must not be marked as "patch",
+ // and its name must make it private.
+ if (!patchElement.name.isPrivate()) {
+ internalError("Cannot add non-private member '"
+ "${patchElement.name.slowToString()}' from patch.");
+ }
+ // TODO(lrn): Create a copy of patchElement that isn't added to any
+ // object/library yet, but which takes its source from patchElement.
+ throw "Adding members from patch is unsupported";
+ }
+
void patchMember(Element originalElement, Element patchElement) {
// The original library has an element with the same name as the patch
// library element.
@@ -955,7 +978,7 @@ class Compiler implements DiagnosticListener {
throw 'Cannot find tokens to produce error message.';
}
if (uri === null && currentElement !== null) {
- uri = currentElement.getScript().uri;
+ uri = currentElement.getCompilationUnit().script.uri;
}
return SourceSpan.withCharacterOffsets(begin, end,
(beginOffset, endOffset) => new SourceSpan(uri, beginOffset, endOffset));
@@ -979,7 +1002,7 @@ class Compiler implements DiagnosticListener {
element = currentElement;
}
Token position = element.position();
- Uri uri = element.getScript().uri;
+ Uri uri = element.getCompilationUnit().script.uri;
return (position === null)
? new SourceSpan(uri, 0, 0)
: spanFromTokens(position, position, uri);
« no previous file with comments | « corelib/unified/math/random.dart ('k') | lib/compiler/implementation/elements/elements.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698