aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--scripts/msgpack-gen.lua3
-rw-r--r--src/nvim/main.c8
2 files changed, 10 insertions, 1 deletions
diff --git a/scripts/msgpack-gen.lua b/scripts/msgpack-gen.lua
index fac1b10b45..8d7bb8ea59 100644
--- a/scripts/msgpack-gen.lua
+++ b/scripts/msgpack-gen.lua
@@ -100,7 +100,7 @@ end
output:write([[
-static const uint8_t msgpack_metadata[] = {
+const uint8_t msgpack_metadata[] = {
]])
-- serialize the API metadata using msgpack and embed into the resulting
@@ -116,6 +116,7 @@ end
-- usually it is the first function called by clients.
output:write([[
};
+const unsigned int msgpack_metadata_size = sizeof(msgpack_metadata);
void msgpack_rpc_dispatch(uint64_t channel_id, msgpack_object *req, msgpack_packer *res)
{
diff --git a/src/nvim/main.c b/src/nvim/main.c
index ffb83ae7d8..d992619287 100644
--- a/src/nvim/main.c
+++ b/src/nvim/main.c
@@ -135,6 +135,8 @@ static void check_swap_exists_action(void);
# endif
#endif /* NO_VIM_MAIN */
+extern const uint8_t msgpack_metadata[];
+extern const unsigned int msgpack_metadata_size;
/*
* Different types of error messages.
@@ -1047,6 +1049,11 @@ static void command_line_scan(mparm_T *parmp)
msg_putchar('\n');
msg_didout = FALSE;
mch_exit(0);
+ } else if (STRICMP(argv[0] + argv_idx, "api-msgpack-metadata") == 0) {
+ for (unsigned int i = 0; i<msgpack_metadata_size; i++) {
+ putchar(msgpack_metadata[i]);
+ }
+ mch_exit(0);
} else if (STRNICMP(argv[0] + argv_idx, "literal", 7) == 0) {
#if !defined(UNIX)
parmp->literal = TRUE;
@@ -2240,6 +2247,7 @@ static void usage(void)
main_msg(_("--startuptime <file>\tWrite startup timing messages to <file>"));
#endif
main_msg(_("-i <viminfo>\t\tUse <viminfo> instead of .viminfo"));
+ main_msg(_("--api-msgpack-metadata\tDump API metadata information and exit"));
main_msg(_("-h or --help\tPrint Help (this message) and exit"));
main_msg(_("--version\t\tPrint version information and exit"));