#include <CGAL/Exact_predicates_exact_constructions_kernel.h>
#include <CGAL/connect_holes.h>
#include <list>
int main (int argc, char* argv[])
{
  
  
  
  
  
  const char* filename = (argc > 1) ? argv[1] : "pgn_holes.dat";  
  std::ifstream input_file (filename);
  if (! input_file.is_open())
  {
    std::cerr << "Failed to open the " << filename <<std::endl;
    return -1;
  }
  
  Polygon_2               outerP;
  unsigned int            num_holes;
  input_file >> outerP;
  input_file >> num_holes;
  std::vector<Polygon_2>  holes (num_holes);
  unsigned int            k;
  for (k = 0; k < num_holes; k++)
    input_file >> holes[k];
  Polygon_with_holes_2    P (outerP, holes.begin(), holes.end());
  
  std::list<Point_2>            pts;
  std::list<Point_2>::iterator  pit;
  for (pit = pts.begin(); pit != pts.end(); ++pit)
    std::cout << '(' << *pit << ")  ";
  std::cout << std::endl;
  return (0);
}