--- fuse/helpers.c | 28 ++++++++++++++++++++++++++++ fuse/helpers.h | 1 + fuse/obexfuse.c | 9 +++++++++ 3 files changed, 38 insertions(+), 0 deletions(-) diff --git a/fuse/helpers.c b/fuse/helpers.c index cabf8f7..d0580c2 100644 --- a/fuse/helpers.c +++ b/fuse/helpers.c @@ -618,6 +618,16 @@ void gobexhlp_put(struct gobexhlp_session* session, g_print("gobexhlp_put(%s%s)\n", l->dir, l->file); + if (g_strcmp0(path, session->vtouch_path) == 0 && + session->vtouch == TRUE) { + session->vtouch = FALSE; + g_free(session->vtouch_path); + } else { + /* delete existing file */ + if (session->rtouch == FALSE) + gobexhlp_delete(session, path); + } + gobexhlp_setpath(session, l->dir); buffer->tmpsize = 0; session->buffer = buffer; @@ -661,3 +671,21 @@ void gobexhlp_touch_real(struct gobexhlp_session* session, gchar *path) session->buffer = tmpbuf; } + +void gobexhlp_delete(struct gobexhlp_session* session, const char *path) +{ + struct gobexhlp_location *l; + l = get_location(path); + + g_print("gobexhlp_delete(%s)\n", l->file); + + gobexhlp_setpath(session, l->dir); + request_new(session, g_strdup_printf("delete %s", path)); + g_obex_delete(session->obex, l->file, response_func, session, + &session->err); + + g_hash_table_remove(session->file_stat, path); + + free_location(l); + request_wait_free(session); +} diff --git a/fuse/helpers.h b/fuse/helpers.h index c2b28ca..803cb59 100644 --- a/fuse/helpers.h +++ b/fuse/helpers.h @@ -60,3 +60,4 @@ void gobexhlp_put(struct gobexhlp_session* session, struct gobexhlp_buffer *buffer, const char *path); void gobexhlp_touch(struct gobexhlp_session* session, const char *path); +void gobexhlp_delete(struct gobexhlp_session* session, const char *path); diff --git a/fuse/obexfuse.c b/fuse/obexfuse.c index b4599d8..2a6ee11 100644 --- a/fuse/obexfuse.c +++ b/fuse/obexfuse.c @@ -230,6 +230,13 @@ static int obexfuse_mknod(const char *path, mode_t mode, dev_t dev) return 0; } +static int obexfuse_unlink(const char *path) +{ + gobexhlp_delete(session, path); + + return session->status; +} + static struct fuse_operations obexfuse_oper = { .readdir = obexfuse_readdir, .getattr = obexfuse_getattr, @@ -240,6 +247,8 @@ static struct fuse_operations obexfuse_oper = { .release = obexfuse_release, .utimens = obexfuse_utimens, .mknod = obexfuse_mknod, + .unlink = obexfuse_unlink, + .rmdir = obexfuse_unlink, .init = obexfuse_init, .destroy = obexfuse_destroy, }; -- 1.7.8.6 -- To unsubscribe from this list: send the line "unsubscribe linux-bluetooth" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html