blob: a2a21d55204765cd24d13aa7c465794dac8bd2b5 (
plain)
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
|
#include "nbt.h"
#include "map.h"
#include <stdlib.h>
void tag_free(tag_t *tag) {
if (tag->name_len > 0 && tag->name != NULL)
free(tag->name);
switch(tag->type) {
case TAG_END:
case TAG_BYTE:
case TAG_SHORT:
case TAG_INT:
case TAG_LONG:
case TAG_FLOAT:
case TAG_DOUBLE:
break;
case TAG_BYTE_ARRAY:
free(tag->data.b_arr.data);
break;
case TAG_STRING:
free(tag->data.string.data);
break;
case TAG_LIST:
for (int32_t i = 0; i < tag->data.list.size; i++)
tag_free(&tag->data.list.tags[i]);
free(tag->data.list.tags);
break;
case TAG_COMPOUND:
map_free(&tag->data.compound);
break;
case TAG_INT_ARRAY:
free(tag->data.i_arr.data);
break;
case TAG_LONG_ARRAY:
free(tag->data.l_arr.data);
break;
}
}
bool tag_read(tag_t *tag, const stream_t *stream, format_t format) {
switch (format) {
case JSON:
return json_read(tag, stream);
case NBT:
return nbt_read(tag, stream);
case SNBT:
return snbt_read(tag, stream);
default:
return false;
}
}
bool tag_print(tag_t *tag, const stream_t *stream, format_t format) {
switch (format) {
case JSON:
return json_print(tag, stream);
case NBT:
return nbt_print(tag, stream);
case SNBT:
return snbt_print(tag, stream);
default:
return false;
}
}
|