Before:
BUG: invalid range expression type symbol
nft: expression.c:1494: range_expr_value_high: Assertion `0' failed.
After:
range_expr_value_high_assert:5:20-27: Error: Could not resolve protocol name
elements = { 100-11.0.0.0, }
^^^^^^^^
range_expr_value_high_assert:7:6-7: Error: set definition has conflicting key (ipv4_addr vs inet_proto)
Signed-off-by: Florian Westphal <fw@strlen.de>
existing_set = set_cache_find(table, set->handle.set.name);
if (!existing_set)
set_cache_add(set_get(set), table);
+ else if (!datatype_equal(existing_set->key->dtype, set->key->dtype))
+ return set_error(ctx, set, "%s definition has conflicting key (%s vs %s)\n",
+ type, set->key->dtype->name, existing_set->key->dtype->name);
if (existing_set && existing_set->flags & NFT_SET_EVAL) {
uint32_t existing_flags = existing_set->flags & ~NFT_SET_EVAL;
--- /dev/null
+table inet t {
+ set s3 {
+ type inet_proto
+ flags interval
+ elements = { 100-11.0.0.0, }
+ }
+ set s3 {
+ type ipv4_addr
+ flags interval
+ elements = { 100-11.0.0.0, }
+ }
+}