Mercurial > audlegacy
view libaudacious/vfs_buffer.c @ 2126:dba25b0e98c8 trunk
[svn] - use playlist_get_active() at the top of each thread.
author | nenolod |
---|---|
date | Fri, 15 Dec 2006 07:52:09 -0800 |
parents | f18a5b617c34 |
children |
line wrap: on
line source
/* Audacious * Copyright (c) 2006 William Pitcock * * 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; under version 2 of the License. * * 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 <glib.h> #include <string.h> #include "vfs.h" #include "vfs_buffer.h" VFSFile * buffer_vfs_fopen_impl(const gchar * path, const gchar * mode) { return NULL; } gint buffer_vfs_fclose_impl(VFSFile * file) { g_return_val_if_fail(file != NULL, -1); if (file->handle) g_free(file->handle); return 0; } size_t buffer_vfs_fread_impl(gpointer i_ptr, size_t size, size_t nmemb, VFSFile * file) { VFSBuffer *handle; guchar *i; size_t read = 0; guchar *ptr = (guchar *) i_ptr; if (file == NULL) return 0; handle = (VFSBuffer *) file->handle; for (i = ptr; i - ptr <= nmemb * size && i - ptr <= handle->size; i++, handle->iter++) { *i = *handle->iter; read++; } return (read / nmemb); } size_t buffer_vfs_fwrite_impl(gconstpointer i_ptr, size_t size, size_t nmemb, VFSFile * file) { VFSBuffer *handle; const guchar *i; size_t written = 0; const guchar *ptr = (const guchar *) i_ptr; if (file == NULL) return 0; handle = (VFSBuffer *) file->handle; for (i = ptr; (i - ptr) <= nmemb * size && (i - ptr) <= handle->size; i++, handle->iter++) { *handle->iter = *i; written++; } return (written / nmemb); } gint buffer_vfs_getc_impl(VFSFile *stream) { VFSBuffer *handle = (VFSBuffer *) stream->handle; gint c; c = *handle->iter; handle->iter++; return c; } gint buffer_vfs_ungetc_impl(gint c, VFSFile *stream) { return -1; } gint buffer_vfs_fseek_impl(VFSFile * file, glong offset, gint whence) { VFSBuffer *handle; if (file == NULL) return 0; handle = (VFSBuffer *) file->handle; switch(whence) { case SEEK_CUR: handle->iter = handle->iter + offset; break; case SEEK_END: handle->iter = handle->end; break; case SEEK_SET: default: handle->iter = handle->data + offset; break; } return 0; } void buffer_vfs_rewind_impl(VFSFile * file) { VFSBuffer *handle; if (file == NULL) return; handle = (VFSBuffer *) file->handle; handle->iter = handle->data; } glong buffer_vfs_ftell_impl(VFSFile * file) { VFSBuffer *handle; if (file == NULL) return 0; handle = (VFSBuffer *) file->handle; return handle->iter - handle->data; } gboolean buffer_vfs_feof_impl(VFSFile * file) { VFSBuffer *handle; if (file == NULL) return FALSE; handle = (VFSBuffer *) file->handle; return (gboolean) (handle->iter == handle->end); } gint buffer_vfs_truncate_impl(VFSFile * file, glong size) { return 0; } VFSConstructor buffer_const = { NULL, // not a normal VFS class buffer_vfs_fopen_impl, buffer_vfs_fclose_impl, buffer_vfs_fread_impl, buffer_vfs_fwrite_impl, buffer_vfs_getc_impl, buffer_vfs_ungetc_impl, buffer_vfs_fseek_impl, buffer_vfs_rewind_impl, buffer_vfs_ftell_impl, buffer_vfs_feof_impl, buffer_vfs_truncate_impl }; VFSFile * vfs_buffer_new(gpointer data, gsize size) { VFSFile *handle; VFSBuffer *buffer; g_return_val_if_fail(data != NULL, NULL); g_return_val_if_fail(size > 0, NULL); handle = g_new0(VFSFile, 1); handle->uri == NULL; buffer = g_new0(VFSBuffer, 1); buffer->data = data; buffer->iter = data; buffer->end = data + size; buffer->size = size; handle->handle = buffer; handle->base = &buffer_const; return handle; } VFSFile * vfs_buffer_new_from_string(gchar *str) { g_return_val_if_fail(str != NULL, NULL); return vfs_buffer_new(str, strlen(str)); }