aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAnton Khirnov <anton@khirnov.net>2013-04-22 18:54:15 +0200
committerAnton Khirnov <anton@khirnov.net>2013-11-04 11:02:13 +0100
commitfb1586abf5a4081bb0b7397577f584c5a06daa84 (patch)
treebad931b1929e8099a71c7dea93b9f4a1d8ca3a90
parentcf7d6e3374ca3d54e71124b54ead5fdd8d6973e1 (diff)
decoder_buffer: remove
It is unused.
-rw-r--r--src/Makefile1
-rw-r--r--src/decoder_buffer.c167
-rw-r--r--src/decoder_buffer.h106
3 files changed, 0 insertions, 274 deletions
diff --git a/src/Makefile b/src/Makefile
index 7e7b5598..c6820dff 100644
--- a/src/Makefile
+++ b/src/Makefile
@@ -33,7 +33,6 @@ OBJS = aiff.o \
db_save.o \
dbUtils.o \
decoder_api.o \
- decoder_buffer.o \
decoder_control.o \
decoder_internal.o \
decoder_list.o \
diff --git a/src/decoder_buffer.c b/src/decoder_buffer.c
deleted file mode 100644
index fcb13597..00000000
--- a/src/decoder_buffer.c
+++ /dev/null
@@ -1,167 +0,0 @@
-/*
- * Copyright (C) 2003-2011 The Music Player Daemon Project
- * http://www.musicpd.org
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License along
- * with this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
- */
-
-#include "config.h"
-#include "decoder_buffer.h"
-#include "decoder_api.h"
-
-#include <glib.h>
-
-#include <assert.h>
-
-struct decoder_buffer {
- struct decoder *decoder;
- struct input_stream *is;
-
- /** the allocated size of the buffer */
- size_t size;
-
- /** the current length of the buffer */
- size_t length;
-
- /** number of bytes already consumed at the beginning of the
- buffer */
- size_t consumed;
-
- /** the actual buffer (dynamic size) */
- unsigned char data[sizeof(size_t)];
-};
-
-struct decoder_buffer *
-decoder_buffer_new(struct decoder *decoder, struct input_stream *is,
- size_t size)
-{
- struct decoder_buffer *buffer =
- g_malloc(sizeof(*buffer) - sizeof(buffer->data) + size);
-
- assert(is != NULL);
- assert(size > 0);
-
- buffer->decoder = decoder;
- buffer->is = is;
- buffer->size = size;
- buffer->length = 0;
- buffer->consumed = 0;
-
- return buffer;
-}
-
-void
-decoder_buffer_free(struct decoder_buffer *buffer)
-{
- assert(buffer != NULL);
-
- g_free(buffer);
-}
-
-bool
-decoder_buffer_is_empty(const struct decoder_buffer *buffer)
-{
- return buffer->consumed == buffer->length;
-}
-
-bool
-decoder_buffer_is_full(const struct decoder_buffer *buffer)
-{
- return buffer->consumed == 0 && buffer->length == buffer->size;
-}
-
-static void
-decoder_buffer_shift(struct decoder_buffer *buffer)
-{
- assert(buffer->consumed > 0);
-
- buffer->length -= buffer->consumed;
- memmove(buffer->data, buffer->data + buffer->consumed, buffer->length);
- buffer->consumed = 0;
-}
-
-bool
-decoder_buffer_fill(struct decoder_buffer *buffer)
-{
- size_t nbytes;
-
- if (buffer->consumed > 0)
- decoder_buffer_shift(buffer);
-
- if (buffer->length >= buffer->size)
- /* buffer is full */
- return false;
-
- nbytes = decoder_read(buffer->decoder, buffer->is,
- buffer->data + buffer->length,
- buffer->size - buffer->length);
- if (nbytes == 0)
- /* end of file, I/O error or decoder command
- received */
- return false;
-
- buffer->length += nbytes;
- assert(buffer->length <= buffer->size);
-
- return true;
-}
-
-const void *
-decoder_buffer_read(const struct decoder_buffer *buffer, size_t *length_r)
-{
- if (buffer->consumed >= buffer->length)
- /* buffer is empty */
- return NULL;
-
- *length_r = buffer->length - buffer->consumed;
- return buffer->data + buffer->consumed;
-}
-
-void
-decoder_buffer_consume(struct decoder_buffer *buffer, size_t nbytes)
-{
- /* just move the "consumed" pointer - decoder_buffer_shift()
- will do the real work later (called by
- decoder_buffer_fill()) */
- buffer->consumed += nbytes;
-
- assert(buffer->consumed <= buffer->length);
-}
-
-bool
-decoder_buffer_skip(struct decoder_buffer *buffer, size_t nbytes)
-{
- size_t length;
- const void *data;
- bool success;
-
- /* this could probably be optimized by seeking */
-
- while (true) {
- data = decoder_buffer_read(buffer, &length);
- if (data != NULL) {
- if (length > nbytes)
- length = nbytes;
- decoder_buffer_consume(buffer, length);
- nbytes -= length;
- if (nbytes == 0)
- return true;
- }
-
- success = decoder_buffer_fill(buffer);
- if (!success)
- return false;
- }
-}
diff --git a/src/decoder_buffer.h b/src/decoder_buffer.h
deleted file mode 100644
index 77eff5dd..00000000
--- a/src/decoder_buffer.h
+++ /dev/null
@@ -1,106 +0,0 @@
-/*
- * Copyright (C) 2003-2011 The Music Player Daemon Project
- * http://www.musicpd.org
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License along
- * with this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
- */
-
-#ifndef MPD_DECODER_BUFFER_H
-#define MPD_DECODER_BUFFER_H
-
-#include <stdbool.h>
-#include <stddef.h>
-
-/**
- * This objects handles buffered reads in decoder plugins easily. You
- * create a buffer object, and use its high-level methods to fill and
- * read it. It will automatically handle shifting the buffer.
- */
-struct decoder_buffer;
-
-struct decoder;
-struct input_stream;
-
-/**
- * Creates a new buffer.
- *
- * @param decoder the decoder object, used for decoder_read(), may be NULL
- * @param is the input stream object where we should read from
- * @param size the maximum size of the buffer
- * @return the new decoder_buffer object
- */
-struct decoder_buffer *
-decoder_buffer_new(struct decoder *decoder, struct input_stream *is,
- size_t size);
-
-/**
- * Frees resources used by the decoder_buffer object.
- */
-void
-decoder_buffer_free(struct decoder_buffer *buffer);
-
-bool
-decoder_buffer_is_empty(const struct decoder_buffer *buffer);
-
-bool
-decoder_buffer_is_full(const struct decoder_buffer *buffer);
-
-/**
- * Read data from the input_stream and append it to the buffer.
- *
- * @return true if data was appended; false if there is no data
- * available (yet), end of file, I/O error or a decoder command was
- * received
- */
-bool
-decoder_buffer_fill(struct decoder_buffer *buffer);
-
-/**
- * Reads data from the buffer. This data is not yet consumed, you
- * have to call decoder_buffer_consume() to do that. The returned
- * buffer becomes invalid after a decoder_buffer_fill() or a
- * decoder_buffer_consume() call.
- *
- * @param buffer the decoder_buffer object
- * @param length_r pointer to a size_t where you will receive the
- * number of bytes available
- * @return a pointer to the read buffer, or NULL if there is no data
- * available
- */
-const void *
-decoder_buffer_read(const struct decoder_buffer *buffer, size_t *length_r);
-
-/**
- * Consume (delete, invalidate) a part of the buffer. The "nbytes"
- * parameter must not be larger than the length returned by
- * decoder_buffer_read().
- *
- * @param buffer the decoder_buffer object
- * @param nbytes the number of bytes to consume
- */
-void
-decoder_buffer_consume(struct decoder_buffer *buffer, size_t nbytes);
-
-/**
- * Skips the specified number of bytes, discarding its data.
- *
- * @param buffer the decoder_buffer object
- * @param nbytes the number of bytes to skip
- * @return true on success, false on error
- */
-bool
-decoder_buffer_skip(struct decoder_buffer *buffer, size_t nbytes);
-
-#endif