1
0
mirror of https://gitlab.com/OpenMW/openmw.git synced 2025-01-25 15:35:23 +00:00
OpenMW/apps/opencs/model/world/refidcollection.hpp

121 lines
3.8 KiB
C++
Raw Normal View History

#ifndef CSM_WOLRD_REFIDCOLLECTION_H
#define CSM_WOLRD_REFIDCOLLECTION_H
#include <vector>
#include <map>
#include <deque>
#include "columnbase.hpp"
#include "collectionbase.hpp"
#include "refiddata.hpp"
2013-09-24 13:53:19 +02:00
namespace ESM
{
class ESMWriter;
}
namespace CSMWorld
{
class RefIdAdapter;
class RefIdColumn : public ColumnBase
{
bool mEditable;
bool mUserEditable;
public:
2013-12-30 18:41:16 +01:00
RefIdColumn (int columnId, Display displayType,
int flag = Flag_Table | Flag_Dialogue, bool editable = true,
bool userEditable = true);
virtual bool isEditable() const;
virtual bool isUserEditable() const;
};
class RefIdCollection : public CollectionBase
{
private:
RefIdData mData;
std::deque<RefIdColumn> mColumns;
2013-12-30 18:41:16 +01:00
std::map<UniversalId::Type, RefIdAdapter *> mAdapters;
private:
2013-12-30 18:41:16 +01:00
const RefIdAdapter& findAdaptor (UniversalId::Type) const;
///< Throws an exception if no adaptor for \a Type can be found.
public:
RefIdCollection();
virtual ~RefIdCollection();
virtual int getSize() const;
2013-12-30 18:41:16 +01:00
virtual std::string getId (int index) const;
2013-12-30 18:41:16 +01:00
virtual int getIndex (const std::string& id) const;
virtual int getColumns() const;
2013-12-30 18:41:16 +01:00
virtual const ColumnBase& getColumn (int column) const;
2013-12-30 18:41:16 +01:00
virtual QVariant getData (int index, int column) const;
2013-12-30 18:41:16 +01:00
virtual void setData (int index, int column, const QVariant& data);
2013-12-30 18:41:16 +01:00
virtual void removeRows (int index, int count);
virtual void cloneRecord(const std::string& origin,
const std::string& destination,
2014-01-27 13:08:14 +01:00
const UniversalId::Type type);
2014-01-27 19:40:05 +01:00
2013-12-30 18:41:16 +01:00
virtual void appendBlankRecord (const std::string& id, UniversalId::Type type);
///< \param type Will be ignored, unless the collection supports multiple record types
2013-12-30 18:41:16 +01:00
virtual int searchId (const std::string& id) const;
////< Search record with \a id.
/// \return index of record (if found) or -1 (not found)
2013-12-30 18:41:16 +01:00
virtual void replace (int index, const RecordBase& record);
///< If the record type does not match, an exception is thrown.
///
/// \attention \a record must not change the ID.
2013-12-30 18:41:16 +01:00
virtual void appendRecord (const RecordBase& record, UniversalId::Type type);
///< If the record type does not match, an exception is thrown.
///
///< \param type Will be ignored, unless the collection supports multiple record types
2013-12-30 18:41:16 +01:00
virtual const RecordBase& getRecord (const std::string& id) const;
2013-12-30 18:41:16 +01:00
virtual const RecordBase& getRecord (int index) const;
2013-12-30 18:41:16 +01:00
void load (ESM::ESMReader& reader, bool base, UniversalId::Type type);
2013-12-30 18:41:16 +01:00
virtual int getAppendIndex (const std::string& id, UniversalId::Type type) const;
///< \param type Will be ignored, unless the collection supports multiple record types
2013-12-30 18:41:16 +01:00
virtual std::vector<std::string> getIds (bool listDeleted) const;
///< Return a sorted collection of all IDs
///
/// \param listDeleted include deleted record in the list
2013-09-24 13:53:19 +02:00
2013-12-30 18:41:16 +01:00
virtual bool reorderRows (int baseIndex, const std::vector<int>& newOrder);
///< Reorder the rows [baseIndex, baseIndex+newOrder.size()) according to the indices
/// given in \a newOrder (baseIndex+newOrder[0] specifies the new index of row baseIndex).
///
/// \return Success?
2013-12-30 18:41:16 +01:00
void save (int index, ESM::ESMWriter& writer) const;
2013-12-30 13:23:16 +01:00
2013-12-30 18:41:16 +01:00
const RefIdData& getDataSet() const; //I can't figure out a better name for this one :(
};
}
#endif
2013-12-30 18:41:16 +01:00