// Copyright (c) 2008 INRIA Sophia-Antipolis (France). // All rights reserved. // // This file is part of CGAL (www.cgal.org). // You can redistribute it and/or modify it under the terms of the GNU // General Public License as published by the Free Software Foundation, // either version 3 of the License, or (at your option) any later version. // // Licensees holding a valid commercial license may use this file in // accordance with the commercial license agreement provided with the software. // // This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE // WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. // // $URL$ // $Id$ // SPDX-License-Identifier: GPL-3.0+ // // Author(s) : Monique Teillaud, Sylvain Pion, Pedro Machado, // Sebastien Loriot, Julien Hazebrouck, Damien Leroy // Partially supported by the IST Programme of the EU as a // STREP (FET Open) Project under Contract No IST-006413 // (ACS -- Algorithms for Complex Shapes) #ifndef CGAL_SPHERICAL_KERNEL_3_H #define CGAL_SPHERICAL_KERNEL_3_H #include #include #include #include #include #include #include #include #include #include #include namespace CGAL { namespace internal { template < class SphericalKernel, class LinearKernelBase > struct Spherical_kernel_base_ref_count: public LinearKernelBase // takes classes in internal sub-namespace { typedef internal::Circular_arc_point_3 Circular_arc_point_3; typedef internal::Line_arc_3 Line_arc_3; typedef internal::Circular_arc_3 Circular_arc_3; // The mechanism that allows to specify reference-counting or not. template < typename T > struct Handle { typedef Handle_for type; }; #define CGAL_Spherical_Kernel_pred(Y,Z) typedef SphericalFunctors::Y Y; \ Y Z() const { return Y(); } #define CGAL_Spherical_Kernel_cons(Y,Z) CGAL_Spherical_Kernel_pred(Y,Z) #define CGAL_Spherical_Kernel_overload_cons(Y,Z) CGAL_Spherical_Kernel_pred(Y,Z) #define CGAL_Spherical_Kernel_overload_pred(Y,Z) CGAL_Spherical_Kernel_pred(Y,Z) #define CGAL_Spherical_Kernel_pred_on_sphere(Y,Z) typedef SphericalFunctors::Y Y; \ Y Z(const CGAL::Sphere_3& S) const { return Y(S); } #include }; } // namespace internal template < class LinearKernel, class AlgebraicKernel > struct Spherical_kernel_3 : // there should be a derivation from // LinearKernel::Kernel_base to have types equalities for // the Linearkernel types public Spherical_kernel_type_equality_wrapper, typename LinearKernel:: template Base >::Type >, Spherical_kernel_3 > { typedef Spherical_kernel_3 Self; typedef typename LinearKernel::template Base >::Type Linear_kernel; typedef AlgebraicKernel Algebraic_kernel; // //Please remove this if you consider it to be sloppy struct Circular_tag{}; typedef Circular_tag Definition_tag; // //////////////////////////////////////////////////// typedef typename LinearKernel::RT RT; typedef typename LinearKernel::FT FT; //~ typedef Algebraic_kernel AK; typedef typename Algebraic_kernel::Root_of_2 Root_of_2; typedef typename Algebraic_kernel::Root_for_spheres_2_3 Root_for_spheres_2_3; typedef typename Algebraic_kernel::Polynomial_for_spheres_2_3 Polynomial_for_spheres_2_3; typedef typename Algebraic_kernel::Polynomial_1_3 Polynomial_1_3; typedef typename Algebraic_kernel::Polynomials_for_line_3 Polynomials_for_line_3; typedef std::pair< Polynomial_for_spheres_2_3, Polynomial_1_3 > Polynomials_for_circle_3; // public classes typedef CGAL::Object Object_3; }; } // namespace CGAL #endif // CGAL_SPHERICAL_KERNEL_3_H