// // Copyright 2021 Staysail Systems, Inc. // Copyright 2017 Capitar IT Group BV // // This software is supplied under the terms of the MIT License, a // copy of which should be located in the distribution where this // file was obtained (LICENSE.txt). A copy of the license may also be // found online at https://opensource.org/licenses/MIT. // #ifndef CORE_MESSAGE_H #define CORE_MESSAGE_H // Internally used message API. Again, this is not part of our public API. // "trim" operations work from the front, and "chop" work from the end. extern int nni_msg_alloc(nni_msg **, size_t); extern void nni_msg_free(nni_msg *); extern int nni_msg_realloc(nni_msg *, size_t); extern int nni_msg_reserve(nni_msg *, size_t); extern size_t nni_msg_capacity(nni_msg *); extern int nni_msg_dup(nni_msg **, const nni_msg *); extern void * nni_msg_header(nni_msg *); extern size_t nni_msg_header_len(const nni_msg *); extern void * nni_msg_body(nni_msg *); extern size_t nni_msg_len(const nni_msg *); extern int nni_msg_append(nni_msg *, const void *, size_t); extern int nni_msg_insert(nni_msg *, const void *, size_t); extern int nni_msg_header_append(nni_msg *, const void *, size_t); extern int nni_msg_header_insert(nni_msg *, const void *, size_t); extern int nni_msg_trim(nni_msg *, size_t); extern int nni_msg_chop(nni_msg *, size_t); extern void nni_msg_clear(nni_msg *); extern void nni_msg_header_clear(nni_msg *); extern int nni_msg_header_trim(nni_msg *, size_t); extern int nni_msg_header_chop(nni_msg *, size_t); extern void nni_msg_dump(const char *, const nni_msg *); extern void nni_msg_header_append_u32(nni_msg *, uint32_t); extern uint32_t nni_msg_header_trim_u32(nni_msg *); extern uint32_t nni_msg_trim_u32(nni_msg *); // Peek and poke variants just access the first uint32 in the // header. This is useful when incrementing reference counts, etc. // It's faster than trim and append, but logically equivalent. extern uint32_t nni_msg_header_peek_u32(nni_msg *); extern void nni_msg_header_poke_u32(nni_msg *, uint32_t); extern void nni_msg_set_pipe(nni_msg *, uint32_t); extern uint32_t nni_msg_get_pipe(const nni_msg *); // Reference counting messages. This allows the same message to be // cheaply reused instead of copied over and over again. Callers of // this functionality MUST be certain to use nni_msg_unique() before // passing a message out of their control (e.g. to user programs.) // Failure to do so will likely result in corruption. extern void nni_msg_clone(nni_msg *); extern nni_msg *nni_msg_unique(nni_msg *); extern bool nni_msg_shared(nni_msg *); // nni_msg_pull_up ensures that the message is unique, and that any // header present is "pulled up" into the message body. If the function // cannot do this for any reason (out of space in the body), then NULL // is returned. It is the responsibility of the caller to free the // original message in that case (same semantics as realloc). extern nni_msg *nni_msg_pull_up(nni_msg *); #endif // CORE_SOCKET_H