git subrepo clone --branch=sono6good https://github.com/essej/JUCE.git deps/juce
subrepo: subdir: "deps/juce" merged: "b13f9084e" upstream: origin: "https://github.com/essej/JUCE.git" branch: "sono6good" commit: "b13f9084e" git-subrepo: version: "0.4.3" origin: "https://github.com/ingydotnet/git-subrepo.git" commit: "2f68596"
This commit is contained in:
132
deps/juce/modules/juce_core/time/juce_PerformanceCounter.cpp
vendored
Normal file
132
deps/juce/modules/juce_core/time/juce_PerformanceCounter.cpp
vendored
Normal file
@ -0,0 +1,132 @@
|
||||
/*
|
||||
==============================================================================
|
||||
|
||||
This file is part of the JUCE library.
|
||||
Copyright (c) 2020 - Raw Material Software Limited
|
||||
|
||||
JUCE is an open source library subject to commercial or open-source
|
||||
licensing.
|
||||
|
||||
The code included in this file is provided under the terms of the ISC license
|
||||
http://www.isc.org/downloads/software-support-policy/isc-license. Permission
|
||||
To use, copy, modify, and/or distribute this software for any purpose with or
|
||||
without fee is hereby granted provided that the above copyright notice and
|
||||
this permission notice appear in all copies.
|
||||
|
||||
JUCE IS PROVIDED "AS IS" WITHOUT ANY WARRANTY, AND ALL WARRANTIES, WHETHER
|
||||
EXPRESSED OR IMPLIED, INCLUDING MERCHANTABILITY AND FITNESS FOR PURPOSE, ARE
|
||||
DISCLAIMED.
|
||||
|
||||
==============================================================================
|
||||
*/
|
||||
|
||||
namespace juce
|
||||
{
|
||||
|
||||
static void appendToFile (const File& f, const String& s)
|
||||
{
|
||||
if (f.getFullPathName().isNotEmpty())
|
||||
{
|
||||
FileOutputStream out (f);
|
||||
|
||||
if (! out.failedToOpen())
|
||||
out << s << newLine;
|
||||
}
|
||||
}
|
||||
|
||||
PerformanceCounter::PerformanceCounter (const String& name, int runsPerPrintout, const File& loggingFile)
|
||||
: runsPerPrint (runsPerPrintout), startTime (0), outputFile (loggingFile)
|
||||
{
|
||||
stats.name = name;
|
||||
appendToFile (outputFile, "**** Counter for \"" + name + "\" started at: " + Time::getCurrentTime().toString (true, true));
|
||||
}
|
||||
|
||||
PerformanceCounter::~PerformanceCounter()
|
||||
{
|
||||
if (stats.numRuns > 0)
|
||||
printStatistics();
|
||||
}
|
||||
|
||||
PerformanceCounter::Statistics::Statistics() noexcept
|
||||
: averageSeconds(), maximumSeconds(), minimumSeconds(), totalSeconds(), numRuns()
|
||||
{
|
||||
}
|
||||
|
||||
void PerformanceCounter::Statistics::clear() noexcept
|
||||
{
|
||||
averageSeconds = maximumSeconds = minimumSeconds = totalSeconds = 0;
|
||||
numRuns = 0;
|
||||
}
|
||||
|
||||
void PerformanceCounter::Statistics::addResult (double elapsed) noexcept
|
||||
{
|
||||
if (numRuns == 0)
|
||||
{
|
||||
maximumSeconds = elapsed;
|
||||
minimumSeconds = elapsed;
|
||||
}
|
||||
else
|
||||
{
|
||||
maximumSeconds = jmax (maximumSeconds, elapsed);
|
||||
minimumSeconds = jmin (minimumSeconds, elapsed);
|
||||
}
|
||||
|
||||
++numRuns;
|
||||
totalSeconds += elapsed;
|
||||
}
|
||||
|
||||
static String timeToString (double secs)
|
||||
{
|
||||
return String ((int64) (secs * (secs < 0.01 ? 1000000.0 : 1000.0) + 0.5))
|
||||
+ (secs < 0.01 ? " microsecs" : " millisecs");
|
||||
}
|
||||
|
||||
String PerformanceCounter::Statistics::toString() const
|
||||
{
|
||||
MemoryOutputStream s;
|
||||
|
||||
s << "Performance count for \"" << name << "\" over " << numRuns << " run(s)" << newLine
|
||||
<< "Average = " << timeToString (averageSeconds)
|
||||
<< ", minimum = " << timeToString (minimumSeconds)
|
||||
<< ", maximum = " << timeToString (maximumSeconds)
|
||||
<< ", total = " << timeToString (totalSeconds);
|
||||
|
||||
return s.toString();
|
||||
}
|
||||
|
||||
void PerformanceCounter::start() noexcept
|
||||
{
|
||||
startTime = Time::getHighResolutionTicks();
|
||||
}
|
||||
|
||||
bool PerformanceCounter::stop()
|
||||
{
|
||||
stats.addResult (Time::highResolutionTicksToSeconds (Time::getHighResolutionTicks() - startTime));
|
||||
|
||||
if (stats.numRuns < runsPerPrint)
|
||||
return false;
|
||||
|
||||
printStatistics();
|
||||
return true;
|
||||
}
|
||||
|
||||
void PerformanceCounter::printStatistics()
|
||||
{
|
||||
const String desc (getStatisticsAndReset().toString());
|
||||
|
||||
Logger::writeToLog (desc);
|
||||
appendToFile (outputFile, desc);
|
||||
}
|
||||
|
||||
PerformanceCounter::Statistics PerformanceCounter::getStatisticsAndReset()
|
||||
{
|
||||
Statistics s (stats);
|
||||
stats.clear();
|
||||
|
||||
if (s.numRuns > 0)
|
||||
s.averageSeconds = s.totalSeconds / (float) s.numRuns;
|
||||
|
||||
return s;
|
||||
}
|
||||
|
||||
} // namespace juce
|
165
deps/juce/modules/juce_core/time/juce_PerformanceCounter.h
vendored
Normal file
165
deps/juce/modules/juce_core/time/juce_PerformanceCounter.h
vendored
Normal file
@ -0,0 +1,165 @@
|
||||
/*
|
||||
==============================================================================
|
||||
|
||||
This file is part of the JUCE library.
|
||||
Copyright (c) 2020 - Raw Material Software Limited
|
||||
|
||||
JUCE is an open source library subject to commercial or open-source
|
||||
licensing.
|
||||
|
||||
The code included in this file is provided under the terms of the ISC license
|
||||
http://www.isc.org/downloads/software-support-policy/isc-license. Permission
|
||||
To use, copy, modify, and/or distribute this software for any purpose with or
|
||||
without fee is hereby granted provided that the above copyright notice and
|
||||
this permission notice appear in all copies.
|
||||
|
||||
JUCE IS PROVIDED "AS IS" WITHOUT ANY WARRANTY, AND ALL WARRANTIES, WHETHER
|
||||
EXPRESSED OR IMPLIED, INCLUDING MERCHANTABILITY AND FITNESS FOR PURPOSE, ARE
|
||||
DISCLAIMED.
|
||||
|
||||
==============================================================================
|
||||
*/
|
||||
|
||||
namespace juce
|
||||
{
|
||||
|
||||
//==============================================================================
|
||||
/** A timer for measuring performance of code and dumping the results to a file.
|
||||
|
||||
e.g. @code
|
||||
|
||||
PerformanceCounter pc ("fish", 50, "/temp/myfishlog.txt");
|
||||
|
||||
for (;;)
|
||||
{
|
||||
pc.start();
|
||||
|
||||
doSomethingFishy();
|
||||
|
||||
pc.stop();
|
||||
}
|
||||
@endcode
|
||||
|
||||
In this example, the time of each period between calling start/stop will be
|
||||
measured and averaged over 50 runs, and the results printed to a file
|
||||
every 50 times round the loop.
|
||||
|
||||
@tags{Core}
|
||||
*/
|
||||
class JUCE_API PerformanceCounter
|
||||
{
|
||||
public:
|
||||
//==============================================================================
|
||||
/** Creates a PerformanceCounter object.
|
||||
|
||||
@param counterName the name used when printing out the statistics
|
||||
@param runsPerPrintout the number of start/stop iterations before calling
|
||||
printStatistics()
|
||||
@param loggingFile a file to dump the results to - if this is File(),
|
||||
the results are just written to the debugger output
|
||||
*/
|
||||
PerformanceCounter (const String& counterName,
|
||||
int runsPerPrintout = 100,
|
||||
const File& loggingFile = File());
|
||||
|
||||
/** Destructor. */
|
||||
~PerformanceCounter();
|
||||
|
||||
//==============================================================================
|
||||
/** Starts timing.
|
||||
@see stop
|
||||
*/
|
||||
void start() noexcept;
|
||||
|
||||
/** Stops timing and prints out the results.
|
||||
|
||||
The number of iterations before doing a printout of the
|
||||
results is set in the constructor.
|
||||
|
||||
@see start
|
||||
*/
|
||||
bool stop();
|
||||
|
||||
/** Dumps the current metrics to the debugger output and to a file.
|
||||
|
||||
As well as using Logger::outputDebugString to print the results,
|
||||
this will write then to the file specified in the constructor (if
|
||||
this was valid).
|
||||
*/
|
||||
void printStatistics();
|
||||
|
||||
/** Holds the current statistics. */
|
||||
struct Statistics
|
||||
{
|
||||
Statistics() noexcept;
|
||||
|
||||
void clear() noexcept;
|
||||
String toString() const;
|
||||
|
||||
void addResult (double elapsed) noexcept;
|
||||
|
||||
String name;
|
||||
double averageSeconds;
|
||||
double maximumSeconds;
|
||||
double minimumSeconds;
|
||||
double totalSeconds;
|
||||
int64 numRuns;
|
||||
};
|
||||
|
||||
/** Returns a copy of the current stats, and resets the internal counter. */
|
||||
Statistics getStatisticsAndReset();
|
||||
|
||||
private:
|
||||
//==============================================================================
|
||||
Statistics stats;
|
||||
int64 runsPerPrint, startTime;
|
||||
File outputFile;
|
||||
|
||||
JUCE_DECLARE_NON_COPYABLE_WITH_LEAK_DETECTOR (PerformanceCounter)
|
||||
};
|
||||
|
||||
|
||||
//==============================================================================
|
||||
/**
|
||||
Simple RAII class for measuring the time spent in a scope.
|
||||
|
||||
Example:
|
||||
|
||||
{
|
||||
double timeSec;
|
||||
|
||||
{
|
||||
ScopedTimeMeasurement m (timeSec);
|
||||
doSomething();
|
||||
}
|
||||
|
||||
Logger::writeToLog ("doSomething() took " + String (timeSec) + "seconds");
|
||||
}
|
||||
|
||||
@param resultInSeconds The result of the measurement will be stored in this variable.
|
||||
|
||||
@tags{Core}
|
||||
*/
|
||||
class JUCE_API ScopedTimeMeasurement
|
||||
{
|
||||
public:
|
||||
ScopedTimeMeasurement (double& resultInSeconds) noexcept
|
||||
: result (resultInSeconds)
|
||||
{
|
||||
result = 0.0;
|
||||
}
|
||||
|
||||
~ScopedTimeMeasurement()
|
||||
{
|
||||
static auto scaler = 1.0 / static_cast<double> (Time::getHighResolutionTicksPerSecond());
|
||||
result = static_cast<double> (Time::getHighResolutionTicks() - startTimeTicks) * scaler;
|
||||
}
|
||||
|
||||
private:
|
||||
int64 startTimeTicks = Time::getHighResolutionTicks();
|
||||
double& result;
|
||||
|
||||
JUCE_DECLARE_NON_COPYABLE_WITH_LEAK_DETECTOR (ScopedTimeMeasurement)
|
||||
};
|
||||
|
||||
} // namespace juce
|
157
deps/juce/modules/juce_core/time/juce_RelativeTime.cpp
vendored
Normal file
157
deps/juce/modules/juce_core/time/juce_RelativeTime.cpp
vendored
Normal file
@ -0,0 +1,157 @@
|
||||
/*
|
||||
==============================================================================
|
||||
|
||||
This file is part of the JUCE library.
|
||||
Copyright (c) 2020 - Raw Material Software Limited
|
||||
|
||||
JUCE is an open source library subject to commercial or open-source
|
||||
licensing.
|
||||
|
||||
The code included in this file is provided under the terms of the ISC license
|
||||
http://www.isc.org/downloads/software-support-policy/isc-license. Permission
|
||||
To use, copy, modify, and/or distribute this software for any purpose with or
|
||||
without fee is hereby granted provided that the above copyright notice and
|
||||
this permission notice appear in all copies.
|
||||
|
||||
JUCE IS PROVIDED "AS IS" WITHOUT ANY WARRANTY, AND ALL WARRANTIES, WHETHER
|
||||
EXPRESSED OR IMPLIED, INCLUDING MERCHANTABILITY AND FITNESS FOR PURPOSE, ARE
|
||||
DISCLAIMED.
|
||||
|
||||
==============================================================================
|
||||
*/
|
||||
|
||||
namespace juce
|
||||
{
|
||||
|
||||
RelativeTime::RelativeTime (const double secs) noexcept : numSeconds (secs) {}
|
||||
RelativeTime::RelativeTime (const RelativeTime& other) noexcept : numSeconds (other.numSeconds) {}
|
||||
RelativeTime::~RelativeTime() noexcept {}
|
||||
|
||||
//==============================================================================
|
||||
RelativeTime RelativeTime::milliseconds (int milliseconds) noexcept { return RelativeTime ((double) milliseconds * 0.001); }
|
||||
RelativeTime RelativeTime::milliseconds (int64 milliseconds) noexcept { return RelativeTime ((double) milliseconds * 0.001); }
|
||||
RelativeTime RelativeTime::seconds (double s) noexcept { return RelativeTime (s); }
|
||||
RelativeTime RelativeTime::minutes (double numberOfMinutes) noexcept { return RelativeTime (numberOfMinutes * 60.0); }
|
||||
RelativeTime RelativeTime::hours (double numberOfHours) noexcept { return RelativeTime (numberOfHours * (60.0 * 60.0)); }
|
||||
RelativeTime RelativeTime::days (double numberOfDays) noexcept { return RelativeTime (numberOfDays * (60.0 * 60.0 * 24.0)); }
|
||||
RelativeTime RelativeTime::weeks (double numberOfWeeks) noexcept { return RelativeTime (numberOfWeeks * (60.0 * 60.0 * 24.0 * 7.0)); }
|
||||
|
||||
//==============================================================================
|
||||
int64 RelativeTime::inMilliseconds() const noexcept { return (int64) (numSeconds * 1000.0); }
|
||||
double RelativeTime::inMinutes() const noexcept { return numSeconds / 60.0; }
|
||||
double RelativeTime::inHours() const noexcept { return numSeconds / (60.0 * 60.0); }
|
||||
double RelativeTime::inDays() const noexcept { return numSeconds / (60.0 * 60.0 * 24.0); }
|
||||
double RelativeTime::inWeeks() const noexcept { return numSeconds / (60.0 * 60.0 * 24.0 * 7.0); }
|
||||
|
||||
//==============================================================================
|
||||
RelativeTime& RelativeTime::operator= (const RelativeTime& other) noexcept { numSeconds = other.numSeconds; return *this; }
|
||||
|
||||
RelativeTime RelativeTime::operator+= (RelativeTime t) noexcept { numSeconds += t.numSeconds; return *this; }
|
||||
RelativeTime RelativeTime::operator-= (RelativeTime t) noexcept { numSeconds -= t.numSeconds; return *this; }
|
||||
RelativeTime RelativeTime::operator+= (double secs) noexcept { numSeconds += secs; return *this; }
|
||||
RelativeTime RelativeTime::operator-= (double secs) noexcept { numSeconds -= secs; return *this; }
|
||||
|
||||
JUCE_API RelativeTime JUCE_CALLTYPE operator+ (RelativeTime t1, RelativeTime t2) noexcept { return t1 += t2; }
|
||||
JUCE_API RelativeTime JUCE_CALLTYPE operator- (RelativeTime t1, RelativeTime t2) noexcept { return t1 -= t2; }
|
||||
|
||||
JUCE_API bool JUCE_CALLTYPE operator== (RelativeTime t1, RelativeTime t2) noexcept { return t1.inSeconds() == t2.inSeconds(); }
|
||||
JUCE_API bool JUCE_CALLTYPE operator!= (RelativeTime t1, RelativeTime t2) noexcept { return t1.inSeconds() != t2.inSeconds(); }
|
||||
JUCE_API bool JUCE_CALLTYPE operator> (RelativeTime t1, RelativeTime t2) noexcept { return t1.inSeconds() > t2.inSeconds(); }
|
||||
JUCE_API bool JUCE_CALLTYPE operator< (RelativeTime t1, RelativeTime t2) noexcept { return t1.inSeconds() < t2.inSeconds(); }
|
||||
JUCE_API bool JUCE_CALLTYPE operator>= (RelativeTime t1, RelativeTime t2) noexcept { return t1.inSeconds() >= t2.inSeconds(); }
|
||||
JUCE_API bool JUCE_CALLTYPE operator<= (RelativeTime t1, RelativeTime t2) noexcept { return t1.inSeconds() <= t2.inSeconds(); }
|
||||
|
||||
//==============================================================================
|
||||
static String translateTimeField (int n, const char* singular, const char* plural)
|
||||
{
|
||||
return TRANS (n == 1 ? singular : plural).replace (n == 1 ? "1" : "2", String (n));
|
||||
}
|
||||
|
||||
static String describeYears (int n) { return translateTimeField (n, NEEDS_TRANS("1 year"), NEEDS_TRANS("2 years")); }
|
||||
static String describeMonths (int n) { return translateTimeField (n, NEEDS_TRANS("1 month"), NEEDS_TRANS("2 months")); }
|
||||
static String describeWeeks (int n) { return translateTimeField (n, NEEDS_TRANS("1 week"), NEEDS_TRANS("2 weeks")); }
|
||||
static String describeDays (int n) { return translateTimeField (n, NEEDS_TRANS("1 day"), NEEDS_TRANS("2 days")); }
|
||||
static String describeHours (int n) { return translateTimeField (n, NEEDS_TRANS("1 hr"), NEEDS_TRANS("2 hrs")); }
|
||||
static String describeMinutes (int n) { return translateTimeField (n, NEEDS_TRANS("1 min"), NEEDS_TRANS("2 mins")); }
|
||||
static String describeSeconds (int n) { return translateTimeField (n, NEEDS_TRANS("1 sec"), NEEDS_TRANS("2 secs")); }
|
||||
|
||||
String RelativeTime::getApproximateDescription() const
|
||||
{
|
||||
if (numSeconds <= 1.0)
|
||||
return "< 1 sec";
|
||||
|
||||
auto weeks = (int) inWeeks();
|
||||
|
||||
if (weeks > 52) return describeYears (weeks / 52);
|
||||
if (weeks > 8) return describeMonths ((weeks * 12) / 52);
|
||||
if (weeks > 1) return describeWeeks (weeks);
|
||||
|
||||
auto days = (int) inWeeks();
|
||||
|
||||
if (days > 1)
|
||||
return describeDays (days);
|
||||
|
||||
auto hours = (int) inHours();
|
||||
|
||||
if (hours > 0)
|
||||
return describeHours (hours);
|
||||
|
||||
auto minutes = (int) inMinutes();
|
||||
|
||||
if (minutes > 0)
|
||||
return describeMinutes (minutes);
|
||||
|
||||
return describeSeconds ((int) numSeconds);
|
||||
}
|
||||
|
||||
String RelativeTime::getDescription (const String& returnValueForZeroTime) const
|
||||
{
|
||||
if (std::abs (numSeconds) < 0.001)
|
||||
return returnValueForZeroTime;
|
||||
|
||||
if (numSeconds < 0)
|
||||
return "-" + RelativeTime (-numSeconds).getDescription();
|
||||
|
||||
StringArray fields;
|
||||
|
||||
auto n = (int) inWeeks();
|
||||
|
||||
if (n > 0)
|
||||
fields.add (describeWeeks (n));
|
||||
|
||||
n = ((int) inDays()) % 7;
|
||||
|
||||
if (n > 0)
|
||||
fields.add (describeDays (n));
|
||||
|
||||
if (fields.size() < 2)
|
||||
{
|
||||
n = ((int) inHours()) % 24;
|
||||
|
||||
if (n > 0)
|
||||
fields.add (describeHours (n));
|
||||
|
||||
if (fields.size() < 2)
|
||||
{
|
||||
n = ((int) inMinutes()) % 60;
|
||||
|
||||
if (n > 0)
|
||||
fields.add (describeMinutes (n));
|
||||
|
||||
if (fields.size() < 2)
|
||||
{
|
||||
n = ((int) inSeconds()) % 60;
|
||||
|
||||
if (n > 0)
|
||||
fields.add (describeSeconds (n));
|
||||
|
||||
if (fields.isEmpty())
|
||||
fields.add (String (((int) inMilliseconds()) % 1000) + " " + TRANS ("ms"));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return fields.joinIntoString (" ");
|
||||
}
|
||||
|
||||
} // namespace juce
|
184
deps/juce/modules/juce_core/time/juce_RelativeTime.h
vendored
Normal file
184
deps/juce/modules/juce_core/time/juce_RelativeTime.h
vendored
Normal file
@ -0,0 +1,184 @@
|
||||
/*
|
||||
==============================================================================
|
||||
|
||||
This file is part of the JUCE library.
|
||||
Copyright (c) 2020 - Raw Material Software Limited
|
||||
|
||||
JUCE is an open source library subject to commercial or open-source
|
||||
licensing.
|
||||
|
||||
The code included in this file is provided under the terms of the ISC license
|
||||
http://www.isc.org/downloads/software-support-policy/isc-license. Permission
|
||||
To use, copy, modify, and/or distribute this software for any purpose with or
|
||||
without fee is hereby granted provided that the above copyright notice and
|
||||
this permission notice appear in all copies.
|
||||
|
||||
JUCE IS PROVIDED "AS IS" WITHOUT ANY WARRANTY, AND ALL WARRANTIES, WHETHER
|
||||
EXPRESSED OR IMPLIED, INCLUDING MERCHANTABILITY AND FITNESS FOR PURPOSE, ARE
|
||||
DISCLAIMED.
|
||||
|
||||
==============================================================================
|
||||
*/
|
||||
|
||||
namespace juce
|
||||
{
|
||||
|
||||
//==============================================================================
|
||||
/** A relative measure of time.
|
||||
|
||||
The time is stored as a number of seconds, at double-precision floating
|
||||
point accuracy, and may be positive or negative.
|
||||
|
||||
If you need an absolute time, (i.e. a date + time), see the Time class.
|
||||
|
||||
@tags{Core}
|
||||
*/
|
||||
class JUCE_API RelativeTime
|
||||
{
|
||||
public:
|
||||
//==============================================================================
|
||||
/** Creates a RelativeTime.
|
||||
|
||||
@param seconds the number of seconds, which may be +ve or -ve.
|
||||
@see milliseconds, minutes, hours, days, weeks
|
||||
*/
|
||||
explicit RelativeTime (double seconds = 0.0) noexcept;
|
||||
|
||||
/** Copies another relative time. */
|
||||
RelativeTime (const RelativeTime& other) noexcept;
|
||||
|
||||
/** Copies another relative time. */
|
||||
RelativeTime& operator= (const RelativeTime& other) noexcept;
|
||||
|
||||
/** Destructor. */
|
||||
~RelativeTime() noexcept;
|
||||
|
||||
//==============================================================================
|
||||
/** Creates a new RelativeTime object representing a number of milliseconds.
|
||||
@see seconds, minutes, hours, days, weeks
|
||||
*/
|
||||
static RelativeTime milliseconds (int milliseconds) noexcept;
|
||||
|
||||
/** Creates a new RelativeTime object representing a number of milliseconds.
|
||||
@see seconds, minutes, hours, days, weeks
|
||||
*/
|
||||
static RelativeTime milliseconds (int64 milliseconds) noexcept;
|
||||
|
||||
/** Creates a new RelativeTime object representing a number of seconds.
|
||||
@see milliseconds, minutes, hours, days, weeks
|
||||
*/
|
||||
static RelativeTime seconds (double seconds) noexcept;
|
||||
|
||||
/** Creates a new RelativeTime object representing a number of minutes.
|
||||
@see milliseconds, hours, days, weeks
|
||||
*/
|
||||
static RelativeTime minutes (double numberOfMinutes) noexcept;
|
||||
|
||||
/** Creates a new RelativeTime object representing a number of hours.
|
||||
@see milliseconds, minutes, days, weeks
|
||||
*/
|
||||
static RelativeTime hours (double numberOfHours) noexcept;
|
||||
|
||||
/** Creates a new RelativeTime object representing a number of days.
|
||||
@see milliseconds, minutes, hours, weeks
|
||||
*/
|
||||
static RelativeTime days (double numberOfDays) noexcept;
|
||||
|
||||
/** Creates a new RelativeTime object representing a number of weeks.
|
||||
@see milliseconds, minutes, hours, days
|
||||
*/
|
||||
static RelativeTime weeks (double numberOfWeeks) noexcept;
|
||||
|
||||
//==============================================================================
|
||||
/** Returns the number of milliseconds this time represents.
|
||||
@see milliseconds, inSeconds, inMinutes, inHours, inDays, inWeeks
|
||||
*/
|
||||
int64 inMilliseconds() const noexcept;
|
||||
|
||||
/** Returns the number of seconds this time represents.
|
||||
@see inMilliseconds, inMinutes, inHours, inDays, inWeeks
|
||||
*/
|
||||
double inSeconds() const noexcept { return numSeconds; }
|
||||
|
||||
/** Returns the number of minutes this time represents.
|
||||
@see inMilliseconds, inSeconds, inHours, inDays, inWeeks
|
||||
*/
|
||||
double inMinutes() const noexcept;
|
||||
|
||||
/** Returns the number of hours this time represents.
|
||||
@see inMilliseconds, inSeconds, inMinutes, inDays, inWeeks
|
||||
*/
|
||||
double inHours() const noexcept;
|
||||
|
||||
/** Returns the number of days this time represents.
|
||||
@see inMilliseconds, inSeconds, inMinutes, inHours, inWeeks
|
||||
*/
|
||||
double inDays() const noexcept;
|
||||
|
||||
/** Returns the number of weeks this time represents.
|
||||
@see inMilliseconds, inSeconds, inMinutes, inHours, inDays
|
||||
*/
|
||||
double inWeeks() const noexcept;
|
||||
|
||||
/** Returns a readable textual description of the time.
|
||||
|
||||
The exact format of the string returned will depend on
|
||||
the magnitude of the time - e.g.
|
||||
|
||||
"1 min 4 secs", "1 hr 45 mins", "2 weeks 5 days", "140 ms"
|
||||
|
||||
so that only the two most significant units are printed.
|
||||
|
||||
The returnValueForZeroTime value is the result that is returned if the
|
||||
length is zero. Depending on your application you might want to use this
|
||||
to return something more relevant like "empty" or "0 secs", etc.
|
||||
|
||||
@see inMilliseconds, inSeconds, inMinutes, inHours, inDays, inWeeks
|
||||
*/
|
||||
String getDescription (const String& returnValueForZeroTime = "0") const;
|
||||
|
||||
//==============================================================================
|
||||
/** This returns a string that roughly describes how long ago this time was, which
|
||||
can be handy for showing ages of files, etc.
|
||||
This will only attempt to be accurate to within the nearest order of magnitude
|
||||
so returns strings such as "5 years", "2 weeks", "< 1 minute", "< 1 sec" etc.
|
||||
*/
|
||||
String getApproximateDescription() const;
|
||||
|
||||
//==============================================================================
|
||||
/** Adds another RelativeTime to this one. */
|
||||
RelativeTime operator+= (RelativeTime timeToAdd) noexcept;
|
||||
/** Subtracts another RelativeTime from this one. */
|
||||
RelativeTime operator-= (RelativeTime timeToSubtract) noexcept;
|
||||
|
||||
/** Adds a number of seconds to this time. */
|
||||
RelativeTime operator+= (double secondsToAdd) noexcept;
|
||||
/** Subtracts a number of seconds from this time. */
|
||||
RelativeTime operator-= (double secondsToSubtract) noexcept;
|
||||
|
||||
private:
|
||||
//==============================================================================
|
||||
double numSeconds;
|
||||
};
|
||||
|
||||
//==============================================================================
|
||||
/** Compares two RelativeTimes. */
|
||||
JUCE_API bool JUCE_CALLTYPE operator== (RelativeTime t1, RelativeTime t2) noexcept;
|
||||
/** Compares two RelativeTimes. */
|
||||
JUCE_API bool JUCE_CALLTYPE operator!= (RelativeTime t1, RelativeTime t2) noexcept;
|
||||
/** Compares two RelativeTimes. */
|
||||
JUCE_API bool JUCE_CALLTYPE operator> (RelativeTime t1, RelativeTime t2) noexcept;
|
||||
/** Compares two RelativeTimes. */
|
||||
JUCE_API bool JUCE_CALLTYPE operator< (RelativeTime t1, RelativeTime t2) noexcept;
|
||||
/** Compares two RelativeTimes. */
|
||||
JUCE_API bool JUCE_CALLTYPE operator>= (RelativeTime t1, RelativeTime t2) noexcept;
|
||||
/** Compares two RelativeTimes. */
|
||||
JUCE_API bool JUCE_CALLTYPE operator<= (RelativeTime t1, RelativeTime t2) noexcept;
|
||||
|
||||
//==============================================================================
|
||||
/** Adds two RelativeTimes together. */
|
||||
JUCE_API RelativeTime JUCE_CALLTYPE operator+ (RelativeTime t1, RelativeTime t2) noexcept;
|
||||
/** Subtracts two RelativeTimes. */
|
||||
JUCE_API RelativeTime JUCE_CALLTYPE operator- (RelativeTime t1, RelativeTime t2) noexcept;
|
||||
|
||||
} // namespace juce
|
676
deps/juce/modules/juce_core/time/juce_Time.cpp
vendored
Normal file
676
deps/juce/modules/juce_core/time/juce_Time.cpp
vendored
Normal file
@ -0,0 +1,676 @@
|
||||
/*
|
||||
==============================================================================
|
||||
|
||||
This file is part of the JUCE library.
|
||||
Copyright (c) 2020 - Raw Material Software Limited
|
||||
|
||||
JUCE is an open source library subject to commercial or open-source
|
||||
licensing.
|
||||
|
||||
The code included in this file is provided under the terms of the ISC license
|
||||
http://www.isc.org/downloads/software-support-policy/isc-license. Permission
|
||||
To use, copy, modify, and/or distribute this software for any purpose with or
|
||||
without fee is hereby granted provided that the above copyright notice and
|
||||
this permission notice appear in all copies.
|
||||
|
||||
JUCE IS PROVIDED "AS IS" WITHOUT ANY WARRANTY, AND ALL WARRANTIES, WHETHER
|
||||
EXPRESSED OR IMPLIED, INCLUDING MERCHANTABILITY AND FITNESS FOR PURPOSE, ARE
|
||||
DISCLAIMED.
|
||||
|
||||
==============================================================================
|
||||
*/
|
||||
|
||||
namespace juce
|
||||
{
|
||||
|
||||
namespace TimeHelpers
|
||||
{
|
||||
static std::tm millisToLocal (int64 millis) noexcept
|
||||
{
|
||||
#if JUCE_WINDOWS && JUCE_MINGW
|
||||
auto now = (time_t) (millis / 1000);
|
||||
return *localtime (&now);
|
||||
|
||||
#elif JUCE_WINDOWS
|
||||
std::tm result;
|
||||
millis /= 1000;
|
||||
|
||||
if (_localtime64_s (&result, &millis) != 0)
|
||||
zerostruct (result);
|
||||
|
||||
return result;
|
||||
|
||||
#else
|
||||
std::tm result;
|
||||
auto now = (time_t) (millis / 1000);
|
||||
|
||||
if (localtime_r (&now, &result) == nullptr)
|
||||
zerostruct (result);
|
||||
|
||||
return result;
|
||||
#endif
|
||||
}
|
||||
|
||||
static std::tm millisToUTC (int64 millis) noexcept
|
||||
{
|
||||
#if JUCE_WINDOWS && JUCE_MINGW
|
||||
auto now = (time_t) (millis / 1000);
|
||||
return *gmtime (&now);
|
||||
|
||||
#elif JUCE_WINDOWS
|
||||
std::tm result;
|
||||
millis /= 1000;
|
||||
|
||||
if (_gmtime64_s (&result, &millis) != 0)
|
||||
zerostruct (result);
|
||||
|
||||
return result;
|
||||
|
||||
#else
|
||||
std::tm result;
|
||||
auto now = (time_t) (millis / 1000);
|
||||
|
||||
if (gmtime_r (&now, &result) == nullptr)
|
||||
zerostruct (result);
|
||||
|
||||
return result;
|
||||
#endif
|
||||
}
|
||||
|
||||
static int getUTCOffsetSeconds (const int64 millis) noexcept
|
||||
{
|
||||
auto utc = millisToUTC (millis);
|
||||
utc.tm_isdst = -1; // Treat this UTC time as local to find the offset
|
||||
|
||||
return (int) ((millis / 1000) - (int64) mktime (&utc));
|
||||
}
|
||||
|
||||
static int extendedModulo (const int64 value, const int modulo) noexcept
|
||||
{
|
||||
return (int) (value >= 0 ? (value % modulo)
|
||||
: (value - ((value / modulo) + 1) * modulo));
|
||||
}
|
||||
|
||||
static String formatString (const String& format, const std::tm* const tm)
|
||||
{
|
||||
#if JUCE_ANDROID
|
||||
using StringType = CharPointer_UTF8;
|
||||
#elif JUCE_WINDOWS
|
||||
using StringType = CharPointer_UTF16;
|
||||
#else
|
||||
using StringType = CharPointer_UTF32;
|
||||
#endif
|
||||
|
||||
#ifdef JUCE_MSVC
|
||||
if (tm->tm_year < -1900 || tm->tm_year > 8099)
|
||||
return {}; // Visual Studio's library can only handle 0 -> 9999 AD
|
||||
#endif
|
||||
|
||||
for (size_t bufferSize = 256; ; bufferSize += 256)
|
||||
{
|
||||
HeapBlock<StringType::CharType> buffer (bufferSize);
|
||||
|
||||
auto numChars =
|
||||
#if JUCE_ANDROID
|
||||
strftime (buffer, bufferSize - 1, format.toUTF8(), tm);
|
||||
#elif JUCE_WINDOWS
|
||||
wcsftime (buffer, bufferSize - 1, format.toWideCharPointer(), tm);
|
||||
#else
|
||||
wcsftime (buffer, bufferSize - 1, format.toUTF32(), tm);
|
||||
#endif
|
||||
|
||||
if (numChars > 0 || format.isEmpty())
|
||||
return String (StringType (buffer),
|
||||
StringType (buffer) + (int) numChars);
|
||||
}
|
||||
}
|
||||
|
||||
//==============================================================================
|
||||
static bool isLeapYear (int year) noexcept
|
||||
{
|
||||
return (year % 400 == 0) || ((year % 100 != 0) && (year % 4 == 0));
|
||||
}
|
||||
|
||||
static int daysFromJan1 (int year, int month) noexcept
|
||||
{
|
||||
const short dayOfYear[] = { 0, 31, 59, 90, 120, 151, 181, 212, 243, 273, 304, 334,
|
||||
0, 31, 60, 91, 121, 152, 182, 213, 244, 274, 305, 335 };
|
||||
|
||||
return dayOfYear [(isLeapYear (year) ? 12 : 0) + month];
|
||||
}
|
||||
|
||||
static int64 daysFromYear0 (int year) noexcept
|
||||
{
|
||||
--year;
|
||||
return 365 * year + (year / 400) - (year / 100) + (year / 4);
|
||||
}
|
||||
|
||||
static int64 daysFrom1970 (int year) noexcept
|
||||
{
|
||||
return daysFromYear0 (year) - daysFromYear0 (1970);
|
||||
}
|
||||
|
||||
static int64 daysFrom1970 (int year, int month) noexcept
|
||||
{
|
||||
if (month > 11)
|
||||
{
|
||||
year += month / 12;
|
||||
month %= 12;
|
||||
}
|
||||
else if (month < 0)
|
||||
{
|
||||
auto numYears = (11 - month) / 12;
|
||||
year -= numYears;
|
||||
month += 12 * numYears;
|
||||
}
|
||||
|
||||
return daysFrom1970 (year) + daysFromJan1 (year, month);
|
||||
}
|
||||
|
||||
// There's no posix function that does a UTC version of mktime,
|
||||
// so annoyingly we need to implement this manually..
|
||||
static int64 mktime_utc (const std::tm& t) noexcept
|
||||
{
|
||||
return 24 * 3600 * (daysFrom1970 (t.tm_year + 1900, t.tm_mon) + (t.tm_mday - 1))
|
||||
+ 3600 * t.tm_hour
|
||||
+ 60 * t.tm_min
|
||||
+ t.tm_sec;
|
||||
}
|
||||
|
||||
static Atomic<uint32> lastMSCounterValue { (uint32) 0 };
|
||||
}
|
||||
|
||||
//==============================================================================
|
||||
Time::Time (int64 ms) noexcept : millisSinceEpoch (ms) {}
|
||||
|
||||
Time::Time (int year, int month, int day,
|
||||
int hours, int minutes, int seconds, int milliseconds,
|
||||
bool useLocalTime) noexcept
|
||||
{
|
||||
std::tm t;
|
||||
t.tm_year = year - 1900;
|
||||
t.tm_mon = month;
|
||||
t.tm_mday = day;
|
||||
t.tm_hour = hours;
|
||||
t.tm_min = minutes;
|
||||
t.tm_sec = seconds;
|
||||
t.tm_isdst = -1;
|
||||
|
||||
millisSinceEpoch = 1000 * (useLocalTime ? (int64) mktime (&t)
|
||||
: TimeHelpers::mktime_utc (t))
|
||||
+ milliseconds;
|
||||
}
|
||||
|
||||
//==============================================================================
|
||||
int64 Time::currentTimeMillis() noexcept
|
||||
{
|
||||
#if JUCE_WINDOWS && ! JUCE_MINGW
|
||||
struct _timeb t;
|
||||
_ftime_s (&t);
|
||||
return ((int64) t.time) * 1000 + t.millitm;
|
||||
#else
|
||||
struct timeval tv;
|
||||
gettimeofday (&tv, nullptr);
|
||||
return ((int64) tv.tv_sec) * 1000 + tv.tv_usec / 1000;
|
||||
#endif
|
||||
}
|
||||
|
||||
Time JUCE_CALLTYPE Time::getCurrentTime() noexcept
|
||||
{
|
||||
return Time (currentTimeMillis());
|
||||
}
|
||||
|
||||
//==============================================================================
|
||||
uint32 juce_millisecondsSinceStartup() noexcept;
|
||||
|
||||
uint32 Time::getMillisecondCounter() noexcept
|
||||
{
|
||||
auto now = juce_millisecondsSinceStartup();
|
||||
|
||||
if (now < TimeHelpers::lastMSCounterValue.get())
|
||||
{
|
||||
// in multi-threaded apps this might be called concurrently, so
|
||||
// make sure that our last counter value only increases and doesn't
|
||||
// go backwards..
|
||||
if (now < TimeHelpers::lastMSCounterValue.get() - (uint32) 1000)
|
||||
TimeHelpers::lastMSCounterValue = now;
|
||||
}
|
||||
else
|
||||
{
|
||||
TimeHelpers::lastMSCounterValue = now;
|
||||
}
|
||||
|
||||
return now;
|
||||
}
|
||||
|
||||
uint32 Time::getApproximateMillisecondCounter() noexcept
|
||||
{
|
||||
auto t = TimeHelpers::lastMSCounterValue.get();
|
||||
return t == 0 ? getMillisecondCounter() : t;
|
||||
}
|
||||
|
||||
void Time::waitForMillisecondCounter (uint32 targetTime) noexcept
|
||||
{
|
||||
for (;;)
|
||||
{
|
||||
auto now = getMillisecondCounter();
|
||||
|
||||
if (now >= targetTime)
|
||||
break;
|
||||
|
||||
auto toWait = (int) (targetTime - now);
|
||||
|
||||
if (toWait > 2)
|
||||
{
|
||||
Thread::sleep (jmin (20, toWait >> 1));
|
||||
}
|
||||
else
|
||||
{
|
||||
// xxx should consider using mutex_pause on the mac as it apparently
|
||||
// makes it seem less like a spinlock and avoids lowering the thread pri.
|
||||
for (int i = 10; --i >= 0;)
|
||||
Thread::yield();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
//==============================================================================
|
||||
double Time::highResolutionTicksToSeconds (const int64 ticks) noexcept
|
||||
{
|
||||
return (double) ticks / (double) getHighResolutionTicksPerSecond();
|
||||
}
|
||||
|
||||
int64 Time::secondsToHighResolutionTicks (const double seconds) noexcept
|
||||
{
|
||||
return (int64) (seconds * (double) getHighResolutionTicksPerSecond());
|
||||
}
|
||||
|
||||
//==============================================================================
|
||||
String Time::toString (bool includeDate,
|
||||
bool includeTime,
|
||||
bool includeSeconds,
|
||||
bool use24HourClock) const
|
||||
{
|
||||
String result;
|
||||
|
||||
if (includeDate)
|
||||
{
|
||||
result << getDayOfMonth() << ' '
|
||||
<< getMonthName (true) << ' '
|
||||
<< getYear();
|
||||
|
||||
if (includeTime)
|
||||
result << ' ';
|
||||
}
|
||||
|
||||
if (includeTime)
|
||||
{
|
||||
auto mins = getMinutes();
|
||||
|
||||
result << (use24HourClock ? getHours() : getHoursInAmPmFormat())
|
||||
<< (mins < 10 ? ":0" : ":") << mins;
|
||||
|
||||
if (includeSeconds)
|
||||
{
|
||||
auto secs = getSeconds();
|
||||
result << (secs < 10 ? ":0" : ":") << secs;
|
||||
}
|
||||
|
||||
if (! use24HourClock)
|
||||
result << (isAfternoon() ? "pm" : "am");
|
||||
}
|
||||
|
||||
return result.trimEnd();
|
||||
}
|
||||
|
||||
String Time::formatted (const String& format) const
|
||||
{
|
||||
std::tm t (TimeHelpers::millisToLocal (millisSinceEpoch));
|
||||
return TimeHelpers::formatString (format, &t);
|
||||
}
|
||||
|
||||
//==============================================================================
|
||||
int Time::getYear() const noexcept { return TimeHelpers::millisToLocal (millisSinceEpoch).tm_year + 1900; }
|
||||
int Time::getMonth() const noexcept { return TimeHelpers::millisToLocal (millisSinceEpoch).tm_mon; }
|
||||
int Time::getDayOfYear() const noexcept { return TimeHelpers::millisToLocal (millisSinceEpoch).tm_yday; }
|
||||
int Time::getDayOfMonth() const noexcept { return TimeHelpers::millisToLocal (millisSinceEpoch).tm_mday; }
|
||||
int Time::getDayOfWeek() const noexcept { return TimeHelpers::millisToLocal (millisSinceEpoch).tm_wday; }
|
||||
int Time::getHours() const noexcept { return TimeHelpers::millisToLocal (millisSinceEpoch).tm_hour; }
|
||||
int Time::getMinutes() const noexcept { return TimeHelpers::millisToLocal (millisSinceEpoch).tm_min; }
|
||||
int Time::getSeconds() const noexcept { return TimeHelpers::extendedModulo (millisSinceEpoch / 1000, 60); }
|
||||
int Time::getMilliseconds() const noexcept { return TimeHelpers::extendedModulo (millisSinceEpoch, 1000); }
|
||||
|
||||
int Time::getHoursInAmPmFormat() const noexcept
|
||||
{
|
||||
auto hours = getHours();
|
||||
|
||||
if (hours == 0) return 12;
|
||||
if (hours <= 12) return hours;
|
||||
|
||||
return hours - 12;
|
||||
}
|
||||
|
||||
bool Time::isAfternoon() const noexcept
|
||||
{
|
||||
return getHours() >= 12;
|
||||
}
|
||||
|
||||
bool Time::isDaylightSavingTime() const noexcept
|
||||
{
|
||||
return TimeHelpers::millisToLocal (millisSinceEpoch).tm_isdst != 0;
|
||||
}
|
||||
|
||||
String Time::getTimeZone() const
|
||||
{
|
||||
String zone[2];
|
||||
|
||||
#if JUCE_WINDOWS
|
||||
#if JUCE_MSVC || JUCE_CLANG
|
||||
_tzset();
|
||||
|
||||
for (int i = 0; i < 2; ++i)
|
||||
{
|
||||
char name[128] = { 0 };
|
||||
size_t length;
|
||||
_get_tzname (&length, name, sizeof (name) - 1, i);
|
||||
zone[i] = name;
|
||||
}
|
||||
#else
|
||||
#warning "Can't find a replacement for tzset on mingw - ideas welcome!"
|
||||
#endif
|
||||
#else
|
||||
tzset();
|
||||
|
||||
auto zonePtr = (const char**) tzname;
|
||||
zone[0] = zonePtr[0];
|
||||
zone[1] = zonePtr[1];
|
||||
#endif
|
||||
|
||||
if (isDaylightSavingTime())
|
||||
{
|
||||
zone[0] = zone[1];
|
||||
|
||||
if (zone[0].length() > 3
|
||||
&& zone[0].containsIgnoreCase ("daylight")
|
||||
&& zone[0].contains ("GMT"))
|
||||
zone[0] = "BST";
|
||||
}
|
||||
|
||||
return zone[0].substring (0, 3);
|
||||
}
|
||||
|
||||
int Time::getUTCOffsetSeconds() const noexcept
|
||||
{
|
||||
return TimeHelpers::getUTCOffsetSeconds (millisSinceEpoch);
|
||||
}
|
||||
|
||||
String Time::getUTCOffsetString (bool includeSemiColon) const
|
||||
{
|
||||
if (auto seconds = getUTCOffsetSeconds())
|
||||
{
|
||||
auto minutes = seconds / 60;
|
||||
|
||||
return String::formatted (includeSemiColon ? "%+03d:%02d"
|
||||
: "%+03d%02d",
|
||||
minutes / 60,
|
||||
minutes % 60);
|
||||
}
|
||||
|
||||
return "Z";
|
||||
}
|
||||
|
||||
String Time::toISO8601 (bool includeDividerCharacters) const
|
||||
{
|
||||
return String::formatted (includeDividerCharacters ? "%04d-%02d-%02dT%02d:%02d:%06.03f"
|
||||
: "%04d%02d%02dT%02d%02d%06.03f",
|
||||
getYear(),
|
||||
getMonth() + 1,
|
||||
getDayOfMonth(),
|
||||
getHours(),
|
||||
getMinutes(),
|
||||
getSeconds() + getMilliseconds() / 1000.0)
|
||||
+ getUTCOffsetString (includeDividerCharacters);
|
||||
}
|
||||
|
||||
static int parseFixedSizeIntAndSkip (String::CharPointerType& t, int numChars, char charToSkip) noexcept
|
||||
{
|
||||
int n = 0;
|
||||
|
||||
for (int i = numChars; --i >= 0;)
|
||||
{
|
||||
auto digit = (int) (*t - '0');
|
||||
|
||||
if (! isPositiveAndBelow (digit, 10))
|
||||
return -1;
|
||||
|
||||
++t;
|
||||
n = n * 10 + digit;
|
||||
}
|
||||
|
||||
if (charToSkip != 0 && *t == (juce_wchar) charToSkip)
|
||||
++t;
|
||||
|
||||
return n;
|
||||
}
|
||||
|
||||
Time Time::fromISO8601 (StringRef iso)
|
||||
{
|
||||
auto t = iso.text;
|
||||
auto year = parseFixedSizeIntAndSkip (t, 4, '-');
|
||||
|
||||
if (year < 0)
|
||||
return {};
|
||||
|
||||
auto month = parseFixedSizeIntAndSkip (t, 2, '-');
|
||||
|
||||
if (month < 0)
|
||||
return {};
|
||||
|
||||
auto day = parseFixedSizeIntAndSkip (t, 2, 0);
|
||||
|
||||
if (day < 0)
|
||||
return {};
|
||||
|
||||
int hours = 0, minutes = 0, milliseconds = 0;
|
||||
|
||||
if (*t == 'T')
|
||||
{
|
||||
++t;
|
||||
hours = parseFixedSizeIntAndSkip (t, 2, ':');
|
||||
|
||||
if (hours < 0)
|
||||
return {};
|
||||
|
||||
minutes = parseFixedSizeIntAndSkip (t, 2, ':');
|
||||
|
||||
if (minutes < 0)
|
||||
return {};
|
||||
|
||||
auto seconds = parseFixedSizeIntAndSkip (t, 2, 0);
|
||||
|
||||
if (seconds < 0)
|
||||
return {};
|
||||
|
||||
if (*t == '.' || *t == ',')
|
||||
{
|
||||
++t;
|
||||
milliseconds = parseFixedSizeIntAndSkip (t, 3, 0);
|
||||
|
||||
if (milliseconds < 0)
|
||||
return {};
|
||||
}
|
||||
|
||||
milliseconds += 1000 * seconds;
|
||||
}
|
||||
|
||||
auto nextChar = t.getAndAdvance();
|
||||
|
||||
if (nextChar == '-' || nextChar == '+')
|
||||
{
|
||||
auto offsetHours = parseFixedSizeIntAndSkip (t, 2, ':');
|
||||
|
||||
if (offsetHours < 0)
|
||||
return {};
|
||||
|
||||
auto offsetMinutes = parseFixedSizeIntAndSkip (t, 2, 0);
|
||||
|
||||
if (offsetMinutes < 0)
|
||||
return {};
|
||||
|
||||
auto offsetMs = (offsetHours * 60 + offsetMinutes) * 60 * 1000;
|
||||
milliseconds += nextChar == '-' ? offsetMs : -offsetMs; // NB: this seems backwards but is correct!
|
||||
}
|
||||
else if (nextChar != 0 && nextChar != 'Z')
|
||||
{
|
||||
return {};
|
||||
}
|
||||
|
||||
return Time (year, month - 1, day, hours, minutes, 0, milliseconds, false);
|
||||
}
|
||||
|
||||
String Time::getMonthName (const bool threeLetterVersion) const
|
||||
{
|
||||
return getMonthName (getMonth(), threeLetterVersion);
|
||||
}
|
||||
|
||||
String Time::getWeekdayName (const bool threeLetterVersion) const
|
||||
{
|
||||
return getWeekdayName (getDayOfWeek(), threeLetterVersion);
|
||||
}
|
||||
|
||||
static const char* const shortMonthNames[] = { "Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec" };
|
||||
static const char* const longMonthNames[] = { "January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December" };
|
||||
|
||||
String Time::getMonthName (int monthNumber, const bool threeLetterVersion)
|
||||
{
|
||||
monthNumber %= 12;
|
||||
|
||||
return TRANS (threeLetterVersion ? shortMonthNames [monthNumber]
|
||||
: longMonthNames [monthNumber]);
|
||||
}
|
||||
|
||||
String Time::getWeekdayName (int day, const bool threeLetterVersion)
|
||||
{
|
||||
static const char* const shortDayNames[] = { "Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat" };
|
||||
static const char* const longDayNames[] = { "Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday" };
|
||||
|
||||
day %= 7;
|
||||
|
||||
return TRANS (threeLetterVersion ? shortDayNames [day]
|
||||
: longDayNames [day]);
|
||||
}
|
||||
|
||||
//==============================================================================
|
||||
Time& Time::operator+= (RelativeTime delta) noexcept { millisSinceEpoch += delta.inMilliseconds(); return *this; }
|
||||
Time& Time::operator-= (RelativeTime delta) noexcept { millisSinceEpoch -= delta.inMilliseconds(); return *this; }
|
||||
|
||||
Time operator+ (Time time, RelativeTime delta) noexcept { Time t (time); return t += delta; }
|
||||
Time operator- (Time time, RelativeTime delta) noexcept { Time t (time); return t -= delta; }
|
||||
Time operator+ (RelativeTime delta, Time time) noexcept { Time t (time); return t += delta; }
|
||||
const RelativeTime operator- (Time time1, Time time2) noexcept { return RelativeTime::milliseconds (time1.toMilliseconds() - time2.toMilliseconds()); }
|
||||
|
||||
bool operator== (Time time1, Time time2) noexcept { return time1.toMilliseconds() == time2.toMilliseconds(); }
|
||||
bool operator!= (Time time1, Time time2) noexcept { return time1.toMilliseconds() != time2.toMilliseconds(); }
|
||||
bool operator< (Time time1, Time time2) noexcept { return time1.toMilliseconds() < time2.toMilliseconds(); }
|
||||
bool operator> (Time time1, Time time2) noexcept { return time1.toMilliseconds() > time2.toMilliseconds(); }
|
||||
bool operator<= (Time time1, Time time2) noexcept { return time1.toMilliseconds() <= time2.toMilliseconds(); }
|
||||
bool operator>= (Time time1, Time time2) noexcept { return time1.toMilliseconds() >= time2.toMilliseconds(); }
|
||||
|
||||
static int getMonthNumberForCompileDate (const String& m)
|
||||
{
|
||||
for (int i = 0; i < 12; ++i)
|
||||
if (m.equalsIgnoreCase (shortMonthNames[i]))
|
||||
return i;
|
||||
|
||||
// If you hit this because your compiler has an unusual __DATE__
|
||||
// format, let us know so we can add support for it!
|
||||
jassertfalse;
|
||||
return 0;
|
||||
}
|
||||
|
||||
Time Time::getCompilationDate()
|
||||
{
|
||||
StringArray dateTokens, timeTokens;
|
||||
|
||||
dateTokens.addTokens (__DATE__, true);
|
||||
dateTokens.removeEmptyStrings (true);
|
||||
|
||||
timeTokens.addTokens (__TIME__, ":", StringRef());
|
||||
|
||||
return Time (dateTokens[2].getIntValue(),
|
||||
getMonthNumberForCompileDate (dateTokens[0]),
|
||||
dateTokens[1].getIntValue(),
|
||||
timeTokens[0].getIntValue(),
|
||||
timeTokens[1].getIntValue());
|
||||
}
|
||||
|
||||
|
||||
//==============================================================================
|
||||
//==============================================================================
|
||||
#if JUCE_UNIT_TESTS
|
||||
|
||||
class TimeTests : public UnitTest
|
||||
{
|
||||
public:
|
||||
TimeTests()
|
||||
: UnitTest ("Time", UnitTestCategories::time)
|
||||
{}
|
||||
|
||||
void runTest() override
|
||||
{
|
||||
beginTest ("Time");
|
||||
|
||||
Time t = Time::getCurrentTime();
|
||||
expect (t > Time());
|
||||
|
||||
Thread::sleep (15);
|
||||
expect (Time::getCurrentTime() > t);
|
||||
|
||||
expect (t.getTimeZone().isNotEmpty());
|
||||
expect (t.getUTCOffsetString (true) == "Z" || t.getUTCOffsetString (true).length() == 6);
|
||||
expect (t.getUTCOffsetString (false) == "Z" || t.getUTCOffsetString (false).length() == 5);
|
||||
|
||||
expect (Time::fromISO8601 (t.toISO8601 (true)) == t);
|
||||
expect (Time::fromISO8601 (t.toISO8601 (false)) == t);
|
||||
|
||||
expect (Time::fromISO8601 ("2016-02-16") == Time (2016, 1, 16, 0, 0, 0, 0, false));
|
||||
expect (Time::fromISO8601 ("20160216Z") == Time (2016, 1, 16, 0, 0, 0, 0, false));
|
||||
|
||||
expect (Time::fromISO8601 ("2016-02-16T15:03:57+00:00") == Time (2016, 1, 16, 15, 3, 57, 0, false));
|
||||
expect (Time::fromISO8601 ("20160216T150357+0000") == Time (2016, 1, 16, 15, 3, 57, 0, false));
|
||||
|
||||
expect (Time::fromISO8601 ("2016-02-16T15:03:57.999+00:00") == Time (2016, 1, 16, 15, 3, 57, 999, false));
|
||||
expect (Time::fromISO8601 ("20160216T150357.999+0000") == Time (2016, 1, 16, 15, 3, 57, 999, false));
|
||||
expect (Time::fromISO8601 ("2016-02-16T15:03:57.999Z") == Time (2016, 1, 16, 15, 3, 57, 999, false));
|
||||
expect (Time::fromISO8601 ("2016-02-16T15:03:57,999Z") == Time (2016, 1, 16, 15, 3, 57, 999, false));
|
||||
expect (Time::fromISO8601 ("20160216T150357.999Z") == Time (2016, 1, 16, 15, 3, 57, 999, false));
|
||||
expect (Time::fromISO8601 ("20160216T150357,999Z") == Time (2016, 1, 16, 15, 3, 57, 999, false));
|
||||
|
||||
expect (Time::fromISO8601 ("2016-02-16T15:03:57.999-02:30") == Time (2016, 1, 16, 17, 33, 57, 999, false));
|
||||
expect (Time::fromISO8601 ("2016-02-16T15:03:57,999-02:30") == Time (2016, 1, 16, 17, 33, 57, 999, false));
|
||||
expect (Time::fromISO8601 ("20160216T150357.999-0230") == Time (2016, 1, 16, 17, 33, 57, 999, false));
|
||||
expect (Time::fromISO8601 ("20160216T150357,999-0230") == Time (2016, 1, 16, 17, 33, 57, 999, false));
|
||||
|
||||
expect (Time (1970, 0, 1, 0, 0, 0, 0, false) == Time (0));
|
||||
expect (Time (2106, 1, 7, 6, 28, 15, 0, false) == Time (4294967295000));
|
||||
expect (Time (2007, 10, 7, 1, 7, 20, 0, false) == Time (1194397640000));
|
||||
expect (Time (2038, 0, 19, 3, 14, 7, 0, false) == Time (2147483647000));
|
||||
expect (Time (2016, 2, 7, 11, 20, 8, 0, false) == Time (1457349608000));
|
||||
expect (Time (1969, 11, 31, 23, 59, 59, 0, false) == Time (-1000));
|
||||
expect (Time (1901, 11, 13, 20, 45, 53, 0, false) == Time (-2147483647000));
|
||||
|
||||
expect (Time (1982, 1, 1, 12, 0, 0, 0, true) + RelativeTime::days (365) == Time (1983, 1, 1, 12, 0, 0, 0, true));
|
||||
expect (Time (1970, 1, 1, 12, 0, 0, 0, true) + RelativeTime::days (365) == Time (1971, 1, 1, 12, 0, 0, 0, true));
|
||||
expect (Time (2038, 1, 1, 12, 0, 0, 0, true) + RelativeTime::days (365) == Time (2039, 1, 1, 12, 0, 0, 0, true));
|
||||
|
||||
expect (Time (1982, 1, 1, 12, 0, 0, 0, false) + RelativeTime::days (365) == Time (1983, 1, 1, 12, 0, 0, 0, false));
|
||||
expect (Time (1970, 1, 1, 12, 0, 0, 0, false) + RelativeTime::days (365) == Time (1971, 1, 1, 12, 0, 0, 0, false));
|
||||
expect (Time (2038, 1, 1, 12, 0, 0, 0, false) + RelativeTime::days (365) == Time (2039, 1, 1, 12, 0, 0, 0, false));
|
||||
}
|
||||
};
|
||||
|
||||
static TimeTests timeTests;
|
||||
|
||||
#endif
|
||||
|
||||
} // namespace juce
|
401
deps/juce/modules/juce_core/time/juce_Time.h
vendored
Normal file
401
deps/juce/modules/juce_core/time/juce_Time.h
vendored
Normal file
@ -0,0 +1,401 @@
|
||||
/*
|
||||
==============================================================================
|
||||
|
||||
This file is part of the JUCE library.
|
||||
Copyright (c) 2020 - Raw Material Software Limited
|
||||
|
||||
JUCE is an open source library subject to commercial or open-source
|
||||
licensing.
|
||||
|
||||
The code included in this file is provided under the terms of the ISC license
|
||||
http://www.isc.org/downloads/software-support-policy/isc-license. Permission
|
||||
To use, copy, modify, and/or distribute this software for any purpose with or
|
||||
without fee is hereby granted provided that the above copyright notice and
|
||||
this permission notice appear in all copies.
|
||||
|
||||
JUCE IS PROVIDED "AS IS" WITHOUT ANY WARRANTY, AND ALL WARRANTIES, WHETHER
|
||||
EXPRESSED OR IMPLIED, INCLUDING MERCHANTABILITY AND FITNESS FOR PURPOSE, ARE
|
||||
DISCLAIMED.
|
||||
|
||||
==============================================================================
|
||||
*/
|
||||
|
||||
namespace juce
|
||||
{
|
||||
|
||||
//==============================================================================
|
||||
/**
|
||||
Holds an absolute date and time.
|
||||
|
||||
Internally, the time is stored at millisecond precision.
|
||||
|
||||
@see RelativeTime
|
||||
|
||||
@tags{Core}
|
||||
*/
|
||||
class JUCE_API Time
|
||||
{
|
||||
public:
|
||||
//==============================================================================
|
||||
/** Creates a Time object.
|
||||
This default constructor creates a time of midnight Jan 1st 1970 UTC, (which is
|
||||
represented internally as 0ms).
|
||||
To create a time object representing the current time, use getCurrentTime().
|
||||
@see getCurrentTime
|
||||
*/
|
||||
Time() = default;
|
||||
|
||||
/** Creates a time based on a number of milliseconds.
|
||||
To create a time object set to the current time, use getCurrentTime().
|
||||
|
||||
@param millisecondsSinceEpoch the number of milliseconds since the unix
|
||||
'epoch' (midnight Jan 1st 1970 UTC).
|
||||
@see getCurrentTime, currentTimeMillis
|
||||
*/
|
||||
explicit Time (int64 millisecondsSinceEpoch) noexcept;
|
||||
|
||||
/** Creates a time from a set of date components.
|
||||
|
||||
@param year the year, in 4-digit format, e.g. 2004
|
||||
@param month the month, in the range 0 to 11
|
||||
@param day the day of the month, in the range 1 to 31
|
||||
@param hours hours in 24-hour clock format, 0 to 23
|
||||
@param minutes minutes 0 to 59
|
||||
@param seconds seconds 0 to 59
|
||||
@param milliseconds milliseconds 0 to 999
|
||||
@param useLocalTime if true, assume input is in this machine's local timezone
|
||||
if false, assume input is in UTC.
|
||||
*/
|
||||
Time (int year,
|
||||
int month,
|
||||
int day,
|
||||
int hours,
|
||||
int minutes,
|
||||
int seconds = 0,
|
||||
int milliseconds = 0,
|
||||
bool useLocalTime = true) noexcept;
|
||||
|
||||
Time (const Time&) = default;
|
||||
~Time() = default;
|
||||
|
||||
Time& operator= (const Time&) = default;
|
||||
|
||||
//==============================================================================
|
||||
/** Returns a Time object that is set to the current system time.
|
||||
|
||||
This may not be monotonic, as the system time can change at any moment.
|
||||
You should therefore not use this method for measuring time intervals.
|
||||
|
||||
@see currentTimeMillis
|
||||
*/
|
||||
static Time JUCE_CALLTYPE getCurrentTime() noexcept;
|
||||
|
||||
/** Returns the time as a number of milliseconds.
|
||||
@returns the number of milliseconds this Time object represents, since
|
||||
midnight Jan 1st 1970 UTC.
|
||||
@see getMilliseconds
|
||||
*/
|
||||
int64 toMilliseconds() const noexcept { return millisSinceEpoch; }
|
||||
|
||||
/** Returns the year (in this machine's local timezone).
|
||||
A 4-digit format is used, e.g. 2004.
|
||||
*/
|
||||
int getYear() const noexcept;
|
||||
|
||||
/** Returns the number of the month (in this machine's local timezone).
|
||||
The value returned is in the range 0 to 11.
|
||||
@see getMonthName
|
||||
*/
|
||||
int getMonth() const noexcept;
|
||||
|
||||
/** Returns the name of the month (in this machine's local timezone).
|
||||
@param threeLetterVersion if true, it'll be a 3-letter abbreviation, e.g. "Jan"; if false
|
||||
it'll return the long form, e.g. "January"
|
||||
@see getMonth
|
||||
*/
|
||||
String getMonthName (bool threeLetterVersion) const;
|
||||
|
||||
/** Returns the day of the month (in this machine's local timezone).
|
||||
The value returned is in the range 1 to 31.
|
||||
*/
|
||||
int getDayOfMonth() const noexcept;
|
||||
|
||||
/** Returns the number of the day of the week (in this machine's local timezone).
|
||||
The value returned is in the range 0 to 6 (0 = sunday, 1 = monday, etc).
|
||||
*/
|
||||
int getDayOfWeek() const noexcept;
|
||||
|
||||
/** Returns the number of the day of the year (in this machine's local timezone).
|
||||
The value returned is in the range 0 to 365.
|
||||
*/
|
||||
int getDayOfYear() const noexcept;
|
||||
|
||||
/** Returns the name of the weekday (in this machine's local timezone).
|
||||
@param threeLetterVersion if true, it'll return a 3-letter abbreviation, e.g. "Tue"; if
|
||||
false, it'll return the full version, e.g. "Tuesday".
|
||||
*/
|
||||
String getWeekdayName (bool threeLetterVersion) const;
|
||||
|
||||
/** Returns the number of hours since midnight (in this machine's local timezone).
|
||||
This is in 24-hour clock format, in the range 0 to 23.
|
||||
@see getHoursInAmPmFormat, isAfternoon
|
||||
*/
|
||||
int getHours() const noexcept;
|
||||
|
||||
/** Returns true if the time is in the afternoon (in this machine's local timezone).
|
||||
@returns true for "PM", false for "AM".
|
||||
@see getHoursInAmPmFormat, getHours
|
||||
*/
|
||||
bool isAfternoon() const noexcept;
|
||||
|
||||
/** Returns the hours in 12-hour clock format (in this machine's local timezone).
|
||||
This will return a value 1 to 12 - use isAfternoon() to find out
|
||||
whether this is in the afternoon or morning.
|
||||
@see getHours, isAfternoon
|
||||
*/
|
||||
int getHoursInAmPmFormat() const noexcept;
|
||||
|
||||
/** Returns the number of minutes, 0 to 59 (in this machine's local timezone). */
|
||||
int getMinutes() const noexcept;
|
||||
|
||||
/** Returns the number of seconds, 0 to 59. */
|
||||
int getSeconds() const noexcept;
|
||||
|
||||
/** Returns the number of milliseconds, 0 to 999.
|
||||
|
||||
Unlike toMilliseconds(), this just returns the position within the
|
||||
current second rather than the total number since the epoch.
|
||||
|
||||
@see toMilliseconds
|
||||
*/
|
||||
int getMilliseconds() const noexcept;
|
||||
|
||||
/** Returns true if the local timezone uses a daylight saving correction. */
|
||||
bool isDaylightSavingTime() const noexcept;
|
||||
|
||||
//==============================================================================
|
||||
/** Returns a 3-character string to indicate the local timezone. */
|
||||
String getTimeZone() const;
|
||||
|
||||
/** Returns the local timezone offset from UTC in seconds. */
|
||||
int getUTCOffsetSeconds() const noexcept;
|
||||
|
||||
/** Returns a string to indicate the offset of the local timezone from UTC.
|
||||
@returns "+XX:XX", "-XX:XX" or "Z"
|
||||
@param includeDividerCharacters whether to include or omit the ":" divider in the string
|
||||
*/
|
||||
String getUTCOffsetString (bool includeDividerCharacters) const;
|
||||
|
||||
//==============================================================================
|
||||
/** Returns a string version of this date and time, using this machine's local timezone.
|
||||
|
||||
For a more powerful way of formatting the date and time, see the formatted() method.
|
||||
|
||||
@param includeDate whether to include the date in the string
|
||||
@param includeTime whether to include the time in the string
|
||||
@param includeSeconds if the time is being included, this provides an option not to include
|
||||
the seconds in it
|
||||
@param use24HourClock if the time is being included, sets whether to use am/pm or 24
|
||||
hour notation.
|
||||
@see formatted
|
||||
*/
|
||||
String toString (bool includeDate,
|
||||
bool includeTime,
|
||||
bool includeSeconds = true,
|
||||
bool use24HourClock = false) const;
|
||||
|
||||
/** Converts this date/time to a string with a user-defined format.
|
||||
|
||||
This uses the C strftime() function to format this time as a string. To save you
|
||||
looking it up, these are the escape codes that strftime uses (other codes might
|
||||
work on some platforms and not others, but these are the common ones):
|
||||
|
||||
- %a is replaced by the locale's abbreviated weekday name.
|
||||
- %A is replaced by the locale's full weekday name.
|
||||
- %b is replaced by the locale's abbreviated month name.
|
||||
- %B is replaced by the locale's full month name.
|
||||
- %c is replaced by the locale's appropriate date and time representation.
|
||||
- %d is replaced by the day of the month as a decimal number [01,31].
|
||||
- %H is replaced by the hour (24-hour clock) as a decimal number [00,23].
|
||||
- %I is replaced by the hour (12-hour clock) as a decimal number [01,12].
|
||||
- %j is replaced by the day of the year as a decimal number [001,366].
|
||||
- %m is replaced by the month as a decimal number [01,12].
|
||||
- %M is replaced by the minute as a decimal number [00,59].
|
||||
- %p is replaced by the locale's equivalent of either a.m. or p.m.
|
||||
- %S is replaced by the second as a decimal number [00,60].
|
||||
- %U is replaced by the week number of the year (Sunday as the first day of the week) as a decimal number [00,53].
|
||||
- %w is replaced by the weekday as a decimal number [0,6], with 0 representing Sunday.
|
||||
- %W is replaced by the week number of the year (Monday as the first day of the week) as a decimal number [00,53]. All days in a new year preceding the first Monday are considered to be in week 0.
|
||||
- %x is replaced by the locale's appropriate date representation.
|
||||
- %X is replaced by the locale's appropriate time representation.
|
||||
- %y is replaced by the year without century as a decimal number [00,99].
|
||||
- %Y is replaced by the year with century as a decimal number.
|
||||
- %Z is replaced by the timezone name or abbreviation, or by no bytes if no timezone information exists.
|
||||
- %% is replaced by %.
|
||||
|
||||
@see toString
|
||||
*/
|
||||
String formatted (const String& format) const;
|
||||
|
||||
//==============================================================================
|
||||
/** Returns a fully described string of this date and time in ISO-8601 format
|
||||
(using the local timezone).
|
||||
|
||||
@param includeDividerCharacters whether to include or omit the "-" and ":"
|
||||
dividers in the string
|
||||
*/
|
||||
String toISO8601 (bool includeDividerCharacters) const;
|
||||
|
||||
/** Parses an ISO-8601 string and returns it as a Time. */
|
||||
static Time fromISO8601 (StringRef iso8601);
|
||||
|
||||
//==============================================================================
|
||||
/** Adds a RelativeTime to this time. */
|
||||
Time& operator+= (RelativeTime delta) noexcept;
|
||||
/** Subtracts a RelativeTime from this time. */
|
||||
Time& operator-= (RelativeTime delta) noexcept;
|
||||
|
||||
//==============================================================================
|
||||
/** Tries to set the computer's clock.
|
||||
|
||||
@returns true if this succeeds, although depending on the system, the
|
||||
application might not have sufficient privileges to do this.
|
||||
*/
|
||||
bool setSystemTimeToThisTime() const;
|
||||
|
||||
//==============================================================================
|
||||
/** Returns the name of a day of the week.
|
||||
|
||||
@param dayNumber the day, 0 to 6 (0 = sunday, 1 = monday, etc)
|
||||
@param threeLetterVersion if true, it'll return a 3-letter abbreviation, e.g. "Tue"; if
|
||||
false, it'll return the full version, e.g. "Tuesday".
|
||||
*/
|
||||
static String getWeekdayName (int dayNumber, bool threeLetterVersion);
|
||||
|
||||
/** Returns the name of one of the months.
|
||||
|
||||
@param monthNumber the month, 0 to 11
|
||||
@param threeLetterVersion if true, it'll be a 3-letter abbreviation, e.g. "Jan"; if false
|
||||
it'll return the long form, e.g. "January"
|
||||
*/
|
||||
static String getMonthName (int monthNumber, bool threeLetterVersion);
|
||||
|
||||
//==============================================================================
|
||||
// Static methods for getting system timers directly..
|
||||
|
||||
/** Returns the current system time.
|
||||
|
||||
Returns the number of milliseconds since midnight Jan 1st 1970 UTC.
|
||||
|
||||
Should be accurate to within a few millisecs, depending on platform,
|
||||
hardware, etc.
|
||||
*/
|
||||
static int64 currentTimeMillis() noexcept;
|
||||
|
||||
/** Returns the number of millisecs since a fixed event (usually system startup).
|
||||
|
||||
This returns a monotonically increasing value which is unaffected by changes to the
|
||||
system clock. It should be accurate to within a few millisecs, depending on platform,
|
||||
hardware, etc.
|
||||
|
||||
Being a 32-bit return value, it will of course wrap back to 0 after 2^32 seconds of
|
||||
uptime, so be careful to take that into account. If you need a 64-bit time, you can
|
||||
use currentTimeMillis() instead.
|
||||
|
||||
@see getApproximateMillisecondCounter
|
||||
*/
|
||||
static uint32 getMillisecondCounter() noexcept;
|
||||
|
||||
/** Returns the number of millisecs since a fixed event (usually system startup).
|
||||
|
||||
This has the same function as getMillisecondCounter(), but returns a more accurate
|
||||
value, using a higher-resolution timer if one is available.
|
||||
|
||||
@see getMillisecondCounter
|
||||
*/
|
||||
static double getMillisecondCounterHiRes() noexcept;
|
||||
|
||||
/** Waits until the getMillisecondCounter() reaches a given value.
|
||||
|
||||
This will make the thread sleep as efficiently as it can while it's waiting.
|
||||
*/
|
||||
static void waitForMillisecondCounter (uint32 targetTime) noexcept;
|
||||
|
||||
/** Less-accurate but faster version of getMillisecondCounter().
|
||||
|
||||
This will return the last value that getMillisecondCounter() returned, so doesn't
|
||||
need to make a system call, but is less accurate - it shouldn't be more than
|
||||
100ms away from the correct time, though, so is still accurate enough for a
|
||||
lot of purposes.
|
||||
|
||||
@see getMillisecondCounter
|
||||
*/
|
||||
static uint32 getApproximateMillisecondCounter() noexcept;
|
||||
|
||||
//==============================================================================
|
||||
// High-resolution timers..
|
||||
|
||||
/** Returns the current high-resolution counter's tick-count.
|
||||
|
||||
This is a similar idea to getMillisecondCounter(), but with a higher
|
||||
resolution.
|
||||
|
||||
@see getHighResolutionTicksPerSecond, highResolutionTicksToSeconds,
|
||||
secondsToHighResolutionTicks
|
||||
*/
|
||||
static int64 getHighResolutionTicks() noexcept;
|
||||
|
||||
/** Returns the resolution of the high-resolution counter in ticks per second.
|
||||
|
||||
@see getHighResolutionTicks, highResolutionTicksToSeconds,
|
||||
secondsToHighResolutionTicks
|
||||
*/
|
||||
static int64 getHighResolutionTicksPerSecond() noexcept;
|
||||
|
||||
/** Converts a number of high-resolution ticks into seconds.
|
||||
|
||||
@see getHighResolutionTicks, getHighResolutionTicksPerSecond,
|
||||
secondsToHighResolutionTicks
|
||||
*/
|
||||
static double highResolutionTicksToSeconds (int64 ticks) noexcept;
|
||||
|
||||
/** Converts a number seconds into high-resolution ticks.
|
||||
|
||||
@see getHighResolutionTicks, getHighResolutionTicksPerSecond,
|
||||
highResolutionTicksToSeconds
|
||||
*/
|
||||
static int64 secondsToHighResolutionTicks (double seconds) noexcept;
|
||||
|
||||
/** Returns a Time based on the value of the __DATE__ macro when this module was compiled */
|
||||
static Time getCompilationDate();
|
||||
|
||||
private:
|
||||
//==============================================================================
|
||||
int64 millisSinceEpoch = 0;
|
||||
};
|
||||
|
||||
//==============================================================================
|
||||
/** Adds a RelativeTime to a Time. */
|
||||
JUCE_API Time operator+ (Time time, RelativeTime delta) noexcept;
|
||||
/** Adds a RelativeTime to a Time. */
|
||||
JUCE_API Time operator+ (RelativeTime delta, Time time) noexcept;
|
||||
|
||||
/** Subtracts a RelativeTime from a Time. */
|
||||
JUCE_API Time operator- (Time time, RelativeTime delta) noexcept;
|
||||
/** Returns the relative time difference between two times. */
|
||||
JUCE_API const RelativeTime operator- (Time time1, Time time2) noexcept;
|
||||
|
||||
/** Compares two Time objects. */
|
||||
JUCE_API bool operator== (Time time1, Time time2) noexcept;
|
||||
/** Compares two Time objects. */
|
||||
JUCE_API bool operator!= (Time time1, Time time2) noexcept;
|
||||
/** Compares two Time objects. */
|
||||
JUCE_API bool operator< (Time time1, Time time2) noexcept;
|
||||
/** Compares two Time objects. */
|
||||
JUCE_API bool operator<= (Time time1, Time time2) noexcept;
|
||||
/** Compares two Time objects. */
|
||||
JUCE_API bool operator> (Time time1, Time time2) noexcept;
|
||||
/** Compares two Time objects. */
|
||||
JUCE_API bool operator>= (Time time1, Time time2) noexcept;
|
||||
|
||||
} // namespace juce
|
Reference in New Issue
Block a user