blob: 0372a956f1963cff29b4914aca0af3d80774ea2c [file] [log] [blame]
E. Scott Daniels117030c2020-04-10 17:17:02 -04001
2
3.. This work is licensed under a Creative Commons Attribution 4.0 International License.
4.. SPDX-License-Identifier: CC-BY-4.0
5.. CAUTION: this document is generated from source in doc/src/rtd.
6.. To make changes edit the source and recompile the document.
7.. Do NOT make changes directly to .rst or .md files.
8
9
10============================================================================================
11Man Page: rmr_get_xact
12============================================================================================
13
14RMR Library Functions
15============================================================================================
16
17
18NAME
19--------------------------------------------------------------------------------------------
20
21rmr_get_xact
22
23SYNOPSIS
24--------------------------------------------------------------------------------------------
25
26
27::
28
29 #include <rmr/rmr.h>
30 char* rmr_get_xact( rmr_mbuf_t* mbuf, unsigned char* dest )
31
32
33
34DESCRIPTION
35--------------------------------------------------------------------------------------------
36
37The rmr_get_xact function will copy the transaction field
38from the message into the *dest* buffer provided by the user.
39The buffer referenced by *dest* is assumed to be at least
40RMR_MAX_XID bytes in length. If *dest* is NULL, then a buffer
41is allocated (the calling application is expected to free
42when the buffer is no longer needed).
43
44RETURN VALUE
45--------------------------------------------------------------------------------------------
46
47On success, a pointer to the extracted string is returned. If
48*dest* was supplied, then this is just a pointer to the
49caller's buffer. If *dest* was NULL, this is a pointer to the
50allocated buffer. If an error occurs, a nil pointer is
51returned and errno is set as described below.
52
53ERRORS
54--------------------------------------------------------------------------------------------
55
56If an error occurs, the value of the global variable errno
57will be set to one of the following with the indicated
58meaning.
59
60
61
62EINVAL
63
64 The message, or an internal portion of the message, was
65 corrupted or the pointer was invalid.
66
67
68ENOMEM
69
70 A nil pointer was passed for *dest,* however it was not
71 possible to allocate a buffer using malloc().
72
73
74SEE ALSO
75--------------------------------------------------------------------------------------------
76
77rmr_alloc_msg(3), rmr_bytes2xact(3), rmr_bytes2meid(3),
78rmr_call(3), rmr_free_msg(3), rmr_get_rcvfd(3),
79rmr_get_meid(3), rmr_payload_size(3), rmr_send_msg(3),
80rmr_rcv_msg(3), rmr_rcv_specific(3), rmr_rts_msg(3),
81rmr_ready(3), rmr_fib(3), rmr_has_str(3), rmr_tokenise(3),
82rmr_mk_ring(3), rmr_ring_free(3), rmr_str2meid(3),
83rmr_str2xact(3), rmr_wh_open(3), rmr_wh_send_msg(3)