home · contact · privacy
MAJOR re-write. Split plomrogue into a server and a client. Re-wrote large parts
[plomrogue] / src / server / map.c
1 /* src/server/map.c */
2
3 #include "map.h"
4 #include <stdint.h> /* uint8_t, uint16_t, uint32_t */
5 #include "../common/map.h" /* struct Map */
6 #include "../common/try_malloc.h" /* try_malloc() */
7 #include "../common/yx_uint16.h" /* struct yx_uint16 */
8 #include "rrand.h" /* rrand() */
9 #include "world.h" /* global world */
10
11
12
13 extern void init_map()
14 {
15     char * f_name = "init_map()";
16     world.map.size.x = 64;
17     world.map.size.y = 64;
18     uint32_t size = world.map.size.x * world.map.size.y;
19     world.map.cells = try_malloc(size, f_name);
20     uint16_t y, x;
21     for (y = 0; y < world.map.size.y; y++)
22     {
23         for (x = 0;
24              x < world.map.size.x;
25              world.map.cells[(y * world.map.size.x) + x] = '~', x++);
26     }
27     world.map.cells[size / 2 + (world.map.size.x / 2)] = '.';
28     uint32_t curpos;
29     while (1)
30     {
31         y = rrand() % world.map.size.y;
32         x = rrand() % world.map.size.x;
33         curpos = y * world.map.size.x + x;
34         if ('~' == world.map.cells[curpos]
35             && (   (   curpos >= world.map.size.x
36                     && '.' == world.map.cells[curpos - world.map.size.x])
37                 || (   curpos < world.map.size.x * (world.map.size.y-1)
38                     && '.' == world.map.cells[curpos + world.map.size.x])
39                 || (   curpos > 0 && curpos % world.map.size.x != 0
40                     && '.' == world.map.cells[curpos-1])
41                 || (   curpos < (world.map.size.x * world.map.size.y)
42                     && (curpos+1) % world.map.size.x != 0
43                     && '.' == world.map.cells[curpos+1])))
44         {
45             if (  y == 0 || y == world.map.size.y - 1 || x == 0
46                 || x == world.map.size.x - 1)
47             {
48                 break;
49             }
50             world.map.cells[y * world.map.size.x + x] = '.';
51         }
52     }
53 }
54
55
56
57 extern uint8_t is_passable(struct yx_uint16 pos)
58 {
59     uint8_t passable = 0;
60     if (   0 <= pos.x && pos.x < world.map.size.x
61         && 0 <= pos.y && pos.y < world.map.size.y)
62     {
63         passable = (('.' == world.map.cells[pos.y * world.map.size.x + pos.x]));
64     }
65     return passable;
66 }