annotate libaudacious/vfs.c @ 2060:53a3d5db6b58 trunk

[svn] - finish documenting the libaudacious API
author nenolod
date Mon, 04 Dec 2006 19:24:14 -0800
parents 8aaf0f145578
children b9c6f1305c99
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1997
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
1 /* Audacious
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
2 * Copyright (c) 2006 William Pitcock
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
3 *
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
4 * This program is free software; you can redistribute it and/or modify
1460
411b4aaf928b [svn] fine
nemo
parents: 1459
diff changeset
5 * it under the terms of the GNU General Public License as published by
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
6 * the Free Software Foundation; either version 2 of the License, or
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
7 * (at your option) any later version.
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
8 *
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
9 * This program is distributed in the hope that it will be useful,
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
12 * GNU General Public License for more details.
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
13 *
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
14 * You should have received a copy of the GNU General Public License
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
15 * along with this program; if not, write to the Free Software
1459
705d4c089fce [svn] Fix postal code.
chainsaw
parents: 1458
diff changeset
16 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
17 */
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
18
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
19 #include "vfs.h"
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
20 #include <stdio.h>
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
21
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
22 #include <unistd.h>
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
23 #include <sys/stat.h>
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
24 #include <sys/types.h>
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
25
1997
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
26 static GList *vfs_transports = NULL;
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
27
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
28 #ifdef VFS_DEBUG
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
29 # define DBG(x, args...) g_print(x, ## args);
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
30 #else
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
31 # define DBG(x, args...)
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
32 #endif
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
33
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
34 /**
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
35 * vfs_register_transport:
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
36 * @vtable: The #VFSConstructor vtable to register.
2032
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
37 *
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
38 * Registers a #VFSConstructor vtable with the VFS system.
2032
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
39 *
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
40 * Return value: TRUE on success, FALSE on failure.
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
41 **/
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
42 gboolean
1997
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
43 vfs_register_transport(VFSConstructor *vtable)
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
44 {
1997
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
45 vfs_transports = g_list_append(vfs_transports, vtable);
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
46
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
47 return TRUE;
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
48 }
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
49
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
50 /**
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
51 * vfs_fopen:
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
52 * @path: The path or URI to open.
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
53 * @mode: The preferred access privileges (not guaranteed).
2032
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
54 *
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
55 * Opens a stream from a VFS transport using a #VFSConstructor.
2032
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
56 *
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
57 * Return value: On success, a #VFSFile object representing the stream.
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
58 **/
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
59 VFSFile *
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
60 vfs_fopen(const gchar * path,
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
61 const gchar * mode)
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
62 {
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
63 VFSFile *file;
1997
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
64 gchar **vec;
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
65 VFSConstructor *vtable = NULL;
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
66 GList *node;
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
67
550
adee87ebe853 [svn] Sanity checking inside vfs_() functions.
nenolod
parents: 0
diff changeset
68 if (!path || !mode)
adee87ebe853 [svn] Sanity checking inside vfs_() functions.
nenolod
parents: 0
diff changeset
69 return NULL;
adee87ebe853 [svn] Sanity checking inside vfs_() functions.
nenolod
parents: 0
diff changeset
70
1997
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
71 vec = g_strsplit(path, "://", 2);
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
72
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
73 /* special case: no transport specified, look for the "/" transport */
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
74 if (vec[1] == NULL)
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
75 {
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
76 for (node = vfs_transports; node != NULL; node = g_list_next(node))
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
77 {
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
78 vtable = (VFSConstructor *) node->data;
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
79
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
80 if (*vtable->uri_id == '/')
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
81 break;
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
82 }
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
83 }
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
84 else
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
85 {
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
86 for (node = vfs_transports; node != NULL; node = g_list_next(node))
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
87 {
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
88 vtable = (VFSConstructor *) node->data;
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
89
1997
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
90 if (!g_strcasecmp(vec[0], vtable->uri_id))
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
91 break;
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
92 }
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
93 }
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
94
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
95 /* no transport vtable has been registered, bail. */
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
96 if (vtable == NULL)
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
97 {
2031
ebce0d5efac1 [svn] - don't leak the split URI vector after doing the vtable lookup
nenolod
parents: 1999
diff changeset
98 g_strfreev(vec);
1997
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
99 return NULL;
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
100 }
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
101
1997
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
102 file = vtable->vfs_fopen_impl(vec[1] ? vec[1] : vec[0], mode);
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
103
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
104 if (file == NULL)
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
105 {
2032
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
106 g_strfreev(vec);
1997
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
107 return NULL;
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
108 }
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
109
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
110 file->uri = g_strdup(path);
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
111 file->base = vtable;
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
112
2031
ebce0d5efac1 [svn] - don't leak the split URI vector after doing the vtable lookup
nenolod
parents: 1999
diff changeset
113 g_strfreev(vec);
ebce0d5efac1 [svn] - don't leak the split URI vector after doing the vtable lookup
nenolod
parents: 1999
diff changeset
114
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
115 return file;
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
116 }
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
117
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
118 /**
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
119 * vfs_fclose:
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
120 * @file: A #VFSFile object to destroy.
2032
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
121 *
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
122 * Closes a VFS stream and destroys a #VFSFile object.
2032
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
123 *
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
124 * Return value: -1 on failure, 0 on success.
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
125 **/
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
126 gint
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
127 vfs_fclose(VFSFile * file)
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
128 {
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
129 gint ret = 0;
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
130
821
a17888ed66a8 [svn] - safety checks
nenolod
parents: 811
diff changeset
131 if (file == NULL)
a17888ed66a8 [svn] - safety checks
nenolod
parents: 811
diff changeset
132 return -1;
a17888ed66a8 [svn] - safety checks
nenolod
parents: 811
diff changeset
133
1997
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
134 if (file->base->vfs_fclose_impl(file) != 0)
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
135 ret = -1;
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
136
1999
dcea7c329ad6 [svn] - don't memory leak the uri
nenolod
parents: 1998
diff changeset
137 if (file->uri != NULL)
dcea7c329ad6 [svn] - don't memory leak the uri
nenolod
parents: 1998
diff changeset
138 g_free(file->uri);
dcea7c329ad6 [svn] - don't memory leak the uri
nenolod
parents: 1998
diff changeset
139
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
140 g_free(file);
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
141
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
142 return ret;
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
143 }
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
144
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
145 /**
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
146 * vfs_fread:
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
147 * @ptr: A pointer to the destination buffer.
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
148 * @size: The size of each element to read.
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
149 * @nmemb: The number of elements to read.
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
150 * @file: #VFSFile object that represents the VFS stream.
2032
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
151 *
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
152 * Reads from a VFS stream.
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
153 *
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
154 * Return value: The amount of elements succesfully read.
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
155 **/
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
156 size_t
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
157 vfs_fread(gpointer ptr,
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
158 size_t size,
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
159 size_t nmemb,
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
160 VFSFile * file)
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
161 {
821
a17888ed66a8 [svn] - safety checks
nenolod
parents: 811
diff changeset
162 if (file == NULL)
a17888ed66a8 [svn] - safety checks
nenolod
parents: 811
diff changeset
163 return 0;
a17888ed66a8 [svn] - safety checks
nenolod
parents: 811
diff changeset
164
1997
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
165 return file->base->vfs_fread_impl(ptr, size, nmemb, file);
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
166 }
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
167
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
168 /**
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
169 * vfs_fwrite:
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
170 * @ptr: A const pointer to the source buffer.
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
171 * @size: The size of each element to write.
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
172 * @nmemb: The number of elements to write.
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
173 * @file: #VFSFile object that represents the VFS stream.
2032
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
174 *
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
175 * Writes to a VFS stream.
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
176 *
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
177 * Return value: The amount of elements succesfully written.
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
178 **/
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
179 size_t
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
180 vfs_fwrite(gconstpointer ptr,
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
181 size_t size,
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
182 size_t nmemb,
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
183 VFSFile * file)
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
184 {
821
a17888ed66a8 [svn] - safety checks
nenolod
parents: 811
diff changeset
185 if (file == NULL)
a17888ed66a8 [svn] - safety checks
nenolod
parents: 811
diff changeset
186 return 0;
a17888ed66a8 [svn] - safety checks
nenolod
parents: 811
diff changeset
187
1997
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
188 return file->base->vfs_fwrite_impl(ptr, size, nmemb, file);
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
189 }
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
190
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
191 /**
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
192 * vfs_getc:
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
193 * @stream: #VFSFile object that represents the VFS stream.
2032
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
194 *
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
195 * Reads a character from a VFS stream.
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
196 *
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
197 * Return value: On success, a character. Otherwise, -1.
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
198 **/
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
199 gint
1683
e9c24e35bd76 [svn] - File stream API for audacious vfs; uses real getc/ungetc functions for vfs_stdio and emulated functions for vfs_gnome
giacomo
parents: 1460
diff changeset
200 vfs_getc(VFSFile *stream)
e9c24e35bd76 [svn] - File stream API for audacious vfs; uses real getc/ungetc functions for vfs_stdio and emulated functions for vfs_gnome
giacomo
parents: 1460
diff changeset
201 {
1997
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
202 if (stream == NULL)
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
203 return -1;
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
204
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
205 return stream->base->vfs_getc_impl(stream);
1683
e9c24e35bd76 [svn] - File stream API for audacious vfs; uses real getc/ungetc functions for vfs_stdio and emulated functions for vfs_gnome
giacomo
parents: 1460
diff changeset
206 }
e9c24e35bd76 [svn] - File stream API for audacious vfs; uses real getc/ungetc functions for vfs_stdio and emulated functions for vfs_gnome
giacomo
parents: 1460
diff changeset
207
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
208 /**
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
209 * vfs_ungetc:
2060
53a3d5db6b58 [svn] - finish documenting the libaudacious API
nenolod
parents: 2059
diff changeset
210 * @c: The character to push back.
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
211 * @stream: #VFSFile object that represents the VFS stream.
2032
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
212 *
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
213 * Pushes a character back to the VFS stream.
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
214 *
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
215 * Return value: On success, 0. Otherwise, -1.
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
216 **/
1683
e9c24e35bd76 [svn] - File stream API for audacious vfs; uses real getc/ungetc functions for vfs_stdio and emulated functions for vfs_gnome
giacomo
parents: 1460
diff changeset
217 gint
e9c24e35bd76 [svn] - File stream API for audacious vfs; uses real getc/ungetc functions for vfs_stdio and emulated functions for vfs_gnome
giacomo
parents: 1460
diff changeset
218 vfs_ungetc(gint c, VFSFile *stream)
e9c24e35bd76 [svn] - File stream API for audacious vfs; uses real getc/ungetc functions for vfs_stdio and emulated functions for vfs_gnome
giacomo
parents: 1460
diff changeset
219 {
1997
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
220 if (stream == NULL)
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
221 return -1;
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
222
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
223 return stream->base->vfs_ungetc_impl(c, stream);
1683
e9c24e35bd76 [svn] - File stream API for audacious vfs; uses real getc/ungetc functions for vfs_stdio and emulated functions for vfs_gnome
giacomo
parents: 1460
diff changeset
224 }
e9c24e35bd76 [svn] - File stream API for audacious vfs; uses real getc/ungetc functions for vfs_stdio and emulated functions for vfs_gnome
giacomo
parents: 1460
diff changeset
225
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
226 /**
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
227 * vfs_fseek:
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
228 * @file: #VFSFile object that represents the VFS stream.
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
229 * @offset: The offset to seek to.
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
230 * @whence: Whether or not the seek is absolute or not.
2032
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
231 *
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
232 * Seeks through a VFS stream.
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
233 *
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
234 * Return value: On success, 1. Otherwise, 0.
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
235 **/
1683
e9c24e35bd76 [svn] - File stream API for audacious vfs; uses real getc/ungetc functions for vfs_stdio and emulated functions for vfs_gnome
giacomo
parents: 1460
diff changeset
236 gint
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
237 vfs_fseek(VFSFile * file,
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
238 glong offset,
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
239 gint whence)
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
240 {
821
a17888ed66a8 [svn] - safety checks
nenolod
parents: 811
diff changeset
241 if (file == NULL)
a17888ed66a8 [svn] - safety checks
nenolod
parents: 811
diff changeset
242 return 0;
a17888ed66a8 [svn] - safety checks
nenolod
parents: 811
diff changeset
243
1997
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
244 return file->base->vfs_fseek_impl(file, offset, whence);
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
245 }
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
246
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
247 /**
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
248 * vfs_rewind:
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
249 * @file: #VFSFile object that represents the VFS stream.
2032
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
250 *
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
251 * Rewinds a VFS stream.
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
252 **/
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
253 void
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
254 vfs_rewind(VFSFile * file)
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
255 {
821
a17888ed66a8 [svn] - safety checks
nenolod
parents: 811
diff changeset
256 if (file == NULL)
a17888ed66a8 [svn] - safety checks
nenolod
parents: 811
diff changeset
257 return;
a17888ed66a8 [svn] - safety checks
nenolod
parents: 811
diff changeset
258
1997
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
259 file->base->vfs_rewind_impl(file);
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
260 }
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
261
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
262 /**
2059
8aaf0f145578 [svn] - documentation fixups
nenolod
parents: 2034
diff changeset
263 * vfs_ftell:
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
264 * @file: #VFSFile object that represents the VFS stream.
2032
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
265 *
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
266 * Returns the current position in the VFS stream's buffer.
2032
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
267 *
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
268 * Return value: On success, the current position. Otherwise, -1.
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
269 **/
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
270 glong
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
271 vfs_ftell(VFSFile * file)
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
272 {
821
a17888ed66a8 [svn] - safety checks
nenolod
parents: 811
diff changeset
273 if (file == NULL)
2032
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
274 return -1;
821
a17888ed66a8 [svn] - safety checks
nenolod
parents: 811
diff changeset
275
1997
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
276 return file->base->vfs_ftell_impl(file);
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
277 }
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
278
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
279 /**
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
280 * vfs_feof:
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
281 * @file: #VFSFile object that represents the VFS stream.
2032
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
282 *
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
283 * Returns whether or not the VFS stream has reached EOF.
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
284 *
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
285 * Return value: On success, whether or not the VFS stream is at EOF. Otherwise, FALSE.
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
286 **/
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
287 gboolean
811
86ca43d8a845 [svn] - implement vfs_feof() and vfs_ftell() and update the scrobbler plugin to reflect that,
nenolod
parents: 550
diff changeset
288 vfs_feof(VFSFile * file)
86ca43d8a845 [svn] - implement vfs_feof() and vfs_ftell() and update the scrobbler plugin to reflect that,
nenolod
parents: 550
diff changeset
289 {
821
a17888ed66a8 [svn] - safety checks
nenolod
parents: 811
diff changeset
290 if (file == NULL)
a17888ed66a8 [svn] - safety checks
nenolod
parents: 811
diff changeset
291 return FALSE;
a17888ed66a8 [svn] - safety checks
nenolod
parents: 811
diff changeset
292
1997
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
293 return (gboolean) file->base->vfs_feof_impl(file);
811
86ca43d8a845 [svn] - implement vfs_feof() and vfs_ftell() and update the scrobbler plugin to reflect that,
nenolod
parents: 550
diff changeset
294 }
86ca43d8a845 [svn] - implement vfs_feof() and vfs_ftell() and update the scrobbler plugin to reflect that,
nenolod
parents: 550
diff changeset
295
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
296 /**
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
297 * vfs_truncate:
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
298 * @file: #VFSFile object that represents the VFS stream.
2059
8aaf0f145578 [svn] - documentation fixups
nenolod
parents: 2034
diff changeset
299 * @length: The length to truncate at.
2032
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
300 *
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
301 * Truncates a VFS stream to a certain size.
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
302 *
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
303 * Return value: On success, 0. Otherwise, -1.
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
304 **/
2032
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
305 gint
2059
8aaf0f145578 [svn] - documentation fixups
nenolod
parents: 2034
diff changeset
306 vfs_truncate(VFSFile * file, glong length)
2032
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
307 {
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
308 if (file == NULL)
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
309 return -1;
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
310
2059
8aaf0f145578 [svn] - documentation fixups
nenolod
parents: 2034
diff changeset
311 return file->base->vfs_truncate_impl(file, length);
2032
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
312 }
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
313
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
314 /**
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
315 * vfs_file_test:
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
316 * @path: A path to test.
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
317 * @test: A GFileTest to run.
2032
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
318 *
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
319 * Wrapper for g_file_test().
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
320 *
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
321 * Return value: The result of g_file_test().
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
322 **/
811
86ca43d8a845 [svn] - implement vfs_feof() and vfs_ftell() and update the scrobbler plugin to reflect that,
nenolod
parents: 550
diff changeset
323 gboolean
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
324 vfs_file_test(const gchar * path, GFileTest test)
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
325 {
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
326 return g_file_test(path, test);
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
327 }
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
328
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
329 /**
2059
8aaf0f145578 [svn] - documentation fixups
nenolod
parents: 2034
diff changeset
330 * vfs_is_writeable:
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
331 * @path: A path to test.
2032
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
332 *
2059
8aaf0f145578 [svn] - documentation fixups
nenolod
parents: 2034
diff changeset
333 * Tests if a file is writeable.
2032
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
334 *
2059
8aaf0f145578 [svn] - documentation fixups
nenolod
parents: 2034
diff changeset
335 * Return value: TRUE if the file is writeable, otherwise FALSE.
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
336 **/
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
337 gboolean
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
338 vfs_is_writeable(const gchar * path)
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
339 {
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
340 struct stat info;
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
341
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
342 if (stat(path, &info) == -1)
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
343 return FALSE;
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
344
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
345 return (info.st_mode & S_IWUSR);
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
346 }