gecko/media/webrtc/signaling/test/FakeMediaStreamsImpl.h
Ehsan Akhgari f117c7a7b0 Backed out 2 changesets (bug 579517)
Backed out changeset 5298adc70963
Backed out changeset 86ccf7c918ce (bug 579517)
2012-10-25 12:32:24 -04:00

176 lines
4.1 KiB
C++

/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
#ifndef FAKE_MEDIA_STREAMIMPL_H_
#define FAKE_MEDIA_STREAMIMPL_H_
#include "FakeMediaStreams.h"
#include "nspr.h"
#include "nsError.h"
NS_IMPL_THREADSAFE_ISUPPORTS1(Fake_nsDOMMediaStream, nsIDOMMediaStream)
// DOM Media stream
NS_IMETHODIMP
Fake_nsDOMMediaStream::GetCurrentTime(double *aCurrentTime)
{
PR_ASSERT(PR_FALSE);
*aCurrentTime = 0;
return NS_OK;
}
// Fake_SourceMediaStream
nsresult Fake_SourceMediaStream::Start() {
mTimer = do_CreateInstance(NS_TIMER_CONTRACTID);
if (!mTimer) {
return NS_ERROR_FAILURE;
}
mTimer->InitWithCallback(mPeriodic, 100, nsITimer::TYPE_REPEATING_SLACK);
return NS_OK;
}
nsresult Fake_SourceMediaStream::Stop() {
if (mTimer)
mTimer->Cancel();
mPeriodic->Detach();
return NS_OK;
}
void Fake_SourceMediaStream::Periodic() {
if (mPullEnabled) {
for (std::set<Fake_MediaStreamListener *>::iterator it =
mListeners.begin(); it != mListeners.end(); ++it) {
(*it)->NotifyPull(NULL, mozilla::MillisecondsToMediaTime(10));
}
}
}
// Fake_MediaStreamBase
nsresult Fake_MediaStreamBase::Start() {
mTimer = do_CreateInstance(NS_TIMER_CONTRACTID);
if (!mTimer) {
return NS_ERROR_FAILURE;
}
mTimer->InitWithCallback(mPeriodic, 100, nsITimer::TYPE_REPEATING_SLACK);
return NS_OK;
}
nsresult Fake_MediaStreamBase::Stop() {
mTimer->Cancel();
return NS_OK;
}
// Fake_AudioStreamSource
void Fake_AudioStreamSource::Periodic() {
mozilla::AudioSegment segment;
segment.Init(1);
segment.InsertNullDataAtStart(160);
for (std::set<Fake_MediaStreamListener *>::iterator it = mListeners.begin();
it != mListeners.end(); ++it) {
(*it)->NotifyQueuedTrackChanges(NULL, // Graph
0, // TrackID
16000, // Rate (hz)
0, // Offset TODO(ekr@rtfm.com) fix
0, // ???
segment);
}
}
// Fake_MediaPeriodic
NS_IMPL_THREADSAFE_ISUPPORTS1(Fake_MediaPeriodic, nsITimerCallback)
NS_IMETHODIMP
Fake_MediaPeriodic::Notify(nsITimer *timer) {
if (mStream)
mStream->Periodic();
++mCount;
return NS_OK;
}
#if 0
#define WIDTH 320
#define HEIGHT 240
#define RATE USECS_PER_S
#define USECS_PER_S 1000000
#define FPS 10
NS_IMETHODIMP
Fake_VideoStreamSource::Notify(nsITimer* aTimer)
{
#if 0
mozilla::layers::BufferRecycleBin bin;
nsRefPtr<mozilla::layers::PlanarYCbCrImage> image = new
mozilla::layers::PlanarYCbCrImage(&bin);
const uint8_t lumaBpp = 8;
const uint8_t chromaBpp = 4;
int len = ((WIDTH * HEIGHT) * 3 / 2);
uint8_t* frame = (uint8_t*) PR_Malloc(len);
memset(frame, 0x80, len); // Gray
mozilla::layers::PlanarYCbCrImage::Data data;
data.mYChannel = frame;
data.mYSize = gfxIntSize(WIDTH, HEIGHT);
data.mYStride = WIDTH * lumaBpp / 8.0;
data.mCbCrStride = WIDTH * chromaBpp / 8.0;
data.mCbChannel = frame + HEIGHT * data.mYStride;
data.mCrChannel = data.mCbChannel + HEIGHT * data.mCbCrStride / 2;
data.mCbCrSize = gfxIntSize(WIDTH / 2, HEIGHT / 2);
data.mPicX = 0;
data.mPicY = 0;
data.mPicSize = gfxIntSize(WIDTH, HEIGHT);
data.mStereoMode = mozilla::layers::STEREO_MODE_MONO;
mozilla::VideoSegment segment;
segment.AppendFrame(image.forget(), USECS_PER_S / FPS, gfxIntSize(WIDTH, HEIGHT));
// TODO(ekr@rtfm.com): are we leaking?
#endif
return NS_OK;
}
#if 0
// Fake up buffer recycle bin
mozilla::layers::BufferRecycleBin::BufferRecycleBin() :
mLock("mozilla.layers.BufferRecycleBin.mLock") {
}
void mozilla::layers::BufferRecycleBin::RecycleBuffer(uint8_t* buffer, uint32_t size) {
PR_Free(buffer);
}
uint8_t *mozilla::layers::BufferRecycleBin::GetBuffer(uint32_t size) {
return (uint8_t *)PR_MALLOC(size);
}
// YCbCrImage constructor (from ImageLayers.cpp)
mozilla::layers::PlanarYCbCrImage::PlanarYCbCrImage(BufferRecycleBin *aRecycleBin)
: Image(nsnull, PLANAR_YCBCR)
, mBufferSize(0)
, mRecycleBin(aRecycleBin)
{
}
#endif
#endif
#endif