summaryrefslogtreecommitdiffstats
path: root/tests/ChunkData/ArraytoCoord.cpp
blob: 1138fb5b6f3dfb2749bf0eccb806b32358281d60 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86

#include "TestGlobals.h"
#include "ChunkData.h"



int main(int argc, char** argv)
{
	{
		// Test first segment
		cChunkData buffer;

		BLOCKTYPE SrcBlockBuffer[16 * 16 * 256];
		memset(SrcBlockBuffer, 0x00, 16 * 16 * 256);
		SrcBlockBuffer[7 + (4 * 16) + (5 * 16 * 16)] = 0xCD;
		buffer.SetBlocks(SrcBlockBuffer);
		testassert(buffer.GetBlock(7,5,4) == 0xCD);
	
		NIBBLETYPE SrcNibbleBuffer[16 * 16 * 256 / 2];
		memset(SrcNibbleBuffer, 0x00, 16 * 16 * 256 / 2);
		SrcNibbleBuffer[(6 + (1 * 16) + (2 * 16 * 16)) / 2] = 0xE;
		buffer.SetMeta(SrcNibbleBuffer);
		testassert(buffer.GetMeta(6, 2, 1) == 0xE);
	
		memset(SrcNibbleBuffer, 0x00, 16 * 16 * 256 / 2);
		SrcNibbleBuffer[(6 + (1 * 16) + (2 * 16 * 16)) / 2] = 0xE;
		buffer.SetBlockLight(SrcNibbleBuffer);
		testassert(buffer.GetBlockLight(6, 2, 1) == 0xE);
	
		memset(SrcNibbleBuffer, 0x00, 16 * 16 * 256 / 2);
		SrcNibbleBuffer[(6 + (1 * 16) + (2 * 16 * 16)) / 2] = 0xE;
		buffer.SetSkyLight(SrcNibbleBuffer);
		testassert(buffer.GetSkyLight(6, 2, 1) == 0xE);
	}
	
	{
		// test following segment
		cChunkData buffer;

		BLOCKTYPE SrcBlockBuffer[16 * 16 * 256];
		memset(SrcBlockBuffer, 0x00, 16 * 16 * 256);
		SrcBlockBuffer[7 + (4 * 16) + (24 * 16 * 16)] = 0xCD;
		buffer.SetBlocks(SrcBlockBuffer);
		testassert(buffer.GetBlock(7, 24, 4) == 0xCD);
	
		NIBBLETYPE SrcNibbleBuffer[16 * 16 * 256 / 2];
		memset(SrcNibbleBuffer, 0x00, 16 * 16 * 256 / 2);
		SrcNibbleBuffer[(6 + (1 * 16) + (24 * 16 * 16)) / 2] = 0xE;
		buffer.SetMeta(SrcNibbleBuffer);
		testassert(buffer.GetMeta(6, 24, 1) == 0xE);
	
		memset(SrcNibbleBuffer, 0x00, 16 * 16 * 256 /2);
		SrcNibbleBuffer[(6+1*16+24*16*16)/2] = 0xE;
		buffer.SetBlockLight(SrcNibbleBuffer);
		testassert(buffer.GetBlockLight(6,24,1) == 0xE);
	
		memset(SrcNibbleBuffer, 0xFF, 16 * 16 * 256 / 2);
		SrcNibbleBuffer[(6 + (1 * 16) + (24 * 16 * 16))/2] = 0xE;
		buffer.SetSkyLight(SrcNibbleBuffer);
		testassert(buffer.GetSkyLight(6, 24, 1) == 0xE);
	}
	
	{
		// test zeros
		cChunkData buffer;

		BLOCKTYPE SrcBlockBuffer[16 * 16 * 256];
		memset(SrcBlockBuffer, 0x00, 16 * 16 * 256);
		buffer.SetBlocks(SrcBlockBuffer);
		testassert(buffer.GetBlock(7, 24, 4) == 0x00);
	
		NIBBLETYPE SrcNibbleBuffer[16 * 16 * 256/2];
		memset(SrcNibbleBuffer, 0x00, 16 * 16 * 256 /2);
		buffer.SetMeta(SrcNibbleBuffer);
		testassert(buffer.GetMeta(6, 24, 1) == 0x0);
	
		memset(SrcNibbleBuffer, 0x00, 16 * 16 * 256 /2);
		buffer.SetBlockLight(SrcNibbleBuffer);
		testassert(buffer.GetBlockLight(6,24,1) == 0x0);
	
		memset(SrcNibbleBuffer, 0xFF, 16 * 16 * 256 /2);
		buffer.SetSkyLight(SrcNibbleBuffer);
		testassert(buffer.GetSkyLight(6, 24, 1) == 0xF);
	}
}