blob: 147c6033fca1d7789c09ec34310843cef10f78e0 [file] [log] [blame]
#pragma once
#include <cstdint>
#include <sstream>
#include <string>
namespace witherspoon
{
namespace power
{
namespace util
{
/**
* @class NamesValues
*
* Builds up a string of name=value pairs for use in
* situations like error log metadata.
*
* Names and values can be added to an instance of this
* class, and then calling get() will return a string
* that appends them all together.
*
* Currently, just uint64_t values that will be displayed
* in hex are supported.
*
* For example:
* NamesValues m;
* uint8_t d = 0xFF;
*
* m.add("STATUS_VOUT", d);
* m.add("STATUS_WORD", 0xABCD);
*
* m.get() //returns: "STATUS_VOUT=0xFF|STATUS_WORD=0xABCD"
*/
class NamesValues
{
public:
NamesValues() = default;
NamesValues(const NamesValues&) = default;
NamesValues& operator=(const NamesValues&) = default;
NamesValues(NamesValues&&) = default;
NamesValues& operator=(NamesValues&&) = default;
/**
* Adds a name/value pair to the object
*
* @param name - the name to add
* @param value - the value to add
*/
void add(const std::string& name, uint64_t value)
{
addDivider();
addName(name);
addValue(value);
}
/**
* Returns a formatted concatenation of all of the names and
* their values.
*
* @return string - "<name1>=<value1>|<name2>=<value2>..etc"
*/
const std::string& get() const
{
return all;
}
private:
/**
* Adds a name to the object
*
* @param name - the name to add
*/
void addName(const std::string& name)
{
all += name + '=';
}
/**
* Adds a value to the object
*
* @param value - the value to add
*/
void addValue(uint64_t value)
{
std::ostringstream stream;
stream << "0x" << std::hex << value;
all += stream.str();
}
/**
* Adds a divider to the summary string to
* break up the name/value pairs
*/
void addDivider()
{
if (!all.empty())
{
all += '|';
}
}
/**
* The string containing all name/value pairs
*/
std::string all;
};
} // namespace util
} // namespace power
} // namespace witherspoon