diff options
Diffstat (limited to 'engines/titanic/core')
-rw-r--r-- | engines/titanic/core/project_item.cpp | 14 | ||||
-rw-r--r-- | engines/titanic/core/project_item.h | 14 | ||||
-rw-r--r-- | engines/titanic/core/tree_item.cpp | 21 | ||||
-rw-r--r-- | engines/titanic/core/tree_item.h | 17 |
4 files changed, 24 insertions, 42 deletions
diff --git a/engines/titanic/core/project_item.cpp b/engines/titanic/core/project_item.cpp index e1f5ec4b34..488cdba6c9 100644 --- a/engines/titanic/core/project_item.cpp +++ b/engines/titanic/core/project_item.cpp @@ -124,7 +124,7 @@ void CProjectItem::load(SimpleFile *file) { CTreeItem::load(file); } -CGameManager *CProjectItem::getGameManager() { +CGameManager *CProjectItem::getGameManager() const { return _gameManager; } @@ -276,7 +276,7 @@ void CProjectItem::gameLoaded() { petControl->gameLoaded(); } -CPetControl *CProjectItem::getPetControl() { +CPetControl *CProjectItem::getPetControl() const { CDontSaveFileItem *fileItem = getDontSaveFileItem(); CTreeItem *treeItem; @@ -294,11 +294,11 @@ CPetControl *CProjectItem::getPetControl() { return nullptr; } -CRoomItem *CProjectItem::findFirstRoom() { +CRoomItem *CProjectItem::findFirstRoom() const { return dynamic_cast<CRoomItem *>(findChildInstance(*CRoomItem::_type)); } -CTreeItem *CProjectItem::findChildInstance(ClassDef &classDef) { +CTreeItem *CProjectItem::findChildInstance(ClassDef &classDef) const { CTreeItem *treeItem = getFirstChild(); if (treeItem == nullptr) return nullptr; @@ -316,11 +316,11 @@ CTreeItem *CProjectItem::findChildInstance(ClassDef &classDef) { return nullptr; } -CRoomItem *CProjectItem::findNextRoom(CRoomItem *priorRoom) { +CRoomItem *CProjectItem::findNextRoom(CRoomItem *priorRoom) const { return dynamic_cast<CRoomItem *>(findSiblingInstanceOf(*CRoomItem::_type, priorRoom)); } -CTreeItem *CProjectItem::findSiblingInstanceOf(ClassDef &classDef, CTreeItem *startItem) { +CTreeItem *CProjectItem::findSiblingInstanceOf(ClassDef &classDef, CTreeItem *startItem) const { CTreeItem *treeItem = startItem->getParent()->getNextSibling(); if (treeItem == nullptr) return nullptr; @@ -328,7 +328,7 @@ CTreeItem *CProjectItem::findSiblingInstanceOf(ClassDef &classDef, CTreeItem *st return findChildInstance(classDef); } -CDontSaveFileItem *CProjectItem::getDontSaveFileItem() { +CDontSaveFileItem *CProjectItem::getDontSaveFileItem() const { for (CTreeItem *treeItem = getFirstChild(); treeItem; treeItem = treeItem->getNextSibling()) { if (treeItem->isInstanceOf(*CDontSaveFileItem::_type)) return dynamic_cast<CDontSaveFileItem *>(treeItem); diff --git a/engines/titanic/core/project_item.h b/engines/titanic/core/project_item.h index 07a585237b..2ec3a73647 100644 --- a/engines/titanic/core/project_item.h +++ b/engines/titanic/core/project_item.h @@ -81,12 +81,12 @@ private: /** * Finds the first child instance of a given class type */ - CTreeItem *findChildInstance(ClassDef &classDef); + CTreeItem *findChildInstance(ClassDef &classDef) const; /** * Finds the next sibling occurance of a given class type */ - CTreeItem *findSiblingInstanceOf(ClassDef &classDef, CTreeItem *startItem); + CTreeItem *findSiblingInstanceOf(ClassDef &classDef, CTreeItem *startItem) const; private: /** * Load project data from the passed file @@ -119,12 +119,12 @@ public: /** * Get the game manager for the project */ - virtual CGameManager *getGameManager(); + virtual CGameManager *getGameManager() const; /** * Get a reference to the PET control */ - CPetControl *getPetControl(); + CPetControl *getPetControl() const; /** * Resets the game manager field @@ -154,17 +154,17 @@ public: /** * Returns a reference to the first room item in the project */ - CRoomItem *findFirstRoom(); + CRoomItem *findFirstRoom() const; /** * Returns a reference to the next room following the specified room */ - CRoomItem *findNextRoom(CRoomItem *priorRoom); + CRoomItem *findNextRoom(CRoomItem *priorRoom) const; /** * Returns the don't save file item, if it exists in the project */ - CDontSaveFileItem *getDontSaveFileItem(); + CDontSaveFileItem *getDontSaveFileItem() const; CRoomItem *findHiddenRoom() const; diff --git a/engines/titanic/core/tree_item.cpp b/engines/titanic/core/tree_item.cpp index ee89a0532e..22c4e1ddac 100644 --- a/engines/titanic/core/tree_item.cpp +++ b/engines/titanic/core/tree_item.cpp @@ -40,7 +40,7 @@ void CTreeItem::load(SimpleFile *file) { CMessageTarget::load(file); } -CGameManager *CTreeItem::getGameManager() { +CGameManager *CTreeItem::getGameManager() const { return _parent ? _parent->getGameManager() : nullptr; } @@ -64,17 +64,17 @@ CTreeItem *CTreeItem::getLastSibling() { return item; } -CTreeItem *CTreeItem::getLastChild() { +CTreeItem *CTreeItem::getLastChild() const { if (!_firstChild) return nullptr; return _firstChild->getLastSibling(); } -CTreeItem *CTreeItem::scan(CTreeItem *item) { +CTreeItem *CTreeItem::scan(CTreeItem *item) const { if (_firstChild) return _firstChild; - CTreeItem *treeItem = this; + const CTreeItem *treeItem = this; while (treeItem != item) { if (treeItem->_nextSibling) return treeItem->_nextSibling; @@ -87,19 +87,6 @@ CTreeItem *CTreeItem::scan(CTreeItem *item) { return nullptr; } -CDontSaveFileItem *CTreeItem::getDontSaveFileItem() { - CTreeItem *item = getFirstChild(); - while (item) { - CDontSaveFileItem *fileItem = dynamic_cast<CDontSaveFileItem *>(item); - if (fileItem) - return fileItem; - - item = item->getNextSibling(); - } - - return nullptr; -} - void CTreeItem::addUnder(CTreeItem *newParent) { if (newParent->_firstChild) addSibling(newParent->getLastSibling()); diff --git a/engines/titanic/core/tree_item.h b/engines/titanic/core/tree_item.h index 4e1581b1f6..acfd8bf2f4 100644 --- a/engines/titanic/core/tree_item.h +++ b/engines/titanic/core/tree_item.h @@ -54,7 +54,7 @@ public: /** * Get the game manager for the project */ - virtual CGameManager *getGameManager(); + virtual CGameManager *getGameManager() const; /** * Returns true if the item is a file item @@ -74,12 +74,12 @@ public: /** * Get the next sibling */ - CTreeItem *getNextSibling() { return _nextSibling; } + CTreeItem *getNextSibling() const { return _nextSibling; } /** * Get the prior sibling */ - CTreeItem *getPriorSibling() { return _priorSibling; } + CTreeItem *getPriorSibling() const { return _priorSibling; } /** * Get the last sibling of this sibling @@ -89,23 +89,18 @@ public: /** * Get the first child of the item, if any */ - CTreeItem *getFirstChild() { return _firstChild; } + CTreeItem *getFirstChild() const { return _firstChild; } /** * Get the last child of the item, if any */ - CTreeItem *getLastChild(); + CTreeItem *getLastChild() const; /** * Given all the recursive children of the tree item, gives the next * item in sequence to the passed starting item */ - CTreeItem *scan(CTreeItem *item); - - /** - * Get any dont save file item in the immediate children - */ - CDontSaveFileItem *getDontSaveFileItem(); + CTreeItem *scan(CTreeItem *item) const; /** * Adds the item under another tree item |