diff options
author | 2020-03-02 21:18:32 +0200 | |
---|---|---|
committer | 2020-03-02 21:18:32 +0200 | |
commit | b6fe7f8d9ade5e1b665bcf2cddb145fd2e0fde57 (patch) | |
tree | 54c655f2749b63ce4821fd3cb18d97d1bde88272 | |
parent | ad1bc59382e3cda63ce507cd7f56fc2a201c11e9 (diff) | |
download | algos-ld1-b6fe7f8d9ade5e1b665bcf2cddb145fd2e0fde57.tar.gz algos-ld1-b6fe7f8d9ade5e1b665bcf2cddb145fd2e0fde57.tar.bz2 algos-ld1-b6fe7f8d9ade5e1b665bcf2cddb145fd2e0fde57.zip |
implement get/put wrappers.
Signed-off-by: Gediminas Jakutis <gediminas@varciai.lt>
-rw-r--r-- | src/defs.h | 4 | ||||
-rw-r--r-- | src/io.c | 20 | ||||
-rw-r--r-- | src/main.c | 7 |
3 files changed, 24 insertions, 7 deletions
@@ -29,6 +29,8 @@ struct stream { int fd; int out; char *name; + int (*get)(struct stream *, size_t, struct entry_l *, int); + int (*put)(struct stream *, size_t, struct entry_l *, int); }; struct settings { @@ -39,8 +41,6 @@ struct settings { char *fileout; unsigned int flags; enum opmode opmode; - int (*get)(struct stream, size_t, struct entry_l *, int); - int (*put)(struct stream, size_t, struct entry_l *, int); }; #endif /* ALGOS_DEFS_H_INCLUDED */ @@ -10,6 +10,7 @@ #include <libgen.h> #include "io.h" #include "defs.h" +#include "datagen.h" static int stream_open_in(struct stream * const in, const struct settings * const s); static int stream_open_out(struct stream * const in, const struct settings * const s); @@ -83,6 +84,25 @@ early_err: return ret; } +int stream_get(struct stream *in, size_t idx, struct entry_l *data, int tag) +{ + int ret = 0; + + ret = in->get(in, idx, data, tag); + + return ret; +} + +int stream_put(struct stream *in, size_t idx, struct entry_l *data, int tag) +{ + int ret = 0; + + ret = in->put(in, idx, data, tag); + + return ret; +} + + static int stream_open_out(struct stream * const in, const struct settings * const s) { struct stat st; @@ -37,11 +37,8 @@ int main(int argc, char **argv) file_out.name = settings.fileout ? settings.fileout : settings.filein; - if ((ret = stream_open(&file_in, &settings))) { - goto out; - } - - if ((ret = stream_open(&file_out, &settings))) { + if ((ret = stream_open(&file_in, &settings)) || + (ret = stream_open(&file_out, &settings))) { goto out; } |