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.33
Brad House 2 weeks ago
parent 5f7816cb70
commit dfc4866c36
  1. 5
      src/lib/ares_send.c

@ -150,6 +150,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