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
c5de5bcf
Commit
c5de5bcf
authored
Sep 01, 2013
by
Kenton Varda
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Remove localhost links from docs. Duh.
parent
6c1da9b7
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
15 additions
and
15 deletions
+15
-15
2013-09-04-capnproto-0.3-python-tools-features.md
doc/_posts/2013-09-04-capnproto-0.3-python-tools-features.md
+5
-5
capnp-tool.md
doc/capnp-tool.md
+7
-7
language.md
doc/language.md
+1
-1
otherlang.md
doc/otherlang.md
+2
-2
No files found.
doc/_posts/2013-09-04-capnproto-0.3-python-tools-features.md
View file @
c5de5bcf
...
@@ -55,19 +55,19 @@ to you. Use `capnp eval` to "compile" the whole thing to binary for deployment.
...
@@ -55,19 +55,19 @@ to you. Use `capnp eval` to "compile" the whole thing to binary for deployment.
been a common use case for Protobuf text format, which doesn't even support variable substitution
been a common use case for Protobuf text format, which doesn't even support variable substitution
or imports.)
or imports.)
Anyway, check out the
[
full documentation
](
http://localhost:4000/capnproto/
capnp-tool.html
)
for
Anyway, check out the
[
full documentation
](
{{
site.baseurl }}
capnp-tool.html) for
more.
more.
## New Features
## New Features
The core product has been updated as well:
The core product has been updated as well:
*
Support for unnamed
[
unions
](
http://localhost:4000/capnproto/
language.html#unions
)
reduces the
*
Support for unnamed
[
unions
](
{{
site.baseurl }}
language.html#unions) reduces the
need for noise-words, improving code readability. Additionally, the syntax for unions has been
need for noise-words, improving code readability. Additionally, the syntax for unions has been
simplified by removing the unnecessary ordinal number.
simplified by removing the unnecessary ordinal number.
*
[
Groups
](
http://localhost:4000/capnproto/
language.html#groups
)
pair nicely with unions.
*
[
Groups
](
{{
site.baseurl }}
language.html#groups) pair nicely with unions.
*
[
Constants
](
http://localhost:4000/capnproto/
language.html#constants
)
are now
*
[
Constants
](
{{
site.baseurl }}
language.html#constants) are now
[
implemented in C++
](
http://localhost:4000/capnproto/
cxx.html#constants
)
. Additionally, they
[
implemented in C++
](
{{
site.baseurl }}
cxx.html#constants). Additionally, they
can now be defined in terms of other constants (variable substitution), as described earlier.
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
*
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.
of the new union and group features, making the code more readable.
...
...
doc/capnp-tool.md
View file @
c5de5bcf
...
@@ -30,7 +30,7 @@ and import paths.
...
@@ -30,7 +30,7 @@ and import paths.
The above example generates C++ code, but the tool is able to generate output in any language
The above example generates C++ code, but the tool is able to generate output in any language
for which a plugin is available. Compiler plugins are just regular programs named
for which a plugin is available. Compiler plugins are just regular programs named
`capnpc-language`
. For example, the above command runs
`capnpc-c++`
.
[
More on how to write
`capnpc-language`
. For example, the above command runs
`capnpc-c++`
.
[
More on how to write
compiler plugins](
http://localhost:4000/capnproto/
otherlang.html#how_to_write_compiler_plugins).
compiler plugins](otherlang.html#how_to_write_compiler_plugins).
Note that some Cap'n Proto implementations (especially for interpreted languages) do not require
Note that some Cap'n Proto implementations (especially for interpreted languages) do not require
generating source code.
generating source code.
...
@@ -41,16 +41,16 @@ generating source code.
...
@@ -41,16 +41,16 @@ generating source code.
`capnp decode`
reads a binary Cap'n Proto message from standard input and decodes it to a
`capnp decode`
reads a binary Cap'n Proto message from standard input and decodes it to a
human-readable text format (specifically, the format used for specifying constants and default
human-readable text format (specifically, the format used for specifying constants and default
values in
[
the schema language
](
http://localhost:4000/capnproto/
language.html
)
). By default it
values in
[
the schema language
](
language.html
)
). By default it
expects an unpacked message, but you can decode a
expects an unpacked message, but you can decode a
[
packed
](
http://localhost:4000/capnproto/
encoding.html#packing
)
message with the
`--packed`
flag.
[
packed
](
encoding.html#packing
)
message with the
`--packed`
flag.
## Encoding Messages
## Encoding Messages
capnp encode myschema.capnp MyType < message.txt > message.bin
capnp encode myschema.capnp MyType < message.txt > message.bin
`capnp encode`
is the opposite of
`capnp decode`
: it takes a text-format message on stdin and
`capnp encode`
is the opposite of
`capnp decode`
: it takes a text-format message on stdin and
encodes it to binary (possibly
[
packed
](
http://localhost:4000/capnproto/
encoding.html#packing
)
,
encodes it to binary (possibly
[
packed
](
encoding.html#packing
)
,
with the
`--packed`
flag).
with the
`--packed`
flag).
This is mainly useful for debugging purposes, to build test data or to apply tweaks to data
This is mainly useful for debugging purposes, to build test data or to apply tweaks to data
...
@@ -61,9 +61,9 @@ and maintained in text format long-term -- instead, use `capnp eval`, which is m
...
@@ -61,9 +61,9 @@ and maintained in text format long-term -- instead, use `capnp eval`, which is m
capnp eval myschema.capnp myConstant
capnp eval myschema.capnp myConstant
This prints the value of
`myConstant`
, a
This prints the value of
`myConstant`
, a
[
const
](
language.html#constants
)
declaration, after
[
const
](
http://localhost:4000/capnproto/language.html#constants
)
declaration, after applying
applying variable substitution. It can also output the value in binary format (
`--binary`
or
variable substitution. It can also output the value in binary format (
`--binary`
or
`--packed`
).
`--packed`
).
At first glance, this may seem no more interesting that
`capnp encode`
: the syntax used to define
At first glance, this may seem no more interesting that
`capnp encode`
: the syntax used to define
constants in schema files is the same as the format accepted by
`capnp encode`
, right? There is,
constants in schema files is the same as the format accepted by
`capnp encode`
, right? There is,
...
...
doc/language.md
View file @
c5de5bcf
...
@@ -348,7 +348,7 @@ reference to an object inherently represents a "capability" to access it.
...
@@ -348,7 +348,7 @@ reference to an object inherently represents a "capability" to access it.
You can define constants in Cap'n Proto. These don't affect what is sent on the wire, but they
You can define constants in Cap'n Proto. These don't affect what is sent on the wire, but they
will be included in the generated code, and can be
[
evaluated using the
`capnp`
will be included in the generated code, and can be
[
evaluated using the
`capnp`
tool](
http://localhost:4000/capnproto/
capnp-tool.html#evaluating_constants).
tool](capnp-tool.html#evaluating_constants).
{% highlight capnp %}
{% highlight capnp %}
const pi :Float32 = 3.14159;
const pi :Float32 = 3.14159;
...
...
doc/otherlang.md
View file @
c5de5bcf
...
@@ -100,5 +100,5 @@ compiled source files as `.pyc` bytecode, but that's up to you.
...
@@ -100,5 +100,5 @@ compiled source files as `.pyc` bytecode, but that's up to you.
### Testing Your Implementation
### Testing Your Implementation
The easiest way to test that you've implemented the spec correctly is to use the
`capnp`
tool
The easiest way to test that you've implemented the spec correctly is to use the
`capnp`
tool
to
[
encode
](
http://localhost:4000/capnproto/
capnp-tool.html#encoding_messages
)
test inputs and
to
[
encode
](
capnp-tool.html#encoding_messages
)
test inputs and
[
decode
](
http://localhost:4000/capnproto/
capnp-tool.html#decoding_messages
)
outputs.
[
decode
](
capnp-tool.html#decoding_messages
)
outputs.
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