summaryrefslogtreecommitdiff
path: root/src/include/deno.h
diff options
context:
space:
mode:
Diffstat (limited to 'src/include/deno.h')
-rw-r--r--src/include/deno.h53
1 files changed, 53 insertions, 0 deletions
diff --git a/src/include/deno.h b/src/include/deno.h
new file mode 100644
index 000000000..6246d1d23
--- /dev/null
+++ b/src/include/deno.h
@@ -0,0 +1,53 @@
+// Copyright 2018 Ryan Dahl <ry@tinyclouds.org>
+// All rights reserved. MIT License.
+#ifndef INCLUDE_DENO_H_
+#define INCLUDE_DENO_H_
+// 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
+
+// Data that gets transmitted.
+typedef struct {
+ const char* data;
+ size_t len;
+} deno_buf;
+
+struct deno_s;
+typedef struct deno_s Deno;
+
+// A callback to receive a message from deno_pub javascript call.
+// buf is valid only for the lifetime of the call.
+typedef void (*deno_sub_cb)(Deno* d, const char* channel, deno_buf buf);
+
+void deno_init();
+const char* deno_v8_version();
+void deno_set_flags(int* argc, char** argv);
+
+Deno* deno_new(void* data, deno_sub_cb cb);
+void deno_delete(Deno* d);
+
+// Returns false on error.
+// Get error text with deno_last_exception().
+// 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_sub(). A false return
+// value indicates error. Check deno_last_exception() for exception text.
+// 0 = fail, 1 = success
+int deno_pub(Deno* d, const char* channel, deno_buf buf);
+
+// Call this inside a deno_sub_cb to respond synchronously to messages.
+// If this is not called during the life time of a deno_sub_cb callback
+// the denoPub() call in javascript will return null.
+void deno_set_response(Deno* d, deno_buf buf);
+
+const char* deno_last_exception(Deno* d);
+
+void deno_terminate_execution(Deno* d);
+
+#ifdef __cplusplus
+} // extern "C"
+#endif
+#endif // INCLUDE_DENO_H_