Erlang便利な印刷デバッグ情報

1120 ワード

詳細
現在、モジュールをデバッグするのは面倒ですが、デバッグバージョンに再コンパイルする必要があります.つまり、DEBUGマクロまたはdebug_を追加します.infoなどの情報を再コンパイルします.
 
この効果を達成するには、モジュールをデバッグしたいときにtest:debug()を呼び出して自動的にデバッグモードに変換すると便利です.
効果は次のとおりです.
 
Eshell V5.8.3  (abort with ^G)
1> c(test).
{ok,test}
2> test:test(1).
2
3> test:debug().
{ok,test}
4> test:test(1).
test(1) = 2
2
5> 
 
 
 
すると、次のように書くことができます.
 
-module(test).

-compile(export_all).

-ifdef(DEBUG).
-define(LOG(Format), io:format(Format)).
-define(LOG(Format, Data), io:format(Format, Data)).

-else.
-define(LOG(Format), ok).
-define(LOG(Format, Data), ok).

-endif.

test(N) when is_integer(N) ->
    R = N + N,
    ?LOG("test(~p) = ~p~n", [N, R]),
    R.

debug() ->
    debug(true).

debug(true) ->
    c:c(?MODULE, [{d, 'DEBUG'}]);
debug(false) ->
    c:c(?MODULE, []).