2021-01-02 18:10:00 +00:00
|
|
|
#pragma once
|
|
|
|
|
2024-02-20 21:41:37 -05:00
|
|
|
/**
|
|
|
|
** \defgroup serialize JS binary serialization
|
|
|
|
** Converts JS data to a basic binary format with support for exporting
|
|
|
|
** functions so that they can be called across the barrier, too.
|
|
|
|
** @{
|
|
|
|
*/
|
|
|
|
|
2021-01-02 18:10:00 +00:00
|
|
|
#include "quickjs.h"
|
|
|
|
|
2024-03-05 21:17:20 -05:00
|
|
|
/** A task. */
|
2021-01-02 18:10:00 +00:00
|
|
|
typedef struct _tf_task_t tf_task_t;
|
2024-03-05 21:17:20 -05:00
|
|
|
/** A handle to a remote task. */
|
2021-01-02 18:10:00 +00:00
|
|
|
typedef struct _tf_taskstub_t tf_taskstub_t;
|
|
|
|
|
2024-03-05 21:17:20 -05:00
|
|
|
/**
|
|
|
|
** Store JS data in a binary blob.
|
|
|
|
** @param task The calling task.
|
|
|
|
** @param to The handle to the task to which the data will be sent.
|
|
|
|
** @param[out] out_buffer Populated with the stored data.
|
|
|
|
** @param[out] out_size Populated with the size of out_data.
|
|
|
|
** @param value The JS value to store.
|
|
|
|
*/
|
2021-01-02 18:10:00 +00:00
|
|
|
void tf_serialize_store(tf_task_t* task, tf_taskstub_t* to, void** out_buffer, size_t* out_size, JSValue value);
|
2024-03-05 21:17:20 -05:00
|
|
|
|
|
|
|
/**
|
|
|
|
** Retrieve JS data from a binary blob.
|
|
|
|
** @param task The calling task.
|
|
|
|
** @param from The handle to the task from which the data was received.
|
|
|
|
** @param buffer The data.
|
|
|
|
** @param size The size of the data.
|
|
|
|
** @return The received JS data.
|
|
|
|
*/
|
2021-01-02 18:10:00 +00:00
|
|
|
JSValue tf_serialize_load(tf_task_t* task, tf_taskstub_t* from, const char* buffer, size_t size);
|
2024-02-20 21:41:37 -05:00
|
|
|
|
|
|
|
/** @} */
|