//============================================================================ // Copyright (c) Kitware, Inc. // All rights reserved. // See LICENSE.txt for details. // // This software is distributed WITHOUT ANY WARRANTY; without even // the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR // PURPOSE. See the above copyright notice for more information. //============================================================================ #ifndef vtk_m_cont_PointLocator_h #define vtk_m_cont_PointLocator_h #include #include #include #include namespace vtkm { namespace cont { class VTKM_CONT_EXPORT PointLocator : public vtkm::cont::ExecutionObjectBase { public: virtual ~PointLocator(); PointLocator() : Modified(true) { } vtkm::cont::CoordinateSystem GetCoordinates() const { return this->Coords; } void SetCoordinates(const vtkm::cont::CoordinateSystem& coords) { this->Coords = coords; this->SetModified(); } void Update() { if (this->Modified) { Build(); this->Modified = false; } } VTKM_CONT const vtkm::exec::PointLocator* PrepareForExecution(vtkm::cont::DeviceAdapterId device, vtkm::cont::Token& token) const { this->PrepareExecutionObject(this->ExecutionObjectHandle, device, token); return this->ExecutionObjectHandle.PrepareForExecution(device, token); } VTKM_CONT VTKM_DEPRECATED(1.6, "PrepareForExecution now requires a vtkm::cont::Token object") const vtkm::exec::PointLocator* PrepareForExecution(vtkm::cont::DeviceAdapterId device) const { vtkm::cont::Token token; return this->PrepareForExecution(device, token); } protected: void SetModified() { this->Modified = true; } bool GetModified() const { return this->Modified; } virtual void Build() = 0; using ExecutionObjectHandleType = vtkm::cont::VirtualObjectHandle; VTKM_CONT virtual void PrepareExecutionObject(ExecutionObjectHandleType& execObjHandle, vtkm::cont::DeviceAdapterId deviceId, vtkm::cont::Token& token) const = 0; private: vtkm::cont::CoordinateSystem Coords; bool Modified; mutable ExecutionObjectHandleType ExecutionObjectHandle; }; } } #endif // vtk_m_cont_PointLocator_h