How to use Gnomevfs

 

GnomeVFS

Another library that was introduced in GNOME 1.4, but still worth mentioning here, is GnomeVFS (GNOME Virtual File System). GnomeVFS is a great library which makes accessing various kinds of file systems transparent to the user and developer. The user doesn't even have to take care of whether a file is located on the local machine or on a remote server. Various protocols like HTTP, FTP, local files, WebDAV, are all used in the exact same way.

API

The API for accessing files have been kept close to the POSIX standard with some minor changes:

  • For example, you use GnomeVFSHandle instead of file descriptors in GnomeVFS.
  • All I/O operations return a GnomeVFSResult, indicating the result of the operation.

The API is very straight-forward and easy to use, as we'll show in the following example:

To compile the example:

# gcc `pkg-config --libs --cflags gtk+-2.0 gnome-vfs-2.0` /
vfs-example.c -o vfs-example

The example reads a string from the command-line and uses this string to read an image which is displayed in a window. The string can represent an URL, like http://www.gnome.org/images/logo-large or it can represent a local file, like ~/picture.gif.

Asynchronous operations

GnomeVFS also provides methods for performing asynchronous operations, such as fetching a file in the background. If you, for example, are writing an FTP client, you don't want the entire GUI to freeze while a file is being received. This could be solved by using threads in your application, but using threads makes the application much more complex and harder to debug.

Using the asynchronous operations in GnomeVFS makes it very easy to get the same functionality without the complexity of threads (GnomeVFS actually uses threads internally, but hides them from you).

The method is very similar to using synchronous calls. But instead of waiting for the various function calls to open, read and close to finish, the asynchronous functions return immediately. When the operation is finished, a callback is invoked.

void

 gnome_vfs_async_open (
GnomeVFSAsyncHandle **handle_return,
const gchar *text_uri, GnomeVFSOpenMode open_mode, int priority, GnomeVFSAsyncOpenCallback callback, gpointer callback_data) ;

By calling gnome_vfs_async_open() you start asynchronous operation of opening an URI. This function will return immediately so that you can carry on with other operations.

When the uri has been opened, 'callback' will be called and you can start reading with gnome_vfs_async_read() from the handle. When all data has been read, you call gnome_vfs_async_close() to close the connection.

Writing your own GnomeVFS modules

If GnomeVFS is lacking support for some file system or network protocol, you can write your own module to handle this extra functionality. You then have instant transparent support for this, in all programs using GnomeVFS to access files! How to write such a GnomeVFS module is outside the scope of this article and will be handled in a later article.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值