tmp
[blender.git] / extern / audaspace / include / fx / LimiterReader.h
1 /*******************************************************************************
2  * Copyright 2009-2016 Jörg Müller
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *   http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  ******************************************************************************/
16
17 #pragma once
18
19 /**
20  * @file LimiterReader.h
21  * @ingroup fx
22  * The LimiterReader class.
23  */
24
25 #include "fx/EffectReader.h"
26
27 AUD_NAMESPACE_BEGIN
28
29 /**
30  * This reader limits another reader in start and end times.
31  */
32 class AUD_API LimiterReader : public EffectReader
33 {
34 private:
35         /**
36          * The start sample: inclusive.
37          */
38         const float m_start;
39
40         /**
41          * The end sample: exlusive.
42          */
43         const float m_end;
44
45         // delete copy constructor and operator=
46         LimiterReader(const LimiterReader&) = delete;
47         LimiterReader& operator=(const LimiterReader&) = delete;
48
49 public:
50         /**
51          * Creates a new limiter reader.
52          * \param reader The reader to read from.
53          * \param start The desired start time (inclusive).
54          * \param end The desired end time (sample exklusive), a negative value
55          *            signals that it should play to the end.
56          */
57         LimiterReader(std::shared_ptr<IReader> reader, float start = 0, float end = -1);
58
59         virtual void seek(int position);
60         virtual int getLength() const;
61         virtual int getPosition() const;
62         virtual void read(int& length, bool& eos, sample_t* buffer);
63 };
64
65 AUD_NAMESPACE_END