1
0
mirror of https://github.com/fuse-friends/fuse-native synced 2024-10-27 18:34:01 +00:00

unmacro init

This commit is contained in:
Andrew Osheroff 2019-08-06 11:44:04 +02:00
parent 73b897dfe7
commit f9487a8d34

View File

@ -6,8 +6,8 @@
#include <string.h> #include <string.h>
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
#include <assert.h>
#include <fuse.h> #include <fuse.h>
#include <fuse_opt.h> #include <fuse_opt.h>
@ -35,11 +35,6 @@
blk\ blk\
uv_async_send(&(l->async));\ uv_async_send(&(l->async));\
uv_sem_wait(&(l->sem));\ uv_sem_wait(&(l->sem));\
if (l->ret != NULL) {\
void *tmp = l->ret;\
l->ret = NULL;\
return tmp;\
}\
return l->res; return l->res;
#define FUSE_METHOD(name, callbackArgs, signalArgs, signature, callBlk, callbackBlk, signalBlk)\ #define FUSE_METHOD(name, callbackArgs, signalArgs, signature, callBlk, callbackBlk, signalBlk)\
@ -60,6 +55,7 @@
signalBlk\ signalBlk\
l->res = res;\ l->res = res;\
uv_sem_post(&(l->sem));\ uv_sem_post(&(l->sem));\
return NULL;\
}\ }\
static int fuse_native_##name signature {\ static int fuse_native_##name signature {\
FUSE_NATIVE_HANDLER(name, callBlk)\ FUSE_NATIVE_HANDLER(name, callBlk)\
@ -143,7 +139,6 @@ typedef struct {
gid_t gid; gid_t gid;
uint32_t atim[2]; uint32_t atim[2];
uint32_t mtim[2]; uint32_t mtim[2];
void *ret;
int32_t res; int32_t res;
// Extended attributes // Extended attributes
@ -549,11 +544,30 @@ FUSE_METHOD(removexattr, 2, 0, (const char *path, const char *name), {
}, },
{}) {})
FUSE_METHOD(init, 0, 0, (struct fuse_conn_info *conn, struct fuse_config *cfg), { static void fuse_native_dispatch_init (uv_async_t* handle, int status, fuse_thread_locals_t* l, fuse_thread_t* ft) {\
}, { FUSE_NATIVE_CALLBACK(ft->handlers[op_init], {
}, { napi_value argv[2];
l->ret = (int) l->fuse; napi_create_external_buffer(env, sizeof(fuse_thread_locals_t), l, &fin, NULL, &(argv[0]));
napi_create_uint32(env, l->op, &(argv[1]));
NAPI_MAKE_CALLBACK(env, NULL, ctx, callback, 2, argv, NULL);
}) })
}
NAPI_METHOD(fuse_native_signal_init) {
NAPI_ARGV(2)
NAPI_ARGV_BUFFER_CAST(fuse_thread_locals_t *, l, 0);
NAPI_ARGV_INT32(res, 1);
l->res = res;
uv_sem_post(&(l->sem));
}
static void * fuse_native_init (struct fuse_conn_info *conn, struct fuse_config *cfg) {
fuse_thread_locals_t *l = get_thread_locals();
l->op = op_init;
uv_async_send(&(l->async));
uv_sem_wait(&(l->sem));
return l->fuse;
}
FUSE_METHOD(error, 0, 0, (), {}, {}, {}) FUSE_METHOD(error, 0, 0, (), {}, {}, {})
@ -775,17 +789,14 @@ static void fuse_native_async_init (uv_async_t* handle, int status) {
fuse_thread_t *ft = l->fuse; fuse_thread_t *ft = l->fuse;
int err = uv_async_init(uv_default_loop(), &(l->async), (uv_async_cb) fuse_native_dispatch); int err = uv_async_init(uv_default_loop(), &(l->async), (uv_async_cb) fuse_native_dispatch);
assert(err >= 0);
uv_unref(&(l->async)); uv_unref(&(l->async));
uv_sem_init(&(l->sem), 0); uv_sem_init(&(l->sem), 0);
l->async.data = l; l->async.data = l;
uv_sem_post(&(ft->sem)); uv_sem_post(&(ft->sem));
if (err < 0) {
printf("uv_async_init failed: %i\n", err);
return NULL;
}
} }
static fuse_thread_locals_t* get_thread_locals () { static fuse_thread_locals_t* get_thread_locals () {