summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--include/libnftnl/common.h1
-rw-r--r--src/common.c12
2 files changed, 12 insertions, 1 deletions
diff --git a/include/libnftnl/common.h b/include/libnftnl/common.h
index f8f1304..14db823 100644
--- a/include/libnftnl/common.h
+++ b/include/libnftnl/common.h
@@ -7,6 +7,7 @@ enum {
NFT_PARSE_EBADINPUT = 0,
NFT_PARSE_EMISSINGNODE,
NFT_PARSE_EBADTYPE,
+ NFT_PARSE_EOPNOTSUPP,
};
enum nft_output_type {
diff --git a/src/common.c b/src/common.c
index 7fce48e..d69b522 100644
--- a/src/common.c
+++ b/src/common.c
@@ -44,7 +44,15 @@ EXPORT_SYMBOL(nft_nlmsg_build_hdr);
struct nft_parse_err *nft_parse_err_alloc(void)
{
- return calloc(1, sizeof(struct nft_parse_err));
+ struct nft_parse_err *err;
+
+ err = calloc(1, sizeof(struct nft_parse_err));
+ if (err == NULL)
+ return NULL;
+
+ err->error = NFT_PARSE_EOPNOTSUPP;
+
+ return err;
}
EXPORT_SYMBOL(nft_parse_err_alloc);
@@ -66,6 +74,8 @@ int nft_parse_perror(const char *msg, struct nft_parse_err *err)
case NFT_PARSE_EBADTYPE:
return fprintf(stderr, "%s: Invalid type in node \"%s\"\n",
msg, err->node_name);
+ case NFT_PARSE_EOPNOTSUPP:
+ return fprintf(stderr, "%s: Operation not supported\n", msg);
default:
return fprintf(stderr, "%s: Undefined error\n", msg);
}