1 ## This file is a template. The comment below is emitted 2 ## into the rendered file; feel free to edit this file. 3 // WARNING: Generated header. Do not edit! 4 5 6 #pragma once 7 8 #include <map> 9 #include <iostream> 10 #include "defines.hpp" 11 #include "store.hpp" 12 #include "types.hpp" 13 #include "utils.hpp" 14 #include "extra-properties-gen.hpp" 15 16 namespace openpower 17 { 18 namespace vpd 19 { 20 namespace inventory 21 { 22 23 /** @brief API to write parsed VPD to inventory, 24 * for a specifc FRU 25 * 26 * @param [in] vpdStore - Store object containing 27 * parsed VPD 28 * @param [in] path - FRU object path 29 */ 30 template<Fru F> 31 void writeFru(const Store& vpdStore, const std::string& path); 32 33 % for key in fruDict.iterkeys(): 34 <% 35 fru = fruDict[key] 36 %>\ 37 // Specialization of ${key} 38 template<> 39 void writeFru<Fru::${key}>(const Store& vpdStore, 40 const std::string& path) 41 { 42 ObjectMap objects; 43 InterfaceMap interfaces; 44 auto iter = extra::objects.find(path); 45 46 // Inventory manager needs object path, list of interface names to be 47 // implemented, and property:value pairs contained in said interfaces 48 49 % for interface, properties in fru.iteritems(): 50 <% 51 names = interface.split(".") 52 intfName = names[0] + names[-1] 53 %>\ 54 PropertyMap ${intfName}Props; 55 % for name, value in properties.iteritems(): 56 % if fru and interface and name and value: 57 <% 58 record, keyword = name.split(",") 59 %>\ 60 if (vpdStore.exists<Record::${record}, record::Keyword::${keyword}>()) 61 { 62 ${intfName}Props["${value}"] = 63 vpdStore.get<Record::${record}, record::Keyword::${keyword}>(); 64 } 65 % endif 66 % endfor 67 // Check and update extra properties 68 if(extra::objects.end() != iter) 69 { 70 auto propIter = (iter->second).find("${interface}"); 71 if((iter->second).end() != propIter) 72 { 73 for(const auto& map : propIter->second) 74 { 75 ${intfName}Props[map.first] = map.second; 76 } 77 } 78 } 79 interfaces.emplace("${interface}", 80 std::move(${intfName}Props)); 81 % endfor 82 83 sdbusplus::message::object_path object(path); 84 // Check and update extra properties 85 if(extra::objects.end() != iter) 86 { 87 for(const auto& entry : iter->second) 88 { 89 if(interfaces.end() == interfaces.find(entry.first)) 90 { 91 interfaces.emplace(entry.first, entry.second); 92 } 93 } 94 } 95 objects.emplace(std::move(object), std::move(interfaces)); 96 97 callPIM(std::move(objects)); 98 } 99 100 % endfor 101 } // namespace inventory 102 } // namespace vpd 103 } // namespace openpower 104