annotate libaudacious/vfs.c @ 2087:bc47a2129067 trunk

[svn] - update these files
author nenolod
date Mon, 11 Dec 2006 04:30:50 -0800
parents b9c6f1305c99
children f18a5b617c34
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
2071
b9c6f1305c99 [svn] - move urldecode to libaudacious
nenolod
parents: 2060
diff changeset
26 #include "urldecode.h"
b9c6f1305c99 [svn] - move urldecode to libaudacious
nenolod
parents: 2060
diff changeset
27
1997
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
28 static GList *vfs_transports = NULL;
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
29
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
30 #ifdef VFS_DEBUG
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
31 # define DBG(x, args...) g_print(x, ## args);
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
32 #else
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
33 # define DBG(x, args...)
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
34 #endif
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
35
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
36 /**
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
37 * vfs_register_transport:
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
38 * @vtable: The #VFSConstructor vtable to register.
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 * Registers a #VFSConstructor vtable with the VFS system.
2032
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
41 *
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
42 * Return value: TRUE on success, FALSE on failure.
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
43 **/
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
44 gboolean
1997
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
45 vfs_register_transport(VFSConstructor *vtable)
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
46 {
1997
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
47 vfs_transports = g_list_append(vfs_transports, vtable);
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
48
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
49 return TRUE;
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
50 }
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
51
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
52 /**
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
53 * vfs_fopen:
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
54 * @path: The path or URI to open.
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
55 * @mode: The preferred access privileges (not guaranteed).
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 * Opens a stream from a VFS transport using a #VFSConstructor.
2032
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
58 *
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
59 * Return value: On success, a #VFSFile object representing the stream.
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
60 **/
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
61 VFSFile *
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
62 vfs_fopen(const gchar * path,
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
63 const gchar * mode)
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
64 {
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
65 VFSFile *file;
1997
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
66 gchar **vec;
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
67 VFSConstructor *vtable = NULL;
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
68 GList *node;
2071
b9c6f1305c99 [svn] - move urldecode to libaudacious
nenolod
parents: 2060
diff changeset
69 gchar *decpath;
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
70
550
adee87ebe853 [svn] Sanity checking inside vfs_() functions.
nenolod
parents: 0
diff changeset
71 if (!path || !mode)
adee87ebe853 [svn] Sanity checking inside vfs_() functions.
nenolod
parents: 0
diff changeset
72 return NULL;
adee87ebe853 [svn] Sanity checking inside vfs_() functions.
nenolod
parents: 0
diff changeset
73
2071
b9c6f1305c99 [svn] - move urldecode to libaudacious
nenolod
parents: 2060
diff changeset
74 decpath = xmms_urldecode_plain(path);
b9c6f1305c99 [svn] - move urldecode to libaudacious
nenolod
parents: 2060
diff changeset
75
b9c6f1305c99 [svn] - move urldecode to libaudacious
nenolod
parents: 2060
diff changeset
76 vec = g_strsplit(decpath, "://", 2);
1997
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
77
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
78 /* special case: no transport specified, look for the "/" transport */
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
79 if (vec[1] == NULL)
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
80 {
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
81 for (node = vfs_transports; node != NULL; node = g_list_next(node))
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
82 {
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
83 vtable = (VFSConstructor *) node->data;
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
84
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
85 if (*vtable->uri_id == '/')
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
86 break;
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
87 }
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
88 }
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
89 else
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
90 {
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
91 for (node = vfs_transports; node != NULL; node = g_list_next(node))
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
92 {
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
93 vtable = (VFSConstructor *) node->data;
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
94
1997
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
95 if (!g_strcasecmp(vec[0], vtable->uri_id))
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
96 break;
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
97 }
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
98 }
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
99
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
100 /* no transport vtable has been registered, bail. */
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
101 if (vtable == NULL)
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
102 {
2031
ebce0d5efac1 [svn] - don't leak the split URI vector after doing the vtable lookup
nenolod
parents: 1999
diff changeset
103 g_strfreev(vec);
1997
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
104 return NULL;
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
105 }
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
106
1997
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
107 file = vtable->vfs_fopen_impl(vec[1] ? vec[1] : vec[0], mode);
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
108
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
109 if (file == NULL)
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
110 {
2032
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
111 g_strfreev(vec);
1997
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
112 return NULL;
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
113 }
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
114
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
115 file->uri = g_strdup(path);
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
116 file->base = vtable;
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
117
2031
ebce0d5efac1 [svn] - don't leak the split URI vector after doing the vtable lookup
nenolod
parents: 1999
diff changeset
118 g_strfreev(vec);
2071
b9c6f1305c99 [svn] - move urldecode to libaudacious
nenolod
parents: 2060
diff changeset
119 g_free(decpath);
2031
ebce0d5efac1 [svn] - don't leak the split URI vector after doing the vtable lookup
nenolod
parents: 1999
diff changeset
120
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
121 return file;
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
122 }
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
123
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
124 /**
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
125 * vfs_fclose:
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
126 * @file: A #VFSFile object to destroy.
2032
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
127 *
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
128 * Closes a VFS stream and destroys a #VFSFile object.
2032
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
129 *
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
130 * Return value: -1 on failure, 0 on success.
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
131 **/
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
132 gint
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
133 vfs_fclose(VFSFile * file)
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
134 {
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
135 gint ret = 0;
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
136
821
a17888ed66a8 [svn] - safety checks
nenolod
parents: 811
diff changeset
137 if (file == NULL)
a17888ed66a8 [svn] - safety checks
nenolod
parents: 811
diff changeset
138 return -1;
a17888ed66a8 [svn] - safety checks
nenolod
parents: 811
diff changeset
139
1997
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
140 if (file->base->vfs_fclose_impl(file) != 0)
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
141 ret = -1;
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
142
1999
dcea7c329ad6 [svn] - don't memory leak the uri
nenolod
parents: 1998
diff changeset
143 if (file->uri != NULL)
dcea7c329ad6 [svn] - don't memory leak the uri
nenolod
parents: 1998
diff changeset
144 g_free(file->uri);
dcea7c329ad6 [svn] - don't memory leak the uri
nenolod
parents: 1998
diff changeset
145
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
146 g_free(file);
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
147
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
148 return ret;
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
149 }
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
150
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
151 /**
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
152 * vfs_fread:
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
153 * @ptr: A pointer to the destination buffer.
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
154 * @size: The size of each element to read.
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
155 * @nmemb: The number of elements to read.
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
156 * @file: #VFSFile object that represents the VFS stream.
2032
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
157 *
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
158 * Reads from a VFS stream.
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
159 *
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
160 * Return value: The amount of elements succesfully read.
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
161 **/
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
162 size_t
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
163 vfs_fread(gpointer ptr,
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
164 size_t size,
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
165 size_t nmemb,
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
166 VFSFile * file)
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
167 {
821
a17888ed66a8 [svn] - safety checks
nenolod
parents: 811
diff changeset
168 if (file == NULL)
a17888ed66a8 [svn] - safety checks
nenolod
parents: 811
diff changeset
169 return 0;
a17888ed66a8 [svn] - safety checks
nenolod
parents: 811
diff changeset
170
1997
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
171 return file->base->vfs_fread_impl(ptr, size, nmemb, file);
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
172 }
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
173
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
174 /**
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
175 * vfs_fwrite:
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
176 * @ptr: A const pointer to the source buffer.
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
177 * @size: The size of each element to write.
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
178 * @nmemb: The number of elements to write.
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
179 * @file: #VFSFile object that represents the VFS stream.
2032
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
180 *
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
181 * Writes to a VFS stream.
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
182 *
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
183 * Return value: The amount of elements succesfully written.
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
184 **/
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
185 size_t
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
186 vfs_fwrite(gconstpointer ptr,
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
187 size_t size,
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
188 size_t nmemb,
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
189 VFSFile * file)
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
190 {
821
a17888ed66a8 [svn] - safety checks
nenolod
parents: 811
diff changeset
191 if (file == NULL)
a17888ed66a8 [svn] - safety checks
nenolod
parents: 811
diff changeset
192 return 0;
a17888ed66a8 [svn] - safety checks
nenolod
parents: 811
diff changeset
193
1997
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
194 return file->base->vfs_fwrite_impl(ptr, size, nmemb, file);
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
195 }
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
196
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
197 /**
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
198 * vfs_getc:
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
199 * @stream: #VFSFile object that represents the VFS stream.
2032
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
200 *
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
201 * Reads a character from a VFS stream.
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
202 *
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
203 * Return value: On success, a character. Otherwise, -1.
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
204 **/
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
205 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
206 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
207 {
1997
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
208 if (stream == NULL)
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
209 return -1;
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
210
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
211 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
212 }
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
213
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
214 /**
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
215 * vfs_ungetc:
2060
53a3d5db6b58 [svn] - finish documenting the libaudacious API
nenolod
parents: 2059
diff changeset
216 * @c: The character to push back.
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
217 * @stream: #VFSFile object that represents the VFS stream.
2032
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
218 *
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
219 * Pushes a character back to the VFS stream.
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
220 *
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
221 * Return value: On success, 0. Otherwise, -1.
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
222 **/
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
223 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
224 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
225 {
1997
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
226 if (stream == NULL)
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
227 return -1;
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
228
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
229 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
230 }
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
231
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
232 /**
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
233 * vfs_fseek:
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
234 * @file: #VFSFile object that represents the VFS stream.
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
235 * @offset: The offset to seek to.
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
236 * @whence: Whether or not the seek is absolute or not.
2032
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
237 *
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
238 * Seeks through a VFS stream.
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
239 *
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
240 * Return value: On success, 1. Otherwise, 0.
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
241 **/
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
242 gint
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
243 vfs_fseek(VFSFile * file,
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
244 glong offset,
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
245 gint whence)
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
246 {
821
a17888ed66a8 [svn] - safety checks
nenolod
parents: 811
diff changeset
247 if (file == NULL)
a17888ed66a8 [svn] - safety checks
nenolod
parents: 811
diff changeset
248 return 0;
a17888ed66a8 [svn] - safety checks
nenolod
parents: 811
diff changeset
249
1997
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
250 return file->base->vfs_fseek_impl(file, offset, whence);
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
251 }
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
252
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
253 /**
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
254 * vfs_rewind:
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
255 * @file: #VFSFile object that represents the VFS stream.
2032
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
256 *
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
257 * Rewinds a VFS stream.
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
258 **/
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
259 void
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
260 vfs_rewind(VFSFile * file)
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
261 {
821
a17888ed66a8 [svn] - safety checks
nenolod
parents: 811
diff changeset
262 if (file == NULL)
a17888ed66a8 [svn] - safety checks
nenolod
parents: 811
diff changeset
263 return;
a17888ed66a8 [svn] - safety checks
nenolod
parents: 811
diff changeset
264
1997
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
265 file->base->vfs_rewind_impl(file);
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
266 }
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
267
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
268 /**
2059
8aaf0f145578 [svn] - documentation fixups
nenolod
parents: 2034
diff changeset
269 * vfs_ftell:
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
270 * @file: #VFSFile object that represents the VFS stream.
2032
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
271 *
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
272 * Returns the current position in the VFS stream's buffer.
2032
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
273 *
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
274 * Return value: On success, the current position. Otherwise, -1.
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
275 **/
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
276 glong
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
277 vfs_ftell(VFSFile * file)
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
278 {
821
a17888ed66a8 [svn] - safety checks
nenolod
parents: 811
diff changeset
279 if (file == NULL)
2032
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
280 return -1;
821
a17888ed66a8 [svn] - safety checks
nenolod
parents: 811
diff changeset
281
1997
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
282 return file->base->vfs_ftell_impl(file);
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
283 }
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
284
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
285 /**
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
286 * vfs_feof:
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
287 * @file: #VFSFile object that represents the VFS stream.
2032
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
288 *
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
289 * Returns whether or not the VFS stream has reached EOF.
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
290 *
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
291 * 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
292 **/
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
293 gboolean
811
86ca43d8a845 [svn] - implement vfs_feof() and vfs_ftell() and update the scrobbler plugin to reflect that,
nenolod
parents: 550
diff changeset
294 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
295 {
821
a17888ed66a8 [svn] - safety checks
nenolod
parents: 811
diff changeset
296 if (file == NULL)
a17888ed66a8 [svn] - safety checks
nenolod
parents: 811
diff changeset
297 return FALSE;
a17888ed66a8 [svn] - safety checks
nenolod
parents: 811
diff changeset
298
1997
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1976
diff changeset
299 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
300 }
86ca43d8a845 [svn] - implement vfs_feof() and vfs_ftell() and update the scrobbler plugin to reflect that,
nenolod
parents: 550
diff changeset
301
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
302 /**
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
303 * vfs_truncate:
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
304 * @file: #VFSFile object that represents the VFS stream.
2059
8aaf0f145578 [svn] - documentation fixups
nenolod
parents: 2034
diff changeset
305 * @length: The length to truncate at.
2032
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
306 *
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
307 * Truncates a VFS stream to a certain size.
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
308 *
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
309 * Return value: On success, 0. Otherwise, -1.
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
310 **/
2032
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
311 gint
2059
8aaf0f145578 [svn] - documentation fixups
nenolod
parents: 2034
diff changeset
312 vfs_truncate(VFSFile * file, glong length)
2032
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
313 {
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
314 if (file == NULL)
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
315 return -1;
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
316
2059
8aaf0f145578 [svn] - documentation fixups
nenolod
parents: 2034
diff changeset
317 return file->base->vfs_truncate_impl(file, length);
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
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
320 /**
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
321 * vfs_file_test:
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
322 * @path: A path to test.
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
323 * @test: A GFileTest to run.
2032
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
324 *
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
325 * Wrapper for g_file_test().
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
326 *
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
327 * Return value: The result of g_file_test().
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
328 **/
811
86ca43d8a845 [svn] - implement vfs_feof() and vfs_ftell() and update the scrobbler plugin to reflect that,
nenolod
parents: 550
diff changeset
329 gboolean
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
330 vfs_file_test(const gchar * path, GFileTest test)
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
331 {
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
332 return g_file_test(path, test);
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
333 }
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
334
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
335 /**
2059
8aaf0f145578 [svn] - documentation fixups
nenolod
parents: 2034
diff changeset
336 * vfs_is_writeable:
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
337 * @path: A path to test.
2032
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
338 *
2059
8aaf0f145578 [svn] - documentation fixups
nenolod
parents: 2034
diff changeset
339 * Tests if a file is writeable.
2032
7aed5cf10141 [svn] - document the VFS layer.
nenolod
parents: 2031
diff changeset
340 *
2059
8aaf0f145578 [svn] - documentation fixups
nenolod
parents: 2034
diff changeset
341 * Return value: TRUE if the file is writeable, otherwise FALSE.
2034
c43fb0845b71 [svn] - update VFS documentation
nenolod
parents: 2032
diff changeset
342 **/
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
343 gboolean
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
344 vfs_is_writeable(const gchar * path)
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
345 {
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
346 struct stat info;
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
347
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
348 if (stat(path, &info) == -1)
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
349 return FALSE;
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
350
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
351 return (info.st_mode & S_IWUSR);
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
352 }