X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=synfig-core%2Ftrunk%2Fsrc%2Fsynfig%2Ftime.cpp;h=98dbff564effefe5a0c189744c2d903814f36f9d;hb=068f3f607f6ce56696509225fec71acaee3a79a1;hp=eb2eef7ce617269ebede57309e76f6229d3772cf;hpb=76bc5e374b4f97da13e0ec38f3bd47f2704f864a;p=synfig.git diff --git a/synfig-core/trunk/src/synfig/time.cpp b/synfig-core/trunk/src/synfig/time.cpp index eb2eef7..98dbff5 100644 --- a/synfig-core/trunk/src/synfig/time.cpp +++ b/synfig-core/trunk/src/synfig/time.cpp @@ -6,6 +6,7 @@ ** ** \legal ** Copyright (c) 2002-2005 Robert B. Quattlebaum Jr., Adrian Bentley +** Copyright (c) 2007 Chris Moore ** ** This package is free software; you can redistribute it and/or ** modify it under the terms of the GNU General Public License as @@ -192,7 +193,7 @@ Time::get_string(float fps, Time::Format format)const int second; second=time;time-=second; - if(fps) + if(fps && fps>1) { int frame; frame=round_to_int(time*fps); @@ -218,7 +219,7 @@ Time::get_string(float fps, Time::Format format)const started = true; } - if(fps) + if(fps && fps>1) { int second; float frame; @@ -245,7 +246,19 @@ Time::get_string(float fps, Time::Format format)const if(format<=FORMAT_FULL || second || !started) { if(abs(second-floor(second))>=epsilon_()) - ret+=strprintf("%0.8fs",second); + { + String seconds(strprintf("%0.8f",second)); + + // skip trailing zeros + int count = 0; + for (String::reverse_iterator i = seconds.rbegin(); (*i) == '0'; i++) + count++; + + // if we removed too many, go back one place, leaving one zero + if (*i < '0' || *i > '9') count--; + + ret += seconds.substr(0, seconds.size()-count) + "s"; + } else ret+=strprintf("%0.0fs",second); } @@ -269,6 +282,14 @@ Time::round(float fps)const return ceil(time)/fps; } +#ifdef _DEBUG +const char * +Time::c_str()const +{ + return get_string().c_str(); +} +#endif + //! \writeme bool Time::is_valid()const