Fix result status handling with resolver library callback
authorMarcel Holtmann <marcel@holtmann.org>
Wed, 28 Jul 2010 02:06:42 +0000 (19:06 -0700)
committerMarcel Holtmann <marcel@holtmann.org>
Wed, 28 Jul 2010 02:06:42 +0000 (19:06 -0700)
gresolv/gresolv.c

index ba19672f0a2036205201041473246826fb570c36..66b2641bcae39afd5654a3eb43f574063dec54b0 100644 (file)
@@ -193,6 +193,7 @@ static void parse_response(struct resolv_nameserver *nameserver,
                                        const unsigned char *buf, int len)
 {
        GResolv *resolv = nameserver->resolv;
+       GResolvResultStatus status;
        GList *list;
        char **results;
        ns_msg msg;
@@ -209,6 +210,11 @@ static void parse_response(struct resolv_nameserver *nameserver,
        debug(resolv, "msg id: 0x%04x rcode: %d count: %d",
                                        ns_msg_id(msg), rcode, count);
 
+       if (rcode == 0)
+               status = G_RESOLV_STATUS_SUCCESS;
+       else
+               status = G_RESOLV_STATUS_ERROR;
+
        results = g_try_new(char *, count + 1);
        if (results == NULL)
                return;
@@ -241,8 +247,8 @@ static void parse_response(struct resolv_nameserver *nameserver,
                struct resolv_query *query = list->data;
 
                if (query->result_func != NULL)
-                       query->result_func(G_RESOLV_STATUS_SUCCESS,
-                                               results, query->result_data);
+                       query->result_func(status, results,
+                                               query->result_data);
 
                destroy_query(query);
                g_queue_remove(resolv->query_queue, query);