summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJozef Behran <jozuejozef@gmail.com>2019-08-07 12:06:45 +0200
committersfan5 <sfan5@live.de>2019-08-13 19:40:59 +0200
commite9ceead81dd989936e2de3ff7cd7496aecd09d39 (patch)
tree51c94e2faf111ed63e40e5bc44d8ea5ea614b6c6
parent833e60d8d229a082e9841dc89494e6bda9cd5020 (diff)
downloadminetest-e9ceead81dd989936e2de3ff7cd7496aecd09d39.tar.gz
minetest-e9ceead81dd989936e2de3ff7cd7496aecd09d39.tar.bz2
minetest-e9ceead81dd989936e2de3ff7cd7496aecd09d39.zip
Fix unnecessary exception use in Map::isNodeUnderground
The isNodeUnderground calls getBlockNoCreate which calls getBlockNoCreateNoEx and throws InvalidPositionException if the returned value is nullptr, which isNodeUnderground then catches to return "false". Remove the try..catch in isNodeUnderground by calling getBlockNoCreateNoEx instead of getBlockNoCreate and checking the returned value for nullptr.
-rw-r--r--src/map.cpp10
1 files changed, 2 insertions, 8 deletions
diff --git a/src/map.cpp b/src/map.cpp
index 590c3f2f5..a1389fd10 100644
--- a/src/map.cpp
+++ b/src/map.cpp
@@ -152,14 +152,8 @@ MapBlock * Map::getBlockNoCreate(v3s16 p3d)
bool Map::isNodeUnderground(v3s16 p)
{
v3s16 blockpos = getNodeBlockPos(p);
- try{
- MapBlock * block = getBlockNoCreate(blockpos);
- return block->getIsUnderground();
- }
- catch(InvalidPositionException &e)
- {
- return false;
- }
+ MapBlock *block = getBlockNoCreateNoEx(blockpos);
+ return block && block->getIsUnderground();
}
bool Map::isValidPosition(v3s16 p)