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

Unified Diff: sky/framework/node.dart

Issue 1132063007: Rationalize Dart mojo and sky package structure (Closed) Base URL: https://github.com/domokit/mojo.git@master
Patch Set: Created 5 years, 7 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 | « sky/framework/net/fetch.dart ('k') | sky/framework/reflect.dart » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: sky/framework/node.dart
diff --git a/sky/framework/node.dart b/sky/framework/node.dart
deleted file mode 100644
index ec9a1f94fa9f38d0e8297ea64b30018bc3dcc534..0000000000000000000000000000000000000000
--- a/sky/framework/node.dart
+++ /dev/null
@@ -1,60 +0,0 @@
-library node;
-
-class Node {
-
- // Nodes always have a 'depth' greater than their ancestors'.
- // There's no guarantee regarding depth between siblings. The depth
- // of a node is used to ensure that nodes are processed in depth
- // order. The 'depth' of a child can be more than one greater than
- // the 'depth' of the parent, because the 'depth' values are never
- // decreased: all that matters is that it's greater than the parent.
- // Consider a tree with a root node A, a child B, and a grandchild
- // C. Initially, A will have 'depth' 0, B 'depth' 1, and C 'depth'
- // 2. If C is moved to be a child of A, sibling of B, then the
- // numbers won't change. C's 'depth' will still be 2.
-
- int _depth = 0;
- int get depth => _depth;
- void redepthChild(Node child) { // internal, do not call
- assert(child._attached == _attached);
- if (child._depth <= _depth) {
- child._depth = _depth + 1;
- child.redepthChildren();
- }
- }
- void redepthChildren() { // internal, do not call
- // override this in subclasses with child nodes
- // simply call redepthChild(child) for each child
- }
-
- bool _attached = false;
- bool get attached => _attached;
- void attach() {
- // override this in subclasses with child nodes
- // simply call attach() for each child then call your superclass
- _attached = true;
- attachChildren();
- }
- attachChildren() { } // workaround for lack of inter-class mixins in Dart
- void detach() {
- // override this in subclasses with child nodes
- // simply call detach() for each child then call your superclass
- _attached = false;
- detachChildren();
- }
- detachChildren() { } // workaround for lack of inter-class mixins in Dart
-
- void setAsChild(Node child) { // only for use by subclasses
- assert(child != null);
- if (attached)
- child.attach();
- redepthChild(child);
- }
- void dropChild(Node child) { // only for use by subclasses
- assert(child != null);
- assert(child.attached == attached);
- if (attached)
- child.detach();
- }
-
-}
« no previous file with comments | « sky/framework/net/fetch.dart ('k') | sky/framework/reflect.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698