prophy 1.2.5

Creator: bradpython12

Last updated:

Add to Cart

Description:

prophy 1.2.5

Prophy is a statically typed, binary, tag-free, unpacked serialization protocol.
You can define message schema:
struct MyMsg
{
u16 x<>;
};
generate codecs for chosen languages:
prophyc --python_out . --cpp_full_out . --cpp_out . test.prophy
and serialize data in Python:
>>> import test
>>> msg = test.MyMsg()
>>> msg.x[:] = [1, 2, 3]
>>> msg.encode('<')
'\x03\x00\x00\x00\x01\x00\x02\x00\x03\x00\x00\x00'
>>> print msg
x: 1
x: 2
x: 3
in C++:
#include <iostream>
#include <iterator>
#include "test.ppf.hpp"

int main()
{
prophy::generated::MyMsg msg{{1, 2, 3}};
std::vector<uint8_t> data = msg.encode();
std::copy(data.begin(), data.end(), std::ostream_iterator<unsigned>(std::cout, " "));
std::cout << '\n' << msg.print();
return 0;
}
3 0 0 0 1 0 2 0 3 0 0 0
x: 1
x: 2
x: 3
again in C++ (half hand-rolled, compiler-dependent, but fastest option):
#include <iostream>
#include <iterator>
#include <cstdlib>
#include "test.pp.hpp"

int main()
{
MyMsg* msg = static_cast<MyMsg*>(std::malloc(12));
msg->num_of_x = 3;
msg->x[0] = 1;
msg->x[1] = 2;
msg->x[2] = 3;
std::copy((uint8_t*)msg, ((uint8_t*)msg) + 12, std::ostream_iterator<unsigned>(std::cout, " "));
std::cout << '\n';
return 0;
}
3 0 0 0 1 0 2 0 3 0 0 0
Documentation: http://prophy.readthedocs.org
Issues: https://github.com/aurzenligl/prophy/issues

License

For personal and professional use. You cannot resell or redistribute these repositories in their original state.

Customer Reviews

There are no reviews.