X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=synfig-core%2Ftrunk%2Fsrc%2Fsynfig%2Ftime.cpp;h=ea59b8e1ddae4696ec5abfe8c2d5b299d2ca0640;hb=756c0d29ac1742f231e6615f9a577e574e35a4af;hp=e2256330d41ddce8afb3b3870d44529799297eed;hpb=e3acc0b267b14fda5db3c7bbb2f218b993ef84b3;p=synfig.git diff --git a/synfig-core/trunk/src/synfig/time.cpp b/synfig-core/trunk/src/synfig/time.cpp index e225633..ea59b8e 100644 --- a/synfig-core/trunk/src/synfig/time.cpp +++ b/synfig-core/trunk/src/synfig/time.cpp @@ -1,20 +1,22 @@ -/* === S I N F G =========================================================== */ +/* === S Y N F I G ========================================================= */ /*! \file time.cpp ** \brief Template File ** -** $Id: time.cpp,v 1.1.1.1 2005/01/04 01:23:15 darco Exp $ +** $Id$ ** ** \legal -** Copyright (c) 2002 Robert B. Quattlebaum Jr. +** Copyright (c) 2002-2005 Robert B. Quattlebaum Jr., Adrian Bentley +** Copyright (c) 2007, 2008 Chris Moore ** -** This software and associated documentation -** are CONFIDENTIAL and PROPRIETARY property of -** the above-mentioned copyright holder. +** This package is free software; you can redistribute it and/or +** modify it under the terms of the GNU General Public License as +** published by the Free Software Foundation; either version 2 of +** the License, or (at your option) any later version. ** -** You may not copy, print, publish, or in any -** other way distribute this software without -** a prior written agreement with -** the copyright holder. +** This package is distributed in the hope that it will be useful, +** but WITHOUT ANY WARRANTY; without even the implied warranty of +** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +** General Public License for more details. ** \endlegal */ /* ========================================================================= */ @@ -34,10 +36,10 @@ #include "general.h" #include #include +#include #include #include -#ifndef isnan #ifdef WIN32 #include @@ -47,19 +49,25 @@ extern "C" { int _isnan(double x); } #endif #endif -#ifdef __APPLE__ -#define isnan __isnan +// For some reason isnan() isn't working on macosx any more. +// This is a quick fix. +#if defined(__APPLE__) && !defined(SYNFIG_ISNAN_FIX) +#ifdef isnan +#undef isnan #endif - +inline bool isnan(double x) { return x != x; } +inline bool isnan(float x) { return x != x; } +#define SYNFIG_ISNAN_FIX 1 #endif + #endif /* === U S I N G =========================================================== */ using namespace std; using namespace etl; -using namespace sinfg; +using namespace synfig; #define tolower ::tolower @@ -76,13 +84,13 @@ Time::Time(const String &str_, float fps): std::transform(str.begin(),str.end(),str.begin(),&tolower); // Start/Begin Of Time - if(str=="SOT" || str=="BOT") + if(str=="sot" || str=="bot") { operator=(begin()); return; } // End Of Time - if(str=="EOT") + if(str=="eot") { operator=(end()); return; @@ -92,8 +100,8 @@ Time::Time(const String &str_, float fps): unsigned int pos=0; int read; float amount; - - // Now try to read it in the letter-abreviated format + + // Now try to read it in the letter-abbreviated format while(pos=end()) return "EOT"; // End Of Time - + if(fps<0)fps=0; - + if(ceil(time.value_)-time.value_1) { int frame; frame=round_to_int(time*fps); @@ -194,39 +203,81 @@ Time::get_string(float fps, Time::Format format)const else return strprintf("%02d:%02d:%02d",hour,minute,second); } - + String ret; + bool started = false; if(format<=FORMAT_FULL || hour) - ret+=strprintf(format<=FORMAT_NOSPACES?"%dh":"%dh ",hour); - - if(format<=FORMAT_FULL || hour || minute) - ret+=strprintf(format<=FORMAT_NOSPACES?"%dm":"%dm ",minute); - - if(fps) + { + ret+=strprintf("%dh",hour); + started = true; + } + + if(format<=FORMAT_FULL || minute) + { + if (!(format<=FORMAT_NOSPACES) && started) + ret += " "; + + ret += strprintf("%dm", minute); + started = true; + } + + if(fps && fps>1) { int second; float frame; second=time;time-=second; frame=time*fps; + if(format<=FORMAT_FULL || second) - ret+=strprintf(format<=FORMAT_NOSPACES?"%ds":"%ds ",(int)second); - - if(abs(frame-floor(frame)>=epsilon_())) - ret+=strprintf("%0.3ff",frame); - else - ret+=strprintf("%0.0ff",frame); + { + if (!(format<=FORMAT_NOSPACES) && started) + ret += " "; + + ret += strprintf("%ds", (int)second); + started = true; + } + + if(format<=FORMAT_FULL || frame || !started) + { + if (!(format<=FORMAT_NOSPACES) && started) + ret += " "; + + if(abs(frame-floor(frame) >= epsilon_())) + ret += strprintf("%0.3ff", frame); + else + ret += strprintf("%0.0ff", frame); + } } else { float second; second=time; - if(abs(second-floor(second))>=epsilon_()) - ret+=strprintf("%0.8fs",second); - else - ret+=strprintf("%0.0fs",second); + if(format<=FORMAT_FULL || second || !started) + { + if (!(format<=FORMAT_NOSPACES) && started) + ret += " "; + + if(abs(second-floor(second))>=epsilon_()) + { + String seconds(strprintf("%0.8f",second)); + + // skip trailing zeros + int count = 0; + String::reverse_iterator i = seconds.rbegin(); + for ( ; (*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); + } } - + return ret; } @@ -245,6 +296,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