1 /* 2 Copyright (C) 2010-2014 Kristian Duske 3 4 This file is part of TrenchBroom. 5 6 TrenchBroom is free software: you can redistribute it and/or modify 7 it under the terms of the GNU General Public License as published by 8 the Free Software Foundation, either version 3 of the License, or 9 (at your option) any later version. 10 11 TrenchBroom is distributed in the hope that it will be useful, 12 but WITHOUT ANY WARRANTY; without even the implied warranty of 13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 14 GNU General Public License for more details. 15 16 You should have received a copy of the GNU General Public License 17 along with TrenchBroom. If not, see <http://www.gnu.org/licenses/>. 18 */ 19 20 #ifndef TrenchBroom_BoundsIntersectsNodeVisitor 21 #define TrenchBroom_BoundsIntersectsNodeVisitor 22 23 #include "TrenchBroom.h" 24 #include "VecMath.h" 25 #include "Model/ModelTypes.h" 26 #include "Model/NodeVisitor.h" 27 28 namespace TrenchBroom { 29 namespace Model { 30 class BoundsIntersectsNodeVisitor : public ConstNodeVisitor, public NodeQuery<bool> { 31 private: 32 const BBox3& m_bounds; 33 public: 34 BoundsIntersectsNodeVisitor(const BBox3& bounds); 35 private: 36 void doVisit(const World* world); 37 void doVisit(const Layer* layer); 38 void doVisit(const Group* group); 39 void doVisit(const Entity* entity); 40 void doVisit(const Brush* brush); 41 }; 42 } 43 } 44 45 #endif /* defined(TrenchBroom_BoundsIntersectsNodeVisitor) */ 46