Erlang 函数名称在运行时被更改
Erlang function name getting changed at runtime
我有一个版本 20 下的 erlang OTP 应用程序 运行。
在 gen_statem 模块之一中,我有以下代码片段:
state_bitfield(internal, bitfield, #state{} = State) ->
maybe_send_bitfield(State),
{next_state, state_operate, State}.
maybe_send_bitfield(#state{pieces_info = PiecesInfo} = State) ->
lager:info("Calling have_pieces"),
case have_pieces(PiecesInfo) of
true -> send_bitfield(State);
_ -> lager:info("Not sending bitfield as no pieces.")
end.
have_pieces(PiecesInfo) ->
length([ ok || {Status, _, _} <- PiecesInfo, Status == 3 ]) > 0.
此外,我使用 erlang.mk 定义啤酒的解析转换,如下所示:
ERLC_COMPILE_OPTS= +'{parse_transform, lager_transform}' +debug_info
ERLC_OPTS += $(ERLC_COMPILE_OPTS)
代码编译良好,但在运行时出现以下错误:
22:56:12.454 [error] Lager event handler error_logger_lager_h exited
with reason {'EXIT',{{case_clause,['peer_fsm:4516571b-8f41-4d1b-a9cf-
bf06fc31d54e',
{internal,bitfield},some_term,error,function_clause,state_functions,
[{peer_fsm,'-have_pieces/1-lc$^0/1-0-',[{array,27,0,undefined,
{{{0,undefined,0,[],0},{0,undefined,0,[],0},
{0,undefined,0,...},...},...}}],...},...]]},...}}
我不明白函数名称如何从 changed/transformed 变为“-have_pieces/1-lc$^0/1-0-”,如上所示。
这可能是因为某些解析转换吗?
任何帮助将不胜感激。
-have_pieces/1-lc$^0/1-0-
是 have_pieces
函数内部的一个匿名函数的名称。你可以从这个名字看起来乱七八糟的事实中看出。
匿名函数名中的-lc
代表"list comprehension",所以这个匿名函数就是由此而来。
它失败了,因为 PiecesInfo
是一个数组(它在错误中说 {array,...
),并且列表理解需要列表。
我有一个版本 20 下的 erlang OTP 应用程序 运行。 在 gen_statem 模块之一中,我有以下代码片段:
state_bitfield(internal, bitfield, #state{} = State) ->
maybe_send_bitfield(State),
{next_state, state_operate, State}.
maybe_send_bitfield(#state{pieces_info = PiecesInfo} = State) ->
lager:info("Calling have_pieces"),
case have_pieces(PiecesInfo) of
true -> send_bitfield(State);
_ -> lager:info("Not sending bitfield as no pieces.")
end.
have_pieces(PiecesInfo) ->
length([ ok || {Status, _, _} <- PiecesInfo, Status == 3 ]) > 0.
此外,我使用 erlang.mk 定义啤酒的解析转换,如下所示:
ERLC_COMPILE_OPTS= +'{parse_transform, lager_transform}' +debug_info
ERLC_OPTS += $(ERLC_COMPILE_OPTS)
代码编译良好,但在运行时出现以下错误:
22:56:12.454 [error] Lager event handler error_logger_lager_h exited
with reason {'EXIT',{{case_clause,['peer_fsm:4516571b-8f41-4d1b-a9cf-
bf06fc31d54e',
{internal,bitfield},some_term,error,function_clause,state_functions,
[{peer_fsm,'-have_pieces/1-lc$^0/1-0-',[{array,27,0,undefined,
{{{0,undefined,0,[],0},{0,undefined,0,[],0},
{0,undefined,0,...},...},...}}],...},...]]},...}}
我不明白函数名称如何从 changed/transformed 变为“-have_pieces/1-lc$^0/1-0-”,如上所示。 这可能是因为某些解析转换吗? 任何帮助将不胜感激。
-have_pieces/1-lc$^0/1-0-
是 have_pieces
函数内部的一个匿名函数的名称。你可以从这个名字看起来乱七八糟的事实中看出。
匿名函数名中的-lc
代表"list comprehension",所以这个匿名函数就是由此而来。
它失败了,因为 PiecesInfo
是一个数组(它在错误中说 {array,...
),并且列表理解需要列表。