From: José Bollo Date: Mon, 12 Jun 2017 17:02:12 +0000 (+0200) Subject: Fix lack of error message on mustach issue X-Git-Tag: dab/3.99.2~20 X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?p=src%2Fapp-framework-main.git;a=commitdiff_plain;h=ed2743714bec59de1273cc0617d6b588a06a1203 Fix lack of error message on mustach issue Change-Id: I16139c133d7031e38f4c63ff6369f1d7478fc86f Signed-off-by: José Bollo --- diff --git a/src/wgtpkg-mustach.c b/src/wgtpkg-mustach.c index 110f11b..45d94e8 100644 --- a/src/wgtpkg-mustach.c +++ b/src/wgtpkg-mustach.c @@ -21,10 +21,12 @@ #include #include +#include #include #include "mustach.h" +#include "verbose.h" #define MAX_DEPTH 256 @@ -321,8 +323,29 @@ static struct mustach_itf itf = { */ int apply_mustach(const char *template, struct json_object *root, char **result, size_t *size) { + int rc; struct expl e; + e.root = root; - return mustach(template, &itf, &e, result, size); + rc = mustach(template, &itf, &e, result, size); + if (rc < 0) { + static const char *msgs[] = { + "SYSTEM", + "UNEXPECTED_END", + "EMPTY_TAG", + "TAG_TOO_LONG", + "BAD_SEPARATORS", + "TOO_DEPTH", + "CLOSING", + "BAD_UNESCAPE_TAG" + }; + + rc = -(rc + 1); + ERROR("mustach error found: MUSTACH_ERROR_%s", + rc < 0 || rc >= (int)(sizeof msgs / sizeof * msgs) ? "???" : msgs[rc]); + rc = -1; + errno = EINVAL; + } + return rc; }