1
0
Fork 0
mirror of https://github.com/OpenMW/openmw.git synced 2025-10-25 07:26:36 +00:00
openmw/components/esm/loadcont.hpp
scrawl 49d912e5b6 Don't rely on subrecord order part 2
Nice side effects:
 - Subrecord name comparison now uses magic number instead of string (faster)
 - Improves the error message for unknown subrecords: will print the record in question instead of failing to read the next record with a strange error
2015-02-12 05:43:22 +01:00

60 lines
1,021 B
C++

#ifndef OPENMW_ESM_CONT_H
#define OPENMW_ESM_CONT_H
#include <string>
#include <vector>
#include "esmcommon.hpp"
namespace ESM
{
class ESMReader;
class ESMWriter;
/*
* Container definition
*/
struct ContItem
{
int mCount;
NAME32 mItem;
};
/// InventoryList, NPCO subrecord
struct InventoryList
{
std::vector<ContItem> mList;
/// Load one item, assumes subrecord name is already read
void add(ESMReader &esm);
void save(ESMWriter &esm) const;
};
struct Container
{
static unsigned int sRecordId;
enum Flags
{
Organic = 1, // Objects cannot be placed in this container
Respawn = 2, // Respawns after 4 months
Unknown = 8
};
std::string mId, mName, mModel, mScript;
float mWeight; // Not sure, might be max total weight allowed?
int mFlags;
InventoryList mInventory;
void load(ESMReader &esm);
void save(ESMWriter &esm) const;
void blank();
///< Set record to default state (does not touch the ID).
};
}
#endif