Some comments; fix up a UUID I think.
[libdcp.git] / src / asset.cc
1 /*
2     Copyright (C) 2012 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 <iostream>
21 #include <boost/filesystem.hpp>
22 #include "AS_DCP.h"
23 #include "KM_util.h"
24 #include "asset.h"
25 #include "util.h"
26 #include "tags.h"
27
28 using namespace std;
29 using namespace boost;
30 using namespace libdcp;
31
32 /** Construct an Asset.
33  *  @param p Pathname of MXF file.
34  *  @param fps Frames per second.
35  *  @param len Length in frames.
36  */
37
38 Asset::Asset (string p, int fps, int len)
39         : _mxf_path (p)
40         , _fps (fps)
41         , _length (len)
42         , _uuid (make_uuid ())
43 {
44         
45 }
46
47 /** Write details of the asset to a PKL stream.
48  *  @param s Stream.
49  */
50 void
51 Asset::write_to_pkl (ostream& s) const
52 {
53         s << "    <Asset>\n"
54           << "      <Id>urn:uuid:" << _uuid << "</Id>\n"
55           << "      <AnnotationText>" << filesystem::path(_mxf_path).filename() << "</AnnotationText>\n"
56           << "      <Hash>" << _digest << "</Hash>\n"
57           << "      <Size>" << filesystem::file_size(_mxf_path) << "</Size>\n"
58           << "      <Type>application/mxf</Type>\n"
59           << "    </Asset>\n";
60 }
61
62 /** Write details of the asset to a ASSETMAP stream.
63  *  @param s Stream.
64  */
65 void
66 Asset::write_to_assetmap (ostream& s) const
67 {
68         s << "    <Asset>\n"
69           << "      <Id>urn:uuid:" << _uuid << "</Id>\n"
70           << "      <ChunkList>\n"
71           << "        <Chunk>\n"
72           << "          <Path>" << filesystem::path(_mxf_path).filename() << "</Path>\n"
73           << "          <VolumeIndex>1</VolumeIndex>\n"
74           << "          <Offset>0</Offset>\n"
75           << "          <Length>" << filesystem::file_size(_mxf_path) << "</Length>\n"
76           << "        </Chunk>\n"
77           << "      </ChunkList>\n"
78           << "    </Asset>\n";
79 }
80
81 /** Fill in a ADSCP::WriteInfo struct */
82 void
83 Asset::fill_writer_info (ASDCP::WriterInfo* writer_info) const
84 {
85         writer_info->ProductVersion = Tags::instance()->product_version;
86         writer_info->CompanyName = Tags::instance()->company_name;
87         writer_info->ProductName = Tags::instance()->product_name.c_str();
88
89         writer_info->LabelSetType = ASDCP::LS_MXF_SMPTE;
90         unsigned int c;
91         Kumu::hex2bin (_uuid.c_str(), writer_info->AssetUUID, Kumu::UUID_Length, &c);
92         assert (c == Kumu::UUID_Length);
93 }