2013-07-06 18:40:05 -07:00
#capnpc-python-cpp
2013-08-26 10:08:34 -07:00
More thorough docs are available at [http://jparyani.github.io/capnpc-python-cpp/ ](http://jparyani.github.io/capnpc-python-cpp/ ).
2013-07-06 18:40:05 -07:00
## Requirements
2013-08-26 10:08:34 -07:00
First you need a system-wide installation of the Cap'n Proto C++ library >= 0.3. Unfortunately, as of now, that means you have to build from the HEAD of Cap'n Proto. Follow these instructions to do so:
2013-08-21 17:28:02 -07:00
2013-08-21 17:45:13 -07:00
```bash
2013-08-22 08:31:07 -07:00
wget https://github.com/kentonv/capnproto/archive/master.zip
unzip master.zip
cd capnproto-master/c++
./setup-autotools.sh
autoreconf -i
./configure
make -j6 check
sudo make install
sudo ldconfig
2013-08-21 17:45:13 -07:00
```
2013-08-26 11:12:56 -07:00
A recent version of cython and setuptools is also required. You can install these with:
2013-08-21 17:45:13 -07:00
2013-08-22 08:31:07 -07:00
```bash
2013-08-26 11:12:56 -07:00
pip install -U cython
2013-08-21 17:45:13 -07:00
pip install -U setuptools
```
2013-07-06 18:40:05 -07:00
## Building and installation
2013-08-12 15:52:50 -07:00
Install with `pip install capnp`
Or you can clone the repo like so:
git clone https://github.com/jparyani/capnpc-python-cpp.git
2013-08-12 13:26:48 -07:00
`cd` into the repo directory and run `pip install .`
2013-07-06 18:40:05 -07:00
2013-08-28 22:55:10 -07:00
## Development
This project uses [git-flow ](http://jeffkreeftmeijer.com/2010/why-arent-you-using-git-flow/ ). Essentially, just make sure you do your changes in the `develop` branch.
2013-07-06 18:40:05 -07:00
## Documentation/Example
2013-08-21 17:28:02 -07:00
There is some basic documentation [here ](http://jparyani.github.io/capnpc-python-cpp/ ).
2013-07-06 18:40:05 -07:00
2013-07-07 00:11:45 -07:00
The examples directory has one example that shows off the capabilities quite nicely. Here it is, reproduced:
2013-08-12 12:39:35 -07:00
2013-07-06 23:57:47 -07:00
```python
import capnp
addressbook = capnp.load('addressbook.capnp')
def writeAddressBook(fd):
message = capnp.MallocMessageBuilder()
addressBook = message.initRoot(addressbook.AddressBook)
people = addressBook.initPeople(2)
alice = people[0]
alice.id = 123
alice.name = 'Alice'
alice.email = 'alice@example .com'
alicePhones = alice.initPhones(1)
alicePhones[0].number = "555-1212"
alicePhones[0].type = 'mobile'
alice.employment.school = "MIT"
bob = people[1]
bob.id = 456
bob.name = 'Bob'
bob.email = 'bob@example .com'
bobPhones = bob.initPhones(2)
bobPhones[0].number = "555-4567"
bobPhones[0].type = 'home'
bobPhones[1].number = "555-7654"
2013-08-12 10:47:31 -07:00
bobPhones[1].type = 'work'
2013-07-06 23:58:28 -07:00
bob.employment.unemployed = None
2013-07-06 23:57:47 -07:00
capnp.writePackedMessageToFd(fd, message)
f = open('example', 'w')
writeAddressBook(f.fileno())
def printAddressBook(fd):
message = capnp.PackedFdMessageReader(f.fileno())
addressBook = message.getRoot(addressbook.AddressBook)
for person in addressBook.people:
print person.name, ':', person.email
for phone in person.phones:
print phone.type, ':', phone.number
which = person.employment.which()
print which
2013-08-12 10:47:31 -07:00
if which == 'unemployed':
print('unemployed')
elif which == 'employer':
print('employer:', person.employment.employer)
elif which == 'school':
print('student at:', person.employment.school)
elif which == 'selfEmployed':
print('self employed')
2013-07-06 23:57:47 -07:00
print
f = open('example', 'r')
printAddressBook(f.fileno())
```
2013-08-12 17:20:58 -07:00
2013-08-21 17:45:13 -07:00
## Common Problems
If you get an error on installation like:
...
gcc-4.8: error: capnp/capnp.c: No such file or directory
gcc-4.8: fatal error: no input files
Then you have too old a version of setuptools. Run `pip install -U setuptools` then try again.
2013-08-12 17:20:58 -07:00
[](https://travis-ci.org/jparyani/capnpc-python-cpp)