awk: fix length(array)
function old new delta evaluate 3526 3548 +22 Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
This commit is contained in:
@ -2784,8 +2784,16 @@ static var *evaluate(node *op, var *res)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case F_le:
|
case F_le:
|
||||||
if (!op1)
|
debug_printf_eval("length: L.s:'%s'\n", L.s);
|
||||||
|
if (!op1) {
|
||||||
L.s = getvar_s(intvar[F0]);
|
L.s = getvar_s(intvar[F0]);
|
||||||
|
debug_printf_eval("length: L.s='%s'\n", L.s);
|
||||||
|
}
|
||||||
|
else if (L.v->type & VF_ARRAY) {
|
||||||
|
R_d = L.v->x.array->nel;
|
||||||
|
debug_printf_eval("length: array_len:%d\n", L.v->x.array->nel);
|
||||||
|
break;
|
||||||
|
}
|
||||||
R_d = strlen(L.s);
|
R_d = strlen(L.s);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -274,6 +274,11 @@ testing "awk large integer" \
|
|||||||
"2147483647 2147483647 0 2147483648 2147483648 0\n" \
|
"2147483647 2147483647 0 2147483648 2147483648 0\n" \
|
||||||
"" ""
|
"" ""
|
||||||
|
|
||||||
|
testing "awk length(array)" \
|
||||||
|
"awk 'BEGIN{ A[1]=2; A["qwe"]="asd"; print length(A)}'" \
|
||||||
|
"2\n" \
|
||||||
|
"" ""
|
||||||
|
|
||||||
# testing "description" "command" "result" "infile" "stdin"
|
# testing "description" "command" "result" "infile" "stdin"
|
||||||
|
|
||||||
exit $FAILCOUNT
|
exit $FAILCOUNT
|
||||||
|
Reference in New Issue
Block a user