Skip to content

File GeometryCollection.h

File List > src > GeometryCollection.h

Go to the documentation of this file

// Copyright (c) 2012-2013, IGN France.
// Copyright (c) 2012-2022, Oslandia.
// SPDX-License-Identifier: LGPL-2.0-or-later

#ifndef _SFCGAL_GEOMETRYCOLLECTION_H_
#define _SFCGAL_GEOMETRYCOLLECTION_H_

#include <boost/assert.hpp>
#include <boost/ptr_container/ptr_vector.hpp>
#include <boost/ptr_container/serialize_ptr_vector.hpp>
#include <boost/serialization/base_object.hpp>
#include <vector>

#include "SFCGAL/Geometry.h"

namespace SFCGAL {

class SFCGAL_API GeometryCollection : public Geometry {
public:
  typedef boost::ptr_vector<Geometry>::iterator       iterator;
  typedef boost::ptr_vector<Geometry>::const_iterator const_iterator;

  GeometryCollection();
  GeometryCollection(const GeometryCollection &other);
  GeometryCollection &
  operator=(GeometryCollection other);
  virtual ~GeometryCollection();

  //-- SFCGAL::Geometry
  virtual GeometryCollection *
  clone() const;

  //-- SFCGAL::Geometry
  virtual std::string
  geometryType() const;
  //-- SFCGAL::Geometry
  virtual GeometryType
  geometryTypeId() const;
  //-- SFCGAL::Geometry
  virtual int
  dimension() const;
  //-- SFCGAL::Geometry
  virtual int
  coordinateDimension() const;
  //-- SFCGAL::Geometry
  virtual bool
  isEmpty() const;
  //-- SFCGAL::Geometry
  virtual bool
  is3D() const;
  //-- SFCGAL::Geometry
  virtual bool
  isMeasured() const;

  //-- SFCGAL::Geometry
  virtual size_t
  numGeometries() const;
  //-- SFCGAL::Geometry
  virtual const Geometry &
  geometryN(size_t const &n) const;
  //-- SFCGAL::Geometry
  virtual Geometry &
  geometryN(size_t const &n);

  void
  addGeometry(Geometry *geometry);
  void
  addGeometry(Geometry const &geometry);

  //-- iterators

  inline iterator
  begin()
  {
    return _geometries.begin();
  }
  inline const_iterator
  begin() const
  {
    return _geometries.begin();
  }

  inline iterator
  end()
  {
    return _geometries.end();
  }
  inline const_iterator
  end() const
  {
    return _geometries.end();
  }

  //-- visitors

  //-- SFCGAL::Geometry
  virtual void
  accept(GeometryVisitor &visitor);
  //-- SFCGAL::Geometry
  virtual void
  accept(ConstGeometryVisitor &visitor) const;

  template <class Archive>
  void
  serialize(Archive &ar, const unsigned int /*version*/)
  {
    ar &boost::serialization::base_object<Geometry>(*this);
    ar &_geometries;
  }

private:
  boost::ptr_vector<Geometry> _geometries;

protected:
  virtual bool
  isAllowed(Geometry const &g);

  void
  swap(GeometryCollection &other)
  {
    _geometries.swap(other._geometries);
  }
};

} // namespace SFCGAL

#endif