blob: 1afe96abdee706aa4ea0930e3b42c5fb9a9f166c [file] [log] [blame]
#include "parser_factory.hpp"
#include "const.hpp"
#include "ibm_vpd_utils.hpp"
#include "ipz_parser.hpp"
#include "isdimm_vpd_parser.hpp"
#include "keyword_vpd_parser.hpp"
#include "memory_vpd_parser.hpp"
#include "vpd_exceptions.hpp"
using namespace vpd::keyword::parser;
using namespace openpower::vpd::memory::parser;
using namespace openpower::vpd::isdimm::parser;
using namespace openpower::vpd::parser::interface;
using namespace openpower::vpd::ipz::parser;
using namespace openpower::vpd::exceptions;
using namespace openpower::vpd::constants;
namespace openpower
{
namespace vpd
{
namespace parser
{
namespace factory
{
interface::ParserInterface*
ParserFactory::getParser(const Binary& vpdVector,
const std::string& inventoryPath)
{
vpdType type = vpdTypeCheck(vpdVector);
switch (type)
{
case IPZ_VPD:
{
return new IpzVpdParser(vpdVector, inventoryPath);
}
case KEYWORD_VPD:
{
return new KeywordVpdParser(vpdVector);
}
case DDR4_DDIMM_MEMORY_VPD:
case DDR5_DDIMM_MEMORY_VPD:
{
return new memoryVpdParser(vpdVector);
}
case DDR4_ISDIMM_MEMORY_VPD:
case DDR5_ISDIMM_MEMORY_VPD:
{
return new isdimmVpdParser(vpdVector);
}
default:
throw VpdDataException("Unable to determine VPD format");
}
}
void ParserFactory::freeParser(interface::ParserInterface* parser)
{
if (parser)
{
delete parser;
parser = nullptr;
}
}
} // namespace factory
} // namespace parser
} // namespace vpd
} // namespace openpower