Files
scummvm-cursorfix/engines/ags/tests/test_file.cpp
2026-02-02 04:50:13 +01:00

199 lines
5.9 KiB
C++

/* ScummVM - Graphic Adventure Engine
*
* ScummVM is the legal property of its developers, whose names
* are too numerous to list here. Please refer to the COPYRIGHT
* file distributed with this source distribution.
*
* 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 3 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, see <http://www.gnu.org/licenses/>.
*
*/
#include "ags/shared/core/platform.h"
//#include <string.h>
//#include "ags/shared/debugging/assert.h"
// File not present??
#include "common/scummsys.h"
#include "ags/shared/util/aligned_stream.h"
#include "ags/shared/util/file.h"
namespace AGS3 {
using namespace AGS::Shared;
struct TTrickyAlignedData {
char a;
int b;
int c;
short d[3];
int e;
char f[17];
int g[4];
short h[13];
char i[3];
short j;
int k;
short l;
short m;
int n;
int64_t i64a;
char o;
int64_t i64b;
short p;
int64_t i64c;
short q;
short r;
int64_t i64d;
char final;
};
void Test_File() {
//-----------------------------------------------------
// Operations
Stream *out = File::OpenFile("test.tmp", AGS::Shared::kFile_CreateAlways, AGS::Shared::kFile_Write);
out->WriteInt16(10);
out->WriteInt64(-20202);
//String::WriteString("test.tmp", out);
String("test.tmp").Write(out);
String very_long_string;
very_long_string.FillString('a', 10000);
very_long_string.Write(out);
TTrickyAlignedData tricky_data_out;
memset(&tricky_data_out, 0xAA, sizeof(tricky_data_out));
{
tricky_data_out.a = 11;
tricky_data_out.b = 12;
tricky_data_out.c = 13;
tricky_data_out.d[0] = 14;
tricky_data_out.d[1] = 15;
tricky_data_out.d[2] = 16;
tricky_data_out.e = 17;
memset(tricky_data_out.f, 0, 17);
tricky_data_out.g[0] = 18;
tricky_data_out.g[1] = 19;
tricky_data_out.g[2] = 20;
tricky_data_out.g[3] = 21;
memset(tricky_data_out.h, 0, 13 * sizeof(short));
tricky_data_out.i[0] = 22;
tricky_data_out.i[1] = 23;
tricky_data_out.i[2] = 24;
tricky_data_out.j = 25;
tricky_data_out.k = 26;
tricky_data_out.l = 27;
tricky_data_out.m = 28;
tricky_data_out.n = 29;
tricky_data_out.i64a = 30;
tricky_data_out.o = 31;
tricky_data_out.i64b = 32;
tricky_data_out.p = 33;
tricky_data_out.i64c = 34;
tricky_data_out.q = 35;
tricky_data_out.r = 36;
tricky_data_out.i64d = 37;
tricky_data_out.final = 38;
#if defined (TEST_BIGENDIAN)
TTrickyAlignedData bigend_data = tricky_data_out;
bigend_data.b = BBOp::SwapBytesInt32(bigend_data.b);
bigend_data.c = BBOp::SwapBytesInt32(bigend_data.c);
for (int i = 0; i < 3; ++i) {
bigend_data.d[i] = BBOp::SwapBytesInt16(bigend_data.d[i]);
}
bigend_data.e = BBOp::SwapBytesInt32(bigend_data.e);
for (int i = 0; i < 4; ++i) {
bigend_data.g[i] = BBOp::SwapBytesInt32(bigend_data.g[i]);
}
for (int i = 0; i < 13; ++i) {
bigend_data.h[i] = BBOp::SwapBytesInt16(bigend_data.h[i]);
}
bigend_data.j = BBOp::SwapBytesInt16(bigend_data.j);
bigend_data.k = BBOp::SwapBytesInt32(bigend_data.k);
bigend_data.l = BBOp::SwapBytesInt16(bigend_data.l);
bigend_data.m = BBOp::SwapBytesInt16(bigend_data.m);
bigend_data.n = BBOp::SwapBytesInt32(bigend_data.n);
bigend_data.i64a = BBOp::SwapBytesInt64(bigend_data.i64a);
bigend_data.i64b = BBOp::SwapBytesInt64(bigend_data.i64b);
bigend_data.p = BBOp::SwapBytesInt16(bigend_data.p);
bigend_data.i64c = BBOp::SwapBytesInt64(bigend_data.i64c);
bigend_data.q = BBOp::SwapBytesInt16(bigend_data.q);
bigend_data.r = BBOp::SwapBytesInt16(bigend_data.r);
bigend_data.i64d = BBOp::SwapBytesInt64(bigend_data.i64d);
out->Write(&bigend_data, sizeof(TTrickyAlignedData));
#else
out->Write(&tricky_data_out, sizeof(TTrickyAlignedData));
#endif
}
out->WriteInt32(20);
delete out;
//-------------------------------------------------------------------------
Stream *in = File::OpenFile("test.tmp", AGS::Shared::kFile_Open, AGS::Shared::kFile_Read);
int16_t int16val = in->ReadInt16();
int64_t int64val = in->ReadInt64();
String str1 = String::FromStream(in);
String str2 = String::FromStream(in);
TTrickyAlignedData tricky_data_in;
memset(&tricky_data_in, 0xAA, sizeof(tricky_data_in));
{
AlignedStream as(in, AGS::Shared::kAligned_Read);
tricky_data_in.a = as.ReadInt8();
tricky_data_in.b = as.ReadInt32();
tricky_data_in.c = as.ReadInt32();
as.ReadArrayOfInt16(tricky_data_in.d, 3);
tricky_data_in.e = as.ReadInt32();
as.Read(tricky_data_in.f, 17);
as.ReadArrayOfInt32(tricky_data_in.g, 4);
as.ReadArrayOfInt16(tricky_data_in.h, 13);
as.Read(tricky_data_in.i, 3);
tricky_data_in.j = as.ReadInt16();
tricky_data_in.k = as.ReadInt32();
tricky_data_in.l = as.ReadInt16();
tricky_data_in.m = as.ReadInt16();
tricky_data_in.n = as.ReadInt32();
tricky_data_in.i64a = as.ReadInt64();
tricky_data_in.o = as.ReadInt8();
tricky_data_in.i64b = as.ReadInt64();
tricky_data_in.p = as.ReadInt16();
tricky_data_in.i64c = as.ReadInt64();
tricky_data_in.q = as.ReadInt16();
tricky_data_in.r = as.ReadInt16();
tricky_data_in.i64d = as.ReadInt64();
tricky_data_in.final = as.ReadInt8();
}
int32_t int32val = in->ReadInt32();
delete in;
File::DeleteFile("test.tmp");
//-----------------------------------------------------
// Assertions
assert(int16val == 10);
assert(int64val == -20202);
assert(strcmp(str1, "test.tmp") == 0);
assert(strcmp(str2, very_long_string) == 0);
assert(memcmp(&tricky_data_in, &tricky_data_out, sizeof(TTrickyAlignedData)) == 0);
assert(int32val == 20);
assert(!File::TestReadFile("test.tmp"));
}
} // namespace AGS3