X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fvideo_examiner.h;h=4e5c6dc0a322c3fd57c024aa6611775178a68226;hb=54af50c3b8e9082f9751e809d63540c51197a4a1;hp=98c0cdff1433d21e0ad0106c994bf06762f6ffd8;hpb=8353a009aae1a604251c0160193c39741c2fa27c;p=dcpomatic.git diff --git a/src/lib/video_examiner.h b/src/lib/video_examiner.h index 98c0cdff1..4e5c6dc0a 100644 --- a/src/lib/video_examiner.h +++ b/src/lib/video_examiner.h @@ -1,31 +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 ~VideoExaminer () {} - virtual float video_frame_rate () const = 0; - virtual libdcp::Size video_size () const = 0; - virtual VideoFrame video_length () const = 0; + + 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; };