Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
C
capnproto
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
submodule
capnproto
Commits
89e1a2e1
Commit
89e1a2e1
authored
Aug 29, 2013
by
Kenton Varda
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
News post for 0.3 (getting it ready early).
parent
695d9e76
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
93 additions
and
1 deletion
+93
-1
2013-09-04-capnproto-0.3-python-tools-features.md
doc/_posts/2013-09-04-capnproto-0.3-python-tools-features.md
+92
-0
otherlang.md
doc/otherlang.md
+1
-1
No files found.
doc/_posts/2013-09-04-capnproto-0.3-python-tools-features.md
0 → 100644
View file @
89e1a2e1
---
layout
:
post
title
:
"
Cap'n
Proto
v0.3:
Python,
tools,
new
features"
author
:
kentonv
---
The first release of Cap'n Proto came three months after the project was announced. The second
release came six weeks after that. And the third release is three weeks later. If the pattern
holds, there will be an infinite number of releases before the end of this month.
Version 0.3 is not a paradigm-shifting release, but rather a slew of new features largely made
possible by building on the rewritten compiler from the last release. Let's go through the
list...
## Python Support!
Thanks to the tireless efforts of contributor
[
Jason Paryani
](
https://github.com/jparyani
)
, I can
now comfortably claim that Cap'n Proto supports multiple languages.
[
His Python
implementation](http://jparyani.github.io/capnpc-python-cpp/) wraps the C++ library and exposes
most of its features in a nice, easy-to-use way.
And I have to say, it's _way_ better than the old Python Protobuf implementation that I helped put
together at Google. Here's why:
*
Jason's implementation parses Cap'n Proto schema files at runtime. There is no need to run a
compiler to generate code every time you update your schema, as with protobufs. So, you get
to use Python the way Python was intended to be used.
*
It's _fast_. Whereas the Python Protobuf implementation -- which we made the mistake of
implementing in pure-Python -- is _slow_. And while technically there is an experimental
C-extension-based Python Protobuf implementation (which isn't enabled by default due to various
obscure problems), Jason's Cap'n Proto implementation is faster than that, too.
Go
[
check it out
](
http://jparyani.github.io/capnpc-python-cpp/
)
!
By the way, there is also a budding
[
Erlang implementation
](
http://ecapnp.astekk.se/
)
(by Andreas Stenius), and work
continues on
[
Rust
](
https://github.com/dwrensha/capnproto-rust
)
(
David
Renshaw) and
[
Ruby
](
https://github.com/cstrahan/capnp-ruby
)
(
Charles
Strahan) implementations.
## Tools: Cap'n Proto on the Command Line
The
`capnp`
command-line tool previously served mostly to generate code, via the
`capnp compile`
command. It now additionally supports converting encoded Cap'n Proto messages to a human-readable
text format via
`capnp decode`
, and converting that format back to binary with
`capnp encode`
.
These tools are, of course, critical for debugging.
You can also use the new
`capnp eval`
command to do something interesting: given a schema file and
the name of a constant defined therein, it will print out the value of that constant, or optionally
encode it to binary. This is more interesting than it sounds because the schema language supports
variable substitution in the definitions of these constants. This means you can build a large
structure by importing smaller bits from many different files. This may make it convenient to
use Cap'n Proto schemas as a config format: define your service configuration as a constant in
a schema file, importing bits specific to each client from other files that those clients submit
to you. Use
`capnp eval`
to "compile" the whole thing to binary for deployment. (This has always
been a common use case for Protobuf text format, which doesn't even support variable substitution
or imports.)
Anyway, check out the
[
full documentation
](
http://localhost:4000/capnproto/capnp-tool.html
)
for
more.
## New Features
The core product has been updated as well:
*
Support for unnamed
[
unions
](
http://localhost:4000/capnproto/language.html#unions
)
reduces the
need for noise-words, improving code readability. Additionally, the syntax for unions has been
simplified by removing the unnecessary ordinal number.
*
[
Groups
](
http://localhost:4000/capnproto/language.html#groups
)
pair nicely with unions.
*
[
Constants
](
http://localhost:4000/capnproto/language.html#constants
)
are now
[
implemented in C++
](
http://localhost:4000/capnproto/cxx.html#constants
)
. Additionally, they
can now be defined in terms of other constants (variable substitution), as described earlier.
*
The schema API and
`schema.capnp`
have been radically refactored, in particular to take advantage
of the new union and group features, making the code more readable.
*
More and better tests, bug fixes, etc.
## Users!
Some news originating outside of the project itself:
*
A Cap'n Proto package will
[
soon land in Debian
](
http://ftp-master.debian.org/new/capnproto_0.2.1-1.html
)
, thanks to
[
Tom Lee
](
https://github.com/thomaslee
)
.
*
Popular OSX-based text editor
[
TextMate
](
http://macromates.com/
)
now
[
uses Cap'n Proto internally
](
https://github.com/textmate/textmate/commit/5c02b4ff5cc0c7c319d3d4f127c8ee19b81f80b7
)
,
and the developer's feedback lead directly to several usability improvements included in this
release.
*
Many people using Cap'n Proto _haven't bothered to tell us about it_! Please, if you use it,
[
let us know
](
https://groups.google.com/group/capnproto
)
about your experience, both what you like
and especially what you don't like. This is the critical time where the system is usable but
can still be changed if it's not right, so your feedback is critical to our long-term success.
*
I have revenue! A whopping
[
$1.25 per week
](
https://www.gittip.com/kentonv/
)
! >_> It's
totally worth it; I love this project. (But thanks for the tips!)
doc/otherlang.md
View file @
89e1a2e1
...
@@ -12,7 +12,7 @@ maintained by respective authors and have not been reviewed by me
...
@@ -12,7 +12,7 @@ maintained by respective authors and have not been reviewed by me
##### Ready To Use
##### Ready To Use
*
[
C++
](
cxx.html
)
by
[
@kentonv
](
https://github.com/kentonv
)
-- Official reference implementation
*
[
C++
](
cxx.html
)
by
[
@kentonv
](
https://github.com/kentonv
)
-- Official reference implementation
*
[
Python
](
http
s://github.com/jparyani/capnpc-python-cpp
)
by
*
[
Python
](
http
://jparyani.github.io/capnpc-python-cpp/
)
by
[
@jparyani
](
https://github.com/jparyani
)
-- Based on C extensions wrapping the C++ implementation.
[
@jparyani
](
https://github.com/jparyani
)
-- Based on C extensions wrapping the C++ implementation.
##### Works In Progress
##### Works In Progress
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment