1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211
|
/*
* Copyright (c) 2017, Intel Corporation
*
* Permission is hereby granted, free of charge, to any person obtaining a
* copy of this software and associated documentation files (the "Software"),
* to deal in the Software without restriction, including without limitation
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
* and/or sell copies of the Software, and to permit persons to whom the
* Software is furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included
* in all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
* OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
* THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
* OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
* OTHER DEALINGS IN THE SOFTWARE.
*/
//!
//! \file media_ddi_factory.h
//! \brief Defines one template class to create the instance of DDI media encode/decoder.
//!
#ifndef _MEDIA_DDI_FACTORY_H_
#define _MEDIA_DDI_FACTORY_H_
#include <map>
#include <string>
#include <vector>
#include <utility>
#include <cstdarg>
//!
//! \class MediaDdiFactory
//! \brief Media ddi factory class
//!
template <class T, class Arg>
class MediaDdiFactory
{
public:
typedef T *Type;
typedef Arg *ArgType;
typedef Type (*Creator)(ArgType);
typedef std::string KeyType;
typedef std::map<KeyType, Creator> Creators;
typedef typename Creators::iterator iterator;
//!
//! \brief Register one Class C with key.
//! \details Use the member template to register class C with key and C is the
//! derived class of base class T.
//!
//! \param [in] key
//! KeyType, the type alias of std::string.
//!
//! \return True is returned if class C is successfully registerted with key
//! False is returned if key is already registered and doesn't register
//! class C with key.
//!
template <class C>
static bool RegisterCodec(const KeyType &key)
{
std::pair<iterator, bool> result =
GetCreators().insert(std::make_pair(key, create<C>));
return result.second;
}
//!
//! \brief Create a new object that is registered with key.
//! \details Create and return one new object that is registered with key. And Args is passed to create
//! the new object.
//!
//! \param [in] key
//! KeyType, the type alias of std::string.
//!
//! \param [in] arg
//! ArgType, the type alias of Arg template parameter
//!
//! \return The derived object of T is returned if key is found and the object is created.
//! nullptr is returned if key is not found
//!
static Type CreateCodec(
const KeyType &key,
ArgType arg)
{
Creators &creators = GetCreators();
iterator creator = creators.find(key);
if (creator != creators.end())
return (creator->second)(arg);
return nullptr;
}
private:
//!
//! \brief The callback function with key.
//! \details The member template to create the derived object
//!
//! \param [in] arg
//! ArgType, the type alias of class template parameter.
//!
//! \return The created object with arg input for C constructor.
//!
template <class C>
static Type create(ArgType arg)
{
return MOS_New(C, arg);
}
//!
//! \brief Obtain the static pair table of key and callback function
//! \details Obtain the static pair table that is registerted with key and callback function
//!
//! \return Return the static pair table about the param @key and callback function
//!
static Creators &GetCreators()
{
static Creators creators;
return creators;
}
};
//!
//! \class MediaDdiFactoryNoArg
//! \brief Media ddi factory no argument class
//!
template <class T>
class MediaDdiFactoryNoArg
{
public:
typedef T *Type;
typedef Type (*Creator)();
typedef std::string KeyType;
typedef std::map<KeyType, Creator> Creators;
typedef typename Creators::iterator iterator;
//!
//! \brief Register one Class C with key.
//! \details Use the member template to register class C with key and C is the
//! derived class of base class T.
//!
//! \param [in] key
//! KeyType, the type alias of std::string.
//!
//! \return True is returned if class C is successfully registerted with key
//! False is returned if key is already registered and doesn't register
//! class C with key.
//!
template <class C>
static bool RegisterCodec(const KeyType &key)
{
std::pair<iterator, bool> result =
GetCreators().insert(std::make_pair(key, create<C>));
return result.second;
}
//!
//! \brief Create a new object that is registered with key.
//! \details Create and return one new object that is registered with key. And Args is passed to create
//! the new object.
//!
//! \param [in] key
//! KeyType, the type alias of std::string.
//!
//! \return The derived object of T is returned if key is found and the object is created.
//! nullptr is returned if key is not found
//!
static Type CreateCodec(const KeyType &key)
{
Creators &creators = GetCreators();
iterator creator = creators.find(key);
if (creator != creators.end())
return (creator->second)();
return nullptr;
}
private:
//!
//! \brief The callback function with key.
//! \details The member template to create the derived object
//!
//! \return The created object.
//!
template <class C>
static Type create()
{
return MOS_New(C);
}
//!
//! \brief Obtain the static pair table of key and callback function
//! \details Obtain the static pair table that is registerted with param@key and callback function
//!
//! \return Return the static pair table about the param @key and callback function
//!
static Creators &GetCreators()
{
static Creators creators;
return creators;
}
};
#endif /* _MEDIA_DDI_FACTORY_H_ */
|