| version 1.9, 2014/02/08 22:06:17 | version 1.9.8.2, 2016/08/11 12:51:52 | 
| Line 12  terms: | Line 12  terms: | 
 | All of the documentation and software included in the ELWIX and AITNET | All of the documentation and software included in the ELWIX and AITNET | 
 | Releases is copyrighted by ELWIX - Sofia/Bulgaria <info@elwix.org> | Releases is copyrighted by ELWIX - Sofia/Bulgaria <info@elwix.org> | 
 |  |  | 
| Copyright 2004 - 2014 | Copyright 2004 - 2016 | 
 | by Michael Pounov <misho@elwix.org>.  All rights reserved. | by Michael Pounov <misho@elwix.org>.  All rights reserved. | 
 |  |  | 
 | Redistribution and use in source and binary forms, with or without | Redistribution and use in source and binary forms, with or without | 
| Line 70  cf_(struct tagBufIO *buf) | Line 70  cf_(struct tagBufIO *buf) | 
 | return 0; | return 0; | 
 | } | } | 
 |  |  | 
| #ifdef __NetBSD__ | #if defined(__NetBSD__) || defined(__linux__) | 
 | static off_t | static off_t | 
 | sf_lim(struct tagBufIO *buf, off_t pos, int w) | sf_lim(struct tagBufIO *buf, off_t pos, int w) | 
 | #else | #else | 
| Line 139  wf_lim(struct tagBufIO *buf, const char *dat, int siz) | Line 139  wf_lim(struct tagBufIO *buf, const char *dat, int siz) | 
 | return siz; | return siz; | 
 | } | } | 
 |  |  | 
| #ifdef __NetBSD__ | #if defined(__NetBSD__) || defined(__linux__) | 
 | static off_t | static off_t | 
 | sf_inf(struct tagBufIO *buf, off_t pos, int w) | sf_inf(struct tagBufIO *buf, off_t pos, int w) | 
 | #else | #else | 
| Line 254  io_fmemopen(void ** __restrict base, off_t basesize) | Line 254  io_fmemopen(void ** __restrict base, off_t basesize) | 
 | { | { | 
 | FILE *f = NULL; | FILE *f = NULL; | 
 | struct tagBufIO *buf; | struct tagBufIO *buf; | 
 |  | #ifdef __linux__ | 
 |  | cookie_io_functions_t cookie; | 
 |  | #endif | 
 |  |  | 
 | if (!base) { | if (!base) { | 
 | io_SetErr(EINVAL, "Invalid base argument ..."); | io_SetErr(EINVAL, "Invalid base argument ..."); | 
| Line 283  io_fmemopen(void ** __restrict base, off_t basesize) | Line 286  io_fmemopen(void ** __restrict base, off_t basesize) | 
 | buf->buf_base = *base; | buf->buf_base = *base; | 
 | buf->buf_size = basesize; | buf->buf_size = basesize; | 
 |  |  | 
 |  | #ifndef __linux__ | 
 | #ifdef __NetBSD__ | #ifdef __NetBSD__ | 
 | if (buf->buf_mode == BUFIO_MODE_INFINIT) | if (buf->buf_mode == BUFIO_MODE_INFINIT) | 
 | f = funopen(buf, (int (*)(void *, char *, int)) rf_lim, | f = funopen(buf, (int (*)(void *, char *, int)) rf_lim, | 
| Line 306  io_fmemopen(void ** __restrict base, off_t basesize) | Line 310  io_fmemopen(void ** __restrict base, off_t basesize) | 
 | (fpos_t (*)(void *, fpos_t, int)) sf_lim, | (fpos_t (*)(void *, fpos_t, int)) sf_lim, | 
 | (int (*)(void *)) cf_); | (int (*)(void *)) cf_); | 
 | #endif | #endif | 
 |  | #else | 
 |  | if (buf->buf_mode == BUFIO_MODE_INFINIT) { | 
 |  | cookie.read = (cookie_read_function_t*) rf_lim; | 
 |  | cookie.write = (cookie_write_function_t*) wf_inf; | 
 |  | cookie.seek = (cookie_seek_function_t*) sf_inf; | 
 |  | cookie.close = (cookie_close_function_t*) cf_; | 
 |  | } else { | 
 |  | cookie.read = (cookie_read_function_t*) rf_lim; | 
 |  | cookie.write = (cookie_write_function_t*) wf_lim; | 
 |  | cookie.seek = (cookie_seek_function_t*) sf_lim; | 
 |  | cookie.close = (cookie_close_function_t*) cf_; | 
 |  | } | 
 |  |  | 
 |  | f = fopencookie(buf, "r+", cookie); | 
 |  | #endif | 
 | if (!f) { | if (!f) { | 
 | LOGERR; | LOGERR; | 
 | if (buf->buf_mode == BUFIO_MODE_INFINIT) { | if (buf->buf_mode == BUFIO_MODE_INFINIT) { | 
| Line 338  io_fmapopen(const char *csFile, int mode, int perm, in | Line 357  io_fmapopen(const char *csFile, int mode, int perm, in | 
 | void *base; | void *base; | 
 | off_t basesize; | off_t basesize; | 
 | int fd = -1; | int fd = -1; | 
 |  | #ifdef __linux__ | 
 |  | cookie_io_functions_t cookie = { | 
 |  | .read = (cookie_read_function_t*) rf_lim, | 
 |  | .write = (cookie_write_function_t*) wf_lim, | 
 |  | .seek = (cookie_seek_function_t*) sf_lim, | 
 |  | .close = (cookie_close_function_t*) cf_ | 
 |  | }; | 
 |  | #endif | 
 |  |  | 
 | if (csFile) { | if (csFile) { | 
 | fd = open(csFile, mode, perm); | fd = open(csFile, mode, perm); | 
| Line 386  io_fmapopen(const char *csFile, int mode, int perm, in | Line 413  io_fmapopen(const char *csFile, int mode, int perm, in | 
 | buf->buf_size = basesize; | buf->buf_size = basesize; | 
 | buf->buf_unmap = unmap_cf; | buf->buf_unmap = unmap_cf; | 
 |  |  | 
 |  | #ifndef __linux__ | 
 | #ifdef __NetBSD__ | #ifdef __NetBSD__ | 
 | f = funopen(buf, (int (*)(void *, char *, int)) rf_lim, | f = funopen(buf, (int (*)(void *, char *, int)) rf_lim, | 
 | (int (*)(void *, char const *, int)) wf_lim, | (int (*)(void *, char const *, int)) wf_lim, | 
| Line 396  io_fmapopen(const char *csFile, int mode, int perm, in | Line 424  io_fmapopen(const char *csFile, int mode, int perm, in | 
 | (int (*)(void *, char const *, int)) wf_lim, | (int (*)(void *, char const *, int)) wf_lim, | 
 | (fpos_t (*)(void *, fpos_t, int)) sf_lim, | (fpos_t (*)(void *, fpos_t, int)) sf_lim, | 
 | (int (*)(void *)) cf_); | (int (*)(void *)) cf_); | 
 |  | #endif | 
 |  | #else | 
 |  | f = fopencookie(buf, "r+", cookie); | 
 | #endif | #endif | 
 | if (!f) { | if (!f) { | 
 | LOGERR; | LOGERR; |