projects
/
dcpomatic.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
No-op; fix GPL address and use the explicit-program-name version.
[dcpomatic.git]
/
src
/
lib
/
film.h
diff --git
a/src/lib/film.h
b/src/lib/film.h
index da1c09d2fa5739e2f209b2d9cb3bb97831ea2769..3b33aa3058d3c37eb707a1f48b60db3190dd9cee 100644
(file)
--- a/
src/lib/film.h
+++ b/
src/lib/film.h
@@
-1,19
+1,20
@@
/*
/*
- Copyright (C) 2012-201
5
Carl Hetherington <cth@carlh.net>
+ Copyright (C) 2012-201
6
Carl Hetherington <cth@carlh.net>
- 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.
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
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 <http://www.gnu.org/licenses/>.
*/
*/
@@
-30,7
+31,6
@@
#include "isdcf_metadata.h"
#include "frame_rate_change.h"
#include "signaller.h"
#include "isdcf_metadata.h"
#include "frame_rate_change.h"
#include "signaller.h"
-#include "ratio.h"
#include <dcp/key.h>
#include <dcp/encrypted_kdm.h>
#include <boost/signals2.hpp>
#include <dcp/key.h>
#include <dcp/encrypted_kdm.h>
#include <boost/signals2.hpp>
@@
-40,6
+40,10
@@
#include <vector>
#include <inttypes.h>
#include <vector>
#include <inttypes.h>
+namespace xmlpp {
+ class Document;
+}
+
class DCPContentType;
class Log;
class Content;
class DCPContentType;
class Log;
class Content;
@@
-49,6
+53,9
@@
class AudioContent;
class Screen;
class AudioProcessor;
class AudioMapping;
class Screen;
class AudioProcessor;
class AudioMapping;
+class Ratio;
+class Job;
+class ScreenKDM;
struct isdcf_name_test;
/** @class Film
struct isdcf_name_test;
/** @class Film
@@
-64,12
+71,12
@@
public:
Film (boost::filesystem::path, bool log = true);
~Film ();
Film (boost::filesystem::path, bool log = true);
~Film ();
- boost::filesystem::path info_file () const;
- boost::filesystem::path j2c_path (int, Eyes, bool) const;
+ boost::filesystem::path info_file (
DCPTimePeriod p
) const;
+ boost::filesystem::path j2c_path (int,
Frame,
Eyes, bool) const;
boost::filesystem::path internal_video_asset_dir () const;
boost::filesystem::path internal_video_asset_dir () const;
- boost::filesystem::path internal_video_asset_filename () const;
+ boost::filesystem::path internal_video_asset_filename (
DCPTimePeriod p
) const;
- boost::filesystem::path audio_analysis_path () const;
+ boost::filesystem::path audio_analysis_path (
boost::shared_ptr<const Playlist>
) const;
void send_dcp_to_tms ();
void make_dcp ();
void send_dcp_to_tms ();
void make_dcp ();
@@
-101,13
+108,11
@@
public:
std::vector<CPLSummary> cpls () const;
std::vector<CPLSummary> cpls () const;
- boost::shared_ptr<Playlist> playlist () const;
-
int audio_frame_rate () const;
uint64_t required_disk_space () const;
bool should_be_enough_disk_space (double& required, double& available, bool& can_hard_link) const;
int audio_frame_rate () const;
uint64_t required_disk_space () const;
bool should_be_enough_disk_space (double& required, double& available, bool& can_hard_link) const;
-
+
/* Proxies for some Playlist methods */
ContentList content () const;
/* Proxies for some Playlist methods */
ContentList content () const;
@@
-117,18
+122,19
@@
public:
dcp::EncryptedKDM
make_kdm (
dcp::EncryptedKDM
make_kdm (
- dcp::Certificate target,
+ dcp::Certificate recipient,
+ std::vector<dcp::Certificate> trusted_devices,
boost::filesystem::path cpl_file,
dcp::LocalTime from,
dcp::LocalTime until,
dcp::Formulation formulation
) const;
boost::filesystem::path cpl_file,
dcp::LocalTime from,
dcp::LocalTime until,
dcp::Formulation formulation
) const;
-
- std::list<
dcp::Encrypted
KDM> make_kdms (
+
+ std::list<
Screen
KDM> make_kdms (
std::list<boost::shared_ptr<Screen> >,
boost::filesystem::path cpl_file,
std::list<boost::shared_ptr<Screen> >,
boost::filesystem::path cpl_file,
-
dcp::LocalT
ime from,
-
dcp::LocalT
ime until,
+
boost::posix_time::pt
ime from,
+
boost::posix_time::pt
ime until,
dcp::Formulation formulation
) const;
dcp::Formulation formulation
) const;
@@
-141,6
+147,16
@@
public:
void make_audio_mapping_default (AudioMapping & mapping) const;
std::vector<std::string> audio_output_names () const;
void make_audio_mapping_default (AudioMapping & mapping) const;
std::vector<std::string> audio_output_names () const;
+ void repeat_content (ContentList, int);
+
+ boost::shared_ptr<const Playlist> playlist () const {
+ return _playlist;
+ }
+
+ std::list<DCPTimePeriod> reels () const;
+
+ std::list<int> mapped_audio_channels () const;
+
/** Identifiers for the parts of our state;
used for signalling changes.
*/
/** Identifiers for the parts of our state;
used for signalling changes.
*/
@@
-150,6
+166,8
@@
public:
USE_ISDCF_NAME,
/** The playlist's content list has changed (i.e. content has been added or removed) */
CONTENT,
USE_ISDCF_NAME,
/** The playlist's content list has changed (i.e. content has been added or removed) */
CONTENT,
+ /** The order of content in the playlist has changed */
+ CONTENT_ORDER,
DCP_CONTENT_TYPE,
CONTAINER,
RESOLUTION,
DCP_CONTENT_TYPE,
CONTAINER,
RESOLUTION,
@@
-162,11
+180,12
@@
public:
AUDIO_CHANNELS,
/** The setting of _three_d has changed */
THREE_D,
AUDIO_CHANNELS,
/** The setting of _three_d has changed */
THREE_D,
- SEQUENCE
_VIDEO
,
+ SEQUENCE,
INTEROP,
INTEROP,
- /** The setting of _burn_subtitles has changed */
- BURN_SUBTITLES,
AUDIO_PROCESSOR,
AUDIO_PROCESSOR,
+ REEL_TYPE,
+ REEL_LENGTH,
+ UPLOAD_AFTER_MAKE_DCP
};
};
@@
-200,7
+219,7
@@
public:
bool is_signed () const {
return _signed;
}
bool is_signed () const {
return _signed;
}
-
+
bool encrypted () const {
return _encrypted;
}
bool encrypted () const {
return _encrypted;
}
@@
-230,22
+249,29
@@
public:
return _three_d;
}
return _three_d;
}
- bool sequence
_video
() const {
- return _sequence
_video
;
+ bool sequence () const {
+ return _sequence;
}
bool interop () const {
return _interop;
}
}
bool interop () const {
return _interop;
}
- bool burn_subtitles () const {
- return _burn_subtitles;
- }
-
AudioProcessor const * audio_processor () const {
return _audio_processor;
}
AudioProcessor const * audio_processor () const {
return _audio_processor;
}
-
+
+ ReelType reel_type () const {
+ return _reel_type;
+ }
+
+ int64_t reel_length () const {
+ return _reel_length;
+ }
+
+ bool upload_after_make_dcp () const {
+ return _upload_after_make_dcp;
+ }
/* SET */
/* SET */
@@
-256,6
+282,7
@@
public:
void examine_and_add_content (boost::shared_ptr<Content>);
void add_content (boost::shared_ptr<Content>);
void remove_content (boost::shared_ptr<Content>);
void examine_and_add_content (boost::shared_ptr<Content>);
void add_content (boost::shared_ptr<Content>);
void remove_content (boost::shared_ptr<Content>);
+ void remove_content (ContentList);
void move_content_earlier (boost::shared_ptr<Content>);
void move_content_later (boost::shared_ptr<Content>);
void set_dcp_content_type (DCPContentType const *);
void move_content_earlier (boost::shared_ptr<Content>);
void move_content_later (boost::shared_ptr<Content>);
void set_dcp_content_type (DCPContentType const *);
@@
-270,10
+297,12
@@
public:
void set_audio_channels (int);
void set_three_d (bool);
void set_isdcf_date_today ();
void set_audio_channels (int);
void set_three_d (bool);
void set_isdcf_date_today ();
- void set_sequence
_video
(bool);
+ void set_sequence (bool);
void set_interop (bool);
void set_interop (bool);
- void set_burn_subtitles (bool);
void set_audio_processor (AudioProcessor const * processor);
void set_audio_processor (AudioProcessor const * processor);
+ void set_reel_type (ReelType);
+ void set_reel_length (int64_t);
+ void set_upload_after_make_dcp (bool);
/** Emitted when some property has of the Film has changed */
mutable boost::signals2::signal<void (Property)> Changed;
/** Emitted when some property has of the Film has changed */
mutable boost::signals2::signal<void (Property)> Changed;
@@
-291,9
+320,10
@@
private:
void signal_changed (Property);
std::string video_identifier () const;
void playlist_changed ();
void signal_changed (Property);
std::string video_identifier () const;
void playlist_changed ();
+ void playlist_order_changed ();
void playlist_content_changed (boost::weak_ptr<Content>, int, bool frequent);
void playlist_content_changed (boost::weak_ptr<Content>, int, bool frequent);
- std::string filename_safe_name () const;
void maybe_add_content (boost::weak_ptr<Job>, boost::weak_ptr<Content>);
void maybe_add_content (boost::weak_ptr<Job>, boost::weak_ptr<Content>);
+ void audio_analysis_finished ();
/** Log to write to */
boost::shared_ptr<Log> _log;
/** Log to write to */
boost::shared_ptr<Log> _log;
@@
-303,7
+333,7
@@
private:
* must not be relative.
*/
boost::filesystem::path _directory;
* must not be relative.
*/
boost::filesystem::path _directory;
-
+
/** Name for DCP-o-matic */
std::string _name;
/** True if a auto-generated ISDCF-compliant name should be used for our DCP */
/** Name for DCP-o-matic */
std::string _name;
/** True if a auto-generated ISDCF-compliant name should be used for our DCP */
@@
-331,10
+361,13
@@
private:
This will be regardless of what content is on the playlist.
*/
bool _three_d;
This will be regardless of what content is on the playlist.
*/
bool _three_d;
- bool _sequence
_video
;
+ bool _sequence;
bool _interop;
bool _interop;
- bool _burn_subtitles;
AudioProcessor const * _audio_processor;
AudioProcessor const * _audio_processor;
+ ReelType _reel_type;
+ /** Desired reel length in bytes, if _reel_type == REELTYPE_BY_LENGTH */
+ int64_t _reel_length;
+ bool _upload_after_make_dcp;
int _state_version;
int _state_version;
@@
-342,8
+375,10
@@
private:
mutable bool _dirty;
boost::signals2::scoped_connection _playlist_changed_connection;
mutable bool _dirty;
boost::signals2::scoped_connection _playlist_changed_connection;
+ boost::signals2::scoped_connection _playlist_order_changed_connection;
boost::signals2::scoped_connection _playlist_content_changed_connection;
std::list<boost::signals2::connection> _job_connections;
boost::signals2::scoped_connection _playlist_content_changed_connection;
std::list<boost::signals2::connection> _job_connections;
+ std::list<boost::signals2::connection> _audio_analysis_connections;
friend struct paths_test;
friend struct film_metadata_test;
friend struct paths_test;
friend struct film_metadata_test;