blob: 9ff81cfbf8fcdf3b09b1c121540930f9692c7549 (
plain) (
blame)
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
|
/*
* File: maps.cc
* Summary: Functions used to create vaults.
* Written by: Linley Henzell
*
* Modified for Crawl Reference by $Author$ on $Date$
*/
#ifndef MAPS_H
#define MAPS_H
#include "FixVec.h"
#include "dungeon.h"
#include <vector>
class map_def;
int vault_main(vault_placement &vp,
const map_def *vault,
bool check_place = false);
// Given a rectangular region, slides it to fit into the map. size must be
// smaller than (GXM,GYM).
void fit_region_into_map_bounds(coord_def &pos, const coord_def &size);
const map_def *map_by_index(int index);
int map_count();
const map_def *find_map_by_name(const std::string &name);
const map_def *random_map_for_place(const level_id &place, bool mini = false);
const map_def *random_map_in_depth(const level_id &lid,
bool want_minivault = false);
const map_def *random_map_for_tag(const std::string &tag, bool want_minivault,
bool check_depth = false);
void add_parsed_map(const map_def &md);
std::vector<std::string> find_map_matches(const std::string &name);
void read_maps();
void read_map(const std::string &file);
void run_map_preludes();
void reset_map_parser();
std::string get_descache_path(const std::string &file,
const std::string &ext);
typedef std::map<std::string, map_file_place> map_load_info_t;
extern map_load_info_t lc_loaded_maps;
extern std::string lc_desfile;
extern map_def lc_map;
extern level_range lc_range;
extern depth_ranges lc_default_depths;
extern dlua_chunk lc_global_prelude;
extern bool lc_run_global_prelude;
const int MAP_CACHE_VERSION = 1009;
#ifdef DEBUG_DIAGNOSTICS
void mg_report_random_maps(FILE *outf, const level_id &place);
#endif
#endif
|