07d1d1fff1
git-svn-id: file:///srv/svn/repos/haiku/trunk/current@204 a95241bf-73f2-0310-859d-f6bbb57e9c96
397 lines
15 KiB
C++
397 lines
15 KiB
C++
#include <TimedEventQueue.h>
|
|
#include <stdio.h>
|
|
|
|
#define DEBUG 1
|
|
#include <Debug.h>
|
|
|
|
BTimedEventQueue::queue_action DoForEachHook(media_timed_event *event, void *context);
|
|
void DumpEvent(const media_timed_event & e);
|
|
void DumpEvent(const media_timed_event * e);
|
|
void InsertRemoveTest();
|
|
void DoForEachTest();
|
|
void MatchTest();
|
|
void FlushTest();
|
|
|
|
void DumpEvent(const media_timed_event & e)
|
|
{
|
|
DumpEvent(&e);
|
|
}
|
|
|
|
void DumpEvent(const media_timed_event * e)
|
|
{
|
|
if (!e) {
|
|
printf("NULL\n");
|
|
return;
|
|
}
|
|
printf("time = 0x%x, type = ",int(e->event_time));
|
|
switch (e->type) {
|
|
case BTimedEventQueue::B_NO_EVENT: printf("B_NO_EVENT\n"); break;
|
|
case BTimedEventQueue::B_ANY_EVENT: printf("B_ANY_EVENT\n"); break;
|
|
case BTimedEventQueue::B_START: printf("B_START\n"); break;
|
|
case BTimedEventQueue::B_STOP: printf("B_STOP\n"); break;
|
|
case BTimedEventQueue::B_SEEK: printf("B_SEEK\n"); break;
|
|
case BTimedEventQueue::B_WARP: printf("B_WARP\n"); break;
|
|
case BTimedEventQueue::B_TIMER: printf("B_TIMER\n"); break;
|
|
case BTimedEventQueue::B_HANDLE_BUFFER: printf("B_HANDLE_BUFFER\n"); break;
|
|
case BTimedEventQueue::B_DATA_STATUS: printf("B_DATA_STATUS\n"); break;
|
|
case BTimedEventQueue::B_HARDWARE: printf("B_HARDWARE\n"); break;
|
|
case BTimedEventQueue::B_PARAMETER: printf("B_PARAMETER\n"); break;
|
|
default: printf("0x%x\n",int(e->type));
|
|
}
|
|
}
|
|
|
|
void InsertRemoveTest()
|
|
{
|
|
BTimedEventQueue *q =new BTimedEventQueue;
|
|
q->AddEvent(media_timed_event(0x1007,BTimedEventQueue::B_START));//
|
|
q->AddEvent(media_timed_event(0x1005,BTimedEventQueue::B_START));//
|
|
q->AddEvent(media_timed_event(0x9999,BTimedEventQueue::B_STOP));//
|
|
q->AddEvent(media_timed_event(0x1006,BTimedEventQueue::B_START));//
|
|
q->AddEvent(media_timed_event(0x1002,BTimedEventQueue::B_START));//
|
|
q->AddEvent(media_timed_event(0x1011,BTimedEventQueue::B_START));//
|
|
q->AddEvent(media_timed_event(0x1000,BTimedEventQueue::B_START));//
|
|
q->AddEvent(media_timed_event(0x0777,BTimedEventQueue::B_START));//
|
|
q->AddEvent(media_timed_event(0x1001,BTimedEventQueue::B_START));//
|
|
q->AddEvent(media_timed_event(0x1000,BTimedEventQueue::B_STOP));//
|
|
q->AddEvent(media_timed_event(0x1003,BTimedEventQueue::B_START));//
|
|
q->AddEvent(media_timed_event(0x1000,BTimedEventQueue::B_SEEK));//
|
|
ASSERT(q->EventCount() == 12);
|
|
ASSERT(q->HasEvents() == true);
|
|
|
|
media_timed_event e1(0x1003,BTimedEventQueue::B_START);
|
|
q->RemoveEvent(&e1);
|
|
ASSERT(q->EventCount() == 11);
|
|
ASSERT(q->HasEvents() == true);
|
|
|
|
media_timed_event e2(0x1007,BTimedEventQueue::B_START);
|
|
q->RemoveEvent(&e2);
|
|
ASSERT(q->EventCount() == 10);
|
|
ASSERT(q->HasEvents() == true);
|
|
|
|
media_timed_event e3(0x1000,BTimedEventQueue::B_STOP);
|
|
q->RemoveEvent(&e3);
|
|
ASSERT(q->EventCount() == 9);
|
|
ASSERT(q->HasEvents() == true);
|
|
|
|
media_timed_event e4(0x1000,BTimedEventQueue::B_SEEK);
|
|
q->RemoveEvent(&e4);
|
|
ASSERT(q->EventCount() == 8);
|
|
ASSERT(q->HasEvents() == true);
|
|
|
|
//remove non existing element (time)
|
|
media_timed_event e5(0x1111,BTimedEventQueue::B_STOP);
|
|
q->RemoveEvent(&e5);
|
|
ASSERT(q->EventCount() == 8);
|
|
ASSERT(q->HasEvents() == true);
|
|
|
|
//remove non existing element (type)
|
|
media_timed_event e6(0x1011,BTimedEventQueue::B_STOP);
|
|
q->RemoveEvent(&e6);
|
|
ASSERT(q->EventCount() == 8);
|
|
ASSERT(q->HasEvents() == true);
|
|
|
|
media_timed_event e7(0x1000,BTimedEventQueue::B_START);
|
|
q->RemoveEvent(&e7);
|
|
ASSERT(q->EventCount() == 7);
|
|
ASSERT(q->HasEvents() == true);
|
|
|
|
media_timed_event e8(0x1011,BTimedEventQueue::B_START);
|
|
q->RemoveEvent(&e8);
|
|
ASSERT(q->EventCount() == 6);
|
|
ASSERT(q->HasEvents() == true);
|
|
|
|
media_timed_event e9(0x1002,BTimedEventQueue::B_START);
|
|
q->RemoveEvent(&e9);
|
|
ASSERT(q->EventCount() == 5);
|
|
ASSERT(q->HasEvents() == true);
|
|
|
|
media_timed_event e10(0x0777,BTimedEventQueue::B_START);
|
|
q->RemoveEvent(&e10);
|
|
ASSERT(q->EventCount() == 4);
|
|
ASSERT(q->HasEvents() == true);
|
|
|
|
media_timed_event e11(0x9999,BTimedEventQueue::B_STOP);
|
|
q->RemoveEvent(&e11);
|
|
ASSERT(q->EventCount() == 3);
|
|
ASSERT(q->HasEvents() == true);
|
|
|
|
media_timed_event e12(0x1006,BTimedEventQueue::B_START);
|
|
q->RemoveEvent(&e12);
|
|
ASSERT(q->EventCount() == 2);
|
|
ASSERT(q->HasEvents() == true);
|
|
|
|
media_timed_event e13(0x1001,BTimedEventQueue::B_START);
|
|
q->RemoveEvent(&e13);
|
|
ASSERT(q->EventCount() == 1);
|
|
ASSERT(q->HasEvents() == true);
|
|
|
|
media_timed_event e14(0x1005,BTimedEventQueue::B_START);
|
|
q->RemoveEvent(&e14);
|
|
ASSERT(q->EventCount() == 0);
|
|
ASSERT(q->HasEvents() == false);
|
|
|
|
delete q;
|
|
}
|
|
|
|
media_timed_event DoForEachEvent;
|
|
int DoForEachCount;
|
|
|
|
BTimedEventQueue::queue_action
|
|
DoForEachHook(media_timed_event *event, void *context)
|
|
{
|
|
DoForEachEvent = *event;
|
|
DoForEachCount++;
|
|
printf("Callback, event_time = %x\n",int(event->event_time));
|
|
return BTimedEventQueue::B_NO_ACTION;
|
|
}
|
|
|
|
void DoForEachTest()
|
|
{
|
|
BTimedEventQueue *q =new BTimedEventQueue;
|
|
ASSERT(q->EventCount() == 0);
|
|
ASSERT(q->HasEvents() == false);
|
|
|
|
q->AddEvent(media_timed_event(0x1000,BTimedEventQueue::B_SEEK));
|
|
q->AddEvent(media_timed_event(0x1001,BTimedEventQueue::B_START));
|
|
q->AddEvent(media_timed_event(0x1002,BTimedEventQueue::B_START));
|
|
q->AddEvent(media_timed_event(0x1003,BTimedEventQueue::B_START));
|
|
q->AddEvent(media_timed_event(0x1010,BTimedEventQueue::B_START));
|
|
q->AddEvent(media_timed_event(0x1011,BTimedEventQueue::B_START));
|
|
q->AddEvent(media_timed_event(0x1012,BTimedEventQueue::B_START));
|
|
q->AddEvent(media_timed_event(0x1004,BTimedEventQueue::B_START));
|
|
q->AddEvent(media_timed_event(0x1005,BTimedEventQueue::B_START));
|
|
q->AddEvent(media_timed_event(0x1006,BTimedEventQueue::B_STOP));
|
|
q->AddEvent(media_timed_event(0x1007,BTimedEventQueue::B_START));
|
|
q->AddEvent(media_timed_event(0x1008,BTimedEventQueue::B_START));
|
|
q->AddEvent(media_timed_event(0x1009,BTimedEventQueue::B_START));
|
|
q->AddEvent(media_timed_event(0x1013,BTimedEventQueue::B_START));
|
|
q->AddEvent(media_timed_event(0x1013,BTimedEventQueue::B_START));
|
|
q->AddEvent(media_timed_event(0x1013,BTimedEventQueue::B_SEEK));
|
|
ASSERT(q->EventCount() == 16);
|
|
ASSERT(q->HasEvents() == true);
|
|
|
|
|
|
printf("\n expected: 0x1000\n");
|
|
DoForEachCount = 0;
|
|
q->DoForEach(DoForEachHook,(void*)1234,0x1000,BTimedEventQueue::B_AT_TIME);
|
|
ASSERT(DoForEachEvent == media_timed_event(0x1000,BTimedEventQueue::B_SEEK));
|
|
ASSERT(DoForEachCount == 1);
|
|
|
|
|
|
printf("\n expected: 0x1006\n");
|
|
DoForEachCount = 0;
|
|
q->DoForEach(DoForEachHook,(void*)1234,0x1006,BTimedEventQueue::B_AT_TIME);
|
|
ASSERT(DoForEachEvent == media_timed_event(0x1006,BTimedEventQueue::B_STOP));
|
|
ASSERT(DoForEachCount == 1);
|
|
|
|
printf("\n expected: 0x1013, 0x1013, 0x1013\n");
|
|
DoForEachCount = 0;
|
|
q->DoForEach(DoForEachHook,(void*)1234,0x1013,BTimedEventQueue::B_AT_TIME);
|
|
ASSERT(DoForEachCount == 3);
|
|
|
|
printf("\n expected: 0x1000, 0x1001, 0x1002\n");
|
|
DoForEachCount = 0;
|
|
q->DoForEach(DoForEachHook,(void*)1234,0x1003,BTimedEventQueue::B_BEFORE_TIME,false);
|
|
ASSERT(DoForEachCount == 3);
|
|
|
|
printf("\n expected: 0x1000, 0x1001, 0x1002, 0x1003\n");
|
|
DoForEachCount = 0;
|
|
q->DoForEach(DoForEachHook,(void*)1234,0x1003,BTimedEventQueue::B_BEFORE_TIME,true);
|
|
ASSERT(DoForEachCount == 4);
|
|
|
|
printf("\n expected: 0x1013, 0x1013, 0x1013\n");
|
|
DoForEachCount = 0;
|
|
q->DoForEach(DoForEachHook,(void*)1234,0x1012,BTimedEventQueue::B_AFTER_TIME,false);
|
|
ASSERT(DoForEachCount == 3);
|
|
|
|
printf("\n expected: 0x1012, 0x1013, 0x1013, 0x1013\n");
|
|
DoForEachCount = 0;
|
|
q->DoForEach(DoForEachHook,(void*)1234,0x1012,BTimedEventQueue::B_AFTER_TIME,true);
|
|
ASSERT(DoForEachCount == 4);
|
|
|
|
printf("\n expected: none\n");
|
|
DoForEachCount = 0;
|
|
q->DoForEach(DoForEachHook,(void*)1234,0x1013,BTimedEventQueue::B_AFTER_TIME,false);
|
|
ASSERT(DoForEachCount == 0);
|
|
|
|
printf("\n expected: 0x1013, 0x1013, 0x1013\n");
|
|
DoForEachCount = 0;
|
|
q->DoForEach(DoForEachHook,(void*)1234,0x1013,BTimedEventQueue::B_AFTER_TIME,true);
|
|
ASSERT(DoForEachCount == 3);
|
|
|
|
printf("\n expected: all 16\n");
|
|
DoForEachCount = 0;
|
|
q->DoForEach(DoForEachHook,(void*)1234,0x0,BTimedEventQueue::B_ALWAYS);
|
|
ASSERT(DoForEachCount == 16);
|
|
|
|
printf("\n expected: none\n");
|
|
DoForEachCount = 0;
|
|
q->DoForEach(DoForEachHook,(void*)1234,0x0,BTimedEventQueue::B_ALWAYS,false,BTimedEventQueue::B_WARP);
|
|
ASSERT(DoForEachCount == 0);
|
|
|
|
printf("\n expected: 0x1000, 0x1013\n");
|
|
DoForEachCount = 0;
|
|
q->DoForEach(DoForEachHook,(void*)1234,0x0,BTimedEventQueue::B_ALWAYS,false,BTimedEventQueue::B_SEEK);
|
|
ASSERT(DoForEachCount == 2);
|
|
|
|
printf("\n expected: 0x1000, 0x1013\n");
|
|
DoForEachCount = 0;
|
|
q->DoForEach(DoForEachHook,(void*)1234,0x0999,BTimedEventQueue::B_AFTER_TIME,false,BTimedEventQueue::B_SEEK);
|
|
ASSERT(DoForEachCount == 2);
|
|
|
|
printf("\n expected: 0x1000, 0x1013\n");
|
|
DoForEachCount = 0;
|
|
q->DoForEach(DoForEachHook,(void*)1234,0x1014,BTimedEventQueue::B_BEFORE_TIME,false,BTimedEventQueue::B_SEEK);
|
|
ASSERT(DoForEachCount == 2);
|
|
|
|
printf("\n expected: none\n");
|
|
DoForEachCount = 0;
|
|
q->DoForEach(DoForEachHook,(void*)1234,0x0004,BTimedEventQueue::B_BEFORE_TIME,true);
|
|
ASSERT(DoForEachCount == 0);
|
|
|
|
delete q;
|
|
}
|
|
|
|
void MatchTest()
|
|
{
|
|
BTimedEventQueue *q = new BTimedEventQueue;
|
|
ASSERT(q->EventCount() == 0);
|
|
ASSERT(q->HasEvents() == false);
|
|
|
|
q->AddEvent(media_timed_event(0x1000,BTimedEventQueue::B_SEEK));
|
|
q->AddEvent(media_timed_event(0x1001,BTimedEventQueue::B_START));
|
|
q->AddEvent(media_timed_event(0x1002,BTimedEventQueue::B_START));
|
|
q->AddEvent(media_timed_event(0x1003,BTimedEventQueue::B_START));
|
|
q->AddEvent(media_timed_event(0x1010,BTimedEventQueue::B_START));
|
|
q->AddEvent(media_timed_event(0x1011,BTimedEventQueue::B_START));
|
|
q->AddEvent(media_timed_event(0x1012,BTimedEventQueue::B_START));
|
|
q->AddEvent(media_timed_event(0x1004,BTimedEventQueue::B_START));
|
|
q->AddEvent(media_timed_event(0x1005,BTimedEventQueue::B_START));
|
|
q->AddEvent(media_timed_event(0x1006,BTimedEventQueue::B_STOP));
|
|
q->AddEvent(media_timed_event(0x1007,BTimedEventQueue::B_START));
|
|
q->AddEvent(media_timed_event(0x1008,BTimedEventQueue::B_START));
|
|
q->AddEvent(media_timed_event(0x1009,BTimedEventQueue::B_START));
|
|
q->AddEvent(media_timed_event(0x1013,BTimedEventQueue::B_START));
|
|
q->AddEvent(media_timed_event(0x1013,BTimedEventQueue::B_START));
|
|
q->AddEvent(media_timed_event(0x1013,BTimedEventQueue::B_SEEK));
|
|
ASSERT(q->EventCount() == 16);
|
|
ASSERT(q->HasEvents() == true);
|
|
|
|
printf("\nexpected: "); DumpEvent(media_timed_event(0x1006,BTimedEventQueue::B_STOP));
|
|
printf("found: "); DumpEvent(q->FindFirstMatch(0x1001,BTimedEventQueue::B_AFTER_TIME,true,BTimedEventQueue::B_STOP));
|
|
|
|
printf("\nexpected: "); DumpEvent(media_timed_event(0x1006,BTimedEventQueue::B_STOP));
|
|
printf("found: "); DumpEvent(q->FindFirstMatch(0x1006,BTimedEventQueue::B_AT_TIME,true));
|
|
|
|
printf("\nexpected: "); DumpEvent(media_timed_event(0x1006,BTimedEventQueue::B_STOP));
|
|
printf("found: "); DumpEvent(q->FindFirstMatch(0x1007,BTimedEventQueue::B_BEFORE_TIME,true,BTimedEventQueue::B_STOP));
|
|
|
|
printf("\nexpected: "); DumpEvent(media_timed_event(0x1000,BTimedEventQueue::B_SEEK));
|
|
printf("found: "); DumpEvent(q->FindFirstMatch(0x1006,BTimedEventQueue::B_BEFORE_TIME,true));
|
|
|
|
printf("\nexpected: "); DumpEvent(media_timed_event(0x1006,BTimedEventQueue::B_STOP));
|
|
printf("found: "); DumpEvent(q->FindFirstMatch(0x1006,BTimedEventQueue::B_AFTER_TIME,true));
|
|
|
|
printf("\nexpected: "); DumpEvent(0);
|
|
printf("found: "); DumpEvent(q->FindFirstMatch(0x1006,BTimedEventQueue::B_BEFORE_TIME,false,BTimedEventQueue::B_STOP));
|
|
|
|
printf("\nexpected: "); DumpEvent(0);
|
|
printf("found: "); DumpEvent(q->FindFirstMatch(0x1006,BTimedEventQueue::B_AFTER_TIME,false,BTimedEventQueue::B_STOP));
|
|
|
|
printf("\nexpected: "); DumpEvent(0);
|
|
printf("found: "); DumpEvent(q->FindFirstMatch(0x1006,BTimedEventQueue::B_AT_TIME,false,BTimedEventQueue::B_SEEK));
|
|
|
|
printf("\nexpected: "); DumpEvent(media_timed_event(0x1000,BTimedEventQueue::B_SEEK));
|
|
printf("found: "); DumpEvent(q->FindFirstMatch(0x1000,BTimedEventQueue::B_AFTER_TIME,true));
|
|
|
|
printf("\nexpected: "); DumpEvent(media_timed_event(0x1000,BTimedEventQueue::B_SEEK));
|
|
printf("found: "); DumpEvent(q->FindFirstMatch(0x1010,BTimedEventQueue::B_BEFORE_TIME,true));
|
|
|
|
printf("\nexpected: "); DumpEvent(media_timed_event(0x1000,BTimedEventQueue::B_SEEK));
|
|
printf("found: "); DumpEvent(q->FindFirstMatch(0x1007,BTimedEventQueue::B_BEFORE_TIME,false));
|
|
|
|
printf("\nexpected: "); DumpEvent(media_timed_event(0x1013,BTimedEventQueue::B_SEEK));
|
|
printf("found: "); DumpEvent(q->FindFirstMatch(0x1001,BTimedEventQueue::B_AFTER_TIME,false,BTimedEventQueue::B_SEEK));
|
|
|
|
printf("\nexpected: "); DumpEvent(media_timed_event(0x1010,BTimedEventQueue::B_START));
|
|
printf("found: "); DumpEvent(q->FindFirstMatch(0x1009,BTimedEventQueue::B_AFTER_TIME,false));
|
|
|
|
printf("\nexpected: "); DumpEvent(media_timed_event(0x1010,BTimedEventQueue::B_START));
|
|
printf("found: "); DumpEvent(q->FindFirstMatch(0x1010,BTimedEventQueue::B_AFTER_TIME,true));
|
|
|
|
printf("\nexpected: "); DumpEvent(media_timed_event(0x1010,BTimedEventQueue::B_START));
|
|
printf("found: "); DumpEvent(q->FindFirstMatch(0x1010,BTimedEventQueue::B_AT_TIME,true));
|
|
|
|
delete q;
|
|
}
|
|
|
|
void FlushTest()
|
|
{
|
|
BTimedEventQueue *q = new BTimedEventQueue;
|
|
ASSERT(q->EventCount() == 0);
|
|
ASSERT(q->HasEvents() == false);
|
|
|
|
q->AddEvent(media_timed_event(0x1000,BTimedEventQueue::B_SEEK));
|
|
q->AddEvent(media_timed_event(0x1001,BTimedEventQueue::B_START));
|
|
q->AddEvent(media_timed_event(0x1002,BTimedEventQueue::B_START));
|
|
q->AddEvent(media_timed_event(0x1003,BTimedEventQueue::B_START));
|
|
q->AddEvent(media_timed_event(0x1004,BTimedEventQueue::B_START));
|
|
q->AddEvent(media_timed_event(0x1005,BTimedEventQueue::B_START));
|
|
q->AddEvent(media_timed_event(0x1006,BTimedEventQueue::B_STOP));
|
|
q->AddEvent(media_timed_event(0x1007,BTimedEventQueue::B_START));
|
|
q->AddEvent(media_timed_event(0x1008,BTimedEventQueue::B_START));
|
|
q->AddEvent(media_timed_event(0x1009,BTimedEventQueue::B_START));
|
|
q->AddEvent(media_timed_event(0x1010,BTimedEventQueue::B_START));
|
|
q->AddEvent(media_timed_event(0x1011,BTimedEventQueue::B_START));
|
|
q->AddEvent(media_timed_event(0x1012,BTimedEventQueue::B_START));
|
|
q->AddEvent(media_timed_event(0x1013,BTimedEventQueue::B_START));
|
|
q->AddEvent(media_timed_event(0x1013,BTimedEventQueue::B_START));
|
|
q->AddEvent(media_timed_event(0x1013,BTimedEventQueue::B_SEEK));
|
|
ASSERT(q->EventCount() == 16);
|
|
ASSERT(q->HasEvents() == true);
|
|
|
|
printf("### removing 0x1007\n");
|
|
q->FlushEvents(0x1007, BTimedEventQueue::B_AT_TIME);
|
|
ASSERT(q->EventCount() == 15);
|
|
|
|
printf("### removing 0x1013\n");
|
|
q->FlushEvents(0x1012, BTimedEventQueue::B_AFTER_TIME,false);
|
|
ASSERT(q->EventCount() == 12);
|
|
|
|
printf("### removing none\n");
|
|
q->FlushEvents(0x1fff, BTimedEventQueue::B_AFTER_TIME,false);
|
|
ASSERT(q->EventCount() == 12);
|
|
|
|
printf("### removing none\n");
|
|
q->FlushEvents(0x1fff, BTimedEventQueue::B_AFTER_TIME,true);
|
|
ASSERT(q->EventCount() == 12);
|
|
|
|
printf("### removing 0x1010, 0x1011, 0x1012\n");
|
|
q->FlushEvents(0x1010, BTimedEventQueue::B_AFTER_TIME,true);
|
|
ASSERT(q->EventCount() == 9);
|
|
|
|
printf("### removing 0x1000 to 0x1005\n");
|
|
q->FlushEvents(0x1006, BTimedEventQueue::B_BEFORE_TIME,false);
|
|
ASSERT(q->EventCount() == 3);
|
|
|
|
printf("### removing 0x1006\n");
|
|
q->FlushEvents(0x1006, BTimedEventQueue::B_AT_TIME);
|
|
ASSERT(q->EventCount() == 2);
|
|
|
|
printf("### removing 0x1008 0x1009\n");
|
|
q->FlushEvents(0xffffff, BTimedEventQueue::B_BEFORE_TIME);
|
|
ASSERT(q->EventCount() == 0);
|
|
|
|
delete q;
|
|
}
|
|
|
|
|
|
int main()
|
|
{
|
|
InsertRemoveTest();
|
|
DoForEachTest();
|
|
MatchTest();
|
|
FlushTest();
|
|
return 0;
|
|
}
|