X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Faudio_mapping.h;h=f3096764c79c248ddb3bb0a0519efbd6caaa9f8f;hb=2e504b33eb9f38cac629ad31b7c107fb0cf5efda;hp=248d2570eca8a3eee084bfbfe4df957f85f55bf8;hpb=147cca5876dfbdf56e21289c3a36bec4b4850191;p=dcpomatic.git diff --git a/src/lib/audio_mapping.h b/src/lib/audio_mapping.h index 248d2570e..f3096764c 100644 --- a/src/lib/audio_mapping.h +++ b/src/lib/audio_mapping.h @@ -20,43 +20,48 @@ #ifndef DCPOMATIC_AUDIO_MAPPING_H #define DCPOMATIC_AUDIO_MAPPING_H -#include -#include -#include +#include +#include #include -#include "audio_content.h" +namespace xmlpp { + class Node; +} + +namespace cxml { + class Node; +} + +/** A many-to-many mapping from some content channels to DCP channels. + * The number of content channels is set on construction and fixed, + * and then each of those content channels are mapped to each DCP channel + * by a linear gain. + */ class AudioMapping { public: - void as_xml (xmlpp::Node *) const; - void set_from_xml (ContentList const &, boost::shared_ptr); + AudioMapping (); + AudioMapping (int); + AudioMapping (boost::shared_ptr, int); + + /* Default copy constructor is fine */ - struct Channel { - Channel (boost::weak_ptr c, int i) - : content (c) - , index (i) - {} - - boost::weak_ptr content; - int index; - }; - - void add (Channel, libdcp::Channel); - - int dcp_channels () const; - std::list dcp_to_content (libdcp::Channel) const; - std::list > content_to_dcp () const { - return _content_to_dcp; - } + void as_xml (xmlpp::Node *) const; - std::list content_channels () const; - std::list content_to_dcp (Channel) const; + void make_default (); + void set (int, dcp::Channel, float); + float get (int, dcp::Channel) const; + + int content_channels () const { + return _content_channels; + } + private: - std::list > _content_to_dcp; + void setup (int); + + int _content_channels; + std::vector > _gain; }; -extern bool operator== (AudioMapping::Channel const &, AudioMapping::Channel const &); - #endif