From: Felipe Pena Date: Sun, 11 Jan 2009 18:47:17 +0000 (+0000) Subject: MFH: X-Git-Tag: php-5.3.0beta1~196 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=cc50663b56a5094f9946e81f8a3827f2b046acdc;p=php MFH: - Improved fix for #47035 (win32 part by Henrique M. Decaria) [DOC] The TXT part needs be returned as an array of strings. (dns_get_record()) --- diff --git a/ext/standard/dns.c b/ext/standard/dns.c index 63f24b97d4..8b5919c21e 100644 --- a/ext/standard/dns.c +++ b/ext/standard/dns.c @@ -456,20 +456,29 @@ static u_char *php_parserr(u_char *cp, querybuf *answer, int type_to_fetch, int break; case DNS_T_TXT: { + zval *txtarray = NULL; int ll = 0; + char *txt = NULL; add_assoc_string(*subarray, "type", "TXT", 1); tp = emalloc(dlen + 1); + MAKE_STD_ZVAL(txtarray); + array_init(txtarray); + while (ll < dlen) { + txt = tp + ll; n = cp[ll]; - memcpy(tp + ll , cp + ll + 1, n); + memcpy(txt, cp + ll + 1, n); ll = ll + n + 1; + tp[ll] = '\0'; + add_next_index_stringl(txtarray, txt, n, 1); } - tp[dlen] = '\0'; + cp += dlen; - add_assoc_stringl(*subarray, "txt", tp, dlen - 1, 0); + add_assoc_zval(*subarray, "txt", txtarray); + efree(tp); } break; case DNS_T_SOA: diff --git a/ext/standard/dns_win32.c b/ext/standard/dns_win32.c index 07bd362cf2..33ad88da44 100644 --- a/ext/standard/dns_win32.c +++ b/ext/standard/dns_win32.c @@ -194,25 +194,24 @@ static void php_parserr(PDNS_RECORD pRec, int type_to_fetch, int store, zval **s int i = 0; DNS_TXT_DATA *data_txt = &pRec->Data.TXT; DWORD count = data_txt->dwStringCount; - char *txt, *txt_dst; + char *txt; long txt_len; + zval *txtarray; - add_assoc_string(*subarray, "type", "TXT", 1); + MAKE_STD_ZVAL(txtarray); + array_init(txtarray); - txt_len = 0; - for (i = 0; i < count; i++) { - txt_len += strlen(data_txt->pStringArray[i]) + 1; - } + add_assoc_string(*subarray, "type", "TXT", 1); - txt = ecalloc(txt_len * 2, 1); - txt_dst = txt; for (i = 0; i < count; i++) { - int len = strlen(data_txt->pStringArray[i]); - memcpy(txt_dst, data_txt->pStringArray[i], len); - txt_dst += len; + txt_len = strlen(data_txt->pStringArray[i]); + txt = emalloc(txt_len + 1); + memcpy(txt, data_txt->pStringArray[i], txt_len); + txt[txt_len] = '\0'; + add_next_index_stringl(txtarray, txt, txt_len, 0); } - add_assoc_string(*subarray, "txt", txt, 0); + add_assoc_zval(*subarray, "txt", txtarray); } break;