diff options
author | Miklos Szeredi <mszeredi@suse.cz> | 2013-06-21 18:20:23 +0200 |
---|---|---|
committer | Miklos Szeredi <mszeredi@suse.cz> | 2013-06-21 18:20:23 +0200 |
commit | f9a7c2b1135beeacbdcecab9065eddd2f7e68dbd (patch) | |
tree | 386480447871aa2473691c49f8253163b7ace914 /lib/fuse_session.c | |
parent | 561d7054d856eea6c2d634093546d6af773dada9 (diff) | |
download | libfuse-f9a7c2b1135beeacbdcecab9065eddd2f7e68dbd.tar.gz |
libfuse: remove session and chan abstractions
There's actually just one type of channel and session, so we don't need the
generic callback functions.
Diffstat (limited to 'lib/fuse_session.c')
-rw-r--r-- | lib/fuse_session.c | 42 |
1 files changed, 3 insertions, 39 deletions
diff --git a/lib/fuse_session.c b/lib/fuse_session.c index b8687a4..c030d68 100644 --- a/lib/fuse_session.c +++ b/lib/fuse_session.c @@ -15,24 +15,15 @@ #include <assert.h> #include <errno.h> -struct fuse_chan { - struct fuse_chan_ops op; - struct fuse_session *se; - - int fd; -}; - -struct fuse_session *fuse_session_new(void *data) +struct fuse_session *fuse_session_new(void) { struct fuse_session *se = (struct fuse_session *) malloc(sizeof(*se)); if (se == NULL) { fprintf(stderr, "fuse: failed to allocate session\n"); return NULL; } - memset(se, 0, sizeof(*se)); - se->data = data; return se; } @@ -60,18 +51,6 @@ struct fuse_chan *fuse_session_chan(struct fuse_session *se) return se->ch; } -void fuse_session_process_buf(struct fuse_session *se, - const struct fuse_buf *buf, struct fuse_chan *ch) -{ - se->process_buf(se->data, buf, ch); -} - -int fuse_session_receive_buf(struct fuse_session *se, struct fuse_buf *buf, - struct fuse_chan *ch) -{ - return se->receive_buf(se, buf, ch); -} - int fuse_chan_clearfd(struct fuse_chan *ch) { int fd = ch->fd; @@ -79,14 +58,6 @@ int fuse_chan_clearfd(struct fuse_chan *ch) return fd; } -void fuse_session_destroy(struct fuse_session *se) -{ - se->destroy(se->data); - if (se->ch != NULL) - fuse_chan_destroy(se->ch); - free(se); -} - void fuse_session_exit(struct fuse_session *se) { se->exited = 1; @@ -102,12 +73,7 @@ int fuse_session_exited(struct fuse_session *se) return se->exited; } -void *fuse_session_data(struct fuse_session *se) -{ - return se->data; -} - -struct fuse_chan *fuse_chan_new(struct fuse_chan_ops *op, int fd) +struct fuse_chan *fuse_chan_new(int fd) { struct fuse_chan *ch = (struct fuse_chan *) malloc(sizeof(*ch)); if (ch == NULL) { @@ -116,7 +82,6 @@ struct fuse_chan *fuse_chan_new(struct fuse_chan_ops *op, int fd) } memset(ch, 0, sizeof(*ch)); - ch->op = *op; ch->fd = fd; return ch; @@ -135,7 +100,6 @@ struct fuse_session *fuse_chan_session(struct fuse_chan *ch) void fuse_chan_destroy(struct fuse_chan *ch) { fuse_session_remove_chan(ch); - if (ch->op.destroy) - ch->op.destroy(ch); + fuse_chan_close(ch); free(ch); } |