X-Git-Url: https://git.xandkar.net/?p=beam_stats.git;a=blobdiff_plain;f=src%2Fbeam_stats_msg_graphite.erl;fp=src%2Fbeam_stats_msg_graphite.erl;h=d33e45054dc8f6e67a95f60e7e627d4470e481a5;hp=69396539b363cdf8c593d62a57a4f9b7d14d3fe0;hb=cdcb989e330d3a018b44b154c190c33b9b27040c;hpb=7c381eb2b650aa0219b8c489dfc2a377f92a2a52 diff --git a/src/beam_stats_msg_graphite.erl b/src/beam_stats_msg_graphite.erl index 6939653..d33e450 100644 --- a/src/beam_stats_msg_graphite.erl +++ b/src/beam_stats_msg_graphite.erl @@ -14,8 +14,8 @@ -export( [ of_beam_stats/1 , of_beam_stats/2 - , to_bin/1 - , path_to_bin/1 + , to_iolist/1 + , path_to_iolist/1 , node_id_to_bin/1 ]). @@ -64,25 +64,25 @@ of_beam_stats(#beam_stats ++ of_processes(Processes, NodeID, Ts), lists:map(fun path_prefix_schema_version/1, Msgs). --spec to_bin(t()) -> - binary(). -to_bin( +-spec to_iolist(t()) -> + iolist(). +to_iolist( ?T { path = Path , value = Value , timestamp = Timestamp } ) -> - PathBin = path_to_bin(Path), + PathIOList = path_to_iolist(Path), ValueBin = integer_to_binary(Value), TimestampInt = timestamp_to_integer(Timestamp), TimestampBin = integer_to_binary(TimestampInt), - <>. + [PathIOList, <<" ">>, ValueBin, <<" ">>, TimestampBin]. --spec path_to_bin([binary()]) -> - binary(). -path_to_bin(Path) -> - bin_join(Path, <<".">>). +-spec path_to_iolist([binary()]) -> + iolist(). +path_to_iolist(Path) -> + interleave(Path, <<".">>). -spec node_id_to_bin(node()) -> binary(). @@ -109,13 +109,12 @@ path_prefix(?T{path=Path}=T, <>) -> schema_version() -> <<"beam_stats_v0">>. --spec bin_join([binary()], binary()) -> - binary(). -bin_join([] , <<_/binary>> ) -> <<>>; -bin_join([<> | []] , <<_/binary>> ) -> B; -bin_join([<> | [_|_]=Bins], <>) -> - BinsBin = bin_join(Bins, Sep), - <>. +-spec interleave(iolist(), iodata()) -> + iolist(). +interleave([], _) -> []; +interleave([X], _) -> [X]; +interleave([X|Xs], Sep) -> + [X, Sep | interleave(Xs, Sep)]. -spec timestamp_to_integer(erlang:timestamp()) -> non_neg_integer().