]> git.mxchange.org Git - flightgear.git/commitdiff
Environment bugfix: don't write unchanged cloud coverages
authorTorsten Dreyer <Torsten@t3r.de>
Sat, 11 Sep 2010 19:23:11 +0000 (21:23 +0200)
committerTorsten Dreyer <Torsten@t3r.de>
Sat, 11 Sep 2010 19:23:11 +0000 (21:23 +0200)
Only write out changes of the cloud layer to avoid regeneration
of the cloud layers if nothing has changed

src/Environment/environment_mgr.cxx

index 3f1c14431125043b7356017ca4ee832388e85566..5b79b25d088242ef48383489228b055e3db6cd98 100644 (file)
@@ -302,6 +302,9 @@ void
 FGEnvironmentMgr::set_cloud_layer_coverage (int index,
                                             const char * coverage_name)
 {
+  if( thesky->get_cloud_layer(index)->getCoverageString() == coverage_name )
+    return;
+
   thesky->get_cloud_layer(index)->setCoverageString(coverage_name);
   _cloudLayersDirty = true;
 }
@@ -316,10 +319,14 @@ FGEnvironmentMgr::get_cloud_layer_coverage_type (int index) const
 void 
 FGEnvironmentMgr::set_cloud_layer_coverage_type (int index, int type )
 {
-  if( index < 0 || index >= SGCloudLayer::SG_MAX_CLOUD_COVERAGES ) {
+  if( type < 0 || type >= SGCloudLayer::SG_MAX_CLOUD_COVERAGES ) {
     SG_LOG(SG_ALL,SG_WARN,"Unknown cloud layer type " << type << " ignored" );
     return;
   }
+
+  if( static_cast<SGCloudLayer::Coverage>(type) == thesky->get_cloud_layer(index)->getCoverage() )
+    return;
+
   thesky->get_cloud_layer(index)->setCoverage(static_cast<SGCloudLayer::Coverage>(type));
   _cloudLayersDirty = true;
 }