From 7459e3ad45c9bce280817fa906b9906cd06c78f0 Mon Sep 17 00:00:00 2001 From: Anthony Molinaro Date: Thu, 20 Apr 2017 19:44:46 +0000 Subject: [PATCH] avoid a webmachine dependency for a single function --- ChangeLog | 3 +++ src/mondemand.app.src | 2 +- src/mondemand.erl | 2 +- src/mondemand_util.erl | 44 ++++++++++++++++++++++++++++++++++++++++++ 4 files changed, 49 insertions(+), 2 deletions(-) diff --git a/ChangeLog b/ChangeLog index 120c8ad..39ba82b 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,6 @@ +Version 6.8.1 (molinaro) + * avoid webmachine dependency + Version 6.8.0 (molinaro) * add user state to the mondemand_statdb:map function so that you can do the equivalent of mapfold there. diff --git a/src/mondemand.app.src b/src/mondemand.app.src index 1a2a27c..3c0d518 100644 --- a/src/mondemand.app.src +++ b/src/mondemand.app.src @@ -1,7 +1,7 @@ { application, mondemand, [ { description, "Erlang Mondemand Bindings." }, - { vsn, "6.8.0" }, + { vsn, "6.8.1" }, { modules, [] }, { registered, [mondemand,mondemand_sup]}, { applications, [kernel,stdlib,syntax_tools,lwes,inets]}, diff --git a/src/mondemand.erl b/src/mondemand.erl index 5e92484..c61ee7a 100644 --- a/src/mondemand.erl +++ b/src/mondemand.erl @@ -321,7 +321,7 @@ flush ({FlushModule, FlushStatePrepFunction, FlushFunction}) -> ), Finish = os:timestamp (), error_logger:info_msg ("flushing took ~p millis and returned ~p", - [webmachine_util:now_diff_milliseconds (Finish,Start), + [mondemand_util:now_diff_milliseconds (Finish,Start), Ret]), Ret. diff --git a/src/mondemand_util.erl b/src/mondemand_util.erl index 48a87c3..fe4988d 100644 --- a/src/mondemand_util.erl +++ b/src/mondemand_util.erl @@ -34,6 +34,7 @@ now_to_epoch_millis/1, % ({_,_,_}) -> MillisSinceEpoch now_to_epoch_secs/1, % ({_,_,_}) -> SecondsSinceEpoch now_to_epoch_minutes/1, % ({_,_,_}) -> MinutesSinceEpoch + now_diff_milliseconds/2, current/0, current_minute/0, millis_to_next_round_second/0, @@ -155,6 +156,42 @@ now_to_epoch_secs ({Mega, Secs, _}) -> now_to_epoch_minutes (Now) -> trunc (now_to_epoch_secs (Now) / 60). +%% NOTE: Copied from webmachine with the mailing list link corrected, +%% webmachine license is +%% +%% Licensed under the Apache License, Version 2.0 (the "License"); +%% you may not use this file except in compliance with the License. +%% You may obtain a copy of the License at +%% +%% http://www.apache.org/licenses/LICENSE-2.0 +%% +%% Unless required by applicable law or agreed to in writing, software +%% distributed under the License is distributed on an "AS IS" BASIS, +%% WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +%% See the License for the specific language governing permissions and +%% limitations under the License. +%% +%% File is/was +%% +%% https://github.com/webmachine/webmachine/blob/master/src/webmachine_util.erl +%% +%% Test is also copied below +%% +%% This is faster than timer:now_diff() because it does not use bignums. +%% But it returns *milliseconds* (timer:now_diff returns microseconds.) +%% From http://erlang.org/pipermail/erlang-questions/2002-June/005037.html +%% +%% @doc Compute the difference between two now() tuples, in milliseconds. +%% @spec now_diff_milliseconds(now(), now()) -> integer() +now_diff_milliseconds(undefined, undefined) -> + 0; +now_diff_milliseconds(undefined, T2) -> + now_diff_milliseconds(os:timestamp(), T2); +now_diff_milliseconds({M,S,U}, {M,S1,U1}) -> + ((S-S1) * 1000) + ((U-U1) div 1000); +now_diff_milliseconds({M,S,U}, {M1,S1,U1}) -> + ((M-M1)*1000000+(S-S1))*1000 + ((U-U1) div 1000). + current () -> {{Year, Month, Day},{Hour,Minute,_}} = now_to_mdyhms (os:timestamp()), EpochStartSeconds = @@ -293,5 +330,12 @@ dummy () -> -ifdef (TEST). -include_lib ("eunit/include/eunit.hrl"). +%% Copied from webmachine, see NOTE above +now_diff_milliseconds_test() -> + Late = {10, 10, 10}, + Early1 = {10, 9, 9}, + Early2 = {9, 9, 9}, + ?assertEqual(1000, now_diff_milliseconds(Late, Early1)), + ?assertEqual(1000001000, now_diff_milliseconds(Late, Early2)). -endif.