amulet-core 2.0a5__cp312-cp312-win_amd64.whl → 2.0a7__cp312-cp312-win_amd64.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of amulet-core might be problematic. Click here for more details.
- amulet/__init__.cp312-win_amd64.pyd +0 -0
- amulet/__init__.py.cpp +43 -0
- amulet/__init__.pyi +0 -2
- amulet/_init.py +0 -2
- amulet/_version.py +3 -3
- amulet/biome.py.cpp +122 -0
- amulet/biome.pyi +0 -2
- amulet/block.py.cpp +377 -0
- amulet/block.pyi +0 -2
- amulet/block_entity.py.cpp +115 -0
- amulet/block_entity.pyi +0 -2
- amulet/chunk.py.cpp +80 -0
- amulet/chunk.pyi +0 -2
- amulet/chunk_components/biome_3d_component.cpp +5 -0
- amulet/chunk_components/biome_3d_component.hpp +79 -0
- amulet/chunk_components/block_component.cpp +41 -0
- amulet/chunk_components/block_component.hpp +88 -0
- amulet/chunk_components/block_entity_component.cpp +5 -0
- amulet/chunk_components/block_entity_component.hpp +147 -0
- amulet/chunk_components/section_array_map.cpp +129 -0
- amulet/chunk_components/section_array_map.hpp +147 -0
- amulet/chunk_components.pyi +20 -18
- amulet/collections/eq.py.hpp +37 -0
- amulet/collections/hash.py.hpp +27 -0
- amulet/collections/holder.py.hpp +37 -0
- amulet/collections/iterator.py.hpp +80 -0
- amulet/collections/mapping.py.hpp +199 -0
- amulet/collections/mutable_mapping.py.hpp +226 -0
- amulet/collections/sequence.py.hpp +163 -0
- amulet/collections.pyi +8 -5
- amulet/entity.py +22 -20
- amulet/game/translate/_functions/_code_functions/_text.py +2 -2
- amulet/game/translate/_functions/abc.py +10 -3
- amulet/img/__init__.py +10 -0
- amulet/img/missing_no.png +0 -0
- amulet/img/missing_pack.png +0 -0
- amulet/img/missing_world.png +0 -0
- amulet/io/binary_reader.hpp +45 -0
- amulet/io/binary_writer.hpp +30 -0
- amulet/level/__init__.pyi +2 -6
- amulet/level/abc/_level/_creatable_level.py +1 -2
- amulet/level/abc/_level/_level.py +1 -5
- amulet/level/java/__init__.pyi +0 -5
- amulet/level/java/_raw/__init__.pyi +0 -4
- amulet/level/java/_raw/java_chunk_decode.cpp +531 -0
- amulet/level/java/_raw/java_chunk_decode.hpp +23 -0
- amulet/level/java/_raw/java_chunk_encode.cpp +25 -0
- amulet/level/java/_raw/java_chunk_encode.hpp +23 -0
- amulet/level/java/chunk_components/data_version_component.cpp +32 -0
- amulet/level/java/chunk_components/data_version_component.hpp +31 -0
- amulet/level/java/chunk_components/java_raw_chunk_component.cpp +56 -0
- amulet/level/java/chunk_components/java_raw_chunk_component.hpp +45 -0
- amulet/level/java/java_chunk.cpp +170 -0
- amulet/level/java/java_chunk.hpp +141 -0
- amulet/level/java/long_array.hpp +175 -0
- amulet/level/java/long_array.pyi +2 -1
- amulet/mesh/block/__init__.py +1 -0
- amulet/mesh/block/block_mesh.py +369 -0
- amulet/mesh/block/cube.py +149 -0
- amulet/mesh/block/missing_block.py +20 -0
- amulet/mesh/util.py +17 -0
- amulet/palette/biome_palette.hpp +85 -0
- amulet/palette/block_palette.cpp +32 -0
- amulet/palette/block_palette.hpp +93 -0
- amulet/player.py +4 -6
- amulet/pybind11/collections.hpp +118 -0
- amulet/pybind11/numpy.hpp +26 -0
- amulet/pybind11/py_module.hpp +34 -0
- amulet/pybind11/type_hints.hpp +51 -0
- amulet/pybind11/types.hpp +25 -0
- amulet/pybind11/typing.hpp +7 -0
- amulet/resource_pack/__init__.py +62 -0
- amulet/resource_pack/abc/__init__.py +2 -0
- amulet/resource_pack/abc/resource_pack.py +38 -0
- amulet/resource_pack/abc/resource_pack_manager.py +87 -0
- amulet/resource_pack/bedrock/__init__.py +2 -0
- amulet/resource_pack/bedrock/bedrock_vanilla_fix/pack_icon.png +0 -0
- amulet/resource_pack/bedrock/bedrock_vanilla_fix/textures/blocks/grass_carried.png +0 -0
- amulet/resource_pack/bedrock/bedrock_vanilla_fix/textures/blocks/grass_side_carried.png +0 -0
- amulet/resource_pack/bedrock/bedrock_vanilla_fix/textures/blocks/water.png +0 -0
- amulet/resource_pack/bedrock/blockshapes/__init__.py +31 -0
- amulet/resource_pack/bedrock/blockshapes/air.py +35 -0
- amulet/resource_pack/bedrock/blockshapes/base_blockshape.py +29 -0
- amulet/resource_pack/bedrock/blockshapes/bubble_column.py +29 -0
- amulet/resource_pack/bedrock/blockshapes/cake.py +46 -0
- amulet/resource_pack/bedrock/blockshapes/chest.py +54 -0
- amulet/resource_pack/bedrock/blockshapes/comparator.py +51 -0
- amulet/resource_pack/bedrock/blockshapes/cross_texture.py +186 -0
- amulet/resource_pack/bedrock/blockshapes/cross_texture0.py +17 -0
- amulet/resource_pack/bedrock/blockshapes/cross_texture_green.py +16 -0
- amulet/resource_pack/bedrock/blockshapes/cube.py +38 -0
- amulet/resource_pack/bedrock/blockshapes/default.py +14 -0
- amulet/resource_pack/bedrock/blockshapes/door.py +38 -0
- amulet/resource_pack/bedrock/blockshapes/door1.py +14 -0
- amulet/resource_pack/bedrock/blockshapes/door2.py +14 -0
- amulet/resource_pack/bedrock/blockshapes/door3.py +14 -0
- amulet/resource_pack/bedrock/blockshapes/door4.py +14 -0
- amulet/resource_pack/bedrock/blockshapes/door5.py +14 -0
- amulet/resource_pack/bedrock/blockshapes/door6.py +14 -0
- amulet/resource_pack/bedrock/blockshapes/double_plant.py +40 -0
- amulet/resource_pack/bedrock/blockshapes/enchanting_table.py +22 -0
- amulet/resource_pack/bedrock/blockshapes/farmland.py +22 -0
- amulet/resource_pack/bedrock/blockshapes/fence.py +22 -0
- amulet/resource_pack/bedrock/blockshapes/flat.py +55 -0
- amulet/resource_pack/bedrock/blockshapes/flat_wall.py +55 -0
- amulet/resource_pack/bedrock/blockshapes/furnace.py +44 -0
- amulet/resource_pack/bedrock/blockshapes/furnace_lit.py +14 -0
- amulet/resource_pack/bedrock/blockshapes/green_cube.py +39 -0
- amulet/resource_pack/bedrock/blockshapes/ladder.py +36 -0
- amulet/resource_pack/bedrock/blockshapes/lilypad.py +14 -0
- amulet/resource_pack/bedrock/blockshapes/partial_block.py +57 -0
- amulet/resource_pack/bedrock/blockshapes/piston.py +44 -0
- amulet/resource_pack/bedrock/blockshapes/piston_arm.py +72 -0
- amulet/resource_pack/bedrock/blockshapes/portal_frame.py +22 -0
- amulet/resource_pack/bedrock/blockshapes/pressure_plate.py +29 -0
- amulet/resource_pack/bedrock/blockshapes/pumpkin.py +36 -0
- amulet/resource_pack/bedrock/blockshapes/pumpkin_carved.py +14 -0
- amulet/resource_pack/bedrock/blockshapes/pumpkin_lit.py +14 -0
- amulet/resource_pack/bedrock/blockshapes/red_dust.py +14 -0
- amulet/resource_pack/bedrock/blockshapes/repeater.py +53 -0
- amulet/resource_pack/bedrock/blockshapes/slab.py +33 -0
- amulet/resource_pack/bedrock/blockshapes/slab_double.py +15 -0
- amulet/resource_pack/bedrock/blockshapes/tree.py +41 -0
- amulet/resource_pack/bedrock/blockshapes/turtle_egg.py +15 -0
- amulet/resource_pack/bedrock/blockshapes/vine.py +52 -0
- amulet/resource_pack/bedrock/blockshapes/wall.py +22 -0
- amulet/resource_pack/bedrock/blockshapes/water.py +38 -0
- amulet/resource_pack/bedrock/download_resources.py +147 -0
- amulet/resource_pack/bedrock/resource_pack.py +40 -0
- amulet/resource_pack/bedrock/resource_pack_manager.py +361 -0
- amulet/resource_pack/bedrock/sort_blockshapes.py +15 -0
- amulet/resource_pack/java/__init__.py +2 -0
- amulet/resource_pack/java/download_resources.py +212 -0
- amulet/resource_pack/java/java_vanilla_fix/assets/minecraft/textures/block/banner/banner_black.png +0 -0
- amulet/resource_pack/java/java_vanilla_fix/assets/minecraft/textures/block/banner/banner_blue.png +0 -0
- amulet/resource_pack/java/java_vanilla_fix/assets/minecraft/textures/block/banner/banner_brown.png +0 -0
- amulet/resource_pack/java/java_vanilla_fix/assets/minecraft/textures/block/banner/banner_cyan.png +0 -0
- amulet/resource_pack/java/java_vanilla_fix/assets/minecraft/textures/block/banner/banner_gray.png +0 -0
- amulet/resource_pack/java/java_vanilla_fix/assets/minecraft/textures/block/banner/banner_green.png +0 -0
- amulet/resource_pack/java/java_vanilla_fix/assets/minecraft/textures/block/banner/banner_light_blue.png +0 -0
- amulet/resource_pack/java/java_vanilla_fix/assets/minecraft/textures/block/banner/banner_light_gray.png +0 -0
- amulet/resource_pack/java/java_vanilla_fix/assets/minecraft/textures/block/banner/banner_lime.png +0 -0
- amulet/resource_pack/java/java_vanilla_fix/assets/minecraft/textures/block/banner/banner_magenta.png +0 -0
- amulet/resource_pack/java/java_vanilla_fix/assets/minecraft/textures/block/banner/banner_orange.png +0 -0
- amulet/resource_pack/java/java_vanilla_fix/assets/minecraft/textures/block/banner/banner_pink.png +0 -0
- amulet/resource_pack/java/java_vanilla_fix/assets/minecraft/textures/block/banner/banner_purple.png +0 -0
- amulet/resource_pack/java/java_vanilla_fix/assets/minecraft/textures/block/banner/banner_red.png +0 -0
- amulet/resource_pack/java/java_vanilla_fix/assets/minecraft/textures/block/banner/banner_white.png +0 -0
- amulet/resource_pack/java/java_vanilla_fix/assets/minecraft/textures/block/banner/banner_yellow.png +0 -0
- amulet/resource_pack/java/java_vanilla_fix/assets/minecraft/textures/block/barrier.png +0 -0
- amulet/resource_pack/java/java_vanilla_fix/assets/minecraft/textures/block/end_portal.png +0 -0
- amulet/resource_pack/java/java_vanilla_fix/assets/minecraft/textures/block/grass.png +0 -0
- amulet/resource_pack/java/java_vanilla_fix/assets/minecraft/textures/block/lava.png +0 -0
- amulet/resource_pack/java/java_vanilla_fix/assets/minecraft/textures/block/structure_void.png +0 -0
- amulet/resource_pack/java/java_vanilla_fix/assets/minecraft/textures/block/water.png +0 -0
- amulet/resource_pack/java/java_vanilla_fix/pack.png +0 -0
- amulet/resource_pack/java/resource_pack.py +44 -0
- amulet/resource_pack/java/resource_pack_manager.py +551 -0
- amulet/resource_pack/unknown_resource_pack.py +10 -0
- amulet/utils/__init__.pyi +0 -5
- amulet/utils/call_spec/_call_spec.py +2 -7
- amulet/utils/comment_json.py +188 -0
- amulet/utils/matrix.py +3 -3
- amulet/utils/numpy.hpp +36 -0
- amulet/utils/numpy_helpers.py +2 -2
- amulet/utils/world_utils.py +2 -2
- amulet/version.py.cpp +281 -0
- amulet/version.pyi +0 -8
- {amulet_core-2.0a5.dist-info → amulet_core-2.0a7.dist-info}/METADATA +3 -3
- amulet_core-2.0a7.dist-info/RECORD +295 -0
- amulet/chunk_/components/biome.py +0 -155
- amulet/chunk_/components/block_entity.py +0 -117
- amulet/chunk_/components/entity.py +0 -64
- amulet/chunk_/components/height_2d.py +0 -16
- amulet/level/bedrock/__init__.py +0 -2
- amulet/level/bedrock/_chunk_handle.py +0 -19
- amulet/level/bedrock/_dimension.py +0 -22
- amulet/level/bedrock/_level.py +0 -187
- amulet/level/bedrock/_raw/__init__.py +0 -5
- amulet/level/bedrock/_raw/_actor_counter.py +0 -53
- amulet/level/bedrock/_raw/_chunk.py +0 -54
- amulet/level/bedrock/_raw/_chunk_decode.py +0 -668
- amulet/level/bedrock/_raw/_chunk_encode.py +0 -602
- amulet/level/bedrock/_raw/_constant.py +0 -9
- amulet/level/bedrock/_raw/_dimension.py +0 -343
- amulet/level/bedrock/_raw/_level.py +0 -463
- amulet/level/bedrock/_raw/_level_dat.py +0 -90
- amulet/level/bedrock/_raw/_typing.py +0 -6
- amulet/level/bedrock/_raw/leveldb_chunk_versions.py +0 -83
- amulet/level/bedrock/chunk/__init__.py +0 -1
- amulet/level/bedrock/chunk/_chunk.py +0 -126
- amulet/level/bedrock/chunk/components/chunk_version.py +0 -12
- amulet/level/bedrock/chunk/components/finalised_state.py +0 -13
- amulet/level/bedrock/chunk/components/raw_chunk.py +0 -15
- amulet/level/construction/__init__.py +0 -0
- amulet/level/java/_chunk_handle.pyi +0 -15
- amulet/level/java/_dimension.pyi +0 -13
- amulet/level/java/_level.pyi +0 -120
- amulet/level/java/_raw/_chunk_decode.py +0 -561
- amulet/level/java/_raw/_chunk_encode.py +0 -463
- amulet/level/java/_raw/_constant.pyi +0 -20
- amulet/level/java/_raw/_data_pack/__init__.pyi +0 -8
- amulet/level/java/_raw/_data_pack/data_pack.pyi +0 -197
- amulet/level/java/_raw/_data_pack/data_pack_manager.pyi +0 -75
- amulet/level/java/_raw/_dimension.pyi +0 -72
- amulet/level/java/_raw/_level.pyi +0 -238
- amulet/level/java/_raw/_typing.pyi +0 -5
- amulet/level/java/anvil/__init__.pyi +0 -11
- amulet/level/java/anvil/_dimension.pyi +0 -109
- amulet/level/java/anvil/_region.pyi +0 -197
- amulet/level/java/anvil/_sector_manager.pyi +0 -142
- amulet/level/java_forge/__init__.py +0 -0
- amulet/level/mcstructure/__init__.py +0 -0
- amulet/level/nbt/__init__.py +0 -0
- amulet/level/schematic/__init__.py +0 -0
- amulet/level/sponge_schematic/__init__.py +0 -0
- amulet/utils/call_spec/__init__.pyi +0 -53
- amulet/utils/call_spec/_call_spec.pyi +0 -272
- amulet/utils/matrix.pyi +0 -177
- amulet/utils/shareable_lock.pyi +0 -190
- amulet/utils/signal/__init__.pyi +0 -25
- amulet/utils/signal/_signal.pyi +0 -84
- amulet/utils/task_manager.pyi +0 -168
- amulet/utils/typing.py +0 -4
- amulet/utils/typing.pyi +0 -6
- amulet/utils/weakref.pyi +0 -50
- amulet/utils/world_utils.pyi +0 -109
- amulet_core-2.0a5.dist-info/RECORD +0 -210
- /amulet/{level/bedrock/chunk/components → mesh}/__init__.py +0 -0
- {amulet_core-2.0a5.dist-info → amulet_core-2.0a7.dist-info}/WHEEL +0 -0
- {amulet_core-2.0a5.dist-info → amulet_core-2.0a7.dist-info}/entry_points.txt +0 -0
- {amulet_core-2.0a5.dist-info → amulet_core-2.0a7.dist-info}/top_level.txt +0 -0
|
@@ -0,0 +1,115 @@
|
|
|
1
|
+
#include <memory>
|
|
2
|
+
|
|
3
|
+
#include <pybind11/pybind11.h>
|
|
4
|
+
#include <pybind11/stl.h>
|
|
5
|
+
#include <pybind11/operators.h>
|
|
6
|
+
#include <pybind11/typing.h>
|
|
7
|
+
|
|
8
|
+
#include <amulet/collections/eq.py.hpp>
|
|
9
|
+
#include <amulet/collections/hash.py.hpp>
|
|
10
|
+
#include <amulet_nbt/tag/named_tag.hpp>
|
|
11
|
+
#include <amulet/version.hpp>
|
|
12
|
+
#include <amulet/block_entity.hpp>
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
namespace py = pybind11;
|
|
16
|
+
|
|
17
|
+
void init_block_entity(py::module m_parent) {
|
|
18
|
+
auto m = m_parent.def_submodule("block_entity");
|
|
19
|
+
|
|
20
|
+
py::class_<Amulet::BlockEntity, Amulet::PlatformVersionContainer, std::shared_ptr<Amulet::BlockEntity>> BlockEntity(m, "BlockEntity",
|
|
21
|
+
"A class to contain all the data to define a BlockEntity."
|
|
22
|
+
);
|
|
23
|
+
BlockEntity.def(
|
|
24
|
+
py::init<
|
|
25
|
+
const Amulet::PlatformType&,
|
|
26
|
+
std::shared_ptr<Amulet::VersionNumber>,
|
|
27
|
+
const std::string&,
|
|
28
|
+
const std::string&,
|
|
29
|
+
std::shared_ptr<AmuletNBT::NamedTag>
|
|
30
|
+
>(),
|
|
31
|
+
py::arg("platform"),
|
|
32
|
+
py::arg("version"),
|
|
33
|
+
py::arg("namespace"),
|
|
34
|
+
py::arg("base_name"),
|
|
35
|
+
py::arg("nbt")
|
|
36
|
+
);
|
|
37
|
+
BlockEntity.def_property_readonly(
|
|
38
|
+
"namespaced_name",
|
|
39
|
+
[](const Amulet::BlockEntity& self) {
|
|
40
|
+
return self.get_namespace() + ":" + self.get_base_name();
|
|
41
|
+
},
|
|
42
|
+
py::doc(
|
|
43
|
+
"The namespace:base_name of the block entity represented by the :class:`BlockEntity` object.\n"
|
|
44
|
+
"\n"
|
|
45
|
+
">>> block_entity: BlockEntity\n"
|
|
46
|
+
">>> block_entity.namespaced_name\n"
|
|
47
|
+
"\n"
|
|
48
|
+
":return: The namespace:base_name of the block entity"
|
|
49
|
+
)
|
|
50
|
+
);
|
|
51
|
+
BlockEntity.def_property(
|
|
52
|
+
"namespace",
|
|
53
|
+
&Amulet::BlockEntity::get_namespace,
|
|
54
|
+
&Amulet::BlockEntity::set_namespace,
|
|
55
|
+
py::doc(
|
|
56
|
+
"The namespace of the block entity represented by the :class:`BlockEntity` object.\n"
|
|
57
|
+
"\n"
|
|
58
|
+
">>> block_entity: BlockEntity\n"
|
|
59
|
+
">>> block_entity.namespace\n"
|
|
60
|
+
"\n"
|
|
61
|
+
":return: The namespace of the block entity"
|
|
62
|
+
)
|
|
63
|
+
);
|
|
64
|
+
BlockEntity.def_property(
|
|
65
|
+
"base_name",
|
|
66
|
+
&Amulet::BlockEntity::get_base_name,
|
|
67
|
+
&Amulet::BlockEntity::set_base_name,
|
|
68
|
+
py::doc(
|
|
69
|
+
"The base name of the block entity represented by the :class:`BlockEntity` object.\n"
|
|
70
|
+
"\n"
|
|
71
|
+
">>> block_entity: BlockEntity\n"
|
|
72
|
+
">>> block_entity.base_name\n"
|
|
73
|
+
"\n"
|
|
74
|
+
":return: The base name of the block entity"
|
|
75
|
+
)
|
|
76
|
+
);
|
|
77
|
+
BlockEntity.def_property(
|
|
78
|
+
"nbt",
|
|
79
|
+
&Amulet::BlockEntity::get_nbt,
|
|
80
|
+
&Amulet::BlockEntity::set_nbt,
|
|
81
|
+
py::doc(
|
|
82
|
+
"The nbt data for the block entity.\n"
|
|
83
|
+
">>> block_entity: BlockEntity\n"
|
|
84
|
+
">>> block_entity.nbt\n"
|
|
85
|
+
"\n"
|
|
86
|
+
":return: The NamedTag of the block entity"
|
|
87
|
+
)
|
|
88
|
+
);
|
|
89
|
+
BlockEntity.def(
|
|
90
|
+
"__repr__",
|
|
91
|
+
[](const Amulet::BlockEntity& self){
|
|
92
|
+
return "Block(" +
|
|
93
|
+
py::repr(py::cast(self.get_platform())).cast<std::string>() + ", " +
|
|
94
|
+
py::repr(py::cast(self.get_version())).cast<std::string>() + ", " +
|
|
95
|
+
py::repr(py::cast(self.get_namespace())).cast<std::string>() + ", " +
|
|
96
|
+
py::repr(py::cast(self.get_base_name())).cast<std::string>() + ", " +
|
|
97
|
+
py::repr(py::cast(self.get_nbt())).cast<std::string>() +
|
|
98
|
+
")";
|
|
99
|
+
}
|
|
100
|
+
);
|
|
101
|
+
BlockEntity.def(
|
|
102
|
+
py::pickle(
|
|
103
|
+
[](const Amulet::BlockEntity& self) -> py::bytes {
|
|
104
|
+
return py::bytes(Amulet::serialise(self));
|
|
105
|
+
},
|
|
106
|
+
[](py::bytes state){
|
|
107
|
+
return Amulet::deserialise<Amulet::BlockEntity>(state.cast<std::string>());
|
|
108
|
+
}
|
|
109
|
+
)
|
|
110
|
+
);
|
|
111
|
+
|
|
112
|
+
Eq(BlockEntity);
|
|
113
|
+
Eq_default(BlockEntity);
|
|
114
|
+
hash_default(BlockEntity);
|
|
115
|
+
}
|
amulet/block_entity.pyi
CHANGED
|
@@ -17,7 +17,6 @@ class BlockEntity(amulet.version.PlatformVersionContainer):
|
|
|
17
17
|
def __eq__(self, arg0: BlockEntity) -> bool: ...
|
|
18
18
|
@typing.overload
|
|
19
19
|
def __eq__(self, arg0: typing.Any) -> bool | types.NotImplementedType: ...
|
|
20
|
-
def __getstate__(self) -> bytes: ...
|
|
21
20
|
def __hash__(self) -> int: ...
|
|
22
21
|
def __init__(
|
|
23
22
|
self,
|
|
@@ -28,7 +27,6 @@ class BlockEntity(amulet.version.PlatformVersionContainer):
|
|
|
28
27
|
nbt: amulet_nbt.NamedTag,
|
|
29
28
|
) -> None: ...
|
|
30
29
|
def __repr__(self) -> str: ...
|
|
31
|
-
def __setstate__(self, arg0: bytes) -> None: ...
|
|
32
30
|
@property
|
|
33
31
|
def base_name(self) -> str:
|
|
34
32
|
"""
|
amulet/chunk.py.cpp
ADDED
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
#include <amulet/chunk.hpp>
|
|
2
|
+
|
|
3
|
+
#include <pybind11/pybind11.h>
|
|
4
|
+
#include <pybind11/stl.h>
|
|
5
|
+
#include <pybind11/operators.h>
|
|
6
|
+
#include <pybind11/typing.h>
|
|
7
|
+
|
|
8
|
+
|
|
9
|
+
namespace py = pybind11;
|
|
10
|
+
|
|
11
|
+
void init_chunk(py::module m_parent) {
|
|
12
|
+
auto m = m_parent.def_submodule("chunk");
|
|
13
|
+
py::class_<Amulet::Chunk, std::shared_ptr<Amulet::Chunk>> Chunk(m, "Chunk",
|
|
14
|
+
"A base class for all chunk classes."
|
|
15
|
+
);
|
|
16
|
+
Chunk.def_property_readonly(
|
|
17
|
+
"chunk_id",
|
|
18
|
+
&Amulet::Chunk::get_chunk_id
|
|
19
|
+
);
|
|
20
|
+
Chunk.def_property_readonly(
|
|
21
|
+
"component_ids",
|
|
22
|
+
&Amulet::Chunk::get_component_ids
|
|
23
|
+
);
|
|
24
|
+
auto py_serialise = [](const Amulet::Chunk& self) -> py::typing::Dict<py::str, py::typing::Optional<py::bytes>> {
|
|
25
|
+
py::dict data;
|
|
26
|
+
for (const auto& [k, v] : self.serialise_chunk()) {
|
|
27
|
+
if (v) {
|
|
28
|
+
data[py::str(k)] = py::bytes(v.value());
|
|
29
|
+
}
|
|
30
|
+
else {
|
|
31
|
+
data[py::str(k)] = py::none();
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
return data;
|
|
35
|
+
};
|
|
36
|
+
Chunk.def(
|
|
37
|
+
"serialise_chunk",
|
|
38
|
+
py_serialise,
|
|
39
|
+
py::doc("This is private. Do not use this. It will be removed in the future.")
|
|
40
|
+
);
|
|
41
|
+
auto py_deserialise = [](Amulet::Chunk& self, py::typing::Dict<py::str, py::typing::Optional<py::bytes>> data) {
|
|
42
|
+
Amulet::SerialisedComponents component_data;
|
|
43
|
+
for (const auto& [k, v] : data) {
|
|
44
|
+
if (v.is(py::none())) {
|
|
45
|
+
component_data[k.cast<std::string>()];
|
|
46
|
+
}
|
|
47
|
+
else {
|
|
48
|
+
component_data[k.cast<std::string>()] = v.cast<std::string>();
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
self.reconstruct_chunk(component_data);
|
|
52
|
+
};
|
|
53
|
+
Chunk.def(
|
|
54
|
+
"reconstruct_chunk",
|
|
55
|
+
py_deserialise,
|
|
56
|
+
py::doc("This is private. Do not use this. It will be removed in the future.")
|
|
57
|
+
);
|
|
58
|
+
Chunk.def(
|
|
59
|
+
py::pickle(
|
|
60
|
+
[py_serialise](const Amulet::Chunk& self) {
|
|
61
|
+
return py::make_tuple(
|
|
62
|
+
self.get_chunk_id(),
|
|
63
|
+
py_serialise(self)
|
|
64
|
+
);
|
|
65
|
+
},
|
|
66
|
+
[py_deserialise](py::tuple state) {
|
|
67
|
+
if (state.size() != 2) { throw std::runtime_error("Invalid state!"); }
|
|
68
|
+
auto self = Amulet::get_null_chunk(state[0].cast<std::string>());
|
|
69
|
+
py_deserialise(*self, state[1]);
|
|
70
|
+
return self;
|
|
71
|
+
}
|
|
72
|
+
)
|
|
73
|
+
);
|
|
74
|
+
|
|
75
|
+
m.def(
|
|
76
|
+
"get_null_chunk",
|
|
77
|
+
&Amulet::get_null_chunk,
|
|
78
|
+
py::doc("This is a private function")
|
|
79
|
+
);
|
|
80
|
+
}
|
amulet/chunk.pyi
CHANGED
|
@@ -7,8 +7,6 @@ class Chunk:
|
|
|
7
7
|
A base class for all chunk classes.
|
|
8
8
|
"""
|
|
9
9
|
|
|
10
|
-
def __getstate__(self) -> tuple: ...
|
|
11
|
-
def __setstate__(self, arg0: tuple) -> None: ...
|
|
12
10
|
def reconstruct_chunk(self, arg0: dict[str, bytes | None]) -> None:
|
|
13
11
|
"""
|
|
14
12
|
This is private. Do not use this. It will be removed in the future.
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
#pragma once
|
|
2
|
+
|
|
3
|
+
#include <memory>
|
|
4
|
+
#include <tuple>
|
|
5
|
+
#include <optional>
|
|
6
|
+
#include <cstdint>
|
|
7
|
+
#include <memory>
|
|
8
|
+
|
|
9
|
+
#include <amulet/version.hpp>
|
|
10
|
+
#include <amulet/biome.hpp>
|
|
11
|
+
#include <amulet/palette/biome_palette.hpp>
|
|
12
|
+
#include <amulet/chunk_components/section_array_map.hpp>
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
namespace Amulet {
|
|
16
|
+
class Biome3DComponentData {
|
|
17
|
+
private:
|
|
18
|
+
std::shared_ptr<BiomePalette> _palette;
|
|
19
|
+
std::shared_ptr<SectionArrayMap> _sections;
|
|
20
|
+
public:
|
|
21
|
+
Biome3DComponentData(
|
|
22
|
+
std::shared_ptr<VersionRange> version_range,
|
|
23
|
+
const SectionShape& array_shape,
|
|
24
|
+
std::shared_ptr<Biome> default_biome
|
|
25
|
+
):
|
|
26
|
+
_palette(std::make_shared<BiomePalette>(version_range)),
|
|
27
|
+
_sections(std::make_shared<SectionArrayMap>(array_shape, static_cast<std::uint32_t>(0)))
|
|
28
|
+
{
|
|
29
|
+
_palette->biome_to_index(default_biome);
|
|
30
|
+
}
|
|
31
|
+
std::shared_ptr<BiomePalette> get_palette() {
|
|
32
|
+
return _palette;
|
|
33
|
+
}
|
|
34
|
+
std::shared_ptr<SectionArrayMap> get_sections() {
|
|
35
|
+
return _sections;
|
|
36
|
+
}
|
|
37
|
+
};
|
|
38
|
+
|
|
39
|
+
class Biome3DComponent {
|
|
40
|
+
private:
|
|
41
|
+
std::optional<std::shared_ptr<Biome3DComponentData>> _value;
|
|
42
|
+
protected:
|
|
43
|
+
// Null constructor
|
|
44
|
+
Biome3DComponent() {};
|
|
45
|
+
// Default constructor
|
|
46
|
+
void init(
|
|
47
|
+
std::shared_ptr<VersionRange> version_range,
|
|
48
|
+
const SectionShape& array_shape,
|
|
49
|
+
std::shared_ptr<Biome> default_biome
|
|
50
|
+
) { _value = std::make_shared<Biome3DComponentData>(version_range, array_shape, default_biome); }
|
|
51
|
+
|
|
52
|
+
// Serialise the component data
|
|
53
|
+
std::optional<std::string> serialise() const;
|
|
54
|
+
// Deserialise the component
|
|
55
|
+
void deserialise(std::optional<std::string>);
|
|
56
|
+
public:
|
|
57
|
+
static const std::string ComponentID;
|
|
58
|
+
std::shared_ptr<Biome3DComponentData> get_biome() {
|
|
59
|
+
if (_value) {
|
|
60
|
+
return *_value;
|
|
61
|
+
}
|
|
62
|
+
throw std::runtime_error("BiomeComponent has not been loaded.");
|
|
63
|
+
};
|
|
64
|
+
void set_biome(std::shared_ptr<Biome3DComponentData> component) {
|
|
65
|
+
if (_value) {
|
|
66
|
+
if ((*_value)->get_sections()->get_array_shape() != component->get_sections()->get_array_shape()) {
|
|
67
|
+
throw std::invalid_argument("New biome array shape does not match old array shape.");
|
|
68
|
+
}
|
|
69
|
+
if ((*_value)->get_palette()->get_version_range() != component->get_palette()->get_version_range()) {
|
|
70
|
+
throw std::invalid_argument("New biome version range does not match old version range.");
|
|
71
|
+
}
|
|
72
|
+
_value = component;
|
|
73
|
+
}
|
|
74
|
+
else {
|
|
75
|
+
throw std::runtime_error("BiomeComponent has not been loaded.");
|
|
76
|
+
}
|
|
77
|
+
};
|
|
78
|
+
};
|
|
79
|
+
}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
#include <amulet/chunk_components/block_component.hpp>
|
|
2
|
+
|
|
3
|
+
namespace Amulet {
|
|
4
|
+
void BlockComponentData::serialise(BinaryWriter& writer) const {
|
|
5
|
+
writer.writeNumeric<std::uint8_t>(1);
|
|
6
|
+
get_palette()->serialise(writer);
|
|
7
|
+
get_sections()->serialise(writer);
|
|
8
|
+
}
|
|
9
|
+
std::shared_ptr<BlockComponentData> BlockComponentData::deserialise(BinaryReader& reader) {
|
|
10
|
+
auto version = reader.readNumeric<std::uint8_t>();
|
|
11
|
+
switch (version) {
|
|
12
|
+
case 1:
|
|
13
|
+
{
|
|
14
|
+
auto palette = BlockPalette::deserialise(reader);
|
|
15
|
+
auto sections = SectionArrayMap::deserialise(reader);
|
|
16
|
+
return std::make_shared<BlockComponentData>(palette, sections);
|
|
17
|
+
}
|
|
18
|
+
default:
|
|
19
|
+
throw std::invalid_argument("Unsupported BlockComponentData version " + std::to_string(version));
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
const std::string BlockComponent::ComponentID = "Amulet::BlockComponent";
|
|
24
|
+
|
|
25
|
+
std::optional<std::string> BlockComponent::serialise() const {
|
|
26
|
+
if (_value) {
|
|
27
|
+
return Amulet::serialise(**_value);
|
|
28
|
+
}
|
|
29
|
+
else {
|
|
30
|
+
return std::nullopt;
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
void BlockComponent::deserialise(std::optional<std::string> data) {
|
|
34
|
+
if (data) {
|
|
35
|
+
_value = Amulet::deserialise<BlockComponentData>(*data);
|
|
36
|
+
}
|
|
37
|
+
else {
|
|
38
|
+
_value = std::nullopt;
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
}
|
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
#pragma once
|
|
2
|
+
|
|
3
|
+
#include <memory>
|
|
4
|
+
#include <tuple>
|
|
5
|
+
#include <optional>
|
|
6
|
+
|
|
7
|
+
#include <amulet/version.hpp>
|
|
8
|
+
#include <amulet/block.hpp>
|
|
9
|
+
#include <amulet/palette/block_palette.hpp>
|
|
10
|
+
#include <amulet/chunk_components/section_array_map.hpp>
|
|
11
|
+
#include <amulet/io/binary_writer.hpp>
|
|
12
|
+
#include <amulet/io/binary_reader.hpp>
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
namespace Amulet {
|
|
16
|
+
class BlockComponentData {
|
|
17
|
+
private:
|
|
18
|
+
std::shared_ptr<BlockPalette> _palette;
|
|
19
|
+
std::shared_ptr<SectionArrayMap> _sections;
|
|
20
|
+
public:
|
|
21
|
+
BlockComponentData(
|
|
22
|
+
std::shared_ptr<VersionRange> version_range,
|
|
23
|
+
const SectionShape& array_shape,
|
|
24
|
+
std::shared_ptr<BlockStack> default_block
|
|
25
|
+
):
|
|
26
|
+
_palette(std::make_shared<BlockPalette>(version_range)),
|
|
27
|
+
_sections(std::make_shared<SectionArrayMap>(array_shape, static_cast<std::uint32_t>(0)))
|
|
28
|
+
{
|
|
29
|
+
_palette->block_stack_to_index(default_block);
|
|
30
|
+
}
|
|
31
|
+
BlockComponentData(
|
|
32
|
+
std::shared_ptr<BlockPalette> palette,
|
|
33
|
+
std::shared_ptr<SectionArrayMap> sections
|
|
34
|
+
): _palette(palette), _sections(sections){}
|
|
35
|
+
|
|
36
|
+
void serialise(BinaryWriter&) const;
|
|
37
|
+
static std::shared_ptr<BlockComponentData> deserialise(BinaryReader&);
|
|
38
|
+
|
|
39
|
+
std::shared_ptr<BlockPalette> get_palette() const {
|
|
40
|
+
return _palette;
|
|
41
|
+
}
|
|
42
|
+
std::shared_ptr<SectionArrayMap> get_sections() const {
|
|
43
|
+
return _sections;
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
};
|
|
47
|
+
|
|
48
|
+
class BlockComponent {
|
|
49
|
+
private:
|
|
50
|
+
std::optional<std::shared_ptr<BlockComponentData>> _value;
|
|
51
|
+
protected:
|
|
52
|
+
// Null constructor
|
|
53
|
+
BlockComponent() {};
|
|
54
|
+
// Default constructor
|
|
55
|
+
void init(
|
|
56
|
+
std::shared_ptr<VersionRange> version_range,
|
|
57
|
+
const SectionShape& array_shape,
|
|
58
|
+
std::shared_ptr<BlockStack> default_block
|
|
59
|
+
) { _value = std::make_shared<BlockComponentData>(version_range, array_shape, default_block); }
|
|
60
|
+
|
|
61
|
+
// Serialise the component data
|
|
62
|
+
std::optional<std::string> serialise() const;
|
|
63
|
+
// Deserialise the component
|
|
64
|
+
void deserialise(std::optional<std::string>);
|
|
65
|
+
public:
|
|
66
|
+
static const std::string ComponentID;
|
|
67
|
+
std::shared_ptr<BlockComponentData> get_block() {
|
|
68
|
+
if (_value) {
|
|
69
|
+
return *_value;
|
|
70
|
+
}
|
|
71
|
+
throw std::runtime_error("BlockComponent has not been loaded.");
|
|
72
|
+
};
|
|
73
|
+
void set_block(std::shared_ptr<BlockComponentData> component) {
|
|
74
|
+
if (_value) {
|
|
75
|
+
if ((*_value)->get_sections()->get_array_shape() != component->get_sections()->get_array_shape()) {
|
|
76
|
+
throw std::invalid_argument("New block array shape does not match old array shape.");
|
|
77
|
+
}
|
|
78
|
+
if ((*_value)->get_palette()->get_version_range() != component->get_palette()->get_version_range()) {
|
|
79
|
+
throw std::invalid_argument("New block version range does not match old version range.");
|
|
80
|
+
}
|
|
81
|
+
_value = component;
|
|
82
|
+
}
|
|
83
|
+
else {
|
|
84
|
+
throw std::runtime_error("BlockComponent has not been loaded.");
|
|
85
|
+
}
|
|
86
|
+
};
|
|
87
|
+
};
|
|
88
|
+
}
|
|
@@ -0,0 +1,147 @@
|
|
|
1
|
+
#pragma once
|
|
2
|
+
|
|
3
|
+
#include <memory>
|
|
4
|
+
#include <tuple>
|
|
5
|
+
#include <optional>
|
|
6
|
+
#include <cstdint>
|
|
7
|
+
#include <memory>
|
|
8
|
+
#include <map>
|
|
9
|
+
|
|
10
|
+
#include <amulet/version.hpp>
|
|
11
|
+
#include <amulet/block_entity.hpp>
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
namespace Amulet {
|
|
15
|
+
typedef std::tuple<std::uint16_t, std::int64_t, std::uint16_t> BlockEntityChunkCoord;
|
|
16
|
+
class BlockEntityComponentData: public VersionRangeContainer {
|
|
17
|
+
private:
|
|
18
|
+
std::uint16_t _x_size;
|
|
19
|
+
std::uint16_t _z_size;
|
|
20
|
+
std::map<
|
|
21
|
+
BlockEntityChunkCoord,
|
|
22
|
+
std::shared_ptr<BlockEntity>
|
|
23
|
+
> _block_entities;
|
|
24
|
+
public:
|
|
25
|
+
BlockEntityComponentData(
|
|
26
|
+
std::shared_ptr<VersionRange> version_range,
|
|
27
|
+
const std::uint16_t& x_size,
|
|
28
|
+
const std::uint16_t& z_size
|
|
29
|
+
) :
|
|
30
|
+
VersionRangeContainer(version_range),
|
|
31
|
+
_x_size(x_size),
|
|
32
|
+
_z_size(z_size),
|
|
33
|
+
_block_entities()
|
|
34
|
+
{}
|
|
35
|
+
|
|
36
|
+
std::uint16_t get_x_size() const { return _x_size; }
|
|
37
|
+
std::uint16_t get_z_size() const { return _z_size; }
|
|
38
|
+
|
|
39
|
+
const std::map<
|
|
40
|
+
BlockEntityChunkCoord,
|
|
41
|
+
std::shared_ptr<BlockEntity>
|
|
42
|
+
>& get_block_entities() const {
|
|
43
|
+
return _block_entities;
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
size_t get_size() const { return _block_entities.size(); }
|
|
47
|
+
|
|
48
|
+
bool contains(
|
|
49
|
+
const BlockEntityChunkCoord& coord
|
|
50
|
+
) const {
|
|
51
|
+
return _block_entities.contains(coord);
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
std::shared_ptr<BlockEntity> get(
|
|
55
|
+
const BlockEntityChunkCoord& coord
|
|
56
|
+
) const {
|
|
57
|
+
return _block_entities.at(coord);
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
void set(
|
|
61
|
+
const BlockEntityChunkCoord& coord,
|
|
62
|
+
std::shared_ptr<BlockEntity> block_entity
|
|
63
|
+
) {
|
|
64
|
+
if (
|
|
65
|
+
std::get<0>(coord) < 0 ||
|
|
66
|
+
std::get<2>(coord) < 0 ||
|
|
67
|
+
_x_size <= std::get<0>(coord) ||
|
|
68
|
+
_z_size <= std::get<2>(coord)
|
|
69
|
+
){
|
|
70
|
+
throw std::invalid_argument(
|
|
71
|
+
"Coord must be 0 <= " +
|
|
72
|
+
std::to_string(std::get<0>(coord)) +
|
|
73
|
+
" < " +
|
|
74
|
+
std::to_string(_x_size) +
|
|
75
|
+
"and 0 <= " +
|
|
76
|
+
std::to_string(std::get<1>(coord)) +
|
|
77
|
+
" < " +
|
|
78
|
+
std::to_string(_z_size)
|
|
79
|
+
);
|
|
80
|
+
}
|
|
81
|
+
if (!(
|
|
82
|
+
get_version_range()->contains(
|
|
83
|
+
block_entity->get_platform(),
|
|
84
|
+
*block_entity->get_version()
|
|
85
|
+
)
|
|
86
|
+
)){
|
|
87
|
+
throw std::invalid_argument(
|
|
88
|
+
"BlockEntity is incompatible with VersionRange."
|
|
89
|
+
);
|
|
90
|
+
}
|
|
91
|
+
_block_entities[coord] = block_entity;
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
void del(
|
|
95
|
+
const BlockEntityChunkCoord& coord
|
|
96
|
+
) {
|
|
97
|
+
_block_entities.erase(coord);
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
};
|
|
101
|
+
|
|
102
|
+
class BlockEntityComponent {
|
|
103
|
+
private:
|
|
104
|
+
std::optional<std::shared_ptr<BlockEntityComponentData>> _value;
|
|
105
|
+
protected:
|
|
106
|
+
// Null constructor
|
|
107
|
+
BlockEntityComponent() {};
|
|
108
|
+
// Default constructor
|
|
109
|
+
void init(
|
|
110
|
+
std::shared_ptr<VersionRange> version_range,
|
|
111
|
+
const std::uint16_t& x_size,
|
|
112
|
+
const std::uint16_t& z_size
|
|
113
|
+
) {
|
|
114
|
+
_value = std::make_shared<BlockEntityComponentData>(version_range, x_size, z_size);
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
// Serialise the component data
|
|
118
|
+
std::optional<std::string> serialise() const;
|
|
119
|
+
// Deserialise the component
|
|
120
|
+
void deserialise(std::optional<std::string>);
|
|
121
|
+
public:
|
|
122
|
+
static const std::string ComponentID;
|
|
123
|
+
std::shared_ptr<BlockEntityComponentData> get_block_entity() {
|
|
124
|
+
if (_value) {
|
|
125
|
+
return *_value;
|
|
126
|
+
}
|
|
127
|
+
throw std::runtime_error("BlockEntityComponent has not been loaded.");
|
|
128
|
+
};
|
|
129
|
+
void set_block_entity(std::shared_ptr<BlockEntityComponentData> component) {
|
|
130
|
+
if (_value) {
|
|
131
|
+
if (
|
|
132
|
+
(*_value)->get_x_size() != component->get_x_size() ||
|
|
133
|
+
(*_value)->get_z_size() != component->get_z_size()
|
|
134
|
+
) {
|
|
135
|
+
throw std::invalid_argument("New BlockEntityComponent shape does not match old shape.");
|
|
136
|
+
}
|
|
137
|
+
if ((*_value)->get_version_range() != component->get_version_range()) {
|
|
138
|
+
throw std::invalid_argument("New BlockEntityComponent version range does not match old version range.");
|
|
139
|
+
}
|
|
140
|
+
_value = component;
|
|
141
|
+
}
|
|
142
|
+
else {
|
|
143
|
+
throw std::runtime_error("BlockEntityComponent has not been loaded.");
|
|
144
|
+
}
|
|
145
|
+
};
|
|
146
|
+
};
|
|
147
|
+
}
|