playqueue: Updates for my recent renaiming

Rename everything from playlist -> playqueue.

Signed-off-by: Anna Schumaker <schumaker.anna@gmail.com>
This commit is contained in:
Anna Schumaker 2014-01-02 21:12:46 -05:00 committed by Anna Schumaker
parent 98e8324a61
commit 82a57ec2b5
7 changed files with 195 additions and 195 deletions

View File

@ -1,33 +1,33 @@
/*
* Copyright 2013 (c) Anna Schumaker.
*/
#ifndef OCARINA_PLAYLIST_H
#define OCARINA_PLAYLIST_H
#ifndef OCARINA_PLAYQUEUE_H
#define OCARINA_PLAYQUEUE_H
#include <file.h>
#include <vector>
enum playlist_flags {
PL_ENABLED = (1 << 0),
PL_RANDOM = (1 << 1),
PL_LOCKED = (1 << 2),
enum playqueue_flags {
PQ_ENABLED = (1 << 0),
PQ_RANDOM = (1 << 1),
PQ_REPEAT = (1 << 2),
};
class Playlist {
class Playqueue {
private:
std :: vector <unsigned int> tracks;
unsigned int flags;
unsigned int cur;
public:
Playlist();
Playlist(playlist_flags);
~Playlist();
Playqueue();
Playqueue(playqueue_flags);
~Playqueue();
void write(File &);
void read(File &);
void set_flag(playlist_flags);
void unset_flag(playlist_flags);
void set_flag(playqueue_flags);
void unset_flag(playqueue_flags);
const unsigned int get_flags();
unsigned int add(unsigned int);
@ -37,4 +37,4 @@ public:
unsigned int next();
};
#endif /* OCARINA_PLAYLIST_H */
#endif /* OCARINA_PLAYQUEUE_H */

View File

@ -23,7 +23,7 @@ modules = {
"IDLE" : Module("idle.cpp"),
"LIBRARY" : Module("library.cpp", package = "taglib", depends = [ "DATABASE", "FILTER", "IDLE" ]),
"PLAYLIST" : Module("playlist.cpp", depends = [ "DATABASE" ]),
"PLAYQUEUE" : Module("playlist.cpp", depends = [ "FILE" ]),
"PLAYQUEUE" : Module("playqueue.cpp", depends = [ "FILE" ]),
###########################
###########################

View File

@ -1,31 +1,31 @@
/*
* Copyright 2013 (c) Anna Schumaker.
*/
#include <playlist.h>
#include <playqueue.h>
#include <stdlib.h>
Playlist :: Playlist()
Playqueue :: Playqueue()
: flags(0), cur(-1)
{
}
Playlist :: Playlist(playlist_flags f)
Playqueue :: Playqueue(playqueue_flags f)
: flags(f), cur(-1)
{
}
Playlist :: ~Playlist()
Playqueue :: ~Playqueue()
{
}
void Playlist :: write(File &f)
void Playqueue :: write(File &f)
{
f << flags << " " << tracks.size();
for (unsigned int i = 0; i < tracks.size(); i++)
f << " " << tracks[i];
}
void Playlist :: read(File &f)
void Playqueue :: read(File &f)
{
unsigned int n;
f >> flags >> n;
@ -34,44 +34,44 @@ void Playlist :: read(File &f)
f >> tracks[i];
}
void Playlist :: set_flag(playlist_flags f)
void Playqueue :: set_flag(playqueue_flags f)
{
flags |= f;
}
void Playlist :: unset_flag(playlist_flags f)
void Playqueue :: unset_flag(playqueue_flags f)
{
flags &= ~f;
}
const unsigned int Playlist :: get_flags()
const unsigned int Playqueue :: get_flags()
{
return flags;
}
unsigned int Playlist :: add(unsigned int track_id)
unsigned int Playqueue :: add(unsigned int track_id)
{
tracks.push_back(track_id);
return tracks.size() - 1;
}
void Playlist :: del(unsigned int plist_id)
void Playqueue :: del(unsigned int plist_id)
{
tracks.erase(tracks.begin() + plist_id);
}
unsigned int Playlist :: size()
unsigned int Playqueue :: size()
{
return tracks.size();
}
unsigned int Playlist :: next()
unsigned int Playqueue :: next()
{
unsigned int res;
if (tracks.size() == 1)
cur = 0;
else if (flags & PL_RANDOM)
else if (flags & PQ_RANDOM)
cur += rand() % (tracks.size() / 2) + 1;
else
cur++;
@ -80,7 +80,7 @@ unsigned int Playlist :: next()
cur -= tracks.size();
res = tracks[cur];
if (!(flags & PL_LOCKED)) {
if (!(flags & PQ_REPEAT)) {
tracks.erase(tracks.begin() + cur);
cur--;
}

View File

@ -1,6 +1,6 @@
#!/usr/bin/python
Import("Test", "CONFIG")
CONFIG.PLAYLIST = True
CONFIG.PLAYQUEUE = True
Test("playlist", "playlist.cpp")
Test("playqueue", "playqueue.cpp")

View File

@ -1,164 +0,0 @@
/*
* Copyright 2013 (c) Anna Schumaker.
*/
#include <playlist.h>
#include <print.h>
#include <stdlib.h>
#include <string>
void test_flags(const std :: string &test, Playlist &plist, unsigned int expected)
{
print("Test %s: ", test.c_str());
if (plist.get_flags() == expected)
print("SUCCESS\n");
else
print("FAILED\n");
}
void test_add_tracks(const std :: string & test, Playlist &plist,
unsigned int start, unsigned int end)
{
bool passed = true;
print("Test %s: ", test.c_str());
for (unsigned int i = start; i <= end; i++) {
if (plist.add(i) != (i - start))
passed = false;
}
if (passed == true)
print("SUCCESS\n");
else
print("FAILED\n");
}
void test_rm_tracks(const std :: string & test, Playlist & plist, unsigned int n)
{
unsigned int size = plist.size();
unsigned int expected = size - n;
print("Test %s: ", test.c_str());
for (unsigned int i = 0; i < n; i++)
plist.del(i);
if (plist.size() == expected)
print("SUCCESS\n");
else
print("FAILED\n");
}
/* Test flag setting / unsetting / getting */
void test_0()
{
Playlist plist(PL_ENABLED);
test_flags("0a", plist, PL_ENABLED);
plist.set_flag(PL_RANDOM);
test_flags("0b", plist, PL_ENABLED | PL_RANDOM);
plist.set_flag(PL_ENABLED);
test_flags("0c", plist, PL_ENABLED | PL_RANDOM);
plist.unset_flag(PL_ENABLED);
test_flags("0d", plist, PL_RANDOM);
plist.unset_flag(PL_RANDOM);
test_flags("0f", plist, 0);
print("\n");
}
/* Test adding / deleting / size queries */
void test_1()
{
Playlist plist(PL_ENABLED);
test_add_tracks("1a", plist, 10, 49);
print("Test 1b: Plist size: %u\n", plist.size());
test_rm_tracks("1c", plist, 10);
print("\n");
}
/* Test read / write */
void test_2()
{
Playlist plist(PL_ENABLED);
Playlist plist2(PL_ENABLED);
File f("plist.lst", FILE_TYPE_DATA);
plist.set_flag(PL_RANDOM);
test_add_tracks("2a", plist, 0, 99);
f.open(OPEN_WRITE);
plist.write(f);
f.close();
f.open(OPEN_READ);
plist2.read(f);
f.close();
print("Test 2b: ");
if (plist.get_flags() != plist2.get_flags()) {
print("FAILED: flag mismatch\n");
return;
} else if (plist.size() != plist2.size()) {
print("FAILED: size mismatch\n");
return;
}
print("SUCCESS\n\n");
}
/* Sequential next() without removing tracks */
void test_3()
{
Playlist plist(PL_ENABLED);
plist.set_flag(PL_LOCKED);
test_add_tracks("3", plist, 0, 15);
for (unsigned int i = 0; i < 20; i++)
print("Selecting id: %u\n", plist.next());
print("\n");
}
/* Sequential next() with removal */
void test_4()
{
Playlist plist(PL_ENABLED);
test_add_tracks("4", plist, 0, 15);
while (plist.size() > 0)
print("Selecting id: %u\n", plist.next());
print("\n");
}
/* Random next() without removing tracks */
void test_5()
{
Playlist plist(PL_ENABLED);
plist.set_flag(PL_RANDOM);
plist.set_flag(PL_LOCKED);
test_add_tracks("5", plist, 0, 15);
for (unsigned int i = 0; i < 30; i++)
print("Selecting id: %u\n", plist.next());
print("\n");
}
/* Random next() with removal */
void test_6()
{
Playlist plist(PL_ENABLED);
plist.set_flag(PL_RANDOM);
test_add_tracks("6", plist, 0, 15);
while (plist.size() > 0)
print("Selecting id: %u\n", plist.next());
}
int main(int argc, char **argv)
{
srand(42);
test_0();
test_1();
test_2();
test_3();
test_4();
test_5();
test_6();
return 0;
}

View File

@ -0,0 +1,164 @@
/*
* Copyright 2013 (c) Anna Schumaker.
*/
#include <playqueue.h>
#include <print.h>
#include <stdlib.h>
#include <string>
void test_flags(const std :: string &test, Playqueue &pqueue, unsigned int expected)
{
print("Test %s: ", test.c_str());
if (pqueue.get_flags() == expected)
print("SUCCESS\n");
else
print("FAILED\n");
}
void test_add_tracks(const std :: string & test, Playqueue &pqueue,
unsigned int start, unsigned int end)
{
bool passed = true;
print("Test %s: ", test.c_str());
for (unsigned int i = start; i <= end; i++) {
if (pqueue.add(i) != (i - start))
passed = false;
}
if (passed == true)
print("SUCCESS\n");
else
print("FAILED\n");
}
void test_rm_tracks(const std :: string & test, Playqueue & pqueue, unsigned int n)
{
unsigned int size = pqueue.size();
unsigned int expected = size - n;
print("Test %s: ", test.c_str());
for (unsigned int i = 0; i < n; i++)
pqueue.del(i);
if (pqueue.size() == expected)
print("SUCCESS\n");
else
print("FAILED\n");
}
/* Test flag setting / unsetting / getting */
void test_0()
{
Playqueue pqueue(PQ_ENABLED);
test_flags("0a", pqueue, PQ_ENABLED);
pqueue.set_flag(PQ_RANDOM);
test_flags("0b", pqueue, PQ_ENABLED | PQ_RANDOM);
pqueue.set_flag(PQ_ENABLED);
test_flags("0c", pqueue, PQ_ENABLED | PQ_RANDOM);
pqueue.unset_flag(PQ_ENABLED);
test_flags("0d", pqueue, PQ_RANDOM);
pqueue.unset_flag(PQ_RANDOM);
test_flags("0f", pqueue, 0);
print("\n");
}
/* Test adding / deleting / size queries */
void test_1()
{
Playqueue pqueue(PQ_ENABLED);
test_add_tracks("1a", pqueue, 10, 49);
print("Test 1b: Plist size: %u\n", pqueue.size());
test_rm_tracks("1c", pqueue, 10);
print("\n");
}
/* Test read / write */
void test_2()
{
Playqueue pqueue(PQ_ENABLED);
Playqueue pqueue2(PQ_ENABLED);
File f("pqueue.lst", FILE_TYPE_DATA);
pqueue.set_flag(PQ_RANDOM);
test_add_tracks("2a", pqueue, 0, 99);
f.open(OPEN_WRITE);
pqueue.write(f);
f.close();
f.open(OPEN_READ);
pqueue2.read(f);
f.close();
print("Test 2b: ");
if (pqueue.get_flags() != pqueue2.get_flags()) {
print("FAILED: flag mismatch\n");
return;
} else if (pqueue.size() != pqueue2.size()) {
print("FAILED: size mismatch\n");
return;
}
print("SUCCESS\n\n");
}
/* Sequential next() without removing tracks */
void test_3()
{
Playqueue pqueue(PQ_ENABLED);
pqueue.set_flag(PQ_REPEAT);
test_add_tracks("3", pqueue, 0, 15);
for (unsigned int i = 0; i < 20; i++)
print("Selecting id: %u\n", pqueue.next());
print("\n");
}
/* Sequential next() with removal */
void test_4()
{
Playqueue pqueue(PQ_ENABLED);
test_add_tracks("4", pqueue, 0, 15);
while (pqueue.size() > 0)
print("Selecting id: %u\n", pqueue.next());
print("\n");
}
/* Random next() without removing tracks */
void test_5()
{
Playqueue pqueue(PQ_ENABLED);
pqueue.set_flag(PQ_RANDOM);
pqueue.set_flag(PQ_REPEAT);
test_add_tracks("5", pqueue, 0, 15);
for (unsigned int i = 0; i < 30; i++)
print("Selecting id: %u\n", pqueue.next());
print("\n");
}
/* Random next() with removal */
void test_6()
{
Playqueue pqueue(PQ_ENABLED);
pqueue.set_flag(PQ_RANDOM);
test_add_tracks("6", pqueue, 0, 15);
while (pqueue.size() > 0)
print("Selecting id: %u\n", pqueue.next());
}
int main(int argc, char **argv)
{
srand(42);
test_0();
test_1();
test_2();
test_3();
test_4();
test_5();
test_6();
return 0;
}