|
version 1.5, 2012/05/14 12:49:21
|
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, 2005, 2006, 2007, 2008, 2009, 2010, 2011, 2012 | 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 62 cf_(struct tagBufIO *buf)
|
Line 62 cf_(struct tagBufIO *buf)
|
| } |
} |
| |
|
| if (buf->buf_mode == BUFIO_MODE_INFINIT) |
if (buf->buf_mode == BUFIO_MODE_INFINIT) |
| free(buf->buf_base); | e_free(buf->buf_base); |
| else if (buf->buf_unmap) |
else if (buf->buf_unmap) |
| buf->buf_unmap(buf); |
buf->buf_unmap(buf); |
| |
|
| free(buf); | e_free(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 157 sf_inf(struct tagBufIO *buf, fpos_t pos, int w)
|
Line 157 sf_inf(struct tagBufIO *buf, fpos_t pos, int w)
|
| if (pos < 0) |
if (pos < 0) |
| goto err; |
goto err; |
| if (buf->buf_size < pos) { |
if (buf->buf_size < pos) { |
| b = realloc(buf->buf_base, pos); | b = e_realloc(buf->buf_base, pos); |
| if (!b) { |
if (!b) { |
| LOGERR; |
LOGERR; |
| return -1; |
return -1; |
|
Line 173 sf_inf(struct tagBufIO *buf, fpos_t pos, int w)
|
Line 173 sf_inf(struct tagBufIO *buf, fpos_t pos, int w)
|
| if ((buf->buf_offset + pos) < 0) |
if ((buf->buf_offset + pos) < 0) |
| goto err; |
goto err; |
| if (buf->buf_size < (buf->buf_offset + pos)) { |
if (buf->buf_size < (buf->buf_offset + pos)) { |
| b = realloc(buf->buf_base, buf->buf_offset + pos); | b = e_realloc(buf->buf_base, buf->buf_offset + pos); |
| if (!b) { |
if (!b) { |
| LOGERR; |
LOGERR; |
| return -1; |
return -1; |
|
Line 190 sf_inf(struct tagBufIO *buf, fpos_t pos, int w)
|
Line 190 sf_inf(struct tagBufIO *buf, fpos_t pos, int w)
|
| if ((buf->buf_size + pos) < 0) |
if ((buf->buf_size + pos) < 0) |
| goto err; |
goto err; |
| if (buf->buf_size < (buf->buf_size + pos)) { |
if (buf->buf_size < (buf->buf_size + pos)) { |
| b = realloc(buf->buf_base, buf->buf_size + pos); | b = e_realloc(buf->buf_base, buf->buf_size + pos); |
| if (!b) { |
if (!b) { |
| LOGERR; |
LOGERR; |
| return -1; |
return -1; |
|
Line 224 wf_inf(struct tagBufIO *buf, const char *dat, int siz)
|
Line 224 wf_inf(struct tagBufIO *buf, const char *dat, int siz)
|
| } |
} |
| |
|
| if (buf->buf_offset + siz > buf->buf_size) { |
if (buf->buf_offset + siz > buf->buf_size) { |
| b = realloc(buf->buf_base, buf->buf_offset + siz); | b = e_realloc(buf->buf_base, buf->buf_offset + siz); |
| if (!b) { |
if (!b) { |
| LOGERR; |
LOGERR; |
| return -1; |
return -1; |
|
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 ..."); |
| return NULL; |
return NULL; |
| } |
} |
| |
|
| buf = malloc(sizeof(struct tagBufIO)); | buf = e_malloc(sizeof(struct tagBufIO)); |
| if (!buf) { |
if (!buf) { |
| LOGERR; |
LOGERR; |
| return NULL; |
return NULL; |
|
Line 268 io_fmemopen(void ** __restrict base, off_t basesize)
|
Line 271 io_fmemopen(void ** __restrict base, off_t basesize)
|
| memset(buf, 0, sizeof(struct tagBufIO)); |
memset(buf, 0, sizeof(struct tagBufIO)); |
| |
|
| if (!*base) { |
if (!*base) { |
| *base = malloc(basesize); | *base = e_malloc(basesize); |
| if (!*base) { |
if (!*base) { |
| LOGERR; |
LOGERR; |
| free(buf); | e_free(buf); |
| return NULL; |
return NULL; |
| } else |
} else |
| memset(*base, 0, basesize); |
memset(*base, 0, basesize); |
|
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) { |
| free(*base); | e_free(*base); |
| *base = NULL; |
*base = NULL; |
| } |
} |
| free(buf); | e_free(buf); |
| return NULL; |
return NULL; |
| } |
} |
| |
|
|
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 373 io_fmapopen(const char *csFile, int mode, int perm, in
|
Line 400 io_fmapopen(const char *csFile, int mode, int perm, in
|
| } |
} |
| |
|
| |
|
| buf = malloc(sizeof(struct tagBufIO)); | buf = e_malloc(sizeof(struct tagBufIO)); |
| if (!buf) { |
if (!buf) { |
| LOGERR; |
LOGERR; |
| munmap(base, basesize); |
munmap(base, basesize); |
|
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 397 io_fmapopen(const char *csFile, int mode, int perm, in
|
Line 425 io_fmapopen(const char *csFile, int mode, int perm, in
|
| (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 |
| |
f = fopencookie(buf, "r+", cookie); |
| |
#endif |
| if (!f) { |
if (!f) { |
| LOGERR; |
LOGERR; |
| free(buf); | e_free(buf); |
| munmap(base, basesize); |
munmap(base, basesize); |
| return NULL; |
return NULL; |
| } |
} |
|
Line 447 err:
|
Line 478 err:
|
| * @mode = Permissions for new buffered file I/O |
* @mode = Permissions for new buffered file I/O |
| * return: NULL error or open buffered file |
* return: NULL error or open buffered file |
| */ |
*/ |
| inline FILE * | FILE * |
| io_fd2buf(int fd, const char *mode) |
io_fd2buf(int fd, const char *mode) |
| { |
{ |
| FILE *f; |
FILE *f; |