File: endian.h

package info (click to toggle)
scummvm 2.9.1%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 450,580 kB
  • sloc: cpp: 4,299,825; asm: 28,322; python: 12,901; sh: 11,302; java: 9,289; xml: 7,895; perl: 2,639; ansic: 2,465; yacc: 1,670; javascript: 1,020; makefile: 933; lex: 578; awk: 275; objc: 82; sed: 11; php: 1
file content (114 lines) | stat: -rw-r--r-- 3,203 bytes parent folder | download | duplicates (3)
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
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
#include <cxxtest/TestSuite.h>
#include "common/endian.h"

class EndianTestSuite : public CxxTest::TestSuite
{
	public:
	void test_MKTAG() {
		const char *str_tag = "ABCD";
		uint32 tag = READ_BE_UINT32(str_tag);
		TS_ASSERT_EQUALS(MKTAG('A','B','C','D'), tag);
	}

	void test_READ_BE_UINT64() {
		const byte data[8] = {0x12, 0x34, 0x56, 0x78, 0x9A, 0xBC, 0xDE, 0xFF};
		uint64 value = READ_BE_UINT64(data);
		TS_ASSERT_EQUALS(value, 0x123456789ABCDEFFULL);
	}

	void test_READ_LE_UINT64() {
		const byte data[8] = {0x12, 0x34, 0x56, 0x78, 0x9A, 0xBC, 0xDE, 0xFF};
		uint64 value = READ_LE_UINT64(data);
		TS_ASSERT_EQUALS(value, 0xFFDEBC9A78563412ULL);
	}

	void test_READ_BE_UINT32() {
		const char data[4] = { 0x12, 0x34, 0x56, 0x78 };
		uint32 value = READ_BE_UINT32(data);
		TS_ASSERT_EQUALS(value, 0x12345678UL);
	}

	void test_READ_LE_UINT32() {
		const char data[4] = { 0x12, 0x34, 0x56, 0x78 };
		uint32 value = READ_LE_UINT32(data);
		TS_ASSERT_EQUALS(value, 0x78563412UL);
	}

	void test_READ_BE_UINT16() {
		const char data[4] = { 0x12, 0x34, 0x56, 0x78 };
		uint32 value = READ_BE_UINT16(data);
		TS_ASSERT_EQUALS(value, 0x1234UL);
	}

	void test_READ_LE_UINT16() {
		const char data[4] = { 0x12, 0x34, 0x56, 0x78 };
		uint32 value = READ_LE_UINT16(data);
		TS_ASSERT_EQUALS(value, 0x3412UL);
	}

	void test_READ_BE_FLOAT32() {
		const uint8 data[4] = { 0x40, 0x49, 0x0f, 0xdc };
		float value = READ_BE_FLOAT32(data);
		TS_ASSERT_EQUALS(value, 3.141593f);
	}

	void test_READ_LE_FLOAT32() {
		const uint8 data[4] = { 0xdc, 0x0f, 0x49, 0x40 };
		float value = READ_LE_FLOAT32(data);
		TS_ASSERT_EQUALS(value, 3.141593f);
	}

	void test_READ_BE_FLOAT64() {
		const uint8 data[8] = { 0x40, 0x09, 0x21, 0xfb, 0x82, 0xc2, 0xbd, 0x7f };
		double value = READ_BE_FLOAT64(data);
		TS_ASSERT_EQUALS(value, 3.141593);
	}

	void test_READ_LE_FLOAT64() {
		const uint8 data[8] = { 0x7f, 0xbd, 0xc2, 0x82, 0xfb, 0x21, 0x09, 0x40 };
		double value = READ_LE_FLOAT64(data);
		TS_ASSERT_EQUALS(value, 3.141593);
	}

	void test_READ_FPA_FLOAT64() {
		const uint8 data[8] = { 0xfb, 0x21, 0x09, 0x40, 0x7f, 0xbd, 0xc2, 0x82 };
		double value = READ_FPA_FLOAT64(data);
		TS_ASSERT_EQUALS(value, 3.141593);
	}

	void test_WRITE_BE_FLOAT32() {
		const uint8 data[4] = { 0x40, 0x49, 0x0f, 0xdc };
		uint8 out[4];
		WRITE_BE_FLOAT32(out, 3.141593f);
		TS_ASSERT_EQUALS(memcmp(data, out, 4), 0);
	}

	void test_WRITE_LE_FLOAT32() {
		const uint8 data[4] = { 0xdc, 0x0f, 0x49, 0x40 };
		uint8 out[4];
		WRITE_LE_FLOAT32(out, 3.141593f);
		TS_ASSERT_EQUALS(memcmp(data, out, 4), 0);
	}

	void test_WRITE_BE_FLOAT64() {
		const uint8 data[8] = { 0x40, 0x09, 0x21, 0xfb, 0x82, 0xc2, 0xbd, 0x7f };
		uint8 out[8];
		WRITE_BE_FLOAT64(out, 3.141593);
		TS_ASSERT_EQUALS(memcmp(data, out, 8), 0);
	}

	void test_WRITE_LE_FLOAT64() {
		const uint8 data[8] = { 0x7f, 0xbd, 0xc2, 0x82, 0xfb, 0x21, 0x09, 0x40 };
		uint8 out[8];
		WRITE_LE_FLOAT64(out, 3.141593);
		TS_ASSERT_EQUALS(memcmp(data, out, 8), 0);
	}

	void test_WRITE_FPA_FLOAT64() {
		const uint8 data[8] = { 0xfb, 0x21, 0x09, 0x40, 0x7f, 0xbd, 0xc2, 0x82 };
		uint8 out[8];
		WRITE_FPA_FLOAT64(out, 3.141593);
		TS_ASSERT_EQUALS(memcmp(data, out, 8), 0);
	}

};