X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=libs%2Fevoral%2Fevoral%2FTimeConverter.hpp;h=23e0823ac9f7b34f04f90895ea0b2a076f7217b7;hb=07c08e46735a50476fc1a25698caae84f99078d4;hp=17c8b0766599a4a8c7ff45612039ea7c3f5a4c80;hpb=0906b39918ba0551044bd1f8c50e9de4d5aa1694;p=ardour.git diff --git a/libs/evoral/evoral/TimeConverter.hpp b/libs/evoral/evoral/TimeConverter.hpp index 17c8b07665..23e0823ac9 100644 --- a/libs/evoral/evoral/TimeConverter.hpp +++ b/libs/evoral/evoral/TimeConverter.hpp @@ -19,18 +19,27 @@ #ifndef EVORAL_TIME_CONVERTER_HPP #define EVORAL_TIME_CONVERTER_HPP +#include "evoral/visibility.h" + namespace Evoral { /** A bidirectional converter between two different time units. * * Think of the conversion method names as if they are written in-between * the two template parameters (i.e. "A B"). + * + * _origin_b should be the origin for conversion in the units of B. + * That is, there is some point in time _origin_b, such that: + * + * to() converts a time _origin_b + a into an offset from _origin_b in units of B. + * from() converts a time _origin_b + b into an offset from _origin_b in units of A. */ template -class TimeConverter { +class LIBEVORAL_TEMPLATE_API TimeConverter { public: - TimeConverter (B ob = 0) : _origin_b (ob) {} - virtual ~TimeConverter() {} + TimeConverter () : _origin_b (0) {} + TimeConverter (B ob) : _origin_b (ob) {} + virtual ~TimeConverter(); /** Convert A time to B time (A to B) */ virtual B to(A a) const = 0; @@ -51,11 +60,17 @@ protected: }; -/** A stub TimeConverter that simple statically casts between types. */ +/** A stub TimeConverter that simple statically casts between types. + * _origin_b has no bearing here, as there is no time conversion + * going on. + */ template -class IdentityConverter : public TimeConverter { - B to(A a) const { return static_cast(a); } - A from(B b) const { return static_cast(b); } +class LIBEVORAL_TEMPLATE_API IdentityConverter : public TimeConverter { + public: + IdentityConverter() {} + + B to(A a) const; + A from(B b) const; };