/* * Copyright (C) 2012 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef ANDROID_AUDIO_MONO_PIPE_READER_H #define ANDROID_AUDIO_MONO_PIPE_READER_H #include "MonoPipe.h" namespace android { // MonoPipeReader is safe for only a single reader thread class MonoPipeReader : public NBAIO_Source { public: // Construct a MonoPipeReader and associate it with a MonoPipe; // any data already in the pipe is visible to this MonoPipeReader. // There can be only a single MonoPipeReader per MonoPipe. // FIXME make this constructor a factory method of MonoPipe. MonoPipeReader(MonoPipe* pipe); virtual ~MonoPipeReader(); // NBAIO_Port interface //virtual ssize_t negotiate(const NBAIO_Format offers[], size_t numOffers, // NBAIO_Format counterOffers[], size_t& numCounterOffers); //virtual NBAIO_Format format() const; // NBAIO_Source interface //virtual size_t framesRead() const; //virtual size_t framesOverrun(); //virtual size_t overruns(); virtual ssize_t availableToRead(); virtual ssize_t read(void *buffer, size_t count); virtual void onTimestamp(const ExtendedTimestamp ×tamp); // NBAIO_Source end #if 0 // until necessary MonoPipe* pipe() const { return mPipe; } #endif private: MonoPipe * const mPipe; audio_utils_fifo_reader mFifoReader; }; } // namespace android #endif // ANDROID_AUDIO_MONO_PIPE_READER_H