summaryrefslogtreecommitdiff
path: root/fluid/nodes/Tree.h
diff options
context:
space:
mode:
Diffstat (limited to 'fluid/nodes/Tree.h')
-rw-r--r--fluid/nodes/Tree.h106
1 files changed, 106 insertions, 0 deletions
diff --git a/fluid/nodes/Tree.h b/fluid/nodes/Tree.h
new file mode 100644
index 000000000..f494af651
--- /dev/null
+++ b/fluid/nodes/Tree.h
@@ -0,0 +1,106 @@
+//
+// Node Tree header file for the Fast Light Tool Kit (FLTK).
+//
+// Copyright 1998-2025 by Bill Spitzak and others.
+//
+// This library is free software. Distribution and use rights are outlined in
+// the file "COPYING" which should have been included with this file. If this
+// file is missing or damaged, see the license at:
+//
+// https://www.fltk.org/COPYING.php
+//
+// Please see the following page on how to report bugs and issues:
+//
+// https://www.fltk.org/bugs.php
+//
+
+#ifndef FLUID_NODES_TREE_H
+#define FLUID_NODES_TREE_H
+
+#include "nodes/Widget_Node.h"
+
+class Node;
+
+namespace fld {
+
+class Project;
+
+namespace node {
+
+class Tree {
+
+ // A class that can iterate over the entire scene graph.
+ class Iterator {
+ Node *type_ = nullptr;
+ bool only_selected_ = false;
+ public:
+ explicit Iterator(Node *t, bool only_selected);
+ Node* operator*() { return type_; }
+ Iterator& operator++();
+ bool operator!=(const Iterator& other) const { return type_ != other.type_; }
+ };
+
+ // A container for a node iterator
+ class Container {
+ Tree &tree_;
+ bool only_selected_ = false;
+ public:
+ Container(Tree &tree, bool only_selected) : tree_(tree), only_selected_(only_selected) { }
+ Iterator begin() { return Iterator(tree_.first, only_selected_); }
+ Iterator end() { return Iterator(nullptr, only_selected_); }
+ };
+
+ // A class that iterate over the scene graph, but returns only nodes of type widget.
+ class WIterator {
+ Node *type_ = nullptr;
+ bool only_selected_ = false;
+ public:
+ explicit WIterator(Node *t, bool only_selected);
+ Widget_Node* operator*() { return static_cast<Widget_Node*>(type_); }
+ WIterator& operator++();
+ bool operator!=(const WIterator& other) const { return type_ != other.type_; }
+ };
+
+ // A container for a widget node iterator
+ class WContainer {
+ Tree &tree_;
+ bool only_selected_ = false;
+ public:
+ WContainer(Tree &tree, bool only_selected) : tree_(tree), only_selected_(only_selected) { }
+ WIterator begin() { return WIterator(tree_.first, only_selected_); }
+ WIterator end() { return WIterator(nullptr, only_selected_); }
+ };
+
+ /// Link Tree class to the project.
+ Project &proj_;
+
+public:
+
+ Node *first = nullptr;
+ Node *last = nullptr;
+ Node *current = nullptr; // most recently picked object
+ Node *current_dnd = nullptr;
+ /// If this is greater zero, widgets will be allowed to lay out their children.
+ int allow_layout = 0;
+
+public:
+
+ Tree(Project &proj);
+
+ bool empty() { return first == nullptr; }
+
+ // Iterators: `for (auto &n: tree.all_nodes()) { n.print(); }
+ Container all_nodes() { return Container(*this, false); }
+ WContainer all_widgets() { return WContainer(*this, false); }
+ Container all_selected_nodes() { return Container(*this, true); }
+ WContainer all_selected_widgets() { return WContainer(*this, true); }
+
+ Node *find_by_uid(unsigned short uid);
+ Node *find_in_text(int text_type, int crsr);
+};
+
+} // namespace node
+} // namespace fld
+
+
+#endif // FLUID_NODES_TREE_H