mirror of
https://github.com/GothenburgBitFactory/taskwarrior.git
synced 2025-06-26 10:54:26 +02:00
Msg: C++11
This commit is contained in:
parent
1579705fec
commit
9720e7dab4
3 changed files with 34 additions and 45 deletions
32
src/Msg.cpp
32
src/Msg.cpp
|
@ -29,32 +29,12 @@
|
|||
#include <Lexer.h>
|
||||
#include <text.h>
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////
|
||||
Msg::Msg ()
|
||||
: _payload ("")
|
||||
{
|
||||
// All messages are marked with the version number, so that the messages may
|
||||
// be properly evaluated in context.
|
||||
_header["client"] = PACKAGE_STRING;
|
||||
}
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////
|
||||
Msg::~Msg ()
|
||||
{
|
||||
}
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////
|
||||
void Msg::set (const std::string& name, const std::string& value)
|
||||
{
|
||||
_header[name] = value;
|
||||
}
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////
|
||||
void Msg::setPayload (const std::string& payload)
|
||||
{
|
||||
_payload = payload;
|
||||
}
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////
|
||||
std::string Msg::get (const std::string& name) const
|
||||
{
|
||||
|
@ -65,6 +45,12 @@ std::string Msg::get (const std::string& name) const
|
|||
return "";
|
||||
}
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////
|
||||
void Msg::setPayload (const std::string& payload)
|
||||
{
|
||||
_payload = payload;
|
||||
}
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////
|
||||
std::string Msg::getPayload () const
|
||||
{
|
||||
|
@ -72,17 +58,19 @@ std::string Msg::getPayload () const
|
|||
}
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////
|
||||
void Msg::all (std::vector <std::string>& names) const
|
||||
std::vector <std::string> Msg::all () const
|
||||
{
|
||||
std::vector <std::string> names;
|
||||
for (auto& i : _header)
|
||||
names.push_back (i.first);
|
||||
|
||||
return names;
|
||||
}
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////
|
||||
std::string Msg::serialize () const
|
||||
{
|
||||
std::string output;
|
||||
|
||||
for (auto& i : _header)
|
||||
output += i.first + ": " + i.second + "\n";
|
||||
|
||||
|
|
12
src/Msg.h
12
src/Msg.h
|
@ -34,21 +34,19 @@
|
|||
class Msg
|
||||
{
|
||||
public:
|
||||
Msg ();
|
||||
~Msg ();
|
||||
|
||||
void set (const std::string&, const std::string&);
|
||||
void setPayload (const std::string&);
|
||||
std::string get (const std::string&) const;
|
||||
|
||||
void setPayload (const std::string&);
|
||||
std::string getPayload () const;
|
||||
|
||||
void all (std::vector <std::string>&) const;
|
||||
std::vector <std::string> all () const;
|
||||
std::string serialize () const;
|
||||
bool parse (const std::string&);
|
||||
|
||||
private:
|
||||
std::map <std::string, std::string> _header;
|
||||
std::string _payload;
|
||||
std::map <std::string, std::string> _header {};
|
||||
std::string _payload {""};
|
||||
};
|
||||
|
||||
#endif
|
||||
|
|
|
@ -37,32 +37,35 @@ int main (int, char**)
|
|||
UnitTest t (13);
|
||||
|
||||
Msg m;
|
||||
t.is (m.serialize (), std::string ("client: ") + PACKAGE_STRING + "\n\n\n", "Msg::serialize '' --> '\\n\\n'");
|
||||
t.is (m.serialize (), "\n\n", "Msg::serialize '' --> '\\n\\n'");
|
||||
|
||||
m.set ("name", "value");
|
||||
t.is (m.serialize (), std::string ("client: ") + PACKAGE_STRING + "\nname: value\n\n\n", "Msg::serialize 1 var");
|
||||
t.is (m.serialize (), "name: value\n\n\n",
|
||||
"Msg::serialize 1 var");
|
||||
|
||||
m.set ("foo", "bar");
|
||||
t.is (m.serialize (), std::string ("client: ") + PACKAGE_STRING + "\nfoo: bar\nname: value\n\n\n", "Msg::serialize 2 vars");
|
||||
t.is (m.serialize (), "foo: bar\nname: value\n\n\n",
|
||||
"Msg::serialize 2 vars");
|
||||
|
||||
m.setPayload ("payload");
|
||||
t.is (m.serialize (), std::string ("client: ") + PACKAGE_STRING + "\nfoo: bar\nname: value\n\npayload\n", "Msg::serialize 2 vars + payload");
|
||||
t.is (m.serialize (), "foo: bar\nname: value\n\npayload\n",
|
||||
"Msg::serialize 2 vars + payload");
|
||||
|
||||
Msg m2;
|
||||
t.ok (m2.parse ("foo: bar\nname: value\n\npayload\n"), "Msg::parse ok");
|
||||
t.is (m2.get ("foo"), "bar", "Msg::get");
|
||||
t.is (m2.get ("name"), "value", "Msg::get");
|
||||
t.is (m2.getPayload (), "payload\n", "Msg::getPayload");
|
||||
t.ok (m2.parse ("foo: bar\nname: value\n\npayload\n"),
|
||||
"Msg::parse ok");
|
||||
t.is (m2.get ("foo"), "bar", "Msg::get");
|
||||
t.is (m2.get ("name"), "value", "Msg::get");
|
||||
t.is (m2.getPayload (), "payload\n", "Msg::getPayload");
|
||||
|
||||
Msg m3;
|
||||
t.ok (m3.parse ("foo:bar\nname: value\n\npayload\n"), "Msg::parse ok");
|
||||
t.is (m3.get ("foo"), "bar", "Msg::get");
|
||||
t.is (m3.get ("name"), "value", "Msg::get");
|
||||
t.is (m3.getPayload (), "payload\n", "Msg::getPayload");
|
||||
|
||||
std::vector <std::string> vars;
|
||||
m3.all (vars);
|
||||
t.ok (vars.size () == 2, "Msg::all --> 2 vars");
|
||||
t.ok (m3.parse ("foo:bar\nname: value\n\npayload\n"),
|
||||
"Msg::parse ok");
|
||||
t.is (m3.get ("foo"), "bar", "Msg::get");
|
||||
t.is (m3.get ("name"), "value", "Msg::get");
|
||||
t.is (m3.getPayload (), "payload\n", "Msg::getPayload");
|
||||
t.ok (m3.all () == std::vector <std::string> {"foo", "name"},
|
||||
"Msg::all --> {'foo', 'name'}");
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue