| /* |
| * Copyright (c) 2012 The WebRTC project authors. All Rights Reserved. |
| * |
| * Use of this source code is governed by a BSD-style license |
| * that can be found in the LICENSE file in the root of the source |
| * tree. An additional intellectual property rights grant can be found |
| * in the file PATENTS. All contributing project authors may |
| * be found in the AUTHORS file in the root of the source tree. |
| */ |
| |
| #ifndef WEBRTC_MODULES_AUDIO_CODING_NETEQ_DTMF_BUFFER_H_ |
| #define WEBRTC_MODULES_AUDIO_CODING_NETEQ_DTMF_BUFFER_H_ |
| |
| #include <list> |
| #include <string> // size_t |
| |
| #include "webrtc/base/constructormagic.h" |
| #include "webrtc/typedefs.h" |
| |
| namespace webrtc { |
| |
| struct DtmfEvent { |
| uint32_t timestamp; |
| int event_no; |
| int volume; |
| int duration; |
| bool end_bit; |
| |
| // Constructors |
| DtmfEvent() |
| : timestamp(0), |
| event_no(0), |
| volume(0), |
| duration(0), |
| end_bit(false) { |
| } |
| DtmfEvent(uint32_t ts, int ev, int vol, int dur, bool end) |
| : timestamp(ts), |
| event_no(ev), |
| volume(vol), |
| duration(dur), |
| end_bit(end) { |
| } |
| }; |
| |
| // This is the buffer holding DTMF events while waiting for them to be played. |
| class DtmfBuffer { |
| public: |
| enum BufferReturnCodes { |
| kOK = 0, |
| kInvalidPointer, |
| kPayloadTooShort, |
| kInvalidEventParameters, |
| kInvalidSampleRate |
| }; |
| |
| // Set up the buffer for use at sample rate |fs_hz|. |
| explicit DtmfBuffer(int fs_hz) { |
| SetSampleRate(fs_hz); |
| } |
| |
| virtual ~DtmfBuffer() {} |
| |
| // Flushes the buffer. |
| virtual void Flush() { buffer_.clear(); } |
| |
| // Static method to parse 4 bytes from |payload| as a DTMF event (RFC 4733) |
| // and write the parsed information into the struct |event|. Input variable |
| // |rtp_timestamp| is simply copied into the struct. |
| static int ParseEvent(uint32_t rtp_timestamp, |
| const uint8_t* payload, |
| size_t payload_length_bytes, |
| DtmfEvent* event); |
| |
| // Inserts |event| into the buffer. The method looks for a matching event and |
| // merges the two if a match is found. |
| virtual int InsertEvent(const DtmfEvent& event); |
| |
| // Checks if a DTMF event should be played at time |current_timestamp|. If so, |
| // the method returns true; otherwise false. The parameters of the event to |
| // play will be written to |event|. |
| virtual bool GetEvent(uint32_t current_timestamp, DtmfEvent* event); |
| |
| // Number of events in the buffer. |
| virtual size_t Length() const { return buffer_.size(); } |
| |
| virtual bool Empty() const { return buffer_.empty(); } |
| |
| // Set a new sample rate. |
| virtual int SetSampleRate(int fs_hz); |
| |
| private: |
| typedef std::list<DtmfEvent> DtmfList; |
| |
| int max_extrapolation_samples_; |
| int frame_len_samples_; // TODO(hlundin): Remove this later. |
| |
| // Compares two events and returns true if they are the same. |
| static bool SameEvent(const DtmfEvent& a, const DtmfEvent& b); |
| |
| // Merges |event| to the event pointed out by |it|. The method checks that |
| // the two events are the same (using the SameEvent method), and merges them |
| // if that was the case, returning true. If the events are not the same, false |
| // is returned. |
| bool MergeEvents(DtmfList::iterator it, const DtmfEvent& event); |
| |
| // Method used by the sort algorithm to rank events in the buffer. |
| static bool CompareEvents(const DtmfEvent& a, const DtmfEvent& b); |
| |
| DtmfList buffer_; |
| |
| DISALLOW_COPY_AND_ASSIGN(DtmfBuffer); |
| }; |
| |
| } // namespace webrtc |
| #endif // WEBRTC_MODULES_AUDIO_CODING_NETEQ_DTMF_BUFFER_H_ |