ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/deliantra/server/random_maps/square_spiral.C
(Generate patch)

Comparing deliantra/server/random_maps/square_spiral.C (file contents):
Revision 1.19 by root, Fri Mar 26 01:04:44 2010 UTC vs.
Revision 1.27 by root, Sat Nov 17 23:40:02 2018 UTC

1/* 1/*
2 * This file is part of Deliantra, the Roguelike Realtime MMORPG. 2 * This file is part of Deliantra, the Roguelike Realtime MMORPG.
3 * 3 *
4 * Copyright (©) 2017,2018 Marc Alexander Lehmann / the Deliantra team
4 * Copyright (©) 2005,2006,2007,2008,2009,2010 Marc Alexander Lehmann / Robin Redeker / the Deliantra team 5 * Copyright (©) 2005,2006,2007,2008,2009,2010,2011,2012,2013,2014,2015,2016 Marc Alexander Lehmann / Robin Redeker / the Deliantra team
5 * Copyright (©) 2001 Mark Wedel & Crossfire Development Team 6 * Copyright (©) 2001 Mark Wedel & Crossfire Development Team
6 * Copyright (©) 1992 Frank Tore Johansen 7 * Copyright (©) 1992 Frank Tore Johansen
7 * 8 *
8 * Deliantra is free software: you can redistribute it and/or modify it under 9 * Deliantra is free software: you can redistribute it and/or modify it under
9 * the terms of the Affero GNU General Public License as published by the 10 * the terms of the Affero GNU General Public License as published by the
10 * Free Software Foundation, either version 3 of the License, or (at your 11 * Free Software Foundation, either version 3 of the License, or (at your
11 * option) any later version. 12 * option) any later version.
12 * 13 *
13 * This program is distributed in the hope that it will be useful, 14 * This program is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of 15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 * GNU General Public License for more details. 17 * GNU General Public License for more details.
17 * 18 *
18 * You should have received a copy of the Affero GNU General Public License 19 * You should have received a copy of the Affero GNU General Public License
19 * and the GNU General Public License along with this program. If not, see 20 * and the GNU General Public License along with this program. If not, see
20 * <http://www.gnu.org/licenses/>. 21 * <http://www.gnu.org/licenses/>.
21 * 22 *
22 * The authors can be reached via e-mail to <support@deliantra.net> 23 * The authors can be reached via e-mail to <support@deliantra.net>
23 */ 24 */
24 25
25/* peterm@langmuir.eecs.berkeley.edu: this function generates a random 26/* peterm@langmuir.eecs.berkeley.edu: this function generates a random
26snake-type layout. 27snake-type maze.
27 28
28input: xsize, ysize; 29input: xsize, ysize;
29output: a char** array with # and . for closed and open respectively. 30output: a char** array with # and . for closed and open respectively.
30 31
31a char value of 0 represents a blank space: a '#' is 32a char value of 0 represents a blank space: a '#' is
33 34
34*/ 35*/
35 36
36#include <global.h> 37#include <global.h>
37 38
38#include "random_map.h" 39#include <rmg.h>
39#include "rproto.h" 40#include "rproto.h"
40 41
41/* These are some helper functions which help with 42/* These are some helper functions which help with
42 manipulating a centered onion and turning it into 43 manipulating a centered onion and turning it into
43 a square spiral */ 44 a square spiral */
44void 45void
45make_square_spiral_layout (Layout maze, int options) 46make_square_spiral_layout (layout &maze, int options)
46{ 47{
47 /* generate and allocate a doorless, centered onion */ 48 /* generate and allocate a doorless, centered onion */
48 map_gen_onion (maze, RMOPT_CENTERED | RMOPT_NO_DOORS, 0); 49 map_gen_onion (maze, RMOPT_CENTERED | RMOPT_NO_DOORS, 0);
49 50
50 int xsize = maze->w; 51 int xsize = maze.w;
51 int ysize = maze->h; 52 int ysize = maze.h;
52 53
53 /* find the layout center. */ 54 /* find the maze center. */
54 int cx = 0; 55 int cx = 0;
55 int cy = 0; 56 int cy = 0;
56 for (int i = 0; i < xsize; i++) 57 for (int i = 0; i < xsize; i++)
57 for (int j = 0; j < ysize; j++) 58 for (int j = 0; j < ysize; j++)
58 if (maze[i][j] == 'C') 59 if (maze[i][j] == 'C')

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines