mirror of
				https://github.com/OpenMW/openmw.git
				synced 2025-10-25 23:56:38 +00:00 
			
		
		
		
	added signals and functions to Data for handling ID list changes
This commit is contained in:
		
							parent
							
								
									78f7f80fc3
								
							
						
					
					
						commit
						3d2281fe80
					
				
					 9 changed files with 147 additions and 11 deletions
				
			
		|  | @ -18,12 +18,12 @@ opencs_hdrs_noqt (model/doc | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| opencs_units (model/world | opencs_units (model/world | ||||||
|     idtable idtableproxymodel regionmap |     idtable idtableproxymodel regionmap data | ||||||
|     ) |     ) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| opencs_units_noqt (model/world | opencs_units_noqt (model/world | ||||||
|     universalid data record commands columnbase scriptcontext cell refidcollection |     universalid record commands columnbase scriptcontext cell refidcollection | ||||||
|     refidadapter refiddata refidadapterimp ref collectionbase refcollection columns |     refidadapter refiddata refidadapterimp ref collectionbase refcollection columns | ||||||
|     ) |     ) | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -107,6 +107,11 @@ namespace CSMWorld | ||||||
|             virtual int getAppendIndex (UniversalId::Type type = UniversalId::Type_None) const; |             virtual int getAppendIndex (UniversalId::Type type = UniversalId::Type_None) const; | ||||||
|             ///< \param type Will be ignored, unless the collection supports multiple record types
 |             ///< \param type Will be ignored, unless the collection supports multiple record types
 | ||||||
| 
 | 
 | ||||||
|  |             virtual std::vector<std::string> getIds() const; | ||||||
|  |             ///< Return a sorted collection of all IDs
 | ||||||
|  |             ///
 | ||||||
|  |             /// \note Deleted records are not listed.
 | ||||||
|  | 
 | ||||||
|             void addColumn (Column<ESXRecordT> *column); |             void addColumn (Column<ESXRecordT> *column); | ||||||
| 
 | 
 | ||||||
|             void setRecord (int index, const Record<ESXRecordT>& record); |             void setRecord (int index, const Record<ESXRecordT>& record); | ||||||
|  | @ -293,6 +298,21 @@ namespace CSMWorld | ||||||
|         return static_cast<int> (mRecords.size()); |         return static_cast<int> (mRecords.size()); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     template<typename ESXRecordT, typename IdAccessorT> | ||||||
|  |     std::vector<std::string> Collection<ESXRecordT, IdAccessorT>::getIds() const | ||||||
|  |     { | ||||||
|  |         std::vector<std::string> ids; | ||||||
|  | 
 | ||||||
|  |         for (typename std::map<std::string, int>::const_iterator iter = mIndex.begin(); | ||||||
|  |             iter!=mIndex.end(); ++iter) | ||||||
|  |         { | ||||||
|  |             if (!mRecords[iter->second].isDeleted()) | ||||||
|  |                 ids.push_back (IdAccessorT().getId (mRecords[iter->second].get())); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         return ids; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     template<typename ESXRecordT, typename IdAccessorT> |     template<typename ESXRecordT, typename IdAccessorT> | ||||||
|     const Record<ESXRecordT>& Collection<ESXRecordT, IdAccessorT>::getRecord (const std::string& id) const |     const Record<ESXRecordT>& Collection<ESXRecordT, IdAccessorT>::getRecord (const std::string& id) const | ||||||
|     { |     { | ||||||
|  |  | ||||||
|  | @ -78,8 +78,12 @@ namespace CSMWorld | ||||||
| 
 | 
 | ||||||
|             virtual int getAppendIndex (UniversalId::Type type = UniversalId::Type_None) const = 0; |             virtual int getAppendIndex (UniversalId::Type type = UniversalId::Type_None) const = 0; | ||||||
|             ///< \param type Will be ignored, unless the collection supports multiple record types
 |             ///< \param type Will be ignored, unless the collection supports multiple record types
 | ||||||
|     }; |  | ||||||
| 
 | 
 | ||||||
|  |             virtual std::vector<std::string> getIds() const = 0; | ||||||
|  |             ///< Return a sorted collection of all IDs
 | ||||||
|  |             ///
 | ||||||
|  |             /// \note Deleted records are not listed.
 | ||||||
|  |     }; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| #endif | #endif | ||||||
|  | @ -2,6 +2,7 @@ | ||||||
| #include "data.hpp" | #include "data.hpp" | ||||||
| 
 | 
 | ||||||
| #include <stdexcept> | #include <stdexcept> | ||||||
|  | #include <algorithm> | ||||||
| 
 | 
 | ||||||
| #include <QAbstractItemModel> | #include <QAbstractItemModel> | ||||||
| 
 | 
 | ||||||
|  | @ -15,13 +16,30 @@ | ||||||
| #include "columns.hpp" | #include "columns.hpp" | ||||||
| 
 | 
 | ||||||
| void CSMWorld::Data::addModel (QAbstractItemModel *model, UniversalId::Type type1, | void CSMWorld::Data::addModel (QAbstractItemModel *model, UniversalId::Type type1, | ||||||
|     UniversalId::Type type2) |     UniversalId::Type type2, bool update) | ||||||
| { | { | ||||||
|     mModels.push_back (model); |     mModels.push_back (model); | ||||||
|     mModelIndex.insert (std::make_pair (type1, model)); |     mModelIndex.insert (std::make_pair (type1, model)); | ||||||
| 
 | 
 | ||||||
|     if (type2!=UniversalId::Type_None) |     if (type2!=UniversalId::Type_None) | ||||||
|         mModelIndex.insert (std::make_pair (type2, model)); |         mModelIndex.insert (std::make_pair (type2, model)); | ||||||
|  | 
 | ||||||
|  |     if (update) | ||||||
|  |     { | ||||||
|  |         connect (model, SIGNAL (dataChanged (const QModelIndex&, const QModelIndex&)), | ||||||
|  |             this, SLOT (dataChanged (const QModelIndex&, const QModelIndex&))); | ||||||
|  |         connect (model, SIGNAL (rowsInserted (const QModelIndex&, int, int)), | ||||||
|  |             this, SLOT (rowsChanged (const QModelIndex&, int, int))); | ||||||
|  |         connect (model, SIGNAL (rowsRemoved (const QModelIndex&, int, int)), | ||||||
|  |             this, SLOT (rowsChanged (const QModelIndex&, int, int))); | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void CSMWorld::Data::appendIds (std::vector<std::string>& ids, const CollectionBase& collection) | ||||||
|  | { | ||||||
|  |     std::vector<std::string> ids2 = collection.getIds(); | ||||||
|  | 
 | ||||||
|  |     ids.insert (ids.end(), ids2.begin(), ids2.end()); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| CSMWorld::Data::Data() : mRefs (mCells) | CSMWorld::Data::Data() : mRefs (mCells) | ||||||
|  | @ -155,7 +173,7 @@ CSMWorld::Data::Data() : mRefs (mCells) | ||||||
| 
 | 
 | ||||||
|     addModel (new IdTable (&mGlobals), UniversalId::Type_Globals, UniversalId::Type_Global); |     addModel (new IdTable (&mGlobals), UniversalId::Type_Globals, UniversalId::Type_Global); | ||||||
|     addModel (new IdTable (&mGmsts), UniversalId::Type_Gmsts, UniversalId::Type_Gmst); |     addModel (new IdTable (&mGmsts), UniversalId::Type_Gmsts, UniversalId::Type_Gmst); | ||||||
|     addModel (new IdTable (&mSkills), UniversalId::Type_Skills, UniversalId::Type_Skill); |     addModel (new IdTable (&mSkills), UniversalId::Type_Skills, UniversalId::Type_Skill, false); | ||||||
|     addModel (new IdTable (&mClasses), UniversalId::Type_Classes, UniversalId::Type_Class); |     addModel (new IdTable (&mClasses), UniversalId::Type_Classes, UniversalId::Type_Class); | ||||||
|     addModel (new IdTable (&mFactions), UniversalId::Type_Factions, UniversalId::Type_Faction); |     addModel (new IdTable (&mFactions), UniversalId::Type_Factions, UniversalId::Type_Faction); | ||||||
|     addModel (new IdTable (&mRaces), UniversalId::Type_Races, UniversalId::Type_Race); |     addModel (new IdTable (&mRaces), UniversalId::Type_Races, UniversalId::Type_Race); | ||||||
|  | @ -167,8 +185,8 @@ CSMWorld::Data::Data() : mRefs (mCells) | ||||||
|     addModel (new IdTable (&mCells), UniversalId::Type_Cells, UniversalId::Type_Cell); |     addModel (new IdTable (&mCells), UniversalId::Type_Cells, UniversalId::Type_Cell); | ||||||
|     addModel (new IdTable (&mReferenceables), UniversalId::Type_Referenceables, |     addModel (new IdTable (&mReferenceables), UniversalId::Type_Referenceables, | ||||||
|         UniversalId::Type_Referenceable); |         UniversalId::Type_Referenceable); | ||||||
|     addModel (new IdTable (&mRefs), UniversalId::Type_References, UniversalId::Type_Reference); |     addModel (new IdTable (&mRefs), UniversalId::Type_References, UniversalId::Type_Reference, false); | ||||||
|     addModel (new IdTable (&mFilters), UniversalId::Type_Filters, UniversalId::Type_Filter); |     addModel (new IdTable (&mFilters), UniversalId::Type_Filters, UniversalId::Type_Filter, false); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| CSMWorld::Data::~Data() | CSMWorld::Data::~Data() | ||||||
|  | @ -341,7 +359,7 @@ QAbstractItemModel *CSMWorld::Data::getTableModel (const UniversalId& id) | ||||||
|         { |         { | ||||||
|             RegionMap *table = 0; |             RegionMap *table = 0; | ||||||
|             addModel (table = new RegionMap (*this), UniversalId::Type_RegionMap, |             addModel (table = new RegionMap (*this), UniversalId::Type_RegionMap, | ||||||
|                 UniversalId::Type_None); |                 UniversalId::Type_None, false); | ||||||
|             return table; |             return table; | ||||||
|         } |         } | ||||||
|         throw std::logic_error ("No table model available for " + id.toString()); |         throw std::logic_error ("No table model available for " + id.toString()); | ||||||
|  | @ -440,3 +458,37 @@ bool CSMWorld::Data::hasId (const std::string& id) const | ||||||
|         getCells().searchId (id)!=-1 || |         getCells().searchId (id)!=-1 || | ||||||
|         getReferenceables().searchId (id)!=-1; |         getReferenceables().searchId (id)!=-1; | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | std::vector<std::string> CSMWorld::Data::getIds() const | ||||||
|  | { | ||||||
|  |     std::vector<std::string> ids; | ||||||
|  | 
 | ||||||
|  |     appendIds (ids, mGlobals); | ||||||
|  |     appendIds (ids, mGmsts); | ||||||
|  |     appendIds (ids, mClasses); | ||||||
|  |     appendIds (ids, mFactions); | ||||||
|  |     appendIds (ids, mRaces); | ||||||
|  |     appendIds (ids, mSounds); | ||||||
|  |     appendIds (ids, mScripts); | ||||||
|  |     appendIds (ids, mRegions); | ||||||
|  |     appendIds (ids, mBirthsigns); | ||||||
|  |     appendIds (ids, mSpells); | ||||||
|  |     appendIds (ids, mCells); | ||||||
|  |     appendIds (ids, mReferenceables); | ||||||
|  | 
 | ||||||
|  |     std::sort (ids.begin(), ids.end()); | ||||||
|  | 
 | ||||||
|  |     return ids; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void CSMWorld::Data::dataChanged (const QModelIndex& topLeft, const QModelIndex& bottomRight) | ||||||
|  | { | ||||||
|  |     // Note: The performance of of ID list change updates could be improved only emit the signal, if
 | ||||||
|  |     // the state of the record is changed.
 | ||||||
|  |     emit idListChanged(); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void CSMWorld::Data::rowsChanged (const QModelIndex& parent, int start, int end) | ||||||
|  | { | ||||||
|  |     emit idListChanged(); | ||||||
|  | } | ||||||
|  | @ -6,6 +6,9 @@ | ||||||
| 
 | 
 | ||||||
| #include <boost/filesystem/path.hpp> | #include <boost/filesystem/path.hpp> | ||||||
| 
 | 
 | ||||||
|  | #include <QObject> | ||||||
|  | #include <QModelIndex> | ||||||
|  | 
 | ||||||
| #include <components/esm/loadglob.hpp> | #include <components/esm/loadglob.hpp> | ||||||
| #include <components/esm/loadgmst.hpp> | #include <components/esm/loadgmst.hpp> | ||||||
| #include <components/esm/loadskil.hpp> | #include <components/esm/loadskil.hpp> | ||||||
|  | @ -30,8 +33,10 @@ class QAbstractItemModel; | ||||||
| 
 | 
 | ||||||
| namespace CSMWorld | namespace CSMWorld | ||||||
| { | { | ||||||
|     class Data |     class Data : public QObject | ||||||
|     { |     { | ||||||
|  |             Q_OBJECT | ||||||
|  | 
 | ||||||
|             IdCollection<ESM::Global> mGlobals; |             IdCollection<ESM::Global> mGlobals; | ||||||
|             IdCollection<ESM::GameSetting> mGmsts; |             IdCollection<ESM::GameSetting> mGmsts; | ||||||
|             IdCollection<ESM::Skill> mSkills; |             IdCollection<ESM::Skill> mSkills; | ||||||
|  | @ -55,13 +60,16 @@ namespace CSMWorld | ||||||
|             Data& operator= (const Data&); |             Data& operator= (const Data&); | ||||||
| 
 | 
 | ||||||
|             void addModel (QAbstractItemModel *model, UniversalId::Type type1, |             void addModel (QAbstractItemModel *model, UniversalId::Type type1, | ||||||
|                 UniversalId::Type type2 = UniversalId::Type_None); |                 UniversalId::Type type2 = UniversalId::Type_None, bool update = true); | ||||||
|  | 
 | ||||||
|  |             static void appendIds (std::vector<std::string>& ids, const CollectionBase& collection); | ||||||
|  |             ///< Append all IDs from collection to \a ids.
 | ||||||
| 
 | 
 | ||||||
|         public: |         public: | ||||||
| 
 | 
 | ||||||
|             Data(); |             Data(); | ||||||
| 
 | 
 | ||||||
|             ~Data(); |             virtual ~Data(); | ||||||
| 
 | 
 | ||||||
|             const IdCollection<ESM::Global>& getGlobals() const; |             const IdCollection<ESM::Global>& getGlobals() const; | ||||||
| 
 | 
 | ||||||
|  | @ -136,6 +144,21 @@ namespace CSMWorld | ||||||
|             ///< Merging content of a file into base or modified.
 |             ///< Merging content of a file into base or modified.
 | ||||||
| 
 | 
 | ||||||
|             bool hasId (const std::string& id) const; |             bool hasId (const std::string& id) const; | ||||||
|  | 
 | ||||||
|  |             std::vector<std::string> getIds() const; | ||||||
|  |             ///< Return a sorted collection of all IDs that are not internal to the editor.
 | ||||||
|  |             ///
 | ||||||
|  |             /// \note Deleted records are not listed.
 | ||||||
|  | 
 | ||||||
|  |         signals: | ||||||
|  | 
 | ||||||
|  |             void idListChanged(); | ||||||
|  | 
 | ||||||
|  |         private slots: | ||||||
|  | 
 | ||||||
|  |             void dataChanged (const QModelIndex& topLeft, const QModelIndex& bottomRight); | ||||||
|  | 
 | ||||||
|  |             void rowsChanged (const QModelIndex& parent, int start, int end); | ||||||
|     }; |     }; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -534,3 +534,8 @@ int CSMWorld::RefIdCollection::getAppendIndex (UniversalId::Type type) const | ||||||
| { | { | ||||||
|     return mData.getAppendIndex (type); |     return mData.getAppendIndex (type); | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | std::vector<std::string> CSMWorld::RefIdCollection::getIds() const | ||||||
|  | { | ||||||
|  |     return mData.getIds(); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | @ -89,6 +89,11 @@ namespace CSMWorld | ||||||
| 
 | 
 | ||||||
|             virtual int getAppendIndex (UniversalId::Type type) const; |             virtual int getAppendIndex (UniversalId::Type type) const; | ||||||
|             ///< \param type Will be ignored, unless the collection supports multiple record types
 |             ///< \param type Will be ignored, unless the collection supports multiple record types
 | ||||||
|  | 
 | ||||||
|  |             virtual std::vector<std::string> getIds() const; | ||||||
|  |             ///< Return a sorted collection of all IDs
 | ||||||
|  |             ///
 | ||||||
|  |             /// \note Deleted records are not listed.
 | ||||||
|     }; |     }; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -196,3 +196,25 @@ int CSMWorld::RefIdData::getSize() const | ||||||
| { | { | ||||||
|     return mIndex.size(); |     return mIndex.size(); | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | std::vector<std::string> CSMWorld::RefIdData::getIds() const | ||||||
|  | { | ||||||
|  |     std::vector<std::string> ids; | ||||||
|  | 
 | ||||||
|  |     for (std::map<std::string, LocalIndex>::const_iterator iter (mIndex.begin()); iter!=mIndex.end(); | ||||||
|  |          ++iter) | ||||||
|  |     { | ||||||
|  |         if (!getRecord (iter->second).isDeleted()) | ||||||
|  |         { | ||||||
|  |             std::map<UniversalId::Type, RefIdDataContainerBase *>::const_iterator container = | ||||||
|  |                 mRecordContainers.find (iter->second.second); | ||||||
|  | 
 | ||||||
|  |             if (container==mRecordContainers.end()) | ||||||
|  |                 throw std::logic_error ("Invalid referenceable ID type"); | ||||||
|  | 
 | ||||||
|  |             ids.push_back (container->second->getId (iter->second.first)); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     return ids; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | @ -182,6 +182,11 @@ namespace CSMWorld | ||||||
|             void load (const LocalIndex& index, ESM::ESMReader& reader, bool base); |             void load (const LocalIndex& index, ESM::ESMReader& reader, bool base); | ||||||
| 
 | 
 | ||||||
|             int getSize() const; |             int getSize() const; | ||||||
|  | 
 | ||||||
|  |             std::vector<std::string> getIds() const; | ||||||
|  |             ///< Return a sorted collection of all IDs
 | ||||||
|  |             ///
 | ||||||
|  |             /// \note Deleted records are not listed.
 | ||||||
|     }; |     }; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue