From: José Bollo Date: Wed, 8 Jun 2016 08:41:29 +0000 (+0200) Subject: wsj1: minor API refactoring X-Git-Tag: blowfish_2.0.1~39 X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?p=src%2Fapp-framework-binder.git;a=commitdiff_plain;h=80551a0405e8a208af587b6fff7f784a1a2ffbf4 wsj1: minor API refactoring Change-Id: I55e597a7c7cea295993326a6c4b362a136c05e4e Signed-off-by: José Bollo --- diff --git a/src/afb-wsj1.c b/src/afb-wsj1.c index 7f030a0c..5859bd36 100644 --- a/src/afb-wsj1.c +++ b/src/afb-wsj1.c @@ -477,24 +477,14 @@ int afb_wsj1_call_s(struct afb_wsj1 *wsj1, const char *api, const char *verb, co return rc; } - -int afb_wsj1_reply_ok_j(struct afb_wsj1_msg *msg, struct json_object *object, const char *token) -{ - return afb_wsj1_reply_ok_s(msg, json_object_to_json_string_ext(object, JSON_C_TO_STRING_PLAIN), token); -} - -int afb_wsj1_reply_ok_s(struct afb_wsj1_msg *msg, const char *object, const char *token) -{ - return wsj1_send_isot(msg->wsj1, RETOK, msg->id, object, token); -} - -int afb_wsj1_reply_error_j(struct afb_wsj1_msg *msg, struct json_object *object, const char *token) +int afb_wsj1_reply_j(struct afb_wsj1_msg *msg, struct json_object *object, const char *token, int iserror) { - return afb_wsj1_reply_error_s(msg, json_object_to_json_string_ext(object, JSON_C_TO_STRING_PLAIN), token); + const char *objstr = json_object_to_json_string_ext(object, JSON_C_TO_STRING_PLAIN); + return afb_wsj1_reply_s(msg, objstr, token, iserror); } -int afb_wsj1_reply_error_s(struct afb_wsj1_msg *msg, const char *object, const char *token) +int afb_wsj1_reply_s(struct afb_wsj1_msg *msg, const char *object, const char *token, int iserror) { - return wsj1_send_isot(msg->wsj1, RETERR, msg->id, object, token); + return wsj1_send_isot(msg->wsj1, iserror ? RETERR : RETOK, msg->id, object, token); } diff --git a/src/afb-wsj1.h b/src/afb-wsj1.h index 44aa5656..ad734962 100644 --- a/src/afb-wsj1.h +++ b/src/afb-wsj1.h @@ -98,33 +98,64 @@ extern int afb_wsj1_call_s(struct afb_wsj1 *wsj1, const char *api, const char *v */ extern int afb_wsj1_call_j(struct afb_wsj1 *wsj1, const char *api, const char *verb, struct json_object *object, void (*on_reply)(void *closure, struct afb_wsj1_msg *msg), void *closure); +/* + * Sends for message 'msg' the reply with the 'object' and, if not NULL, the token. + * When 'iserror' is zero a OK reply is send, otherwise an ERROR reply is sent. + * If not NULL, 'object' should be a valid JSON string. + * Return 0 in case of success. Otherwise, returns -1 and set errno. + */ +extern int afb_wsj1_reply_s(struct afb_wsj1_msg *msg, const char *object, const char *token, int iserror); + +/* + * Sends for message 'msg' the reply with the 'object' and, if not NULL, the token. + * When 'iserror' is zero a OK reply is send, otherwise an ERROR reply is sent. + * 'object' can be NULL. + * Return 0 in case of success. Otherwise, returns -1 and set errno. + */ +extern int afb_wsj1_reply_j(struct afb_wsj1_msg *msg, struct json_object *object, const char *token, int iserror); + + + + /* * Sends for message 'msg' the OK reply with the 'object' and, if not NULL, the token. * If not NULL, 'object' should be a valid JSON string. * Return 0 in case of success. Otherwise, returns -1 and set errno. */ -extern int afb_wsj1_reply_ok_s(struct afb_wsj1_msg *msg, const char *object, const char *token); +static inline int afb_wsj1_reply_ok_s(struct afb_wsj1_msg *msg, const char *object, const char *token) +{ + return afb_wsj1_reply_s(msg, object, token, 0); +} /* * Sends for message 'msg' the OK reply with the 'object' and, if not NULL, the token. * 'object' can be NULL. * Return 0 in case of success. Otherwise, returns -1 and set errno. */ -extern int afb_wsj1_reply_ok_j(struct afb_wsj1_msg *msg, struct json_object *object, const char *token); +static inline int afb_wsj1_reply_ok_j(struct afb_wsj1_msg *msg, struct json_object *object, const char *token) +{ + return afb_wsj1_reply_j(msg, object, token, 0); +} /* * Sends for message 'msg' the ERROR reply with the 'object' and, if not NULL, the token. * If not NULL, 'object' should be a valid JSON string. * Return 0 in case of success. Otherwise, returns -1 and set errno. */ -extern int afb_wsj1_reply_error_s(struct afb_wsj1_msg *msg, const char *object, const char *token); +static inline int afb_wsj1_reply_error_s(struct afb_wsj1_msg *msg, const char *object, const char *token) +{ + return afb_wsj1_reply_s(msg, object, token, 1); +} /* * Sends for message 'msg' the ERROR reply with the 'object' and, if not NULL, the token. * 'object' can be NULL. * Return 0 in case of success. Otherwise, returns -1 and set errno. */ -extern int afb_wsj1_reply_error_j(struct afb_wsj1_msg *msg, struct json_object *object, const char *token); +static inline int afb_wsj1_reply_error_j(struct afb_wsj1_msg *msg, struct json_object *object, const char *token) +{ + return afb_wsj1_reply_j(msg, object, token, 1); +} /* * Increases by one the count of reference to 'msg'.