修訂 | 8d9634346817a65f4ec927f3bc87a2dded7791bf (tree) |
---|---|
時間 | 2021-08-09 10:30:47 |
作者 | mirabilos <m@mirb...> |
Commiter | mirabilos |
libc/inet/resolv.c: use dn_{comp,expand} for {en,de}code_dotted
Minimal-invasive change: just ifdeffing away the older code.
There is no reason to have two different sets of functions doing
the same thing, one used in half the code and another, doing less
escaping, in the other half; just use one.
Signed-off-by: mirabilos <mirabilos@evolvis.org>
@@ -11,6 +11,7 @@ | ||
11 | 11 | /* |
12 | 12 | * Portions Copyright (c) 1985, 1993 |
13 | 13 | * The Regents of the University of California. All rights reserved. |
14 | + * Portions Copyright © 2021 mirabilos <m@mirbsd.org> | |
14 | 15 | * |
15 | 16 | * Redistribution and use in source and binary forms, with or without |
16 | 17 | * modification, are permitted provided that the following conditions |
@@ -559,6 +560,9 @@ void __decode_header(unsigned char *data, | ||
559 | 560 | the data */ |
560 | 561 | int __encode_dotted(const char *dotted, unsigned char *dest, int maxlen) |
561 | 562 | { |
563 | +#ifndef WHY_UCLIBC_WHY_DID_YOU_DO_THIS | |
564 | + return (dn_comp(dotted, dest, maxlen, NULL, NULL)); | |
565 | +#else | |
562 | 566 | unsigned used = 0; |
563 | 567 | |
564 | 568 | while (dotted && *dotted) { |
@@ -587,6 +591,7 @@ int __encode_dotted(const char *dotted, unsigned char *dest, int maxlen) | ||
587 | 591 | dest[used++] = 0; |
588 | 592 | |
589 | 593 | return used; |
594 | +#endif | |
590 | 595 | } |
591 | 596 | #endif /* L_encoded */ |
592 | 597 |
@@ -601,6 +606,9 @@ int __decode_dotted(const unsigned char *packet, | ||
601 | 606 | char *dest, |
602 | 607 | int dest_len) |
603 | 608 | { |
609 | +#ifndef WHY_UCLIBC_WHY_DID_YOU_DO_THIS | |
610 | + return (dn_expand(packet, packet + packet_len, packet + offset, dest, dest_len)); | |
611 | +#else | |
604 | 612 | unsigned b; |
605 | 613 | bool measure = 1; |
606 | 614 | unsigned total = 0; |
@@ -658,6 +666,7 @@ int __decode_dotted(const unsigned char *packet, | ||
658 | 666 | DPRINTF("Total decode len = %d\n", total); |
659 | 667 | |
660 | 668 | return total; |
669 | +#endif | |
661 | 670 | } |
662 | 671 | #endif /* L_decoded */ |
663 | 672 |