0
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2024-10-31 09:14:20 -04:00
denoland-deno/src/deno.h

64 lines
2.2 KiB
C
Raw Normal View History

// Copyright 2018 Ryan Dahl <ry@tinyclouds.org>
// All rights reserved. MIT License.
#ifndef DENO_H_
#define DENO_H_
2018-07-06 15:00:45 -04:00
#include <stddef.h>
#include <stdint.h>
2018-06-10 08:18:15 -04:00
// Neither Rust nor Go support calling directly into C++ functions, therefore
// the public interface to libdeno is done in C.
#ifdef __cplusplus
extern "C" {
#endif
2018-06-09 20:24:34 -04:00
// Data that gets transmitted.
2018-06-10 08:18:15 -04:00
typedef struct {
uint8_t* alloc_ptr; // Start of memory allocation (returned from `malloc()`).
size_t alloc_len; // Length of the memory allocation.
uint8_t* data_ptr; // Start of logical contents (within the allocation).
size_t data_len; // Length of logical contents.
2018-06-10 08:18:15 -04:00
} deno_buf;
2018-06-09 21:44:56 -04:00
struct deno_s;
typedef struct deno_s Deno;
2018-06-09 21:44:56 -04:00
// A callback to receive a message from deno.send javascript call.
2018-06-11 16:19:34 -04:00
// buf is valid only for the lifetime of the call.
typedef void (*deno_recv_cb)(Deno* d, deno_buf buf);
2018-06-10 08:18:15 -04:00
void deno_init();
2018-06-10 08:34:59 -04:00
const char* deno_v8_version();
void deno_set_flags(int* argc, char** argv);
Deno* deno_new(void* data, deno_recv_cb cb);
2018-06-11 16:36:14 -04:00
void deno_delete(Deno* d);
2018-06-11 11:01:35 -04:00
// Returns false on error.
// Get error text with deno_last_exception().
2018-06-15 09:12:32 -04:00
// 0 = fail, 1 = success
int deno_execute(Deno* d, const char* js_filename, const char* js_source);
// Routes message to the javascript callback set with deno.recv(). A false
// return value indicates error. Check deno_last_exception() for exception text.
2018-06-15 09:12:32 -04:00
// 0 = fail, 1 = success
// After calling deno_send(), the caller no longer owns `buf` and must not use
// it; deno_send() is responsible for releasing it's memory.
// TODO(piscisaureus) In C++ and/or Rust, use a smart pointer or similar to
// enforce this rule.
int deno_send(Deno* d, deno_buf buf);
// Call this inside a deno_recv_cb to respond synchronously to messages.
// If this is not called during the life time of a deno_recv_cb callback
// the deno.send() call in javascript will return null.
// After calling deno_set_response(), the caller no longer owns `buf` and must
// not access it; deno_set_response() is responsible for releasing it's memory.
void deno_set_response(Deno* d, deno_buf buf);
const char* deno_last_exception(Deno* d);
void deno_terminate_execution(Deno* d);
2018-06-10 08:18:15 -04:00
#ifdef __cplusplus
} // extern "C"
#endif
#endif // DENO_H_