diff options
| author | Thiago de Arruda <tpadilha84@gmail.com> | 2014-06-23 11:52:42 -0300 | 
|---|---|---|
| committer | Thiago de Arruda <tpadilha84@gmail.com> | 2014-06-24 13:02:24 -0300 | 
| commit | 296da85198a7d5da36dbb2e6f213edb5da511635 (patch) | |
| tree | 4fb8f7d5e1d7f4153b508e987f268c0222431152 /src/nvim/regexp.c | |
| parent | bc0380038e0a4ff4f4bfaa939b0cef26c5e53582 (diff) | |
| download | rneovim-296da85198a7d5da36dbb2e6f213edb5da511635.tar.gz rneovim-296da85198a7d5da36dbb2e6f213edb5da511635.tar.bz2 rneovim-296da85198a7d5da36dbb2e6f213edb5da511635.zip | |
channel/msgpack_rpc: Refactor API dispatching
This is how API dispatching worked before this commit:
- The generated `msgpack_rpc_dispatch` function receives a the `msgpack_packer`
  argument.
- The response is incrementally built while validating/calling the API.
- Return values/errors are also packed into the `msgpack_packer` while the
  final response is being calculated.
Now the `msgpack_packer` argument is no longer provided, and the
`msgpack_rpc_dispatch` function returns `Object`/`Error` values to
`msgpack_rpc_call`, which will use those values to build the response in a
single pass.
This was done because the new `channel_send_call` function created the
possibility of having recursive API invocations, and this wasn't possible when
sharing a single `msgpack_sbuffer` across call frames(it was shared implicitly
through the `msgpack_packer` instance).
Since we only start to build the response when the necessary information has
been computed, it's now safe to share a single `msgpack_sbuffer` instance
across all channels and API invocations.
Some other changes also had to be performed:
- Handling of the metadata discover was moved to `msgpack_rpc_call`
- Expose more types as subtypes of `Object`, this was required to forward the
  return value from `msgpack_rpc_dispatch` to `msgpack_rpc_call`
- Added more helper macros for casting API types to `Object`
  any
Diffstat (limited to 'src/nvim/regexp.c')
0 files changed, 0 insertions, 0 deletions
