]> git.meshlink.io Git - catta/blobdiff - dns.h
fix some memory corruption bugs
[catta] / dns.h
diff --git a/dns.h b/dns.h
index 0b6e750feb0d85adf19e94a18774307bf9f98bf6..38944d3d86aebd823b7afdad55afc9fcd0a66079 100644 (file)
--- a/dns.h
+++ b/dns.h
@@ -32,6 +32,7 @@ guint8 *flx_dns_packet_append_name_compressed(flxDnsPacket *p, const gchar *name
 guint8 *flx_dns_packet_append_bytes(flxDnsPacket  *p, gconstpointer, guint l);
 guint8* flx_dns_packet_append_key(flxDnsPacket *p, flxKey *k);
 guint8* flx_dns_packet_append_record(flxDnsPacket *p, flxRecord *r, gboolean cache_flush);
+guint8* flx_dns_packet_append_string(flxDnsPacket *p, const gchar *s);
 
 gint flx_dns_packet_is_query(flxDnsPacket *p);
 gint flx_dns_packet_check_valid(flxDnsPacket *p);
@@ -42,13 +43,14 @@ gint flx_dns_packet_consume_name(flxDnsPacket *p, gchar *ret_name, guint l);
 gint flx_dns_packet_consume_bytes(flxDnsPacket *p, gpointer ret_data, guint l);
 flxKey* flx_dns_packet_consume_key(flxDnsPacket *p);
 flxRecord* flx_dns_packet_consume_record(flxDnsPacket *p, gboolean *ret_cache_flush);
+gint flx_dns_packet_consume_string(flxDnsPacket *p, gchar *ret_string, guint l);
 
 gconstpointer flx_dns_packet_get_rptr(flxDnsPacket *p);
 
-
-
 gint flx_dns_packet_skip(flxDnsPacket *p, guint length);
 
+gboolean flx_dns_packet_is_empty(flxDnsPacket *p);
+
 #define DNS_FIELD_ID 0
 #define DNS_FIELD_FLAGS 1
 #define DNS_FIELD_QDCOUNT 2
@@ -59,6 +61,7 @@ gint flx_dns_packet_skip(flxDnsPacket *p, guint length);
 #define DNS_FLAG_QR (1 << 15)
 #define DNS_FLAG_OPCODE (15 << 11)
 #define DNS_FLAG_RCODE (15)
+#define DNS_FLAG_TC (1 << 9)
 
 #define DNS_FLAGS(qr, opcode, aa, tc, rd, ra, z, ad, cd, rcode) \
         (((guint16) !!qr << 15) |  \