| #pragma once | 
 |  | 
 | #include <stdio.h> | 
 | #include <string.h> | 
 |  | 
 | #include <cstdint> | 
 | #include <memory> | 
 | #include <string> | 
 | #include <vector> | 
 |  | 
 | namespace openpower | 
 | { | 
 | namespace pels | 
 | { | 
 | const uint8_t indentLevel = 4; | 
 | const uint8_t colAlign = 32; | 
 | /** | 
 |  * @brief escape json - use it for PEL hex dumps. | 
 |  * @param[in] std::string - the unescaped JSON as a string literal | 
 |  * @return std::string - escaped JSON string literal | 
 |  */ | 
 | std::string escapeJSON(const std::string& input); | 
 |  | 
 | /** | 
 |  * @brief get hex dump for PEL section in json format. | 
 |  * @param[in] const void* data - Raw PEL data | 
 |  * @param[i] size_t size - size of Raw PEL | 
 |  * @param[in] size_t indentCount - The number of indent levels to indent | 
 |  * @param[in] bool toJson - if true, output lines as JSON array, else print | 
 |  *            output as plain text | 
 |  * @return std::unique_ptr<char[]> - the Hex dump | 
 |  */ | 
 | std::unique_ptr<char[]> dumpHex(const void* data, size_t size, | 
 |                                 size_t indentCount, bool toJson = true); | 
 |  | 
 | /** | 
 |  * @brief Inserts key-value into a JSON string | 
 |  * | 
 |  * @param[in] jsonStr - The JSON string | 
 |  * @param[in] fieldName - The JSON key to insert | 
 |  * @param[in] fieldValue - The JSON value to insert | 
 |  * @param[in] indentCount - Indent count for the line | 
 |  */ | 
 | void jsonInsert(std::string& jsonStr, const std::string& fieldName, | 
 |                 const std::string& fieldValue, uint8_t indentCount); | 
 |  | 
 | /** | 
 |  * @brief Inserts key-value array into a JSON string | 
 |  * | 
 |  * @param[in] jsonStr - The JSON string | 
 |  * @param[in] fieldName - The JSON key to insert | 
 |  * @param[in] values - The JSON array to insert | 
 |  * @param[in] indentCount - Indent count for the line | 
 |  */ | 
 | void jsonInsertArray(std::string& jsonStr, const std::string& fieldName, | 
 |                      const std::vector<std::string>& values, | 
 |                      uint8_t indentCount); | 
 |  | 
 | /** | 
 |  * @brief Converts an integer to a formatted string | 
 |  * @param[in] format - the format of output string | 
 |  * @param[in] number - the integer to convert | 
 |  * @return std::string - the formatted string | 
 |  */ | 
 | template <typename T> | 
 | std::string getNumberString(const char* format, T number) | 
 | { | 
 |     constexpr size_t valueSize = 100; | 
 |     char value[valueSize]; | 
 |     std::string numString; | 
 |  | 
 |     static_assert(std::is_integral<T>::value, "Integral required."); | 
 |  | 
 |     int len = snprintf(value, valueSize, format, number); | 
 |     if (len >= 0) | 
 |     { | 
 |         numString = value; | 
 |     } | 
 |     else | 
 |     { | 
 |         throw std::invalid_argument( | 
 |             std::string("getNumberString: invalid format string: ") + format); | 
 |     } | 
 |  | 
 |     return numString; | 
 | } | 
 |  | 
 | /** | 
 |  * @brief helper function to trim trailing whitespaces | 
 |  * @return std::string - trimmed string | 
 |  * @param[in] std::string - string to trim | 
 |  */ | 
 | std::string trimEnd(std::string s); | 
 |  | 
 | /** | 
 |  * @brief Returns the component name for the component ID. | 
 |  * | 
 |  * It will try to look up the name to use in JSON files based on | 
 |  * the creator ID.  If PHYP, will convert the component ID to | 
 |  * two characters. | 
 |  * | 
 |  * If nothing else, it will just return the name as a string like | 
 |  * "0x1234". | 
 |  * | 
 |  * @return std::string - The component name | 
 |  */ | 
 | std::string getComponentName(uint16_t compID, uint8_t creatorID); | 
 |  | 
 | } // namespace pels | 
 | } // namespace openpower |