From f20d1b1b72ec6b8fd4ee990d8d0ff22f9195d723 Mon Sep 17 00:00:00 2001 From: Andrei Kortunov Date: Wed, 14 Nov 2018 15:52:36 +0400 Subject: [PATCH 1/2] Catch exception in the NIFTest --- apps/niftest/niftest.cpp | 17 ++++++++++++++--- 1 file changed, 14 insertions(+), 3 deletions(-) diff --git a/apps/niftest/niftest.cpp b/apps/niftest/niftest.cpp index 572a58f26..6c0c74597 100644 --- a/apps/niftest/niftest.cpp +++ b/apps/niftest/niftest.cpp @@ -10,6 +10,7 @@ #include #include +#include #include #include @@ -128,14 +129,24 @@ std::vector parseOptions (int argc, char** argv) int main(int argc, char **argv) { - std::vector files = parseOptions (argc, argv); + std::vector files; + try + { + files = parseOptions (argc, argv); + } + catch( boost::exception &e ) + { + std::cout << "ERROR parsing arguments: " << boost::diagnostic_information(e) << std::endl; + exit(1); + } // std::cout << "Reading Files" << std::endl; for(std::vector::const_iterator it=files.begin(); it!=files.end(); ++it) { - std::string name = *it; + std::string name = *it; - try{ + try + { if(isNIF(name)) { //std::cout << "Decoding: " << name << std::endl; From 5ac81cfbff1c93db780476c7cc660214a91677db Mon Sep 17 00:00:00 2001 From: Andrei Kortunov Date: Wed, 14 Nov 2018 15:53:43 +0400 Subject: [PATCH 2/2] Throw exceptions with some info int the editor if dynamic_cast failed --- apps/opencs/model/world/commands.cpp | 6 ++-- apps/opencs/view/render/pathgrid.cpp | 36 ++++++++++++---------- apps/opencs/view/world/cellcreator.cpp | 6 +++- apps/opencs/view/world/dialoguesubview.cpp | 5 ++- 4 files changed, 33 insertions(+), 20 deletions(-) diff --git a/apps/opencs/model/world/commands.cpp b/apps/opencs/model/world/commands.cpp index 5ddb753c5..01ee2f738 100644 --- a/apps/opencs/model/world/commands.cpp +++ b/apps/opencs/model/world/commands.cpp @@ -199,8 +199,10 @@ CSMWorld::ModifyCommand::ModifyCommand (QAbstractItemModel& model, const QModelI if (mIndex.parent().isValid()) { CSMWorld::IdTree* tree = dynamic_cast(mModel); - - assert(tree != nullptr); + if (tree == nullptr) + { + throw std::logic_error("CSMWorld::ModifyCommand: Attempt to add nested values to the non-nested model"); + } setText ("Modify " + tree->nestedHeaderData ( mIndex.parent().column(), mIndex.column(), Qt::Horizontal, Qt::DisplayRole).toString()); diff --git a/apps/opencs/view/render/pathgrid.cpp b/apps/opencs/view/render/pathgrid.cpp index 1fa63bedc..d184b4938 100644 --- a/apps/opencs/view/render/pathgrid.cpp +++ b/apps/opencs/view/render/pathgrid.cpp @@ -224,10 +224,11 @@ namespace CSVRender void Pathgrid::applyPoint(CSMWorld::CommandMacro& commands, const osg::Vec3d& worldPos) { - CSMWorld::IdTree* model = dynamic_cast(mData.getTableModel( - CSMWorld::UniversalId::Type_Pathgrids)); - - assert(model != nullptr); + CSMWorld::IdTree* model = dynamic_cast(mData.getTableModel(CSMWorld::UniversalId::Type_Pathgrids)); + if (model == nullptr) + { + throw std::logic_error("CSVRender::Pathgrid: Attempt to add nested values to the non-nested model"); + } const CSMWorld::Pathgrid* source = getPathgridSource(); if (source) @@ -359,10 +360,11 @@ namespace CSVRender const CSMWorld::Pathgrid* source = getPathgridSource(); if (source) { - CSMWorld::IdTree* model = dynamic_cast(mData.getTableModel( - CSMWorld::UniversalId::Type_Pathgrids)); - - assert(model != nullptr); + CSMWorld::IdTree* model = dynamic_cast(mData.getTableModel(CSMWorld::UniversalId::Type_Pathgrids)); + if (model == nullptr) + { + throw std::logic_error("CSVRender::Pathgrid: Attempt to add nested values to the non-nested model"); + } // Want to remove nodes from end of list first std::sort(mSelected.begin(), mSelected.end(), std::greater()); @@ -462,10 +464,11 @@ namespace CSVRender } } - CSMWorld::IdTree* model = dynamic_cast(mData.getTableModel( - CSMWorld::UniversalId::Type_Pathgrids)); - - assert(model != nullptr); + CSMWorld::IdTree* model = dynamic_cast(mData.getTableModel(CSMWorld::UniversalId::Type_Pathgrids)); + if (model == nullptr) + { + throw std::logic_error("CSVRender::Pathgrid: Attempt to add nested values to the non-nested model"); + } int parentColumn = mPathgridCollection.findColumnIndex(CSMWorld::Columns::ColumnId_PathgridEdges); @@ -639,10 +642,11 @@ namespace CSVRender void Pathgrid::addEdge(CSMWorld::CommandMacro& commands, const CSMWorld::Pathgrid& source, unsigned short node1, unsigned short node2) { - CSMWorld::IdTree* model = dynamic_cast(mData.getTableModel( - CSMWorld::UniversalId::Type_Pathgrids)); - - assert(model != nullptr); + CSMWorld::IdTree* model = dynamic_cast(mData.getTableModel(CSMWorld::UniversalId::Type_Pathgrids)); + if (model == nullptr) + { + throw std::logic_error("CSVRender::Pathgrid: Attempt to add nested values to the non-nested model"); + } int recordIndex = mPathgridCollection.getIndex(mId); int parentColumn = mPathgridCollection.findColumnIndex(CSMWorld::Columns::ColumnId_PathgridEdges); diff --git a/apps/opencs/view/world/cellcreator.cpp b/apps/opencs/view/world/cellcreator.cpp index 16338a9a2..54e618cd9 100644 --- a/apps/opencs/view/world/cellcreator.cpp +++ b/apps/opencs/view/world/cellcreator.cpp @@ -25,7 +25,11 @@ std::string CSVWorld::CellCreator::getId() const void CSVWorld::CellCreator::configureCreateCommand(CSMWorld::CreateCommand& command) const { CSMWorld::IdTree *model = dynamic_cast(getData().getTableModel(getCollectionId())); - assert(model != nullptr); + if (model == nullptr) + { + throw std::logic_error("CSVWorld::CellCreator: Attempt to add nested values to the non-nested model"); + } + int parentIndex = model->findColumnIndex(CSMWorld::Columns::ColumnId_Cell); int index = model->findNestedColumnIndex(parentIndex, CSMWorld::Columns::ColumnId_Interior); command.addNestedValue(parentIndex, index, mType->currentIndex() == 0); diff --git a/apps/opencs/view/world/dialoguesubview.cpp b/apps/opencs/view/world/dialoguesubview.cpp index 0b04fe6c9..9f73430f0 100644 --- a/apps/opencs/view/world/dialoguesubview.cpp +++ b/apps/opencs/view/world/dialoguesubview.cpp @@ -556,7 +556,10 @@ void CSVWorld::EditWidget::remake(int row) !(flags & CSMWorld::ColumnBase::Flag_Dialogue_List)) { CSMWorld::IdTree *innerTable = dynamic_cast(mTable); - assert(innerTable != nullptr); + if (innerTable == nullptr) + { + throw std::logic_error("CSVWorld::EditWidget: Attempt to add nested values to the non-nested model"); + } mNestedModels.push_back(new CSMWorld::NestedTableProxyModel (mTable->index(row, i), display, innerTable));