From: Perttu Ahola Date: Sat, 15 Jan 2011 11:07:10 +0000 (+0200) Subject: just backuppin' a working mapblock.cpp X-Git-Url: http://81.2.79.47:8989/gitweb/?a=commitdiff_plain;h=83e083a667d8423ea27555ed58cc90a5f57d103f;p=zefram%2Fminetest%2Fminetest_engine.git just backuppin' a working mapblock.cpp --- diff --git a/src/mapblock.cpp b/src/mapblock.cpp index 2d077121..68b29615 100644 --- a/src/mapblock.cpp +++ b/src/mapblock.cpp @@ -864,8 +864,14 @@ void MapBlock::updateMesh(u32 daynight_ratio) - SUGG: This could be optimized Turns sunglighted mud into grass. + + if remove_light==true, sets non-sunlighted nodes black. + + if black_air_left!=NULL, it is set to true if non-sunlighted + air is left in block. */ -bool MapBlock::propagateSunlight(core::map & light_sources) +bool MapBlock::propagateSunlight(core::map & light_sources, + bool remove_light, bool *black_air_left) { // Whether the sunlight at the top of the bottom block is valid bool block_below_is_valid = true; @@ -959,19 +965,27 @@ bool MapBlock::propagateSunlight(core::map & light_sources) } bool sunlight_should_go_down = (y==-1); - - // Fill rest with black (only transparent ones) - for(; y >= 0; y--){ + + /* + Check rest through to the bottom of the block + */ + for(; y >= 0; y--) + { v3s16 pos(x, y, z); - MapNode &n = getNodeRef(pos); if(n.light_propagates()) { - n.setLight(LIGHTBANK_DAY, 0); - } - else{ - break; + if(black_air_left) + { + *black_air_left = true; + } + + if(remove_light) + { + // Fill transparent nodes with black + n.setLight(LIGHTBANK_DAY, 0); + } } }