- The connection setup APIs have been slightly reworked.
- The
getBootstrap
field ofConnConfig
has been replaced with abootstrap
field that takes the capability itself, which must now be constructed before spawning the connection. - The
withBootstrarp
field inConnConfig
has been removed, Instead use the newrequestBootstrap
function to get the bootstrap interface, using a connection reference supplied bywithConn
oracquireConn
.
- The
- The high level API now maps Cap'n Proto lists to
[]
, rather thanVector
. Fulfiller
now has an instance ofContravariant
.- The Client type's Show instance now distinguishes between a null capability and a capability whose index was outside of a message's cap table's bounds when it was read.
- Get rid of the New qualifier in module paths, now that the old API has been removed.
- Remove references to the old API from the tutorial.
- Add two new modules:
Capnp.Rpc.Membrane
, which provides helpers for implementing membranes.Capnp.Rpc.Revoke
, which supports revocable capabilities.
- Updated to work with GHC 9.2.x. In particular:
- The generated code now enables the
FlexibleContexts
extension since it is no longer implied byUndecidableInstances
- The
IsPtr
type alias now includes an additional constraint, which GHC seems to no longer be able to derive from the others. - Internals have been updated to deal with a breaking change to
template-haskell
.
- The generated code now enables the
- Fixed an error building the documentation.
- There is now a per-connection limit on the total size of incoming
Call
messages that are being serviced, which can be used to limit memory usage and provide backpressure.ConnConfig
has a newmaxCallWords
field to configure this. - Some bugs in the RPC layer have been fixed.
tracingTransport
now provides an option to omit call & return bodies from the logged messages.
- Significant performance improvements.
- The
Data.Mutable
module and itsThaw
class have been replaced byCapnp.Mutability
and a classMaybeMutable
, which serves the same function but is easier to work with. Notably,thaw
andfreeze can now be used on
Raw` values directly. Mutability
is now defined inCapnp.Mutability
instead ofCapnp.Message
, though the latter still re-exports it for compatibility (for now).- The parameters to the
Raw
type constructor have been flipped; the new ordering makes it possible to implement thaw/freeze onRaw a
- The
Untyped
type family has seen similar treatment.
- The
- HasMessage and MessageDefault are now defined on a type of kind
* -> Mutability
, which keeps the mutability out of constraints.- This has the unfortunate side-effect of making type inference for these classes not work very well :(. Hopefully a better solution will be found in the future.
This release drops support for the old API. To upgrade to the new API, Users should first upgrade to the latest 0.12.x version, switch their code to use the new API, and then upgrade to this version.
This release backports some fixes and minor features in the new API.
- The 0.12.x series is the last major version that will support the old API; the next release will not generate code for the old API, and some low level interfaces will be removed. See https://zenhack.net/2021/07/30/new-haskell-capnp-release-reworked-apis.html for details.
- For the new API, there is a new
HasTypeId
class, with instances defined for all generated types. - The new API now supports implementing RPC servers.
Capnp.Tutorial
discusses this, and the examples have been updated to use the new API.
- This release introduces some experimental new APIs; see the blog post
for details: https://zenhack.net/2021/07/30/new-haskell-capnp-release-reworked-apis.html
- The new APIs include support for RPC pipelining, which is not possible with the old APIs.
- The traversal limit is tracked at a coarser granularity. This results in a modest performance improvement, and may result in slightly different (but similar) amounts of the limit being used for a given computation than with the old implementation.
- Bounds on pointers are checked a bit earlier (when the pointer is read, rather than when its referent is accessed). As a result, some malformed messages may trigger bounds check errors which did not previously, because the offending portion of the message was not read.
- The limit on how many capabilities can be attached to a single message has been increased.
LimitT m
now has an instance ofMonadCatch
ifm
has an instance.- Some harmless warnings triggered by the generated code are now silenced.
Capnp.Rpc.Promise
exposes a new functionnewReadyPromise
, which can be used to create an already-fulfilled promise.- Fixed a race condition where if the supervisor for a client is killed before the server has finished spawning, the shutdown method might not be run.
Capnp.Rpc.Server.runServer
no longer calls handleStop on exit. Most users of the library will not be affected, as this function is mostly a low-level implementation detail that is called by higher level functionality.- In
Capnp.Message
some uses of the typeInt
in the API have been strengthened to typeWordCount
.
- Fix a bug causing spurious exceptions when creating very large messages.
- The parametrization of messages has been reworked. Most things that
were parametrized over a message type are now parametrized over a
type parameter of kind
Mutability
(defined inCapnp.Message
).- The Message type class has been replaced with a type
Message
of kindMutability -> *
, and a type classMonadReadMessage
for operations that can work on any Message.
- The Message type class has been replaced with a type
- Message.fromByteString/toByteString:
- are now stand-alone functions, rather than methods on the class
- only operate on immutable segments.
- are pure functions, rather than monadic ones.
- Some functions that were derivative of
toByteString
/fromByteString
, e.g.Untyped.rawBytes
, also only work on immutable messages now, and may be pure functions where before they were monadic. - The types defined in
Capnp.Basics
now haveThaw
instances.
- Significant performance improvements. A few low level APIs have been changed to support this work.
- The code generator now supports type parameters in schema; previously the code generator would treat these the same as AnyPointer, but now the generated Haskell has corresponding type parameters.
- The
Cerialize
andMarshal
type classes now take the state tokens
as a parameter, which was necessary to support type parameters.
- Some of the multi-parameter type classes in Capnp.Classes now have functional dependencies between their parameters. This should generally improve type inference.
- The library now supports canonicalization via Capnp.canonicalize
- There is a new function Capnp.Message.singleSegment for constructing a
ConstMsg
from an (unframed)Segment ConstMsg
.
- Some signatures in Capnp.Rpc.Untyped have changed to facilitate a future release supporting promise pipelining.
- The included schema now match those in version 0.8 of the reference implementation
- Fix a race condition [(#74)][issue74] causing remote objects to very occasionally be released too early.
- Fix a bug (#71) which sometimes caused the code generator to crash.
- Fix a bug in the code generator (#72) which sometimes resulted in build failures of the generated code.
- Fix a serious bug in
newPromiseClient
, resulting in dropped calls made on the promise before it is resolved. - There is now a
Server
class, which all RPC servers must implement. All of its methods have default implementations, so adding an instance to existing servers is straightforward. - It is now possible to "unwrap" clients that point to a local server using the new 'Capnp.Rpc.unwrapServer' function, if the server implements support for it with the new 'Server' type class.
- Servers can now specify a hook to be run when the server is shut down, using the server class's 'shutdown' method.
In Capnp.Untyped
, The dataSection
and ptrSection
APIs have been
removed. structDataSize
has been replaced with structWordCount
,
and new functions structByteCount and
structPtrCount` have been added.
This release brings some improvements to the RPC API:
-
Add
newPromiseClient
for creating a promise-based client that can be fulfilled later. -
Make
Client
an instance ofIsClient
. -
Previously, there were a number of functions that had two variants:
foo
, which ran inIO
fooSTM
, which ran inSTM
.
Now there is just one variant,
foo
, which is polymorphic overMonadSTM
, defined by themonad-stm
package. There are instances of this class forIO
,STM
, and any monad transformer applied to an instance.Note that previously some of the
foo
variants were polymorphic overMonadIO
. Unfortunately it is not possible to define a general instanceMonadIO m => MonadSTM m
, but for a particular mtl stack that has an instance ofMonadIO
, you can fix the problem by defining:instance MonadSTM MyStack where liftSTM = liftIO . liftSTM
Or, you can add
liftIO
/liftSTM
to the appropriate call sites.
- RPC support! This should be considered alpha quality for now. The API will likely change substantially.
- Many bug fixes; users are strongly encouraged to upgrade.
- Reorganization of the module hierarchy:
- Generated code is now placed under
Capnp.Gen
, rather thanCapnp
. - The
Data
prefix has been removed from theData.Capnp
hierarchy.
- Generated code is now placed under
- The included generated modules for the core schema have been updated to those shipped with version 0.7 of the reference implementation.
- Other miscellaneous API Changes:
createPure
can now be used with any instance ofMonadThrow
, not justEither SomeException
.LimitT m
is now an instance ofMonadIO
, provided thatm
is an instance.- More type class instances from elsewhere in the library are
re-exported via the
Capnp
module. - The
IsPtr
type class has been split intoFromPtr
andToPtr
. Most user code should not care about this. - Generated high-level types no longer have Read instances; interfaces make this problematic.
- Getters for anonymous unions are now
get_Foo'
instead ofget_Foo'union'
. newMessage
now accepts an optional size hint.- Instances of
Cerialize
now exist/are generated for(Vector (Vector (Vector ...)))
up to a reasonable depth.
- Other improvements not directly reflected in the API:
- The allocation strategy has changed to reduce unnecessary copying.
- It is now possible to create messages with a size > 2GiB. Note that individual segments are still limited.
- Instances of some type classes are no longer generated for "second class" types (i.e. types which cannot appear as stand-alone definitions in schema files -- groups and unions).
has_*
functions are now only generated for pointer fields.- Various non-functional changes in the output of the code generator.
- We now generate constants for (most) pointer types; previously constants defined in a schema would not result in any generated code (#41).
- The
set_*
functions now check if the arguments are in the same message, and copy if need be (#34). MutMsg
is now an instance ofEq
.- The
HasMessage
class fromData.Capnp.Untyped
is now a type family, rather than a multi-parameter type class. This improves inference and removes some superfluous generalization. - The module
Data.Capnp.Pure
has been folded intoData.Capnp
. If you were previously using theText
andData
type aliases it exported, you should instead useText
fromData.Text
andByteString
fromData.ByteString
; theText
andData
exported byData.Capnp
are types from the low-level API.
- Redesign the 'Mutable' type class's API.
- Provide helpers for doing zero-copy message creation in pure code.
- General improvements to the documentation.
- First release; basic read & write support, serialization only.