diff options
author | Anders Svensson <anders@erlang.org> | 2011-09-22 19:52:47 +0200 |
---|---|---|
committer | Anders Svensson <anders@erlang.org> | 2011-09-26 15:49:04 +0200 |
commit | 73f89318887d473536350b1531cad27f9ab94c7c (patch) | |
tree | ed35be82a6ccc72c9d49167271144086c76ba305 /lib/diameter | |
parent | 97f3a064f27843a9f825210c1c7a27075b7b3ad7 (diff) | |
download | otp-73f89318887d473536350b1531cad27f9ab94c7c.tar.gz otp-73f89318887d473536350b1531cad27f9ab94c7c.tar.bz2 otp-73f89318887d473536350b1531cad27f9ab94c7c.zip |
Fix header folding bug
A prepare_request callback from diameter can return a diameter_header
record with in order to set values in the header of an outgoing
request. The fault in diameter_lib:fold_tuple/3 caused encode of
the outgoing request to fail.
Diffstat (limited to 'lib/diameter')
-rw-r--r-- | lib/diameter/src/app/diameter_lib.erl | 15 |
1 files changed, 8 insertions, 7 deletions
diff --git a/lib/diameter/src/app/diameter_lib.erl b/lib/diameter/src/app/diameter_lib.erl index b5c0e1bf6a..46fd87c591 100644 --- a/lib/diameter/src/app/diameter_lib.erl +++ b/lib/diameter/src/app/diameter_lib.erl @@ -255,12 +255,13 @@ w(L) -> fold_tuple(_, T, undefined) -> T; -fold_tuple(N, T0, T) -> - element(2, lists:foldl(fun(X, {M,_} = A) -> {M+1, ft(X, A)} end, - {N, T0}, - lists:nthtail(N-1, tuple_to_list(T)))). +fold_tuple(N, T0, T1) -> + {_, T} = lists:foldl(fun(V, {I,_} = IT) -> {I+1, ft(V, IT)} end, + {N, T0}, + lists:nthtail(N-1, tuple_to_list(T1))), + T. -ft(undefined, T) -> +ft(undefined, {_, T}) -> T; -ft(X, {N, T}) -> - setelement(N, T, X). +ft(Value, {Idx, T}) -> + setelement(Idx, T, Value). |