Add FrameInfo::write for FILE *; test it.
[libdcp.git] / src / picture_asset_writer.h
1 /*
2     Copyright (C) 2012-2013 Carl Hetherington <cth@carlh.net>
3
4     This program is free software; you can redistribute it and/or modify
5     it under the terms of the GNU General Public License as published by
6     the Free Software Foundation; either version 2 of the License, or
7     (at your option) any later version.
8
9     This program is distributed in the hope that it will be useful,
10     but WITHOUT ANY WARRANTY; without even the implied warranty of
11     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12     GNU General Public License for more details.
13
14     You should have received a copy of the GNU General Public License
15     along with this program; if not, write to the Free Software
16     Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
17
18 */
19
20 #include <stdint.h>
21 #include <string>
22 #include <fstream>
23 #include <boost/shared_ptr.hpp>
24 #include <boost/utility.hpp>
25 #include "metadata.h"
26 #include "types.h"
27
28 namespace libdcp {
29
30 class PictureAsset;     
31
32 struct FrameInfo
33 {
34         FrameInfo (uint64_t o, uint64_t s, std::string h)
35                 : offset (o)
36                 , size (s)
37                 , hash (h)
38         {}
39
40         FrameInfo (std::istream& s);
41
42         void write (std::ostream& s) const;
43         void write (FILE *) const;
44         
45         uint64_t offset;
46         uint64_t size;
47         std::string hash;
48 };
49
50 class PictureAssetWriter : public boost::noncopyable
51 {
52 public:
53         virtual ~PictureAssetWriter () {}
54         virtual FrameInfo write (uint8_t *, int) = 0;
55         virtual void finalize () = 0;
56         virtual void fake_write (int) = 0;
57         
58 protected:
59         template <class P, class Q>
60         friend void start (PictureAssetWriter *, boost::shared_ptr<P>, Q *, uint8_t *, int);
61
62         PictureAssetWriter (PictureAsset *, bool);
63
64         PictureAsset* _asset;
65         
66         /** Number of picture frames written to the asset so far.  For stereo assets
67          *  this will be incremented for each eye (i.e. there will be twice the number
68          *  of frames as in a mono asset).
69          */
70         int _frames_written;
71         bool _started;
72         /** true if finalize() has been called */
73         bool _finalized;
74         bool _overwrite;
75 };
76
77 }