aboutsummaryrefslogtreecommitdiffhomepage
path: root/experimental/sksg/SkSGNode.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'experimental/sksg/SkSGNode.cpp')
-rw-r--r--experimental/sksg/SkSGNode.cpp64
1 files changed, 33 insertions, 31 deletions
diff --git a/experimental/sksg/SkSGNode.cpp b/experimental/sksg/SkSGNode.cpp
index 74867ef819..35b2640dbb 100644
--- a/experimental/sksg/SkSGNode.cpp
+++ b/experimental/sksg/SkSGNode.cpp
@@ -39,64 +39,66 @@ private:
return
Node::Node(uint32_t invalTraits)
- : fInvalReceiver(nullptr)
+ : fInvalObserver(nullptr)
, fBounds(SkRectPriv::MakeLargeS32())
, fInvalTraits(invalTraits)
, fFlags(kInvalidated_Flag) {}
Node::~Node() {
- if (fFlags & kReceiverArray_Flag) {
- SkASSERT(fInvalReceiverArray->isEmpty());
- delete fInvalReceiverArray;
+ if (fFlags & kObserverArray_Flag) {
+ SkASSERT(fInvalObserverArray->isEmpty());
+ delete fInvalObserverArray;
} else {
- SkASSERT(!fInvalReceiver);
+ SkASSERT(!fInvalObserver);
}
}
-void Node::addInvalReceiver(Node* receiver) {
- if (!(fFlags & kReceiverArray_Flag)) {
- if (!fInvalReceiver) {
- fInvalReceiver = receiver;
+void Node::observeInval(const sk_sp<Node>& node) {
+ SkASSERT(node);
+ if (!(node->fFlags & kObserverArray_Flag)) {
+ if (!node->fInvalObserver) {
+ node->fInvalObserver = this;
return;
}
- auto receivers = new SkTDArray<Node*>();
- receivers->setReserve(2);
- receivers->push(fInvalReceiver);
+ auto observers = new SkTDArray<Node*>();
+ observers->setReserve(2);
+ observers->push(node->fInvalObserver);
- fInvalReceiverArray = receivers;
- fFlags |= kReceiverArray_Flag;
+ node->fInvalObserverArray = observers;
+ node->fFlags |= kObserverArray_Flag;
}
- // No duplicate receivers.
- SkASSERT(fInvalReceiverArray->find(receiver) < 0);
+ // No duplicate observers.
+ SkASSERT(node->fInvalObserverArray->find(this) < 0);
- fInvalReceiverArray->push(receiver);
+ node->fInvalObserverArray->push(this);
}
-void Node::removeInvalReceiver(Node* receiver) {
- if (!(fFlags & kReceiverArray_Flag)) {
- SkASSERT(fInvalReceiver == receiver);
- fInvalReceiver = nullptr;
+void Node::unobserveInval(const sk_sp<Node>& node) {
+ SkASSERT(node);
+ if (!(node->fFlags & kObserverArray_Flag)) {
+ SkASSERT(node->fInvalObserver == this);
+ node->fInvalObserver = nullptr;
return;
}
- const auto idx = fInvalReceiverArray->find(receiver);
+ const auto idx = node->fInvalObserverArray->find(this);
SkASSERT(idx >= 0);
- fInvalReceiverArray->remove(idx);
+ node->fInvalObserverArray->remove(idx);
}
template <typename Func>
-void Node::forEachInvalReceiver(Func&& func) const {
- if (fFlags & kReceiverArray_Flag) {
- for (const auto& parent : *fInvalReceiverArray) {
+void Node::forEachInvalObserver(Func&& func) const {
+ if (fFlags & kObserverArray_Flag) {
+ for (const auto& parent : *fInvalObserverArray) {
func(parent);
}
return;
}
- if (fInvalReceiver) {
- func(fInvalReceiver);
+ if (fInvalObserver) {
+ func(fInvalObserver);
}
}
@@ -109,15 +111,15 @@ void Node::invalidate(bool damageBubbling) {
}
if (damageBubbling && !(fInvalTraits & kBubbleDamage_Trait)) {
- // Found a damage receiver.
+ // Found a damage observer.
fFlags |= kDamage_Flag;
damageBubbling = false;
}
fFlags |= kInvalidated_Flag;
- forEachInvalReceiver([&](Node* receiver) {
- receiver->invalidate(damageBubbling);
+ forEachInvalObserver([&](Node* observer) {
+ observer->invalidate(damageBubbling);
});
}