2018-04-08 02:27:36 +00:00
|
|
|
#ifndef OPENMW_CELLNAMELOADER_H
|
|
|
|
#define OPENMW_CELLNAMELOADER_H
|
|
|
|
|
|
|
|
#include <QSet>
|
|
|
|
#include <QString>
|
|
|
|
|
2022-01-22 14:58:41 +00:00
|
|
|
#include <components/esm3/esmreader.hpp>
|
2018-04-08 02:27:36 +00:00
|
|
|
|
2022-09-22 18:26:05 +00:00
|
|
|
namespace ESM
|
|
|
|
{
|
|
|
|
class ESMReader;
|
|
|
|
struct Cell;
|
|
|
|
}
|
|
|
|
namespace ContentSelectorView
|
|
|
|
{
|
|
|
|
class ContentSelector;
|
|
|
|
}
|
|
|
|
|
|
|
|
class CellNameLoader
|
|
|
|
{
|
2018-04-08 02:27:36 +00:00
|
|
|
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
* Returns the names of all cells contained within the given content files
|
|
|
|
* @param contentPaths the file paths of each content file to be examined
|
|
|
|
* @return the names of all cells
|
|
|
|
*/
|
2023-03-20 22:57:53 +00:00
|
|
|
QSet<QString> getCellNames(const QStringList& contentPaths);
|
2018-04-08 02:27:36 +00:00
|
|
|
|
|
|
|
private:
|
|
|
|
/**
|
|
|
|
* Returns whether or not the given record is of type "Cell"
|
|
|
|
* @param name The name associated with the record
|
|
|
|
* @return whether or not the given record is of type "Cell"
|
|
|
|
*/
|
2022-09-22 18:26:05 +00:00
|
|
|
bool isCellRecord(ESM::NAME& name);
|
2018-04-08 02:27:36 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the name of the cell
|
|
|
|
* @param esmReader the reader currently pointed to a loaded cell
|
|
|
|
* @return the name of the cell
|
|
|
|
*/
|
2022-09-22 18:26:05 +00:00
|
|
|
QString getCellName(ESM::ESMReader& esmReader);
|
2018-04-08 02:27:36 +00:00
|
|
|
};
|
|
|
|
|
2022-09-22 18:26:05 +00:00
|
|
|
#endif // OPENMW_CELLNAMELOADER_H
|