rewrite EBADRESP to EBADQUERY on ares_send

Due to the way record duplication works, we might sometimes get a
misleading error code.  Rewrite the error code to make better
sense.

Authored-By: Brad House (@bradh352)
v1.32
Brad House 3 weeks ago
parent 8a32755d96
commit da2b703cef
  1. 5
      src/lib/ares_send.c

@ -151,6 +151,11 @@ ares_status_t ares_send_nolock(ares_channel_t *channel,
/* Duplicate Query */
status = ares_dns_record_duplicate_ex(&query->query, dnsrec);
if (status != ARES_SUCCESS) {
/* Sometimes we might get a EBADRESP response from duplicate due to
* the way it works (write and parse), rewrite it to EBADQUERY. */
if (status == ARES_EBADRESP) {
status = ARES_EBADQUERY;
}
ares_free(query);
callback(arg, status, 0, NULL);
return status;

Loading…
Cancel
Save