1 // Copyright (C) 2007-2015 CEA/DEN, EDF R&D, OPEN CASCADE
3 // Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
4 // CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
6 // This library is free software; you can redistribute it and/or
7 // modify it under the terms of the GNU Lesser General Public
8 // License as published by the Free Software Foundation; either
9 // version 2.1 of the License, or (at your option) any later version.
11 // This library is distributed in the hope that it will be useful,
12 // but WITHOUT ANY WARRANTY; without even the implied warranty of
13 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 // Lesser General Public License for more details.
16 // You should have received a copy of the GNU Lesser General Public
17 // License along with this library; if not, write to the Free Software
18 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
20 // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
23 #ifndef HYDROData_InterpolatorsFactory_HeaderFile
24 #define HYDROData_InterpolatorsFactory_HeaderFile
26 #include <HYDROData.h>
32 class HYDROData_IProfilesInterpolator;
34 /**\class HYDROData_InterpolatorsFactory
36 * \brief Profile interpolators factory.
38 * Allows to register different types of interpolatotors (these interpolators should inherit HYDROData_IProfilesInterpolator).
39 * Once the interpolator of a certain type is registered it should be got by its name.
42 class HYDROData_InterpolatorsFactory
46 HYDROData_InterpolatorsFactory();
47 virtual ~HYDROData_InterpolatorsFactory();
50 * Registers the interpolator of a certain type with the given name.
51 * \param theName the interpolator name used as identifier
53 template <class T> HYDRODATA_EXPORT void Register( const std::string& theName )
55 myInterpolators[theName] = new T();
59 * Get the appropriate interpolator by the name.
60 * \param theName name of the interpolator
61 * \returns the appropriate interpolator or NULL if interpolator with such name is not registered
63 HYDRODATA_EXPORT HYDROData_IProfilesInterpolator* GetInterpolator( const std::string& theName ) const;
66 * Get list of registered interpolator names.
67 * \return the list of unique names
69 std::vector<std::string> GetInterpolatorNames() const;
72 //! Map that stores all interpolators, identified by interpolator name (string)
73 typedef std::map<std::string, HYDROData_IProfilesInterpolator*> FactoryInterpolators;
75 FactoryInterpolators myInterpolators; ///< all interpolators stored by factory