|  |  | @ -118,51 +118,7 @@ Point Map::center_camera(const Point &around, size_t view_x, size_t view_y) { | 
			
		
	
		
		
			
				
					
					|  |  |  |  * in and out. |  |  |  |  * in and out. | 
			
		
	
		
		
			
				
					
					|  |  |  |  */ |  |  |  |  */ | 
			
		
	
		
		
			
				
					
					|  |  |  | bool Map::neighbors(Point &out, bool random, int direction) { |  |  |  | bool Map::neighbors(Point &out, bool random, int direction) { | 
			
		
	
		
		
			
				
					
					|  |  |  |   Matrix &paths = $paths.$paths; |  |  |  |   return $paths.random_walk(out, random, direction); | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |   bool zero_found = false; |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |   // just make a list of the four directions
 |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |   std::array<Point, 4> dirs{{ |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |       {out.x,out.y-1}, // north
 |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |       {out.x+1,out.y}, // east
 |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |       {out.x,out.y+1}, // south
 |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |       {out.x-1,out.y} // west
 |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |   }}; |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |   // get the current dijkstra number
 |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |   int cur = paths[out.y][out.x]; |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |   // pick a random start of directions
 |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |   // BUG: is uniform inclusive of the dir.size()?
 |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |   int rand_start = Random::uniform<int>(0, dirs.size()); |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |   // go through all possible directions
 |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |   for(size_t i = 0; i < dirs.size(); i++) { |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |     // but start at the random start, effectively randomizing
 |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |     // which valid direction to go
 |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |     // BUG: this might be wrong given the above ranom from 0-size
 |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |     Point dir = dirs[(i + rand_start) % dirs.size()]; |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |     if(!inmap(dir.x, dir.y)) continue; //skip unpathable stuff
 |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |     int weight = cur - paths[dir.y][dir.x]; |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |     if(weight == direction) { |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |       // no matter what we follow direct paths
 |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |       out = dir; |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |       return true; |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |     } else if(random && weight == 0) { |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |       // if random is selected and it's a 0 path take it
 |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |       out = dir; |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |       return true; |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |     } else if(weight == 0) { |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |       // otherwise keep the last zero path for after
 |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |       out = dir; |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |       zero_found = true; |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |     } |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |   } |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |   // if we reach this then either zero was found and
 |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |   // zero_found is set true, or it wasn't and nothing found
 |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |   return zero_found; |  |  |  |  | 
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | } |  |  |  | } | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | bool Map::INVARIANT() { |  |  |  | bool Map::INVARIANT() { | 
			
		
	
	
		
		
			
				
					|  |  | 
 |