X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fgeometry%2Funion.h;h=738f1f240f3de600dac9d63e1e048fe786bc3d75;hb=44bd1d1ab256d397be4e2169c4ca5efdd0569d31;hp=8461f8484ee5d085560b6fb70f522447d9a95c6e;hpb=09cc3a8648dd20e9a07d669b353c4a120b67c1c4;p=libs%2Fmath.git diff --git a/source/geometry/union.h b/source/geometry/union.h index 8461f84..738f1f2 100644 --- a/source/geometry/union.h +++ b/source/geometry/union.h @@ -6,20 +6,16 @@ namespace Msp { namespace Geometry { -/** -Joins component shapes together into one. -*/ template struct UnionOps { static BoundingBox combine_aabb(const BoundingBox &a, const BoundingBox &b) { return a|b; } - static bool init_inside() { return false; } - static bool combine_inside(bool a, bool b) { return a || b; } - static bool is_inside_decided(bool a) { return a; } - static bool init_surface() { return true; } - static bool combine_surface(bool a, bool b) { return a && !b; } + static bool shortcircuit(bool c) { return c; } }; +/** +Joins component shapes together into one. +*/ template class Union: public CompositeShape > {