Merge master.
[dcpomatic.git] / src / lib / audio_mapping.h
index 8804bde06174f8e9669a02a81ff207ecbd76310a..a2de8306bbf376457788bb77884d4a523bbabee0 100644 (file)
 
 */
 
-#include <vector>
-#include <map>
-#include <boost/optional.hpp>
+#ifndef DCPOMATIC_AUDIO_MAPPING_H
+#define DCPOMATIC_AUDIO_MAPPING_H
+
+#include <list>
 #include <libdcp/types.h>
+#include <boost/shared_ptr.hpp>
+
+namespace xmlpp {
+       class Node;
+}
+
+namespace cxml {
+       class Node;
+}
 
 class AudioMapping
 {
 public:
-       virtual boost::optional<libdcp::Channel> source_to_dcp (int c) const = 0;
-       virtual boost::optional<int> dcp_to_source (libdcp::Channel c) const = 0;
-};
+       AudioMapping ();
+       AudioMapping (int);
+       AudioMapping (boost::shared_ptr<const cxml::Node>);
+       
+       void as_xml (xmlpp::Node *) const;
 
-class AutomaticAudioMapping : public AudioMapping
-{
-public:
-       AutomaticAudioMapping (int);
+       void add (int, libdcp::Channel);
 
-       boost::optional<libdcp::Channel> source_to_dcp (int c) const;
-       boost::optional<int> dcp_to_source (libdcp::Channel c) const;
-       int dcp_channels () const;
-       
-private:
-       int _source_channels;
-};
+       std::list<int> dcp_to_content (libdcp::Channel) const;
+       std::list<std::pair<int, libdcp::Channel> > content_to_dcp () const {
+               return _content_to_dcp;
+       }
 
-class ConfiguredAudioMapping : public AudioMapping
-{
-public:
-       boost::optional<libdcp::Channel> source_to_dcp (int c) const;
-       boost::optional<int> dcp_to_source (libdcp::Channel c) const;
+       std::list<int> content_channels () const;
+       std::list<libdcp::Channel> content_to_dcp (int) const;
 
 private:
-       std::map<int, libdcp::Channel> _source_to_dcp;
+       std::list<std::pair<int, libdcp::Channel> > _content_to_dcp;
 };
+
+#endif