mirror of
				https://github.com/zenorogue/hyperrogue.git
				synced 2025-10-25 02:47:40 +00:00 
			
		
		
		
	rulegen:: build shortcuts on parent change
This commit is contained in:
		
							
								
								
									
										42
									
								
								rulegen.cpp
									
									
									
									
									
								
							
							
						
						
									
										42
									
								
								rulegen.cpp
									
									
									
									
									
								
							| @@ -104,6 +104,8 @@ struct tcell { | |||||||
|   short code; |   short code; | ||||||
|   /** direction to the parent in the tree */ |   /** direction to the parent in the tree */ | ||||||
|   short parent_dir; |   short parent_dir; | ||||||
|  |   /** direction to the OLD parent in the tree */ | ||||||
|  |   short old_parent_dir; | ||||||
|   /** direction to anyone closer */ |   /** direction to anyone closer */ | ||||||
|   short any_nearer; |   short any_nearer; | ||||||
|   /** can we assume that dist is correct? if we assumed that the dist is correct but then find out it was wrong, throw an error */ |   /** can we assume that dist is correct? if we assumed that the dist is correct but then find out it was wrong, throw an error */ | ||||||
| @@ -178,6 +180,7 @@ tcell *gen_tcell(int id) { | |||||||
|   c->dist = MYSTERY; |   c->dist = MYSTERY; | ||||||
|   c->code = MYSTERY; |   c->code = MYSTERY; | ||||||
|   c->parent_dir = MYSTERY; |   c->parent_dir = MYSTERY; | ||||||
|  |   c->old_parent_dir = MYSTERY; | ||||||
|   first_tcell = c; |   first_tcell = c; | ||||||
|   // println(hlog, c, " is a new tcell of id ", id); |   // println(hlog, c, " is a new tcell of id ", id); | ||||||
|   tcellcount++; |   tcellcount++; | ||||||
| @@ -574,9 +577,11 @@ EX void find_new_shortcuts(tcell *c, int d, tcell *alt, int newdir, int delta) { | |||||||
|  |  | ||||||
| EX void remove_parentdir(tcell *c) { | EX void remove_parentdir(tcell *c) { | ||||||
|   sidecache.clear(); |   sidecache.clear(); | ||||||
|  |   if(c->parent_dir) c->old_parent_dir = c->parent_dir; | ||||||
|   c->parent_dir = MYSTERY; |   c->parent_dir = MYSTERY; | ||||||
|   c->code = MYSTERY; |   c->code = MYSTERY; | ||||||
|   for(int i=0; i<c->type; i++) if(c->move(i)) { |   for(int i=0; i<c->type; i++) if(c->move(i)) { | ||||||
|  |     if(c->move(i)->parent_dir) c->move(i)->old_parent_dir = c->move(i)->parent_dir; | ||||||
|     c->move(i)->parent_dir = MYSTERY; |     c->move(i)->parent_dir = MYSTERY; | ||||||
|     c->move(i)->code = MYSTERY; |     c->move(i)->code = MYSTERY; | ||||||
|     } |     } | ||||||
| @@ -625,38 +630,9 @@ EX void fix_distances(tcell *c) { | |||||||
|           tgt_d = new_d; |           tgt_d = new_d; | ||||||
|           sidecache.clear(); |           sidecache.clear(); | ||||||
|           tgt->any_nearer = tgtw.spin; |           tgt->any_nearer = tgtw.spin; | ||||||
|           tgt->parent_dir = MYSTERY; |           remove_parentdir(tgt); | ||||||
|           if(tgt->is_solid) tgt->parent_dir = tgtw.spin; |  | ||||||
|           tgt->code = MYSTERY; |  | ||||||
|           return true; |           return true; | ||||||
|           } |           } | ||||||
|         if(tgt_d == new_d && tgt->parent_dir != MYSTERY && tgt->parent_dir != tgtw.spin) { |  | ||||||
|           auto& sh = arb::current.shapes[tgt->id]; |  | ||||||
|           auto k = sh.cycle_length; |  | ||||||
|  |  | ||||||
|           int dif = tgtw.spin % k - tgt->parent_dir % k; |  | ||||||
|  |  | ||||||
|           auto oldp = get_parent_dir(tgtw); |  | ||||||
|  |  | ||||||
|           if(dif == 0) { |  | ||||||
|             tgtw.at->parent_dir = MYSTERY; |  | ||||||
|             auto newp = get_parent_dir(tgtw); |  | ||||||
|             if(oldp != newp) { |  | ||||||
|               if(newp != tgtw) throw rulegen_retry("parent_dir confusion should not happen"); |  | ||||||
|               dif = -1; |  | ||||||
|               } |  | ||||||
|             } |  | ||||||
|  |  | ||||||
|           if(dif < 0) { |  | ||||||
|             tgtw.at->parent_dir = tgtw.spin; |  | ||||||
|             tgtw.at->code = MYSTERY; |  | ||||||
|             ufind(oldp); |  | ||||||
|             indenter ind(2); |  | ||||||
|             tgtw.at->any_nearer = oldp.spin; |  | ||||||
|             find_new_shortcuts(tgtw.at, new_d, tgtw.at, tgtw.spin, 0); |  | ||||||
|             sidecache.clear(); |  | ||||||
|             } |  | ||||||
|           } |  | ||||||
|         return false; |         return false; | ||||||
|         }; |         }; | ||||||
|  |  | ||||||
| @@ -951,6 +927,12 @@ EX twalker get_parent_dir(twalker& cw) { | |||||||
|      |      | ||||||
|   if(parent_debug) println(hlog, "set parent_dir to ", bestd); |   if(parent_debug) println(hlog, "set parent_dir to ", bestd); | ||||||
|   c->parent_dir = bestd; |   c->parent_dir = bestd; | ||||||
|  |  | ||||||
|  |   if(c->old_parent_dir != MYSTERY && c->old_parent_dir != bestd && c == oc) { | ||||||
|  |     c->any_nearer = c->old_parent_dir; | ||||||
|  |     find_new_shortcuts(c, c->dist, c, bestd, 0); | ||||||
|  |     } | ||||||
|  |  | ||||||
|   return twalker(c, bestd); |   return twalker(c, bestd); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Zeno Rogue
					Zeno Rogue