53 void const *data, ssize_t len);
82#define msg_home(h) ((su_home_t*)(h))
127 MSG_FLG_USERMASK = (1<<16) - 1
154 MSG_FLG_PARSERMASK = ((-1) ^ ((1<<16) - 1))
157#define MSG_DO_COMPACT MSG_FLG_COMPACT
158#define MSG_DO_CANONIC MSG_FLG_CANONIC
159#define MSG_DO_EXTRACT_COPY MSG_FLG_EXTRACT_COPY
162#define MSG_FLAGS(f, v) (((f) & (v)) == v)
164#define MSG_IS_COMPACT(f) MSG_FLAGS((f), MSG_FLG_COMPACT)
165#define MSG_IS_CANONIC(f) MSG_FLAGS((f), MSG_FLG_CANONIC)
166#define MSG_IS_EXTRACT_COPY(f) MSG_FLAGS((f), MSG_FLG_EXTRACT_COPY)
167#define MSG_IS_COMMA_LISTS(f) MSG_FLAGS((f), MSG_FLG_COMMA_LISTS)
168#define MSG_IS_MAILBOX(f) MSG_FLAGS((f), MSG_FLG_MAILBOX)
170#define MSG_HAS_COMPLETE(f) MSG_FLAGS((f), MSG_FLG_COMPLETE)
171#define MSG_HAS_ERROR(f) MSG_FLAGS((f), MSG_FLG_ERROR)
173#define MSG_IS_COMPLETE(mo) (((mo)->msg_flags & MSG_FLG_COMPLETE) != 0)
void msg_unprepare(msg_t *msg)
Clear 'prepared' flag.
Definition msg_parser.c:1568
msg_t * msg_create(msg_mclass_t const *mc, int flags)
Create a message.
Definition msg.c:100
unsigned msg_set_flags(msg_t *msg, unsigned mask)
Set message flags.
Definition msg_parser.c:96
unsigned msg_mark_as_complete(msg_t *msg, unsigned mask)
Mark message as complete.
Definition msg_parser.c:649
int msg_is_streaming(msg_t const *msg)
Test if streaming is in progress.
Definition msg_parser.c:108
unsigned msg_extract_errors(msg_t const *msg)
Get error classification flags.
Definition msg.c:405
int msg_serialize(msg_t *msg, msg_pub_t *mo)
Serialize headers into the fragment chain.
Definition msg_parser.c:1904
msg_streaming_status
Streaming state of a msg_t object.
Definition msg.h:85
@ msg_start_streaming
Enable streaming.
Definition msg.h:89
@ msg_stop_streaming
Disable streaming.
Definition msg.h:87
usize_t msg_maxsize(msg_t *msg, usize_t maxsize)
Set the maximum size of a message.
Definition msg_parser.c:698
msg_mclass_t const * msg_mclass(msg_t const *msg)
Retrieve message class.
Definition msg.c:251
int msg_is_prepared(msg_t const *msg)
Return true if message is prepared.
Definition msg_parser.c:1574
void msg_destroy(msg_t *)
Destroy a reference to a message.
Definition msg.c:193
int msg_extract(msg_t *msg)
Extract and parse a message from internal buffer.
Definition msg_parser.c:850
char * msg_as_string(su_home_t *home, msg_t *msg, msg_pub_t *pub, int flags, size_t *return_len)
Convert a message to a string.
Definition msg_parser.c:1788
void msg_unref(msg_t *)
Decrease the reference count.
Definition msg.c:87
void msg_set_streaming(msg_t *msg, enum msg_streaming_status what)
Enable/disable streaming.
Definition msg_parser.c:114
msg_t * msg_copy(msg_t *)
Copy a message shallowly.
Definition msg_header_copy.c:380
msg_header_t ** msg_chain_head(msg_t const *msg)
Return head of the fragment chain.
Definition msg_parser.c:1875
msg_flg_user
Flags controlling parser/printer.
Definition msg.h:102
@ MSG_FLG_EXTRACT_COPY
Cache a copy of headers when parsing.
Definition msg.h:108
@ MSG_FLG_STREAMING
Enable streaming - parser gives completed message fragments when they are ready to upper layers.
Definition msg.h:122
@ MSG_FLG_CHUNKING
Use multiple parts for message body.
Definition msg.h:118
@ MSG_FLG_COMMA_LISTS
Print comma-separated lists instead of separate headers.
Definition msg.h:110
@ MSG_FLG_COMPACT
Use compact form when printing.
Definition msg.h:104
@ MSG_FLG_MAILBOX
Use mailbox format when parsing - in mailbox format message has no body unless Content-Length header ...
Definition msg.h:115
@ MSG_FLG_THRDSAFE
Make messages threadsafe.
Definition msg.h:125
@ MSG_FLG_CANONIC
Use canonic representation when printing.
Definition msg.h:106
int msg_has_error(msg_t const *msg)
Return true if message has parsing errors.
Definition msg_parser.c:673
msg_pub_t * msg_public(msg_t const *msg, void *tag)
Retrieve public message structure of given type.
Definition msg.c:231
msg_flg_parser
Flags used by parser.
Definition msg.h:131
@ MSG_FLG_COMPLETE
This message has been completely extracted.
Definition msg.h:143
@ MSG_FLG_CHUNKS
Extract chunks for this message.
Definition msg.h:137
@ MSG_FLG_TOOLARGE
This message is too large.
Definition msg.h:148
@ MSG_FLG_TIMEOUT
This message has timeout.
Definition msg.h:152
@ MSG_FLG_TRAILERS
Extract trailers for this message.
Definition msg.h:139
@ MSG_FLG_FRAGS
Extract last component of this message.
Definition msg.h:141
@ MSG_FLG_BODY
Extract body for this message.
Definition msg.h:135
@ MSG_FLG_TRUNC
This message is truncated.
Definition msg.h:150
@ MSG_FLG_ERROR
This message has parsing errors.
Definition msg.h:146
@ MSG_FLG_HEADERS
Extract headers for this message.
Definition msg.h:133
msg_t * msg_ref(msg_t *)
Increment the reference count.
Definition msg.c:63
void msg_set_parent(msg_t *kid, msg_t *dad)
Set a message parent.
Definition msg.c:162
msg_t * msg_dup(msg_t const *)
Deep copy a message.
Definition msg_header_copy.c:456
int msg_prepare(msg_t *msg)
Encode all message fragments.
Definition msg_parser.c:1547
msg_t * msg_make(msg_mclass_t const *mc, int flags, void const *data, ssize_t len)
Parse a message.
Definition msg_parser_util.c:2019
unsigned msg_zap_flags(msg_t *msg, unsigned mask)
Clear message flags.
Definition msg_parser.c:102
int msg_is_complete(msg_t const *msg)
Return true if message is complete.
Definition msg_parser.c:664
usize_t msg_size(msg_t const *msg)
Total size of message.
Definition msg_parser.c:682
unsigned msg_get_flags(msg_t const *msg, unsigned mask)
Get message flags.
Definition msg_parser.c:90
msg_t * msg_ref_create(msg_t *)
Increment the reference count.
Definition msg.c:146
void msg_ref_destroy(msg_t *)
Destroy a reference to a message.
Definition msg.c:182
msg_pub_t * msg_object(msg_t const *msg)
Retrieve public message structure.
Definition msg.c:209
Types for messages and common headers.
MSG_HDR_T msg_header_t
Any protocol-specific header object.
Definition msg_types.h:87
MSG_PUB_T msg_pub_t
Public protocol-specific message structure for accessing the message.
Definition msg_types.h:81
Factory object for protocol messages.
Definition msg_mclass.h:97
Message object.
Definition msg_internal.h:59