X-Git-Url: http://git.openwrt.org/?a=blobdiff_plain;f=utils.h;h=9a716aec1a9dd8dc03fff00aeaf4cb9d304a1c5c;hb=a4d98aea373e04f3fdc3c492c1688ba52ce490a9;hp=c74a5dd76d22fcab5b7e496ed2582899302e9923;hpb=18f4c6fda6afb912f53ded3112b1f270ddf5ff6c;p=project%2Ffirewall3.git diff --git a/utils.h b/utils.h index c74a5dd..9a716ae 100644 --- a/utils.h +++ b/utils.h @@ -32,6 +32,7 @@ #include #include +#include #include @@ -46,6 +47,16 @@ void warn(const char *format, ...); void error(const char *format, ...); void info(const char *format, ...); + +#define warn_section(t, r, e, fmt, ...) \ + do { \ + if (e) \ + warn_elem(e, fmt, ##__VA_ARGS__); \ + else \ + warn("Warning: ubus " t " (%s) " fmt, \ + (r && r->name) ? r->name : "?", ##__VA_ARGS__); \ + } while(0) + #define fw3_setbit(field, flag) field |= (1 << (flag)) #define fw3_delbit(field, flag) field &= ~(1 << (flag)) #define fw3_hasbit(field, flag) (field & (1 << (flag))) @@ -103,4 +114,6 @@ bool fw3_bitlen2netmask(int family, int bits, void *mask); void fw3_flush_conntrack(void *zone); +bool fw3_attr_parse_name_type(struct blob_attr *entry, const char **name, const char **type); + #endif