annotate libaudacious/vfs.h @ 2059:8aaf0f145578 trunk

[svn] - documentation fixups
author nenolod
date Mon, 04 Dec 2006 18:30:58 -0800
parents 93c59698f5fd
children 53a3d5db6b58
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1974
9f6c17f1cc93 [svn] - define VFSConstructor
nenolod
parents: 1683
diff changeset
1 /*
9f6c17f1cc93 [svn] - define VFSConstructor
nenolod
parents: 1683
diff changeset
2 * Audacious
9f6c17f1cc93 [svn] - define VFSConstructor
nenolod
parents: 1683
diff changeset
3 * Copyright (c) 2006 Audacious team
9f6c17f1cc93 [svn] - define VFSConstructor
nenolod
parents: 1683
diff changeset
4 *
9f6c17f1cc93 [svn] - define VFSConstructor
nenolod
parents: 1683
diff changeset
5 * This program is free software; you can redistribute it and/or modify
9f6c17f1cc93 [svn] - define VFSConstructor
nenolod
parents: 1683
diff changeset
6 * it under the terms of the GNU General Public License as published by
9f6c17f1cc93 [svn] - define VFSConstructor
nenolod
parents: 1683
diff changeset
7 * the Free Software Foundation; either version 2 of the License, or
9f6c17f1cc93 [svn] - define VFSConstructor
nenolod
parents: 1683
diff changeset
8 * (at your option) any later version.
9f6c17f1cc93 [svn] - define VFSConstructor
nenolod
parents: 1683
diff changeset
9 *
9f6c17f1cc93 [svn] - define VFSConstructor
nenolod
parents: 1683
diff changeset
10 * This program is distributed in the hope that it will be useful,
9f6c17f1cc93 [svn] - define VFSConstructor
nenolod
parents: 1683
diff changeset
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
9f6c17f1cc93 [svn] - define VFSConstructor
nenolod
parents: 1683
diff changeset
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
9f6c17f1cc93 [svn] - define VFSConstructor
nenolod
parents: 1683
diff changeset
13 * GNU General Public License for more details.
9f6c17f1cc93 [svn] - define VFSConstructor
nenolod
parents: 1683
diff changeset
14 *
9f6c17f1cc93 [svn] - define VFSConstructor
nenolod
parents: 1683
diff changeset
15 * You should have received a copy of the GNU General Public License
9f6c17f1cc93 [svn] - define VFSConstructor
nenolod
parents: 1683
diff changeset
16 * along with this program; if not, write to the Free Software
9f6c17f1cc93 [svn] - define VFSConstructor
nenolod
parents: 1683
diff changeset
17 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
9f6c17f1cc93 [svn] - define VFSConstructor
nenolod
parents: 1683
diff changeset
18 */
9f6c17f1cc93 [svn] - define VFSConstructor
nenolod
parents: 1683
diff changeset
19
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
20 #ifndef VFS_H
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
21 #define VFS_H
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
22
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
23 #include <glib.h>
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
24 #include <stdio.h>
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
25
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
26 typedef struct _VFSFile VFSFile;
1975
976da06332df [svn] - newvfs code, part 1
nenolod
parents: 1974
diff changeset
27 typedef struct _VFSConstructor VFSConstructor;
976da06332df [svn] - newvfs code, part 1
nenolod
parents: 1974
diff changeset
28
976da06332df [svn] - newvfs code, part 1
nenolod
parents: 1974
diff changeset
29 struct _VFSFile {
976da06332df [svn] - newvfs code, part 1
nenolod
parents: 1974
diff changeset
30 gchar *uri;
976da06332df [svn] - newvfs code, part 1
nenolod
parents: 1974
diff changeset
31 gpointer handle;
976da06332df [svn] - newvfs code, part 1
nenolod
parents: 1974
diff changeset
32 VFSConstructor *base;
976da06332df [svn] - newvfs code, part 1
nenolod
parents: 1974
diff changeset
33 };
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
34
1974
9f6c17f1cc93 [svn] - define VFSConstructor
nenolod
parents: 1683
diff changeset
35 struct _VFSConstructor {
9f6c17f1cc93 [svn] - define VFSConstructor
nenolod
parents: 1683
diff changeset
36 gchar *uri_id;
9f6c17f1cc93 [svn] - define VFSConstructor
nenolod
parents: 1683
diff changeset
37 VFSFile *(*vfs_fopen_impl)(const gchar *path,
9f6c17f1cc93 [svn] - define VFSConstructor
nenolod
parents: 1683
diff changeset
38 const gchar *mode);
9f6c17f1cc93 [svn] - define VFSConstructor
nenolod
parents: 1683
diff changeset
39 gint (*vfs_fclose_impl)(VFSFile * file);
9f6c17f1cc93 [svn] - define VFSConstructor
nenolod
parents: 1683
diff changeset
40 size_t (*vfs_fread_impl)(gpointer ptr, size_t size,
9f6c17f1cc93 [svn] - define VFSConstructor
nenolod
parents: 1683
diff changeset
41 size_t nmemb, VFSFile *file);
1975
976da06332df [svn] - newvfs code, part 1
nenolod
parents: 1974
diff changeset
42 size_t (*vfs_fwrite_impl)(gconstpointer ptr, size_t size,
976da06332df [svn] - newvfs code, part 1
nenolod
parents: 1974
diff changeset
43 size_t nmemb, VFSFile *file);
976da06332df [svn] - newvfs code, part 1
nenolod
parents: 1974
diff changeset
44 gint (*vfs_getc_impl)(VFSFile *stream);
1974
9f6c17f1cc93 [svn] - define VFSConstructor
nenolod
parents: 1683
diff changeset
45 gint (*vfs_ungetc_impl)(gint c, VFSFile *stream);
9f6c17f1cc93 [svn] - define VFSConstructor
nenolod
parents: 1683
diff changeset
46 gint (*vfs_fseek_impl)(VFSFile *file, glong offset, gint whence);
9f6c17f1cc93 [svn] - define VFSConstructor
nenolod
parents: 1683
diff changeset
47 void (*vfs_rewind_impl)(VFSFile *file);
9f6c17f1cc93 [svn] - define VFSConstructor
nenolod
parents: 1683
diff changeset
48 glong (*vfs_ftell_impl)(VFSFile *file);
9f6c17f1cc93 [svn] - define VFSConstructor
nenolod
parents: 1683
diff changeset
49 gboolean (*vfs_feof_impl)(VFSFile *file);
9f6c17f1cc93 [svn] - define VFSConstructor
nenolod
parents: 1683
diff changeset
50 gboolean (*vfs_truncate_impl)(VFSFile *file, glong length);
9f6c17f1cc93 [svn] - define VFSConstructor
nenolod
parents: 1683
diff changeset
51 };
9f6c17f1cc93 [svn] - define VFSConstructor
nenolod
parents: 1683
diff changeset
52
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
53 G_BEGIN_DECLS
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
54
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
55 /* Reserved for private use by BMP */
830
4d60baab67a0 [svn] - use extern here (grr)
nenolod
parents: 811
diff changeset
56 extern gboolean vfs_init(void);
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
57
830
4d60baab67a0 [svn] - use extern here (grr)
nenolod
parents: 811
diff changeset
58 extern VFSFile * vfs_fopen(const gchar * path,
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
59 const gchar * mode);
830
4d60baab67a0 [svn] - use extern here (grr)
nenolod
parents: 811
diff changeset
60 extern gint vfs_fclose(VFSFile * file);
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
61
830
4d60baab67a0 [svn] - use extern here (grr)
nenolod
parents: 811
diff changeset
62 extern size_t vfs_fread(gpointer ptr,
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
63 size_t size,
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
64 size_t nmemb,
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
65 VFSFile * file);
830
4d60baab67a0 [svn] - use extern here (grr)
nenolod
parents: 811
diff changeset
66 extern size_t vfs_fwrite(gconstpointer ptr,
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
67 size_t size,
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
68 size_t nmemb,
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
69 VFSFile *file);
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
70
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: 1669
diff changeset
71 extern gint 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: 1669
diff changeset
72 extern gint vfs_ungetc(gint c,
e9c24e35bd76 [svn] - File stream API for audacious vfs; uses real getc/ungetc functions for vfs_stdio and emulated functions for vfs_gnome
giacomo
parents: 1669
diff changeset
73 VFSFile *stream);
1617
3de4bd38fe4f [svn] generic vfs_gets and m3u updated to use vfs
lu_zero
parents: 830
diff changeset
74 extern gchar *vfs_fgets(gchar *s,
3de4bd38fe4f [svn] generic vfs_gets and m3u updated to use vfs
lu_zero
parents: 830
diff changeset
75 gint n,
3de4bd38fe4f [svn] generic vfs_gets and m3u updated to use vfs
lu_zero
parents: 830
diff changeset
76 VFSFile *stream);
3de4bd38fe4f [svn] generic vfs_gets and m3u updated to use vfs
lu_zero
parents: 830
diff changeset
77
830
4d60baab67a0 [svn] - use extern here (grr)
nenolod
parents: 811
diff changeset
78 extern gint vfs_fseek(VFSFile * file,
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
79 glong offset,
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
80 gint whence);
830
4d60baab67a0 [svn] - use extern here (grr)
nenolod
parents: 811
diff changeset
81 extern void vfs_rewind(VFSFile * file);
4d60baab67a0 [svn] - use extern here (grr)
nenolod
parents: 811
diff changeset
82 extern glong vfs_ftell(VFSFile * file);
4d60baab67a0 [svn] - use extern here (grr)
nenolod
parents: 811
diff changeset
83 extern gboolean vfs_feof(VFSFile * file);
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
84
830
4d60baab67a0 [svn] - use extern here (grr)
nenolod
parents: 811
diff changeset
85 extern gboolean vfs_file_test(const gchar * path,
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
86 GFileTest test);
811
86ca43d8a845 [svn] - implement vfs_feof() and vfs_ftell() and update the scrobbler plugin to reflect that,
nenolod
parents: 0
diff changeset
87
830
4d60baab67a0 [svn] - use extern here (grr)
nenolod
parents: 811
diff changeset
88 extern gboolean vfs_is_writeable(const gchar * path);
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
89
830
4d60baab67a0 [svn] - use extern here (grr)
nenolod
parents: 811
diff changeset
90 extern gboolean vfs_truncate(VFSFile * file, glong length);
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
91
1669
07143b97314d [svn] fprintf implementation in the VFS common layer by Luca Barbato. Use it in the Container plugins.
chainsaw
parents: 1617
diff changeset
92 extern int vfs_fprintf(VFSFile *stream, gchar const *format, ...)
07143b97314d [svn] fprintf implementation in the VFS common layer by Luca Barbato. Use it in the Container plugins.
chainsaw
parents: 1617
diff changeset
93 __attribute__ ((__format__ (__printf__, 2, 3)));
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
94
1997
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1975
diff changeset
95 extern gboolean vfs_register_transport(VFSConstructor *vtable);
93c59698f5fd [svn] - NewVFS lives ;)
nenolod
parents: 1975
diff changeset
96
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
97 G_END_DECLS
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
98
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
99 #endif /* VFS_H */