Preliminary MIDI plugin support.
[ardour.git] / libs / ardour / ardour / chan_mapping.h
1 /*
2     Copyright (C) 2009 Paul Davis 
3         Author: Dave Robillard
4
5     This program is free software; you can redistribute it and/or modify
6     it under the terms of the GNU General Public License as published by
7     the Free Software Foundation; either version 2 of the License, or
8     (at your option) any later version.
9
10     This program is distributed in the hope that it will be useful,
11     but WITHOUT ANY WARRANTY; without even the implied warranty of
12     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13     GNU General Public License for more details.
14
15     You should have received a copy of the GNU General Public License
16     along with this program; if not, write to the Free Software
17     Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
18 */
19
20 #ifndef __ardour_chan_mapping_h__
21 #define __ardour_chan_mapping_h__
22
23 #include <map>
24 #include <cassert>
25 #include <ostream>
26 #include <utility>
27
28 #include "ardour/data_type.h"
29
30 namespace ARDOUR {
31
32
33 /** A mapping from one set of channels to another
34  * (e.g. how to 'connect' two BufferSets).
35  */
36 class ChanMapping {
37 public:
38         ChanMapping() {}
39         ChanMapping(ChanCount identity) {
40                 for (DataType::iterator t = DataType::begin(); t != DataType::end(); ++t) {
41                         for (size_t i = 0; i <= identity.get(*t); ++i)
42                                 set(*t, i, i);
43                 }
44         }
45
46         uint32_t get(DataType t, uint32_t from) {
47                 Mappings::iterator tm = _mappings.find(t);
48                 assert(tm != _mappings.end());
49                 TypeMapping::iterator m = tm->second.find(from);
50                 assert(m != tm->second.end());
51                 return m->second;
52         }
53         
54         void set(DataType t, uint32_t from, uint32_t to) {
55                 Mappings::iterator tm = _mappings.find(t);
56                 if (tm == _mappings.end()) {
57                         tm = _mappings.insert(std::make_pair(t, TypeMapping())).first;
58                 }
59                 tm->second.insert(std::make_pair(from, to));
60         }
61
62         /** Increase the 'to' field of every mapping for type @a t by @a delta */
63         void offset(DataType t, uint32_t delta) {
64                 Mappings::iterator tm = _mappings.find(t);
65                 if (tm != _mappings.end()) {
66                         for (TypeMapping::iterator m = tm->second.begin(); m != tm->second.end(); ++m) {
67                                 m->second += delta;
68                         }
69                 }
70         }
71
72 private:
73         typedef std::map<uint32_t, uint32_t>    TypeMapping;
74         typedef std::map<DataType, TypeMapping> Mappings;
75         
76         Mappings _mappings;
77 };
78
79 } // namespace ARDOUR
80
81 #endif // __ardour_chan_mapping_h__
82