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

Side by Side Diff: pkg/compiler/lib/src/resolution/secret_tree_element.dart

Issue 2722923002: Move TreeElementMixin to avoid out-of-library private overrides (Closed)
Patch Set: Created 3 years, 9 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 unified diff | Download patch
« no previous file with comments | « no previous file | pkg/compiler/lib/src/tree/nodes.dart » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
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 /**
6 * Encapsulates the field [TreeElementMixin._element].
7 *
8 * This library is an implementation detail of dart2js, and should not
9 * be imported except by resolution and tree node libraries, or for
10 * testing.
11 *
12 * We have taken great care to ensure AST nodes can be cached between
13 * compiler instances. Part of this requires that we always access
14 * resolution results through TreeElements.
15 *
16 * So please, do not add additional elements to this library, and do
17 * not import it.
18 */
19 library dart2js.resolution.secret_tree_element; 5 library dart2js.resolution.secret_tree_element;
20 6
21 import '../common.dart'; 7 // The code in this library was moved to ../tree/nodes.dart to satisfy extra
8 // restrictions on overriding private members.
9 //
10 // [See issue for more details](https://github.com/dart-lang/sdk/issues/28809).
22 11
23 /// Interface for associating 12 export '../tree/nodes.dart' show getTreeElement, setTreeElement;
24 abstract class TreeElementMixin {
25 Object get _element;
26 void set _element(Object value);
27 }
28
29 /// Null implementation of [TreeElementMixin] which does not allow association
30 /// of elements.
31 ///
32 /// This class is the superclass of all AST nodes.
33 abstract class NullTreeElementMixin implements TreeElementMixin, Spannable {
34 // Deliberately using [Object] here to thwart code completion.
35 // You're not really supposed to access this field anyways.
36 Object get _element => null;
37 set _element(_) {
38 assert(invariant(this, false,
39 message: "Elements cannot be associated with ${runtimeType}."));
40 }
41 }
42
43 /// Actual implementation of [TreeElementMixin] which stores the associated
44 /// element in the private field [_element].
45 ///
46 /// This class is mixed into the node classes that are actually associated with
47 /// elements.
48 abstract class StoredTreeElementMixin implements TreeElementMixin {
49 Object _element;
50 }
51
52 /**
53 * Do not call this method directly. Instead, use an instance of
54 * TreeElements.
55 *
56 * Using [Object] as return type to thwart code completion.
57 */
58 Object getTreeElement(TreeElementMixin node) => node._element;
59
60 /**
61 * Do not call this method directly. Instead, use an instance of
62 * TreeElements.
63 */
64 void setTreeElement(TreeElementMixin node, Object value) {
65 node._element = value;
66 }
OLDNEW
« no previous file with comments | « no previous file | pkg/compiler/lib/src/tree/nodes.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698