1
0
mirror of https://gitlab.com/OpenMW/openmw.git synced 2025-01-26 18:35:20 +00:00
OpenMW/components/nif/niffile.hpp

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

160 lines
4.9 KiB
C++
Raw Normal View History

/// Main header for reading .nif files
#ifndef OPENMW_COMPONENTS_NIF_NIFFILE_HPP
#define OPENMW_COMPONENTS_NIF_NIFFILE_HPP
#include <atomic>
#include <filesystem>
#include <vector>
#include <components/files/istreamptr.hpp>
2015-02-17 17:08:55 +01:00
#include "record.hpp"
2010-01-04 19:35:11 +01:00
2010-01-06 12:28:37 +01:00
namespace Nif
{
struct NIFFile
2018-07-08 22:22:34 +03:00
{
// For generic versions NIFStream::generateVersion() is used instead
enum NIFVersion
{
VER_MW = 0x04000002, // 4.0.0.2. Main Morrowind NIF version.
VER_OB_OLD = 0x0A000102, // 10.0.1.2. Main older Oblivion NIF version.
VER_OB = 0x14000005, // 20.0.0.5. Main Oblivion NIF version.
VER_BGS = 0x14020007 // 20.2.0.7. Main Fallout 3/4/76/New Vegas and Skyrim/SkyrimSE NIF version.
};
enum BethVersion
{
BETHVER_FO3 = 34, // Fallout 3
2023-05-22 22:28:05 +03:00
BETHVER_SKY = 83, // Skyrim
2023-07-09 10:14:27 +00:00
BETHVER_SSE = 100, // Skyrim SE
BETHVER_FO4 = 130, // Fallout 4
BETHVER_F76 = 155, // Fallout 76
BETHVER_STF = 172, // Starfield
};
2018-07-08 22:22:34 +03:00
/// File version, user version, Bethesda version
std::uint32_t mVersion = 0;
std::uint32_t mUserVersion = 0;
std::uint32_t mBethVersion = 0;
2018-07-08 22:22:34 +03:00
/// File name, used for error messages and opening the file
std::filesystem::path mPath;
std::string mHash;
2018-07-08 22:22:34 +03:00
/// Record list
std::vector<std::unique_ptr<Record>> mRecords;
/// Root list. This is a select portion of the pointers from records
std::vector<Record*> mRoots;
bool mUseSkinning = false;
explicit NIFFile(const std::filesystem::path& path)
: mPath(path)
{
}
};
class FileView
{
public:
FileView(const NIFFile& file)
: mFile(&file)
{
}
2018-07-08 22:22:34 +03:00
/// Get a given root
const Record* getRoot(std::size_t index) const { return mFile->mRoots.at(index); }
2018-07-08 22:22:34 +03:00
/// Number of roots
std::size_t numRoots() const { return mFile->mRoots.size(); }
/// Get the name of the file
const std::filesystem::path& getFilename() const { return mFile->mPath; }
const std::string& getHash() const { return mFile->mHash; }
/// Get the version of the NIF format used
std::uint32_t getVersion() const { return mFile->mVersion; }
/// Get the user version of the NIF format used
std::uint32_t getUserVersion() const { return mFile->mUserVersion; }
2018-07-08 22:22:34 +03:00
/// Get the Bethesda version of the NIF format used
std::uint32_t getBethVersion() const { return mFile->mBethVersion; }
bool getUseSkinning() const { return mFile->mUseSkinning; }
private:
const NIFFile* mFile;
2021-11-15 17:40:22 +01:00
};
class Reader
2022-09-22 21:26:05 +03:00
{
/// File version, user version, Bethesda version
std::uint32_t& mVersion;
std::uint32_t& mUserVersion;
std::uint32_t& mBethVersion;
/// File name, used for error messages and opening the file
std::filesystem::path& mFilename;
std::string& mHash;
/// Record list
std::vector<std::unique_ptr<Record>>& mRecords;
/// Root list. This is a select portion of the pointers from records
std::vector<Record*>& mRoots;
/// String table
std::vector<std::string> mStrings;
bool& mUseSkinning;
2010-01-07 19:11:03 +01:00
static std::atomic_bool sLoadUnsupportedFiles;
static std::atomic_bool sWriteNifDebugLog;
2020-02-02 17:08:17 +03:00
/// Get the file's version in a human readable form
///\returns A string containing a human readable NIF version number
std::string versionToString(std::uint32_t version);
2022-09-22 21:26:05 +03:00
public:
2018-07-08 22:22:34 +03:00
/// Open a NIF stream. The name is used for error messages.
explicit Reader(NIFFile& file);
/// Parse the file
void parse(Files::IStreamPtr&& stream);
/// Get a given record
Record* getRecord(size_t index) const { return mRecords.at(index).get(); }
/// Get a given string from the file's string table
std::string getString(std::uint32_t index) const;
/// Set whether there is skinning contained in this NIF file.
/// @note This is just a hint for users of the NIF file and has no effect on the loading procedure.
void setUseSkinning(bool skinning);
/// Get the name of the file
std::filesystem::path getFilename() const { return mFilename; }
/// Get the version of the NIF format used
std::uint32_t getVersion() const { return mVersion; }
/// Get the user version of the NIF format used
std::uint32_t getUserVersion() const { return mUserVersion; }
2010-01-06 12:28:37 +01:00
/// Get the Bethesda version of the NIF format used
std::uint32_t getBethVersion() const { return mBethVersion; }
static void setLoadUnsupportedFiles(bool load);
static void setWriteNifDebugLog(bool load);
2022-09-22 21:26:05 +03:00
};
using NIFFilePtr = std::shared_ptr<const Nif::NIFFile>;
2010-01-06 12:28:37 +01:00
} // Namespace
#endif