rquickjs-sys 0.11.0

QuickJS bindings for rquickjs
Documentation
/*
 * QuickJS C library
 *
 * Copyright (c) 2017-2018 Fabrice Bellard
 *
 * Permission is hereby granted, free of charge, to any person obtaining a copy
 * of this software and associated documentation files (the "Software"), to deal
 * in the Software without restriction, including without limitation the rights
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 * copies of the Software, and to permit persons to whom the Software is
 * furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included in
 * all copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
 * THE SOFTWARE.
 */
#ifndef QUICKJS_LIBC_H
#define QUICKJS_LIBC_H

#include <stdbool.h>
#include <stdio.h>
#include <stdlib.h>

#include "quickjs.h"

#ifdef __cplusplus
extern "C" {
#endif

#if defined(__GNUC__) || defined(__clang__)
#define JS_EXTERN __attribute__((visibility("default")))
#else
#define JS_EXTERN /* nothing */
#endif

JS_EXTERN JSModuleDef *js_init_module_std(JSContext *ctx,
                                          const char *module_name);
JS_EXTERN JSModuleDef *js_init_module_os(JSContext *ctx,
                                         const char *module_name);
JS_EXTERN JSModuleDef *js_init_module_bjson(JSContext *ctx,
                                            const char *module_name);
JS_EXTERN void js_std_add_helpers(JSContext *ctx, int argc, char **argv);
JS_EXTERN int js_std_loop(JSContext *ctx);
JS_EXTERN JSValue js_std_await(JSContext *ctx, JSValue obj);
JS_EXTERN void js_std_init_handlers(JSRuntime *rt);
JS_EXTERN void js_std_free_handlers(JSRuntime *rt);
JS_EXTERN void js_std_dump_error(JSContext *ctx);
JS_EXTERN uint8_t *js_load_file(JSContext *ctx, size_t *pbuf_len,
                                const char *filename);
JS_EXTERN int js_module_set_import_meta(JSContext *ctx, JSValueConst func_val,
                                        bool use_realpath, bool is_main);
JS_EXTERN JSModuleDef *js_module_loader(JSContext *ctx,
                                        const char *module_name, void *opaque);
JS_EXTERN void js_std_eval_binary(JSContext *ctx, const uint8_t *buf,
                                  size_t buf_len, int flags);
JS_EXTERN void js_std_promise_rejection_tracker(JSContext *ctx,
                                                JSValueConst promise,
                                                JSValueConst reason,
                                                bool is_handled,
                                                void *opaque);
// Defaults to JS_NewRuntime, no-op if compiled without worker support.
// Call before creating the first worker thread.
JS_EXTERN void js_std_set_worker_new_runtime_func(JSRuntime *(*func)(void));
// Defaults to JS_NewContext, no-op if compiled without worker support.
// Call before creating the first worker thread.
JS_EXTERN void js_std_set_worker_new_context_func(JSContext *(*func)(JSRuntime *rt));

#undef JS_EXTERN

#ifdef __cplusplus
} /* extern "C" { */
#endif

#endif /* QUICKJS_LIBC_H */