// Copyright (c) 2000,2001 // Utrecht University (The Netherlands), // ETH Zurich (Switzerland), // INRIA Sophia-Antipolis (France), // Max-Planck-Institute Saarbruecken (Germany), // and Tel-Aviv University (Israel). All rights reserved. // // This file is part of CGAL (www.cgal.org) // // $URL: https://github.com/CGAL/cgal/blob/v5.1/Kernel_d/include/CGAL/Kernel_d/Direction_d.h $ // $Id: Direction_d.h 127d76c 2020-06-10T17:57:54+02:00 Laurent Rineau // SPDX-License-Identifier: LGPL-3.0-or-later OR LicenseRef-Commercial // // // Author(s) : Michael Seel #ifndef CGAL_DIRECTION_D_H #define CGAL_DIRECTION_D_H #include namespace CGAL { template class Vector_d; template class Direction_d : public pR::Direction_d_base { public: typedef CGAL::Dynamic_dimension_tag Ambient_dimension; typedef CGAL::Dimension_tag<0> Feature_dimension; typedef typename pR::Direction_d_base Base; typedef Direction_d Self; typedef pR R; typedef typename R::RT RT; typedef typename R::FT FT; typedef typename R::LA LA; typedef typename Base::Base_direction Base_direction; Direction_d(int d=0) : Base(d) {} Direction_d(int a, int b) : Base(a,b) {} Direction_d(const RT& a, const RT& b) : Base(a,b) {} Direction_d(int a, int b, int c) : Base(a,b,c) {} Direction_d(const RT& a, const RT& b, const RT& c) : Base(a,b,c) {} template Direction_d (int d, InputIterator first, InputIterator last) : Base(d, first, last) {} Direction_d(const Vector_d &v) : Base(v) {} Direction_d(int d, Base_direction, int i) : Base(d,Base_direction(),i) {} Direction_d(const Base& p) : Base(p) {} Self operator-() const { return Base::operator-(); } Vector_d vector() const { return Base::vector(); } bool operator==(const Self& w) const { return Base::operator==(w); } bool operator!=(const Self& w) const { return Base::operator!=(w); } bool operator==(const Base& w) const { return Base::operator==(w); } bool operator!=(const Base& w) const { return Base::operator!=(w); } }; } //namespace CGAL #endif //CGAL_DIRECTION_D_H