22 #ifndef GEOS_GEOM_UTIL_POINTEXTRACTER_H
23 #define GEOS_GEOM_UTIL_POINTEXTRACTER_H
25 #include <geos/export.h>
26 #include <geos/geom/GeometryFilter.h>
27 #include <geos/geom/GeometryCollection.h>
28 #include <geos/platform.h>
49 template <
class ComponentType,
class TargetContainer>
52 if (
const ComponentType* c = dynamic_cast<const ComponentType*>(&geom) )
57 dynamic_cast<const GeometryCollection*>(&geom) )
59 GeometryExtracter::Extracter<ComponentType, TargetContainer> extracter(lst);
60 c->apply_ro(&extracter);
66 template <
class ComponentType,
class TargetContainer>
74 Extracter(TargetContainer& comps) : comps_(comps) {}
76 TargetContainer& comps_;
80 if (
const ComponentType* c = dynamic_cast<const ComponentType*>(geom) ) {
86 Extracter(
const Extracter& other);
87 Extracter& operator=(
const Extracter& rhs);
91 GeometryExtracter(
const GeometryExtracter& other);
92 GeometryExtracter& operator=(
const GeometryExtracter& rhs);
Geometry classes support the concept of applying a Geometry filter to the Geometry.
Definition: GeometryFilter.h:49
Basic implementation of Geometry, constructed and destructed by GeometryFactory.
Definition: Geometry.h:168
Represents a collection of heterogeneous Geometry objects.
Definition: GeometryCollection.h:57