projects
/
dcpomatic.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Merge branch 'master' of /home/carl/git/dvdomatic
[dcpomatic.git]
/
src
/
lib
/
processor.h
diff --git
a/src/lib/processor.h
b/src/lib/processor.h
index cddcbf3f10fe47a466342fbb756e7a62b7758e38..603239f8ff7094ebadb0a09d22304654d88cb427 100644
(file)
--- a/
src/lib/processor.h
+++ b/
src/lib/processor.h
@@
-37,15
+37,20
@@
class Log;
class Processor
{
public:
class Processor
{
public:
- Processor (Log* log)
+ /** Construct a Processor.
+ * @param log Log to use.
+ */
+ Processor (boost::shared_ptr<Log> log)
: _log (log)
{}
: _log (log)
{}
-
- virtual void process_begin () {}
+
+ virtual ~Processor() {}
+
+ /** Will be called at the end of a processing run */
virtual void process_end () {}
protected:
virtual void process_end () {}
protected:
- Log* _log;
+ boost::shared_ptr<Log> _log; ///< log to write to
};
/** @class AudioVideoProcessor
};
/** @class AudioVideoProcessor
@@
-54,18
+59,33
@@
protected:
class AudioVideoProcessor : public Processor, public VideoSource, public VideoSink, public AudioSource, public AudioSink
{
public:
class AudioVideoProcessor : public Processor, public VideoSource, public VideoSink, public AudioSource, public AudioSink
{
public:
- AudioVideoProcessor (Log* log)
+ /** Construct an AudioVideoProcessor.
+ * @param log Log to write to.
+ */
+ AudioVideoProcessor (boost::shared_ptr<Log> log)
: Processor (log)
{}
};
: Processor (log)
{}
};
+class TimedAudioVideoProcessor : public Processor, public TimedVideoSource, public TimedVideoSink, public TimedAudioSource, public TimedAudioSink
+{
+public:
+ TimedAudioVideoProcessor (boost::shared_ptr<Log> log)
+ : Processor (log)
+ {}
+};
+
+
/** @class AudioProcessor
* @brief A processor which handles just audio data.
*/
class AudioProcessor : public Processor, public AudioSource, public AudioSink
{
public:
/** @class AudioProcessor
* @brief A processor which handles just audio data.
*/
class AudioProcessor : public Processor, public AudioSource, public AudioSink
{
public:
- AudioProcessor (Log* log)
+ /** Construct an AudioProcessor.
+ * @param log Log to write to.
+ */
+ AudioProcessor (boost::shared_ptr<Log> log)
: Processor (log)
{}
};
: Processor (log)
{}
};
@@
-76,9
+96,20
@@
public:
class VideoProcessor : public Processor, public VideoSource, public VideoSink
{
public:
class VideoProcessor : public Processor, public VideoSource, public VideoSink
{
public:
- VideoProcessor (Log* log)
+ /** Construct an VideoProcessor.
+ * @param log Log to write to.
+ */
+ VideoProcessor (boost::shared_ptr<Log> log)
: Processor (log)
{}
};
: Processor (log)
{}
};
+class TimedVideoProcessor : public Processor, public TimedVideoSource, public TimedVideoSink
+{
+public:
+ TimedVideoProcessor (boost::shared_ptr<Log> log)
+ : Processor (log)
+ {}
+};
+
#endif
#endif