From 059a8fd32ac1a4b3342dab523273353ce6de69bf Mon Sep 17 00:00:00 2001 From: Andrei Kortunov Date: Thu, 15 Nov 2018 17:50:23 +0400 Subject: [PATCH 1/2] Refactor dynamic casts in the editor --- apps/opencs/model/world/commands.cpp | 14 ++---------- apps/opencs/view/render/pathgrid.cpp | 25 ++++------------------ apps/opencs/view/world/cellcreator.cpp | 6 +----- apps/opencs/view/world/dialoguesubview.cpp | 7 +----- 4 files changed, 8 insertions(+), 44 deletions(-) diff --git a/apps/opencs/model/world/commands.cpp b/apps/opencs/model/world/commands.cpp index 01ee2f738..e9682d7c9 100644 --- a/apps/opencs/model/world/commands.cpp +++ b/apps/opencs/model/world/commands.cpp @@ -198,12 +198,7 @@ CSMWorld::ModifyCommand::ModifyCommand (QAbstractItemModel& model, const QModelI if (mIndex.parent().isValid()) { - CSMWorld::IdTree* tree = dynamic_cast(mModel); - if (tree == nullptr) - { - throw std::logic_error("CSMWorld::ModifyCommand: Attempt to add nested values to the non-nested model"); - } - + CSMWorld::IdTree* tree = &dynamic_cast(*mModel); setText ("Modify " + tree->nestedHeaderData ( mIndex.parent().column(), mIndex.column(), Qt::Horizontal, Qt::DisplayRole).toString()); } @@ -249,12 +244,7 @@ void CSMWorld::CreateCommand::applyModifications() { if (!mNestedValues.empty()) { - CSMWorld::IdTree *tree = dynamic_cast(&mModel); - if (tree == nullptr) - { - throw std::logic_error("CSMWorld::CreateCommand: Attempt to add nested values to the non-nested model"); - } - + CSMWorld::IdTree* tree = &dynamic_cast(mModel); std::map >::const_iterator current = mNestedValues.begin(); std::map >::const_iterator end = mNestedValues.end(); for (; current != end; ++current) diff --git a/apps/opencs/view/render/pathgrid.cpp b/apps/opencs/view/render/pathgrid.cpp index d184b4938..d8acfe2e1 100644 --- a/apps/opencs/view/render/pathgrid.cpp +++ b/apps/opencs/view/render/pathgrid.cpp @@ -224,11 +224,7 @@ namespace CSVRender void Pathgrid::applyPoint(CSMWorld::CommandMacro& commands, const osg::Vec3d& worldPos) { - 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"); - } + CSMWorld::IdTree* model = &dynamic_cast(*mData.getTableModel(CSMWorld::UniversalId::Type_Pathgrids)); const CSMWorld::Pathgrid* source = getPathgridSource(); if (source) @@ -360,11 +356,7 @@ namespace CSVRender const CSMWorld::Pathgrid* source = getPathgridSource(); if (source) { - 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"); - } + CSMWorld::IdTree* model = &dynamic_cast(*mData.getTableModel(CSMWorld::UniversalId::Type_Pathgrids)); // Want to remove nodes from end of list first std::sort(mSelected.begin(), mSelected.end(), std::greater()); @@ -464,12 +456,7 @@ namespace CSVRender } } - 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"); - } - + CSMWorld::IdTree* model = &dynamic_cast(*mData.getTableModel(CSMWorld::UniversalId::Type_Pathgrids)); int parentColumn = mPathgridCollection.findColumnIndex(CSMWorld::Columns::ColumnId_PathgridEdges); std::set >::iterator row; @@ -642,11 +629,7 @@ 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)); - if (model == nullptr) - { - throw std::logic_error("CSVRender::Pathgrid: Attempt to add nested values to the non-nested model"); - } + CSMWorld::IdTree* model = &dynamic_cast(*mData.getTableModel(CSMWorld::UniversalId::Type_Pathgrids)); 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 54e618cd9..5b428a4b3 100644 --- a/apps/opencs/view/world/cellcreator.cpp +++ b/apps/opencs/view/world/cellcreator.cpp @@ -24,11 +24,7 @@ std::string CSVWorld::CellCreator::getId() const void CSVWorld::CellCreator::configureCreateCommand(CSMWorld::CreateCommand& command) const { - CSMWorld::IdTree *model = dynamic_cast(getData().getTableModel(getCollectionId())); - if (model == nullptr) - { - throw std::logic_error("CSVWorld::CellCreator: Attempt to add nested values to the non-nested model"); - } + CSMWorld::IdTree* model = &dynamic_cast(*getData().getTableModel(getCollectionId())); int parentIndex = model->findColumnIndex(CSMWorld::Columns::ColumnId_Cell); int index = model->findNestedColumnIndex(parentIndex, CSMWorld::Columns::ColumnId_Interior); diff --git a/apps/opencs/view/world/dialoguesubview.cpp b/apps/opencs/view/world/dialoguesubview.cpp index 9f73430f0..eeba29d95 100644 --- a/apps/opencs/view/world/dialoguesubview.cpp +++ b/apps/opencs/view/world/dialoguesubview.cpp @@ -555,12 +555,7 @@ void CSVWorld::EditWidget::remake(int row) if (mTable->hasChildren(mTable->index(row, i)) && !(flags & CSMWorld::ColumnBase::Flag_Dialogue_List)) { - CSMWorld::IdTree *innerTable = dynamic_cast(mTable); - if (innerTable == nullptr) - { - throw std::logic_error("CSVWorld::EditWidget: Attempt to add nested values to the non-nested model"); - } - + CSMWorld::IdTree* innerTable = &dynamic_cast(*mTable); mNestedModels.push_back(new CSMWorld::NestedTableProxyModel (mTable->index(row, i), display, innerTable)); int idColumn = mTable->findColumnIndex (CSMWorld::Columns::ColumnId_Id); From 68c170f065b04392bdf68bf9acbfe1ae7c47dd67 Mon Sep 17 00:00:00 2001 From: Andrei Kortunov Date: Thu, 15 Nov 2018 18:10:19 +0400 Subject: [PATCH 2/2] Refactor tools to do not use boost exceptions and exit() command --- apps/esmtool/esmtool.cpp | 9 ++------- apps/niftest/niftest.cpp | 23 ++++++++--------------- 2 files changed, 10 insertions(+), 22 deletions(-) diff --git a/apps/esmtool/esmtool.cpp b/apps/esmtool/esmtool.cpp index d4569000b..699ff855c 100644 --- a/apps/esmtool/esmtool.cpp +++ b/apps/esmtool/esmtool.cpp @@ -123,14 +123,9 @@ bool parseOptions (int argc, char** argv, Arguments &info) bpo::store(valid_opts, variables); } - catch(boost::program_options::unknown_option & x) + catch(std::exception &e) { - std::cerr << "ERROR: " << x.what() << std::endl; - return false; - } - catch(boost::program_options::invalid_command_line_syntax & x) - { - std::cerr << "ERROR: " << x.what() << std::endl; + std::cout << "ERROR parsing arguments: " << e.what() << std::endl; return false; } diff --git a/apps/niftest/niftest.cpp b/apps/niftest/niftest.cpp index 6c0c74597..e3f2b89f8 100644 --- a/apps/niftest/niftest.cpp +++ b/apps/niftest/niftest.cpp @@ -10,7 +10,6 @@ #include #include -#include #include #include @@ -81,7 +80,7 @@ void readVFS(VFS::Archive* anArchive,std::string archivePath = "") } } -std::vector parseOptions (int argc, char** argv) +bool parseOptions (int argc, char** argv, std::vector& files) { bpo::options_description desc("Ensure that OpenMW can use the provided NIF and BSA files\n\n" "Usages:\n" @@ -108,37 +107,31 @@ std::vector parseOptions (int argc, char** argv) { std::cout << "ERROR parsing arguments: " << e.what() << "\n\n" << desc << std::endl; - exit(1); + return false; } bpo::notify(variables); if (variables.count ("help")) { std::cout << desc << std::endl; - exit(1); + return false; } if (variables.count("input-file")) { - return variables["input-file"].as< std::vector >(); + files = variables["input-file"].as< std::vector >(); + return true; } std::cout << "No input files or directories specified!" << std::endl; std::cout << desc << std::endl; - exit(1); + return false; } int main(int argc, char **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); - } + if(!parseOptions (argc, argv, files)) + return 1; // std::cout << "Reading Files" << std::endl; for(std::vector::const_iterator it=files.begin(); it!=files.end(); ++it)