1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253 |
- /*
- * Bael'Zharon's Respite
- * Copyright (C) 2014 Daniel Skorupski
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License along
- * with this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
- */
- #include "resource/PhysicsScriptTable.h"
- #include "BinReader.h"
- static void read(BinReader& reader, PhysicsScriptTableData& scripts)
- {
- uint32_t numScripts = reader.readInt();
- scripts.scripts.resize(numScripts);
- for(ScriptAndModData& script : scripts.scripts)
- {
- script.mod = reader.readFloat();
- script.scriptId = reader.readInt();
- assert((script.scriptId & 0xFF000000) == static_cast<uint32_t>(ResourceType::kPhysicsScript));
- }
- }
- PhysicsScriptTable::PhysicsScriptTable(uint32_t id, const void* data, size_t size) : ResourceImpl{id}
- {
- BinReader reader(data, size);
- uint32_t resourceId = reader.readInt();
- assert(resourceId == id);
- UNUSED(resourceId);
- uint32_t scriptTableSize = reader.readInt();
- for(uint32_t i = 0; i < scriptTableSize; i++)
- {
- uint32_t scriptType = reader.readInt();
- read(reader, scriptTable[scriptType]);
- }
- assert(reader.remaining() == 0);
- }
|