/*========================================================================= * * Copyright NumFOCUS * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * https://www.apache.org/licenses/LICENSE-2.0.txt * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * *=========================================================================*/ #ifndef itkMatlabTransformIO_h #define itkMatlabTransformIO_h #include "ITKIOTransformMatlabExport.h" #include "itkTransformIOBase.h" namespace itk { /** \class MatlabTransformIOTemplate * \brief Create instances of MatlabTransformIOTemplate objects. * \ingroup ITKIOTransformMatlab */ template class ITK_TEMPLATE_EXPORT MatlabTransformIOTemplate : public TransformIOBaseTemplate { public: using Self = MatlabTransformIOTemplate; using Superclass = TransformIOBaseTemplate; using Pointer = SmartPointer; using typename Superclass::TransformType; using typename Superclass::TransformPointer; using typename Superclass::TransformListType; using ConstTransformListType = typename TransformIOBaseTemplate::ConstTransformListType; /** \see LightObject::GetNameOfClass() */ itkOverrideGetNameOfClassMacro(MatlabTransformIOTemplate); itkNewMacro(Self); /** Determine the file type. Returns true if this ImageIO can read the * file specified. */ bool CanReadFile(const char *) override; /** Determine the file type. Returns true if this ImageIO can read the * file specified. */ bool CanWriteFile(const char *) override; /** Reads the data from disk into the memory buffer provided. */ void Read() override; /** Writes the data to disk from the memory buffer provided. Make sure * that the IORegions has been set properly. The buffer is cast to a * pointer to the beginning of the image data. */ void Write() override; protected: MatlabTransformIOTemplate(); ~MatlabTransformIOTemplate() override; }; /** This helps to meet backward compatibility */ using MatlabTransformIO = MatlabTransformIOTemplate; } // namespace itk // Note: Explicit instantiation is done in itkMatlabTransformIO.cxx #endif // itkMatlabTransformIO_h /** Explicit instantiations */ #ifndef ITK_TEMPLATE_EXPLICIT_MatlabTransformIO // Explicit instantiation is required to ensure correct dynamic_cast // behavior across shared libraries. // // IMPORTANT: Since within the same compilation unit, // ITK_TEMPLATE_EXPLICIT_ defined and undefined states // need to be considered. This code *MUST* be *OUTSIDE* the header // guards. // #if defined(ITKIOTransformMatlab_EXPORTS) // We are building this library # define ITKIOTransformMatlab_EXPORT_EXPLICIT ITK_FORWARD_EXPORT #else // We are using this library # define ITKIOTransformMatlab_EXPORT_EXPLICIT ITKIOTransformMatlab_EXPORT #endif namespace itk { ITK_GCC_PRAGMA_DIAG_PUSH() ITK_GCC_PRAGMA_DIAG(ignored "-Wattributes") extern template class ITKIOTransformMatlab_EXPORT_EXPLICIT MatlabTransformIOTemplate; extern template class ITKIOTransformMatlab_EXPORT_EXPLICIT MatlabTransformIOTemplate; ITK_GCC_PRAGMA_DIAG_POP() } // end namespace itk #undef ITKIOTransformMatlab_EXPORT_EXPLICIT #endif