openmw-tes3coop/apps/opencs/model/world/refidcollection.hpp

145 lines
4.9 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 "nestedcollection.hpp"
#include "refiddata.hpp"
2013-09-24 11:53:19 +00:00
namespace ESM
{
class ESMWriter;
}
namespace CSMWorld
{
class RefIdAdapter;
2015-04-09 10:53:41 +00:00
struct NestedTableWrapperBase;
class NestedRefIdAdapterBase;
class RefIdColumn : public NestableColumn
{
bool mEditable;
bool mUserEditable;
public:
2013-12-30 17:41:16 +00: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, public NestedCollection
{
private:
RefIdData mData;
std::deque<RefIdColumn> mColumns;
2013-12-30 17:41:16 +00:00
std::map<UniversalId::Type, RefIdAdapter *> mAdapters;
std::vector<std::pair<const ColumnBase*, std::map<UniversalId::Type, NestedRefIdAdapterBase*> > > mNestedAdapters;
private:
2015-04-11 01:26:29 +00:00
const RefIdAdapter& findAdapter (UniversalId::Type) const;
///< Throws an exception if no adaptor for \a Type can be found.
const NestedRefIdAdapterBase& getNestedAdapter(const ColumnBase &column, UniversalId::Type type) const;
public:
RefIdCollection();
virtual ~RefIdCollection();
virtual int getSize() const;
2013-12-30 17:41:16 +00:00
virtual std::string getId (int index) const;
2013-12-30 17:41:16 +00:00
virtual int getIndex (const std::string& id) const;
virtual int getColumns() const;
2013-12-30 17:41:16 +00:00
virtual const ColumnBase& getColumn (int column) const;
2013-12-30 17:41:16 +00:00
virtual QVariant getData (int index, int column) const;
2013-12-30 17:41:16 +00:00
virtual void setData (int index, int column, const QVariant& data);
2013-12-30 17:41:16 +00:00
virtual void removeRows (int index, int count);
2014-07-17 10:41:43 +00:00
virtual void cloneRecord(const std::string& origin,
const std::string& destination,
2014-01-27 12:08:14 +00:00
const UniversalId::Type type);
2014-01-27 18:40:05 +00:00
2013-12-30 17:41:16 +00: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 17:41:16 +00: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 17:41:16 +00: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 17:41:16 +00: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 17:41:16 +00:00
virtual const RecordBase& getRecord (const std::string& id) const;
2013-12-30 17:41:16 +00:00
virtual const RecordBase& getRecord (int index) const;
2013-12-30 17:41:16 +00:00
void load (ESM::ESMReader& reader, bool base, UniversalId::Type type);
2013-12-30 17:41:16 +00: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 17:41:16 +00: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 11:53:19 +00:00
2013-12-30 17:41:16 +00: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?
virtual QVariant getNestedData(int row, int column, int subRow, int subColumn) const;
virtual NestedTableWrapperBase* nestedTable(int row, int column) const;
virtual void setNestedTable(int row, int column, const NestedTableWrapperBase& nestedTable);
virtual int getNestedRowsCount(int row, int column) const;
virtual int getNestedColumnsCount(int row, int column) const;
NestableColumn *getNestableColumn(int column);
virtual void setNestedData(int row, int column, const QVariant& data, int subRow, int subColumn);
virtual void removeNestedRows(int row, int column, int subRow);
virtual void addNestedRow(int row, int col, int position);
2013-12-30 17:41:16 +00:00
void save (int index, ESM::ESMWriter& writer) const;
2013-12-30 12:23:16 +00:00
2014-07-17 10:41:43 +00:00
const RefIdData& getDataSet() const; //I can't figure out a better name for this one :(
};
}
#endif