diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2022-02-10 09:43:16 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2022-02-10 09:43:16 +0000 |
commit | 61524c58020d03b22e750e8bf7a1871acbfdb8c0 (patch) | |
tree | 8761969b2a8fef51432c6b2f5a796a99acffddc1 /src/gen-macros.sh | |
parent | Releasing debian version 0.2.0-2. (diff) | |
download | dnswire-61524c58020d03b22e750e8bf7a1871acbfdb8c0.tar.xz dnswire-61524c58020d03b22e750e8bf7a1871acbfdb8c0.zip |
Merging upstream version 0.3.3.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'src/gen-macros.sh')
-rwxr-xr-x | src/gen-macros.sh | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/src/gen-macros.sh b/src/gen-macros.sh index 190d74a..a7d74c2 100755 --- a/src/gen-macros.sh +++ b/src/gen-macros.sh @@ -1,11 +1,24 @@ #!/bin/sh -e echo "/* autogenerated, don't edit */" +echo "#include <string.h>" +echo "#include <stdlib.h>" while read prefix base name type typedef; do echo "// $base.$name ($type)" case "$type" in string ) + echo "#define ${prefix}_has_${name}(d) ((d).${base}.${name} != 0) +#define ${prefix}_${name}(d) (const char*)((d).${base}.${name}) +#define ${prefix}_${name}_length(d) strlen((d).${base}.${name}) +#define ${prefix}_set_${name}(d, v) \ + if ((d)._${base}_${name}_alloced) { \ + free((d).${base}.${name}); \ + } \ + (d).${base}.${name} = strdup(v); \ + (d)._${base}_${name}_alloced = true;" + ;; + bytestring ) echo "#define ${prefix}_has_${name}(d) (bool)((d).${base}.has_${name}) #define ${prefix}_${name}(d) (const uint8_t*)((d).${base}.${name}.data) #define ${prefix}_${name}_length(d) (size_t)((d).${base}.${name}.len) |