mirror of
https://github.com/zenorogue/hyperrogue.git
synced 2025-06-29 08:22:51 +00:00
fix to propagate_scale_change
This commit is contained in:
parent
ee788c8822
commit
d9dec7f841
13
geometry.cpp
13
geometry.cpp
@ -1451,9 +1451,8 @@ EX void check_cgi() {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
EX void propagate_scale_change() {
|
/** auxiliary for propagate_scale_change */
|
||||||
|
template<class T> void affect_scale_change(geometry_information*& alt_cgip, const T& switcher) {
|
||||||
auto affect = [] (geometry_information*& alt_cgip, const auto& switcher) {
|
|
||||||
auto gi = alt_cgip;
|
auto gi = alt_cgip;
|
||||||
bool changed = false;
|
bool changed = false;
|
||||||
switcher([&] {
|
switcher([&] {
|
||||||
@ -1467,9 +1466,11 @@ EX void propagate_scale_change() {
|
|||||||
if(changed) switcher(propagate_scale_change);
|
if(changed) switcher(propagate_scale_change);
|
||||||
};
|
};
|
||||||
|
|
||||||
if(mhybrid) affect(hybrid::underlying_cgip, [] (const auto& f) { hybrid::in_underlying_geometry(f); });
|
EX void propagate_scale_change() {
|
||||||
if(hybrid::pmap) affect(hybrid::pcgip, [] (const auto& f) { hybrid::in_actual(f); });
|
|
||||||
if(fake::in()) affect(fake::underlying_cgip, [] (const auto& f) { fake::in_underlying_geometry(f); });
|
if(mhybrid) affect_scale_change(hybrid::underlying_cgip, [] (const auto& f) { hybrid::in_underlying_geometry(f); });
|
||||||
|
if(hybrid::pmap) affect_scale_change(hybrid::pcgip, [] (const auto& f) { hybrid::in_actual(f); });
|
||||||
|
if(fake::in()) affect_scale_change(fake::underlying_cgip, [] (const auto& f) { fake::in_underlying_geometry(f); });
|
||||||
}
|
}
|
||||||
|
|
||||||
void clear_cgis() {
|
void clear_cgis() {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user