--- fuse/gobexfuse.c | 17 +++++++++++++++++ fuse/helpers.c | 40 ++++++++++++++++++++++++++++++++++++++++ fuse/helpers.h | 1 + 3 files changed, 58 insertions(+), 0 deletions(-) diff --git a/fuse/gobexfuse.c b/fuse/gobexfuse.c index a49a8f9..b47d203 100644 --- a/fuse/gobexfuse.c +++ b/fuse/gobexfuse.c @@ -215,6 +215,21 @@ static int gobexfuse_release(const char *path, struct fuse_file_info *fi) return session->status; } +static int gobexfuse_utimens(const char *path, const struct timespec tv[2]) +{ + /* + * Important for mknod (touch) operation + */ + return 0; +} + +static int gobexfuse_mknod(const char *path, mode_t mode, dev_t dev) +{ + gobexhlp_touch(session, path); + + return 0; +} + static struct fuse_operations gobexfuse_oper = { .readdir = gobexfuse_readdir, .getattr = gobexfuse_getattr, @@ -223,6 +238,8 @@ static struct fuse_operations gobexfuse_oper = { .write = gobexfuse_write, .truncate = gobexfuse_truncate, .release = gobexfuse_release, + .utimens = gobexfuse_utimens, + .mknod = gobexfuse_mknod, .init = gobexfuse_init, .destroy = gobexfuse_destroy, }; diff --git a/fuse/helpers.c b/fuse/helpers.c index b807f15..05948be 100644 --- a/fuse/helpers.c +++ b/fuse/helpers.c @@ -56,6 +56,8 @@ struct gobexhlp_location { gchar *file; }; +void gobexhlp_touch_real(struct gobexhlp_session* session, gchar *path); + static uint16_t find_rfcomm_uuid(void *user_data) { sdp_list_t *pds = (sdp_list_t*) user_data; @@ -279,6 +281,12 @@ void request_new(struct gobexhlp_session *session, { g_print("REQUEST %s\n", name); + if (session->vtouch == TRUE) { + session->vtouch = FALSE; + gobexhlp_touch_real(session, session->vtouch_path); + g_free(session->vtouch_path); + } + if (session->request != NULL) g_error("Another request (%s) active!\n", session->request->name); @@ -622,3 +630,35 @@ void gobexhlp_put(struct gobexhlp_session* session, request_wait_free(session); } +/* virtual file creation */ +void gobexhlp_touch(struct gobexhlp_session* session, const char *path) +{ + struct stat *stbuf; + + g_print("gobexhlp_touch(%s)\n", path); + + stbuf = g_malloc0(sizeof(struct stat)); + stbuf->st_mode = S_IFREG; + g_hash_table_replace(session->file_stat, g_strdup(path), stbuf); + + session->vtouch = TRUE; + session->vtouch_path = g_strdup(path); +} + +void gobexhlp_touch_real(struct gobexhlp_session* session, gchar *path) +{ + struct gobexhlp_buffer *buffer, *tmpbuf; + + g_print("gobexhlp_touch_real(%s)\n", path); + + tmpbuf = session->buffer; /* save buffer state */ + + buffer = g_malloc0(sizeof(struct gobexhlp_buffer)); + session->rtouch = TRUE; + gobexhlp_put(session, buffer, path); + session->rtouch = FALSE; + g_free(buffer); + + session->buffer = tmpbuf; +} + diff --git a/fuse/helpers.h b/fuse/helpers.h index 95987c4..da5f96c 100644 --- a/fuse/helpers.h +++ b/fuse/helpers.h @@ -59,4 +59,5 @@ struct gobexhlp_buffer *gobexhlp_get(struct gobexhlp_session* session, void gobexhlp_put(struct gobexhlp_session* session, struct gobexhlp_buffer *buffer, const char *path); +void gobexhlp_touch(struct gobexhlp_session* session, const char *path); -- 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