/* 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 . * */ #include "ags/shared/core/platform.h" //#include //#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