117 lines
2.8 KiB
C++
117 lines
2.8 KiB
C++
/*
|
|
* This file is part of the DXX-Rebirth project <https://www.dxx-rebirth.com/>.
|
|
* It is copyright by its individual contributors, as recorded in the
|
|
* project's Git history. See COPYING.txt at the top level for license
|
|
* terms and a link to the Git history.
|
|
*/
|
|
|
|
/*
|
|
*
|
|
* Segment Loading Stuff
|
|
*
|
|
*/
|
|
|
|
|
|
#include "segment.h"
|
|
#include "physfsx.h"
|
|
#include "physfs-serial.h"
|
|
#include "d_underlying_value.h"
|
|
|
|
namespace dcx {
|
|
|
|
namespace {
|
|
|
|
struct composite_side
|
|
{
|
|
const shared_side &sside;
|
|
const unique_side &uside;
|
|
};
|
|
|
|
DEFINE_SERIAL_UDT_TO_MESSAGE(composite_side, s, (s.sside.wall_num, s.uside.tmap_num, s.uside.tmap_num2));
|
|
ASSERT_SERIAL_UDT_MESSAGE_SIZE(composite_side, 6);
|
|
|
|
}
|
|
|
|
std::optional<sidenum_t> build_sidenum_from_untrusted(const uint8_t untrusted)
|
|
{
|
|
switch (untrusted)
|
|
{
|
|
case static_cast<uint8_t>(sidenum_t::WLEFT):
|
|
case static_cast<uint8_t>(sidenum_t::WTOP):
|
|
case static_cast<uint8_t>(sidenum_t::WRIGHT):
|
|
case static_cast<uint8_t>(sidenum_t::WBOTTOM):
|
|
case static_cast<uint8_t>(sidenum_t::WBACK):
|
|
case static_cast<uint8_t>(sidenum_t::WFRONT):
|
|
return sidenum_t{untrusted};
|
|
default:
|
|
return std::nullopt;
|
|
}
|
|
}
|
|
|
|
void segment_side_wall_tmap_write(PHYSFS_File *fp, const shared_side &sside, const unique_side &uside)
|
|
{
|
|
PHYSFSX_serialize_write(fp, composite_side{sside, uside});
|
|
}
|
|
|
|
}
|
|
|
|
#if defined(DXX_BUILD_DESCENT_II)
|
|
namespace dsx {
|
|
|
|
/*
|
|
* reads a delta_light structure from a PHYSFS_File
|
|
*/
|
|
void delta_light_read(delta_light *dl, PHYSFS_File *fp)
|
|
{
|
|
dl->segnum = PHYSFSX_readShort(fp);
|
|
dl->sidenum = PHYSFSX_readByte(fp);
|
|
PHYSFSX_readByte(fp);
|
|
dl->vert_light[0] = PHYSFSX_readByte(fp);
|
|
dl->vert_light[1] = PHYSFSX_readByte(fp);
|
|
dl->vert_light[2] = PHYSFSX_readByte(fp);
|
|
dl->vert_light[3] = PHYSFSX_readByte(fp);
|
|
}
|
|
|
|
|
|
/*
|
|
* reads a dl_index structure from a PHYSFS_File
|
|
*/
|
|
void dl_index_read(dl_index *di, PHYSFS_File *fp)
|
|
{
|
|
di->segnum = PHYSFSX_readShort(fp);
|
|
di->sidenum = PHYSFSX_readByte(fp);
|
|
di->count = PHYSFSX_readByte(fp);
|
|
di->index = PHYSFSX_readShort(fp);
|
|
}
|
|
|
|
void segment2_write(const cscusegment s2, PHYSFS_File *fp)
|
|
{
|
|
PHYSFSX_writeU8(fp, underlying_value(s2.s.special));
|
|
PHYSFSX_writeU8(fp, underlying_value(s2.s.matcen_num));
|
|
PHYSFSX_writeU8(fp, underlying_value(s2.s.station_idx));
|
|
PHYSFSX_writeU8(fp, s2.s.s2_flags);
|
|
PHYSFSX_writeFix(fp, s2.u.static_light);
|
|
}
|
|
|
|
void delta_light_write(const delta_light *dl, PHYSFS_File *fp)
|
|
{
|
|
PHYSFS_writeSLE16(fp, dl->segnum);
|
|
PHYSFSX_writeU8(fp, dl->sidenum);
|
|
PHYSFSX_writeU8(fp, 0);
|
|
PHYSFSX_writeU8(fp, dl->vert_light[0]);
|
|
PHYSFSX_writeU8(fp, dl->vert_light[1]);
|
|
PHYSFSX_writeU8(fp, dl->vert_light[2]);
|
|
PHYSFSX_writeU8(fp, dl->vert_light[3]);
|
|
}
|
|
|
|
void dl_index_write(const dl_index *di, PHYSFS_File *fp)
|
|
{
|
|
PHYSFS_writeSLE16(fp, di->segnum);
|
|
PHYSFSX_writeU8(fp, di->sidenum);
|
|
PHYSFSX_writeU8(fp, di->count);
|
|
PHYSFS_writeSLE16(fp, di->index);
|
|
}
|
|
|
|
}
|
|
#endif
|