Implement small C header only client library
This commit is contained in:
parent
1425dc1fa0
commit
05e397f142
128
clients/c_cpp/pipe_io.h
Normal file
128
clients/c_cpp/pipe_io.h
Normal file
@ -0,0 +1,128 @@
|
|||||||
|
#pragma once
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdbool.h>
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
|
|
||||||
|
typedef struct pipe_reader {
|
||||||
|
FILE* stream;
|
||||||
|
char* line_buf;
|
||||||
|
size_t buf_size;
|
||||||
|
} pipe_reader;
|
||||||
|
|
||||||
|
pipe_reader new_pipe_reader(const char* pipe_path) {
|
||||||
|
pipe_reader preader;
|
||||||
|
preader.stream = fopen(pipe_path, "r");
|
||||||
|
preader.line_buf = NULL;
|
||||||
|
preader.buf_size = 0;
|
||||||
|
return preader;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool check_pipe_reader(const pipe_reader* preader) {
|
||||||
|
if (!preader || preader->stream == NULL) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
const char* read_line_pipe_reader(pipe_reader* preader) {
|
||||||
|
if (!check_pipe_reader(preader)) {
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
ssize_t read = getline(&preader->line_buf, &preader->buf_size, preader->stream);
|
||||||
|
if (read > 0) {
|
||||||
|
preader->line_buf[read - 1] = '\0';
|
||||||
|
return preader->line_buf;
|
||||||
|
}
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
void close_pipe_reader(pipe_reader* preader) {
|
||||||
|
if (!check_pipe_reader(preader)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
fclose(preader->stream);
|
||||||
|
preader->stream = NULL;
|
||||||
|
if (preader->line_buf) {
|
||||||
|
free(preader->line_buf);
|
||||||
|
preader->line_buf = NULL;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
typedef struct pipe_writer {
|
||||||
|
FILE* stream;
|
||||||
|
} pipe_writer;
|
||||||
|
|
||||||
|
pipe_writer new_pipe_writer(const char* pipe_path) {
|
||||||
|
pipe_writer pwriter;
|
||||||
|
pwriter.stream = fopen(pipe_path, "w");
|
||||||
|
return pwriter;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool check_pipe_writer(const pipe_writer* pwriter) {
|
||||||
|
if (!pwriter || pwriter->stream == NULL) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool send_msg_pipe_writer(pipe_writer* pwriter, const char* msg) {
|
||||||
|
if (!check_pipe_writer(pwriter)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
fprintf(pwriter->stream, "%s\n", msg);
|
||||||
|
fflush(pwriter->stream);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
void close_pipe_writer(pipe_writer* pwriter) {
|
||||||
|
if (!check_pipe_writer(pwriter)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
fclose(pwriter->stream);
|
||||||
|
pwriter->stream = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
typedef struct pipe_io {
|
||||||
|
pipe_reader preader;
|
||||||
|
pipe_writer pwriter;
|
||||||
|
} pipe_io;
|
||||||
|
|
||||||
|
pipe_io new_pipe_io(const char* in_pipe_path, const char* out_pipe_path) {
|
||||||
|
pipe_io pipeio;
|
||||||
|
pipeio.preader = new_pipe_reader(in_pipe_path);
|
||||||
|
pipeio.pwriter = new_pipe_writer(out_pipe_path);
|
||||||
|
return pipeio;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool check_pipe_io(const pipe_io* pipeio) {
|
||||||
|
if (!pipeio) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return (check_pipe_reader(&pipeio->preader) && check_pipe_writer(&pipeio->pwriter));
|
||||||
|
}
|
||||||
|
|
||||||
|
const char* read_line_pipe_io(pipe_io* pipeio) {
|
||||||
|
if (!check_pipe_io(pipeio)) {
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
return read_line_pipe_reader(&pipeio->preader);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool send_msg_pipe_io(pipe_io* pipeio, const char* msg) {
|
||||||
|
if (!check_pipe_io(pipeio)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return send_msg_pipe_writer(&pipeio->pwriter, msg);
|
||||||
|
}
|
||||||
|
|
||||||
|
void close_pipe_io(pipe_io* pipeio) {
|
||||||
|
if (!check_pipe_io(pipeio)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
close_pipe_reader(&pipeio->preader);
|
||||||
|
close_pipe_writer(&pipeio->pwriter);
|
||||||
|
}
|
11
clients/c_cpp/test.c
Normal file
11
clients/c_cpp/test.c
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
#include "pipe_io.h"
|
||||||
|
|
||||||
|
|
||||||
|
int main() {
|
||||||
|
pipe_io pipeio = new_pipe_io("in", "out");
|
||||||
|
const char* line;
|
||||||
|
while ((line = read_line_pipe_io(&pipeio))) {
|
||||||
|
send_msg_pipe_io(&pipeio, line);
|
||||||
|
}
|
||||||
|
close_pipe_io(&pipeio);
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user