X-Git-Url: https://main.carlh.net/gitweb/?p=dcpomatic.git;a=blobdiff_plain;f=src%2Flib%2Fvideo_examiner.h;h=4e5c6dc0a322c3fd57c024aa6611775178a68226;hp=72f6ccc12cab575f2a20e297ecdfed5bbb967344;hb=da44da6f31f97d39ca91c35955e573e76371f2c2;hpb=09a9ac376db005a40a351736bcff4077f098825d diff --git a/src/lib/video_examiner.h b/src/lib/video_examiner.h index 72f6ccc12..4e5c6dc0a 100644 --- a/src/lib/video_examiner.h +++ b/src/lib/video_examiner.h @@ -1,30 +1,52 @@ /* - Copyright (C) 2013 Carl Hetherington + Copyright (C) 2013-2016 Carl Hetherington - This program is free software; you can redistribute it and/or modify + This file is part of DCP-o-matic. + + DCP-o-matic 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. - This program is distributed in the hope that it will be useful, + DCP-o-matic 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. You should have received a copy of the GNU General Public License - along with this program; if not, write to the Free Software - Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. + along with DCP-o-matic. If not, see . */ -#include +/** @file src/lib/video_examiner.h + * @brief VideoExaminer class. + */ + #include "types.h" #include "video_content.h" +#include +/** @class VideoExaminer + * @brief Parent for classes which examine video sources and obtain information about them. + */ class VideoExaminer { public: - virtual float video_frame_rate () const = 0; - virtual libdcp::Size video_size () const = 0; - virtual VideoContent::Frame video_length () const = 0; + virtual ~VideoExaminer () {} + + virtual bool has_video () const = 0; + + /** @return video frame rate (if known); must not be called if has_video() == false */ + virtual boost::optional video_frame_rate () const = 0; + /** @return video size; must not be called if has_video() == false */ + virtual dcp::Size video_size () const = 0; + /** @return video length in frames; must not be called if has_video() == false */ + virtual Frame video_length () const = 0; + /** @return video sample aspect ratio (if known); must not be called if has_video() == false */ + virtual boost::optional sample_aspect_ratio () const { + return boost::optional (); + } + /** @return true if this video is in YUV; must not be called if has_video() == false */ + virtual bool yuv () const = 0; + virtual VideoRange range () const = 0; };