aboutsummaryrefslogtreecommitdiffstats
path: root/src/Queue.cxx
diff options
context:
space:
mode:
authorMax Kellermann <max@duempel.org>2013-01-06 14:58:54 +0100
committerMax Kellermann <max@duempel.org>2013-01-06 18:59:39 +0100
commit70652abf9750b62d2b4e5857d894494ae6058cf1 (patch)
treeba38fec9699eb2094cb2dda7a6f3f9dbb427a709 /src/Queue.cxx
parente202b407ec18570ad54a04c64341f654b447fb31 (diff)
downloadmpd-70652abf9750b62d2b4e5857d894494ae6058cf1.tar.gz
mpd-70652abf9750b62d2b4e5857d894494ae6058cf1.tar.xz
mpd-70652abf9750b62d2b4e5857d894494ae6058cf1.zip
Queue: add constructor and destructor
Diffstat (limited to '')
-rw-r--r--src/Queue.cxx46
1 files changed, 19 insertions, 27 deletions
diff --git a/src/Queue.cxx b/src/Queue.cxx
index 485ffb1cc..a8a737540 100644
--- a/src/Queue.cxx
+++ b/src/Queue.cxx
@@ -300,40 +300,32 @@ queue_clear(struct queue *queue)
queue->length = 0;
}
-void
-queue_init(struct queue *queue, unsigned max_length)
+queue::queue(unsigned _max_length)
+ :max_length(_max_length), length(0),
+ version(1),
+ items(g_new(struct queue_item, max_length)),
+ order((unsigned *)g_malloc(sizeof(order[0]) * max_length)),
+ id_to_position((int *)g_malloc(sizeof(id_to_position[0]) *
+ max_length * QUEUE_HASH_MULT)),
+ repeat(false),
+ single(false),
+ consume(false),
+ random(false),
+ rand(g_rand_new())
{
- queue->max_length = max_length;
- queue->length = 0;
- queue->version = 1;
- queue->repeat = false;
- queue->random = false;
- queue->single = false;
- queue->consume = false;
-
- queue->items = g_new(struct queue_item, max_length);
- queue->order = (unsigned *)
- g_malloc(sizeof(queue->order[0]) * max_length);
- queue->id_to_position = (int *)
- g_malloc(sizeof(queue->id_to_position[0]) *
- max_length * QUEUE_HASH_MULT);
-
for (unsigned i = 0; i < max_length * QUEUE_HASH_MULT; ++i)
- queue->id_to_position[i] = -1;
-
- queue->rand = g_rand_new();
+ id_to_position[i] = -1;
}
-void
-queue_finish(struct queue *queue)
+queue::~queue()
{
- queue_clear(queue);
+ queue_clear(this);
- g_free(queue->items);
- g_free(queue->order);
- g_free(queue->id_to_position);
+ g_free(items);
+ g_free(order);
+ g_free(id_to_position);
- g_rand_free(queue->rand);
+ g_rand_free(rand);
}
static const struct queue_item *