couch/core/Node.h

145 lines
3.6 KiB
C
Raw Normal View History

2021-01-26 16:42:28 -06:00
/**
@file
@author Dane Johnson <dane@danejohnson.org>
@section LICENSE
Couch Copyright (C) 2021 Dane Johnson
2021-01-26 22:04:57 -06:00
2021-01-26 16:42:28 -06:00
This program comes with ABSOLUTELY NO WARRANTY; without event the
implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
2021-01-26 22:04:57 -06:00
See the GNU General Public License for details at
2021-01-26 16:42:28 -06:00
https://www.gnu.org/licenses/gpl-3.0.html
This is free software, and you are welcome to redistribute it
under the terms of the GNU General Public License as published
by the Free Software Foundation; either version 3 of the License,
or (at your option) any later version.
@section DESCRIPTION
Node is the parent class for all classes that would be in the scene
tree. The root of the scene tree is always a node.
*/
2021-01-14 11:52:01 -06:00
#ifndef NODE_H
#define NODE_H
#include <list>
2021-01-14 11:52:01 -06:00
2021-01-21 15:26:39 -06:00
#include "types.h"
2021-01-14 11:52:01 -06:00
class Node; // Forwards declare
2021-01-26 16:42:28 -06:00
/**
A list of nodes, tagged as either a list of prefabs
or a list of instanced nodes.
*/
class NodeList : public std::list<Node*> {
2021-01-14 11:52:01 -06:00
public:
NodeList();
NodeList(bool isPrefabList);
2021-01-26 16:42:28 -06:00
/**
Add a node to this list, will check if it is a prefab
or an instance.
@param node The node to add
*/
2021-01-14 11:52:01 -06:00
void Append(Node *node);
/**
Remove a node from this list
@param node The node to remove
*/
void Remove(Node *node);
2021-01-26 16:42:28 -06:00
/**
Whether or not this is a list of prefabs
@returns true if this is a prefab list,
false if it is an instanced list.
*/
bool IsPrefabList();
/**
Recursively frees all nodes in the list
*/
void FreeList();
2021-01-24 16:37:35 -06:00
private:
bool isPrefabList;
2021-01-24 16:37:35 -06:00
friend class Node;
2021-01-14 11:52:01 -06:00
};
2021-01-26 16:42:28 -06:00
/**
The parent class for any object that will go into the scene tree
*/
2021-01-14 11:52:01 -06:00
class Node {
public:
2021-01-21 15:26:39 -06:00
virtual Name GetType() const;
2021-01-26 16:42:28 -06:00
/**
Whether or not this object is a prefab, that is, if it is
an object being set up to be instanced one or more times.
The alternative to being a prefab is being instanced, in which
case it will be drawn, added to the physics system, etc.
@return true if the object is a prefab, false if it is instanced.
*/
bool IsPrefab();
/**
Returns the children of this node
@return The list of children
*/
NodeList GetChildren();
/**
Adds a node to this nodes list of children
@param child The node to add
*/
void AddChild(Node *child);
/**
@return This node's parent;
*/
Node *GetParent();
/**
Remove this node and it's children from the tree
and queue their memory for freeing
*/
void QueueFree();
/**
Actually frees the memory
Should only be called from root
*/
void DoFree();
2021-01-26 16:42:28 -06:00
/**
Gets the root of the game scene tree
@return The root node
*/
static Node *GetRoot();
/**
Allocates a new "default" version of this node.
@return A reference to the node.
*/
2021-01-24 16:37:35 -06:00
virtual Node* Create();
2021-01-26 16:42:28 -06:00
/**
Copies the properties of this node to a newly allocated node,
created via @ref Create. Subclasses should override this to copy
additional class attributes
@return A reference to the duplicate
*/
2021-01-24 16:37:35 -06:00
virtual Node* Duplicate();
2021-01-26 16:42:28 -06:00
/**
Creates an instanced version of this node, by calling @ref Duplicate.
Subclasses should override this to perform neccesary tasks for
instantiation, i.e. adding a physic object to the physics world.
Any children of this node will also be instanced.
@return an instanced version of this node.
*/
virtual Node* Instance();
2021-01-14 11:52:01 -06:00
private:
2021-01-26 16:42:28 -06:00
NodeList children;
static NodeList *freeList;
2021-01-14 11:52:01 -06:00
static Node *root;
Node *parent;
2021-01-24 16:37:35 -06:00
bool isPrefab = true;
friend class NodeList;
2021-01-14 11:52:01 -06:00
};
#endif /* NODE_H */