C API
init_dora_context_from_env
init_dora_context_from_env
从环境变量设置 dora-coordinator
初始化一个节点。
void *dora_context = init_dora_context_from_env();
dora_next_event
dora_next_event
等待下一个事件(如:输入事件)。 使用 read_dora_event_type
读到事件类型。 输入类型为 DoraEventType_Input
。 提取输入事件的 ID 和数据,在返回的指针上使用 read_dora_input_id
和 read_dora_input_data
。 忽略任何事件并仅处理与节点相关的事件是安全的。
void *input = dora_next_input(dora_context);
// 以 UTF8 编码字符串的形式读出 ID
char *id;
size_t id_len;
read_dora_input_id(input, &id, &id_len);
// 以字节数组的形式读出数据
char *data;
size_t data_len;
read_dora_input_data(input, &data, &data_len);
dora_send_output
dora_send_output
从节点发送数据。
char out_id[] = "tick";
char out_data[50];
dora_send_output(dora_context, out_id, strlen(out_id), out_data, out_data_len);
试试看!
- 建立一个
node.c
文件。
#include <stdio.h>
#include <string.h>
#include <assert.h>
#include "../../apis/c/node/node_api.h"
// sleep
#ifdef _WIN32
#include <Windows.h>
#else
#include <unistd.h>
#endif
int main()
{
printf("[c node] Hello World\n");
void *dora_context = init_dora_context_from_env();
if (dora_context == NULL)
{
fprintf(stderr, "failed to init dora context\n");
return -1;
}
printf("[c node] dora context initialized\n");
for (char i = 0; i < 100; i++)
{
void *event = dora_next_event(dora_context);
if (event == NULL)
{
printf("[c node] ERROR: unexpected end of event\n");
return -1;
}
enum DoraEventType ty = read_dora_event_type(event);
if (ty == DoraEventType_Input)
{
char *data;
size_t data_len;
read_dora_input_data(event, &data, &data_len);
assert(data_len == 0);
char out_id[] = "message";
char out_data[50];
int out_data_len = sprintf(out_data, "loop iteration %d", i);
dora_send_output(dora_context, out_id, strlen(out_id), out_data, out_data_len);
}
else if (ty == DoraEventType_Stop)
{
printf("[c node] received stop event\n");
}
else
{
printf("[c node] received unexpected event: %d\n", ty);
}
free_dora_event(event);
}
printf("[c node] received 10 events\n");
free_dora_context(dora_context);
printf("[c node] finished successfully\n");
return 0;
}
建立自定义节点:
- 在这个目录,建 立一个
build
文件夹 (即, 下一个文件node.c
) - 编译
dora-node-api-c
crate 到一个静态库。- 运行
cargo build -p dora-node-api-c --release
- 可用的静态库结果生成在
../../target/release/libdora-node-api-c.a
。
- 运行
- 编译
node.c
(例如使用clang
) 并链接静态库- 例如,使用如下命令:
clang node.c <FLAGS> -ldora_node_api_c -L ../../target/release --output build/c_node
<FLAGS>
取决于C节点使用的操作系统和库。 每个操作系统都需要以下标志:- Linux:
-lm -lrt -ldl -pthread
- macOS:
-framework CoreServices -framework Security -l System -l resolv -l pthread -l c -l m
- Windows:
另外:在 Windows 上,输出文件应具有
-ladvapi32 -luserenv -lkernel32 -lws2_32 -lbcrypt -lncrypt -lschannel -lntdll -liphlpapi
-lcfgmgr32 -lcredui -lcrypt32 -lcryptnet -lfwpuclnt -lgdi32 -lmsimg32 -lmswsock -lole32
-lopengl32 -lsecur32 -lshell32 -lsynchronization -luser32 -lwinspool
-Wl,-nodefaultlib:libcmt -D_DLL -lmsvcrt.exe
扩展名:--output build/c_node.exe
- Linux:
- 例如,使用如下命令:
- 对
sink.c
重复执行上一步