LeviLamina
Loading...
Searching...
No Matches
NetherGenerator.h
1#pragma once
2
3#include "mc/_HeaderOutputPredefine.h"
4
5// auto generated inclusion list
6#include "mc/deps/core/threading/InstancedThreadLocal.h"
7#include "mc/util/MultidimensionalArray.h"
8#include "mc/util/Random.h"
9#include "mc/world/level/levelgen/WorldGenerator.h"
10
11// auto generated forward declare list
12// clang-format off
13class Biome;
14class BiomeArea;
15class BiomeSource;
16class Block;
17class BlockPos;
18class BlockSource;
19class BlockVolume;
21class BoundingBox;
22class ChunkPos;
23class ChunkViewSource;
24class Dimension;
25class LevelChunk;
26class PerlinNoise;
28// clang-format on
29
30class NetherGenerator : public ::WorldGenerator {
31public:
32 // NetherGenerator inner types declare
33 // clang-format off
34 struct ThreadData;
35 // clang-format on
36
37 // NetherGenerator inner types define
38 struct ThreadData {
39 public:
40 // member variables
41 // NOLINTBEGIN
42 ::ll::TypedStorage<8, 2576, ::Random> random;
43 ::ll::TypedStorage<8, 262144, ::std::array<::Block const*, 32768>> blockBuffer;
44 // NOLINTEND
45 };
46
48
49public:
50 // member variables
51 // NOLINTBEGIN
52 ::ll::TypedStorage<8, 8, ::std::unique_ptr<::PerlinNoise>> lperlinNoise1;
53 ::ll::TypedStorage<8, 8, ::std::unique_ptr<::PerlinNoise>> lperlinNoise2;
54 ::ll::TypedStorage<8, 8, ::std::unique_ptr<::PerlinNoise>> perlinNoise1;
55 ::ll::TypedStorage<8, 8, ::std::unique_ptr<::PerlinNoise>> perlinNoise2;
56 ::ll::TypedStorage<8, 8, ::std::unique_ptr<::PerlinNoise>> scaleNoise;
57 ::ll::TypedStorage<8, 8, ::std::unique_ptr<::PerlinNoise>> depthNoise;
58 ::ll::TypedStorage<8, 8, ::std::unique_ptr<::PerlinSimplexNoise>> surfaceNoise;
59 ::ll::TypedStorage<8, 8, ::std::unique_ptr<::PerlinSimplexNoise>> mMaterialAdjNoise;
60 ::ll::TypedStorage<
61 8,
62 168,
63 ::Bedrock::Threading::
64 InstancedThreadLocal<::NetherGenerator::ThreadData, ::std::allocator<::NetherGenerator::ThreadData>>>
65 generatorHelpersPool;
66 ::ll::TypedStorage<8, 8, ::std::unique_ptr<::BiomeSource>> mBiomeSource;
67 // NOLINTEND
68
69public:
70 // prevent constructor by default
71 NetherGenerator();
72
73public:
74 // virtual functions
75 // NOLINTBEGIN
76 virtual ~NetherGenerator() /*override*/;
77
78 virtual void loadChunk(::LevelChunk& lc, bool forceImmediateReplacementDataLoad) /*override*/;
79
80 virtual bool structurePostProcessChunk(::ChunkViewSource& neighborhoodIn) /*override*/;
81
82 virtual bool decorationPostProcessChunk(::ChunkViewSource& neighborhood) /*override*/;
83
84 virtual void prepareHeights(
85 ::BlockVolume& box,
86 ::ChunkPos const& chunkPos,
87 ::std::vector<short>* ZXheights,
88 bool factorInBeardsAndShavers
89 ) /*override*/;
90
91 virtual ::BiomeArea getBiomeArea(::BoundingBox const& area, uint scale) const /*override*/;
92
93 virtual ::BiomeSource const& getBiomeSource() const /*override*/;
94
95 virtual ::WorldGenerator::BlockVolumeDimensions getBlockVolumeDimensions() const /*override*/;
96
97 virtual ::BlockPos findSpawnPosition() const /*override*/;
98
99 virtual void decorateWorldGenLoadChunk(
100 ::Biome const& biome,
101 ::LevelChunk& lc,
102 ::BlockVolumeTarget& target,
103 ::Random& random,
104 ::ChunkPos const& pos
105 ) const /*override*/;
106
107 virtual void
108 decorateWorldGenPostProcess(::Biome const& biome, ::LevelChunk& lc, ::BlockSource& source, ::Random& random) const
109 /*override*/;
110 // NOLINTEND
111
112public:
113 // member functions
114 // NOLINTBEGIN
115 MCAPI NetherGenerator(::Dimension& dimension, uint seed, ::Biome const* biomeOverride);
116
117 MCAPI void _prepareHeights(::BlockVolume& box, ::ChunkPos const& chunkPos, ::std::vector<short>* ZXheights) const;
118
119 MCAPI void buildSurfaces(::BlockVolume& blocks, ::LevelChunk& levelChunk, ::ChunkPos const& chunkPos);
120
121 MCAPI ::Util::MultidimensionalArray<float, 5, 5, 17> generateDensityCellsForChunk(::ChunkPos const& chunkPos) const;
122 // NOLINTEND
123
124public:
125 // constructor thunks
126 // NOLINTBEGIN
127 MCAPI void* $ctor(::Dimension& dimension, uint seed, ::Biome const* biomeOverride);
128 // NOLINTEND
129
130public:
131 // destructor thunk
132 // NOLINTBEGIN
133 MCAPI void $dtor();
134 // NOLINTEND
135
136public:
137 // virtual function thunks
138 // NOLINTBEGIN
139 MCAPI void $loadChunk(::LevelChunk& lc, bool forceImmediateReplacementDataLoad);
140
141 MCAPI bool $structurePostProcessChunk(::ChunkViewSource& neighborhoodIn);
142
143 MCAPI bool $decorationPostProcessChunk(::ChunkViewSource& neighborhood);
144
145 MCAPI void $prepareHeights(
146 ::BlockVolume& box,
147 ::ChunkPos const& chunkPos,
148 ::std::vector<short>* ZXheights,
149 bool factorInBeardsAndShavers
150 );
151
152 MCAPI ::BiomeArea $getBiomeArea(::BoundingBox const& area, uint scale) const;
153
154 MCFOLD ::BiomeSource const& $getBiomeSource() const;
155
156 MCFOLD ::WorldGenerator::BlockVolumeDimensions $getBlockVolumeDimensions() const;
157
158 MCAPI ::BlockPos $findSpawnPosition() const;
159
160 MCFOLD void $decorateWorldGenLoadChunk(
161 ::Biome const& biome,
162 ::LevelChunk& lc,
163 ::BlockVolumeTarget& target,
164 ::Random& random,
165 ::ChunkPos const& pos
166 ) const;
167
168 MCFOLD void
169 $decorateWorldGenPostProcess(::Biome const& biome, ::LevelChunk& lc, ::BlockSource& source, ::Random& random) const;
170
171
172 // NOLINTEND
173
174public:
175 // vftables
176 // NOLINTBEGIN
178
179 MCNAPI static void** $vftableForChunkSource();
180 // NOLINTEND
181};
Definition BiomeArea.h:11
Definition BiomeSource.h:20
Definition Biome.h:23
Definition BlockPos.h:19
Definition BlockSource.h:68
Definition BlockVolumeTarget.h:29
Definition BlockVolume.h:13
Definition Block.h:43
Definition BoundingBox.h:13
Definition ChunkPos.h:11
Definition ChunkViewSource.h:22
Definition Dimension.h:85
Definition LevelChunk.h:79
static MCAPI void ** $vftableForIPreliminarySurfaceProvider()
static MCAPI void ** $vftableForChunkSource()
Definition PerlinNoise.h:12
Definition PerlinSimplexNoise.h:13
Definition Random.h:10
Definition MultidimensionalArray.h:12
STL namespace.
Definition NetherGenerator.h:38
Definition WorldGenerator.h:39