mirror of
				https://github.com/zenorogue/hyperrogue.git
				synced 2025-10-22 09:27:40 +00:00 
			
		
		
		
	new land structure, CR2-like
This commit is contained in:
		
							
								
								
									
										14
									
								
								landlock.cpp
									
									
									
									
									
								
							
							
						
						
									
										14
									
								
								landlock.cpp
									
									
									
									
									
								
							| @@ -81,7 +81,7 @@ EX eLand firstland = laIce; | ||||
| EX eLand specialland = laIce; | ||||
|  | ||||
| #if HDR | ||||
| enum eLandStructure { lsNiceWalls, lsChaos, lsPatchedChaos, lsTotalChaos, lsChaosRW, lsWallChaos, lsSingle, lsNoWalls, lsHorodisks, lsVoronoi, lsLandscape, lsCrossWalls, lsGUARD }; | ||||
| enum eLandStructure { lsNiceWalls, lsChaos, lsPatchedChaos, lsTotalChaos, lsChaosRW, lsWallChaos, lsSingle, lsNoWalls, lsHorodisks, lsVoronoi, lsLandscape, lsCrossWalls, lsVineWalls, lsGUARD }; | ||||
| #endif | ||||
|  | ||||
| EX eLandStructure land_structure; | ||||
| @@ -90,9 +90,9 @@ EX namespace ls { | ||||
|  | ||||
| EX bool single() { return land_structure == lsSingle; } | ||||
|  | ||||
| EX bool any_chaos() { return among(land_structure, lsChaos, lsPatchedChaos, lsWallChaos, lsTotalChaos, lsChaosRW, lsCrossWalls, lsLandscape); } | ||||
| EX bool any_chaos() { return among(land_structure, lsChaos, lsPatchedChaos, lsWallChaos, lsTotalChaos, lsChaosRW, lsCrossWalls, lsVineWalls, lsLandscape); } | ||||
| EX bool std_chaos() { return land_structure == lsChaos; } | ||||
| EX bool wall_chaos() { return among(land_structure, lsWallChaos, lsCrossWalls); } | ||||
| EX bool wall_chaos() { return among(land_structure, lsWallChaos, lsCrossWalls, lsVineWalls); } | ||||
| EX bool patched_chaos() { return land_structure == lsPatchedChaos; } | ||||
|  | ||||
| EX bool any_order() { return among(land_structure, lsNiceWalls, lsNoWalls, lsHorodisks, lsVoronoi); } | ||||
| @@ -122,6 +122,7 @@ EX int chaoticity() { | ||||
| EX int ls_mul() { | ||||
|   if(land_structure == lsWallChaos) return 2; | ||||
|   if(land_structure == lsCrossWalls) return 3; | ||||
|   if(land_structure == lsVineWalls) return 3; | ||||
|   return 1; | ||||
|   } | ||||
|  | ||||
| @@ -129,6 +130,7 @@ EX int ls_mul() { | ||||
| EX int ls_mul_big() { | ||||
|   if(land_structure == lsWallChaos) return 5; | ||||
|   if(land_structure == lsCrossWalls) return 10; | ||||
|   if(land_structure == lsVineWalls) return 10; | ||||
|   return 1; | ||||
|   } | ||||
|  | ||||
| @@ -161,6 +163,8 @@ EX string land_structure_name(bool which) { | ||||
|       return XLAT("wall-less"); | ||||
|     case lsCrossWalls: | ||||
|       return XLAT("excessive crossing walls"); | ||||
|     case lsVineWalls: | ||||
|       return XLAT("regular walls"); | ||||
|     default: | ||||
|       return "error structure"; | ||||
|     } | ||||
| @@ -183,6 +187,8 @@ EX void fix_land_structure_choice() { | ||||
|     land_structure = lsChaos; | ||||
|   if(!nice_walls_available() && land_structure == lsCrossWalls) | ||||
|     land_structure = lsChaos; | ||||
|   if(land_structure == lsVineWalls && (geometry != gNormal || !BITRUNCATED)) | ||||
|     land_structure = lsNiceWalls; | ||||
|   if(ls::hv_structure() && (!hyperbolic || bt::in() || quotient)) | ||||
|     land_structure = lsSingle; | ||||
|   if(walls_not_implemented() && among(land_structure, lsChaos, lsNoWalls)) | ||||
| @@ -1171,7 +1177,7 @@ EX land_validity_t& land_validity(eLand l) { | ||||
|   if(l == laWhirlwind && hyperbolic_not37) | ||||
|     return pattern_incompatibility; | ||||
|  | ||||
|   bool better_mirror = !geometry && STDVAR && !ls::hv_structure() && !among(land_structure, lsTotalChaos, lsPatchedChaos, lsLandscape); | ||||
|   bool better_mirror = !geometry && STDVAR && !ls::hv_structure() && !among(land_structure, lsTotalChaos, lsPatchedChaos, lsLandscape, lsVineWalls); | ||||
|  | ||||
|   // available only in non-standard geometries | ||||
|   if(l == laMirrorOld && better_mirror) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Zeno Rogue
					Zeno Rogue