51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
*/
-#ifndef DUNGEONGEN_HEADER
-#define DUNGEONGEN_HEADER
+#pragma once
#include "voxel.h"
#include "noise.h"
+#include "mapgen.h"
#define VMANIP_FLAG_DUNGEON_INSIDE VOXELFLAG_CHECKED1
#define VMANIP_FLAG_DUNGEON_PRESERVE VOXELFLAG_CHECKED2
#define VMANIP_FLAG_DUNGEON_UNTOUCHABLE (\
VMANIP_FLAG_DUNGEON_INSIDE|VMANIP_FLAG_DUNGEON_PRESERVE)
-class ManualMapVoxelManipulator;
+class MMVManip;
class INodeDefManager;
-v3s16 rand_ortho_dir(PseudoRandom &random);
+v3s16 rand_ortho_dir(PseudoRandom &random, bool diagonal_dirs);
v3s16 turn_xz(v3s16 olddir, int t);
v3s16 random_turn(PseudoRandom &random, v3s16 olddir);
int dir_to_facedir(v3s16 d);
+
+struct DungeonParams {
+ s32 seed;
+
+ content_t c_water;
+ content_t c_river_water;
+ content_t c_wall;
+ content_t c_alt_wall;
+ content_t c_stair;
+
+ bool diagonal_dirs;
+ bool only_in_ground;
+ v3s16 holesize;
+ u16 corridor_len_min;
+ u16 corridor_len_max;
+ v3s16 room_size_min;
+ v3s16 room_size_max;
+ v3s16 room_size_large_min;
+ v3s16 room_size_large_max;
+ u16 rooms_min;
+ u16 rooms_max;
+ s16 y_min;
+ s16 y_max;
+ GenNotifyType notifytype;
+
+ NoiseParams np_density;
+ NoiseParams np_alt_wall;
+};
+
class DungeonGen {
public:
- u32 blockseed;
- u64 mapseed;
- ManualMapVoxelManipulator *vmanip;
+ MMVManip *vm;
INodeDefManager *ndef;
+ GenerateNotifier *gennotify;
+
+ u32 blockseed;
PseudoRandom random;
v3s16 csize;
- s16 water_level;
-
- NoiseParams *np_rarity;
- NoiseParams *np_wetness;
- NoiseParams *np_density;
-
- content_t cid_water_source;
- content_t cid_cobble;
- content_t cid_mossycobble;
- content_t cid_torch;
- content_t cid_cobblestair;
-
- //RoomWalker
+
+ content_t c_torch;
+ DungeonParams dp;
+
+ // RoomWalker
v3s16 m_pos;
v3s16 m_dir;
- DungeonGen(INodeDefManager *ndef, u64 seed, s16 waterlevel);
- void generate(ManualMapVoxelManipulator *vm, u32 bseed,
- v3s16 full_node_min, v3s16 full_node_max);
- //void generate(v3s16 full_node_min, v3s16 full_node_max, u32 bseed);
-
+ DungeonGen(INodeDefManager *ndef,
+ GenerateNotifier *gennotify, DungeonParams *dparams);
+
+ void generate(MMVManip *vm, u32 bseed,
+ v3s16 full_node_min, v3s16 full_node_max);
+
void makeDungeon(v3s16 start_padding);
void makeRoom(v3s16 roomsize, v3s16 roomplace);
void makeCorridor(v3s16 doorplace, v3s16 doordir,
- v3s16 &result_place, v3s16 &result_dir);
+ v3s16 &result_place, v3s16 &result_dir);
void makeDoor(v3s16 doorplace, v3s16 doordir);
void makeFill(v3s16 place, v3s16 size, u8 avoid_flags, MapNode n, u8 or_flags);
void makeHole(v3s16 place);
bool findPlaceForDoor(v3s16 &result_place, v3s16 &result_dir);
bool findPlaceForRoomDoor(v3s16 roomsize, v3s16 &result_doorplace,
v3s16 &result_doordir, v3s16 &result_roomplace);
-
- void randomizeDir()
- {
- m_dir = rand_ortho_dir(random);
- }
-};
-
-class RoomWalker
-{
-public:
- RoomWalker(VoxelManipulator &vmanip_, v3s16 pos, PseudoRandom &random,
- INodeDefManager *ndef):
- vmanip(vmanip_),
- m_pos(pos),
- m_random(random),
- m_ndef(ndef)
+ inline void randomizeDir()
{
- randomizeDir();
+ m_dir = rand_ortho_dir(random, dp.diagonal_dirs);
}
-
- void randomizeDir()
- {
- m_dir = rand_ortho_dir(m_random);
- }
-
- void setPos(v3s16 pos)
- {
- m_pos = pos;
- }
-
- void setDir(v3s16 dir)
- {
- m_dir = dir;
- }
-
- //bool findPlaceForDoor(v3s16 &result_place, v3s16 &result_dir);
- //bool findPlaceForRoomDoor(v3s16 roomsize, v3s16 &result_doorplace,
- // v3s16 &result_doordir, v3s16 &result_roomplace);
-
-private:
- VoxelManipulator &vmanip;
- v3s16 m_pos;
- v3s16 m_dir;
- PseudoRandom &m_random;
- INodeDefManager *m_ndef;
};
-
-#endif
+extern NoiseParams nparams_dungeon_density;
+extern NoiseParams nparams_dungeon_alt_wall;