hawk/lib/hawk-sio.h

335 lines
8.8 KiB
C

/*
Copyright (c) 2006-2020 Chung, Hyung-Hwan. All rights reserved.
Redistribution and use in source and binary forms, with or without
modification, are permitted provided that the following conditions
are met:
1. Redistributions of source code must retain the above copyright
notice, this list of conditions and the following disclaimer.
2. Redistributions in binary form must reproduce the above copyright
notice, this list of conditions and the following disclaimer in the
documentation and/or other materials provided with the distribution.
THIS SOFTWARE IS PROVIDED BY THE AUTHOR "AS IS" AND ANY EXPRESS OR
IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
#ifndef _HAWK_SIO_H_
#define _HAWK_SIO_H_
#include <hawk-cmn.h>
#include <hawk-fio.h>
#include <hawk-tio.h>
#include <hawk-mtx.h>
#include <stdarg.h>
enum hawk_sio_flag_t
{
/* ensure that these enumerators never overlap with
* hawk_fio_flag_t enumerators. you can use values between
* (1<<0) and (1<<7) inclusive reserved in hawk_fio_flag_t.
* the range is represented by HAWK_FIO_RESERVED. */
HAWK_SIO_LINEBREAK = (1 << 0), /* expand \n to a system line-break convention if necessary */
HAWK_SIO_IGNOREECERR = (1 << 1),
HAWK_SIO_NOAUTOFLUSH = (1 << 2),
HAWK_SIO_KEEPPATH = (1 << 3),
HAWK_SIO_REENTRANT = (1 << 4),
/* ensure that the following enumerators are one of
* hawk_fio_flags_t enumerators */
HAWK_SIO_HANDLE = HAWK_FIO_HANDLE,
HAWK_SIO_TEMPORARY = HAWK_FIO_TEMPORARY,
HAWK_SIO_NOCLOSE = HAWK_FIO_NOCLOSE,
HAWK_SIO_BCSTRPATH = HAWK_FIO_BCSTRPATH,
HAWK_SIO_READ = HAWK_FIO_READ,
HAWK_SIO_WRITE = HAWK_FIO_WRITE,
HAWK_SIO_APPEND = HAWK_FIO_APPEND,
HAWK_SIO_CREATE = HAWK_FIO_CREATE,
HAWK_SIO_TRUNCATE = HAWK_FIO_TRUNCATE,
HAWK_SIO_EXCLUSIVE = HAWK_FIO_EXCLUSIVE,
HAWK_SIO_SYNC = HAWK_FIO_SYNC,
HAWK_SIO_NOFOLLOW = HAWK_FIO_NOFOLLOW,
HAWK_SIO_NOSHREAD = HAWK_FIO_NOSHREAD,
HAWK_SIO_NOSHWRITE = HAWK_FIO_NOSHWRITE,
HAWK_SIO_NOSHDELETE = HAWK_FIO_NOSHDELETE,
HAWK_SIO_RANDOM = HAWK_FIO_RANDOM,
HAWK_SIO_SEQUENTIAL = HAWK_FIO_SEQUENTIAL
};
typedef hawk_fio_off_t hawk_sio_pos_t;
typedef hawk_fio_hnd_t hawk_sio_hnd_t;
typedef hawk_fio_std_t hawk_sio_std_t;
typedef hawk_fio_ori_t hawk_sio_ori_t;
#define HAWK_SIO_STDIN HAWK_FIO_STDIN
#define HAWK_SIO_STDOUT HAWK_FIO_STDOUT
#define HAWK_SIO_STDERR HAWK_FIO_STDERR
#define HAWK_SIO_BEGIN HAWK_FIO_BEGIN
#define HAWK_SIO_CURRENT HAWK_FIO_CURRENT
#define HAWK_SIO_END HAWK_FIO_END
/**
* The hawk_sio_t type defines a simple text stream over a file. It also
* provides predefined streams for standard input, output, and error.
*/
typedef struct hawk_sio_t hawk_sio_t;
struct hawk_sio_t
{
hawk_gem_t* gem;
hawk_fio_t file;
struct
{
hawk_tio_t io;
hawk_sio_t* xtn; /* static extension for tio */
} tio;
hawk_bch_t inbuf[2048];
hawk_bch_t outbuf[2048];
hawk_ooch_t* path;
hawk_mtx_t* mtx;
#if defined(_WIN32) || defined(__OS2__)
int status;
#endif
};
/** access the @a errnum field of the #hawk_sio_t structure */
#define HAWK_SIO_ERRNUM(sio) ((sio)->errnum)
#if defined(__cplusplus)
extern "C" {
#endif
/**
* The hawk_sio_open() fucntion creates a stream object.
*/
HAWK_EXPORT hawk_sio_t* hawk_sio_open (
hawk_gem_t* gem,
hawk_oow_t xtnsize, /**< extension size in bytes */
const hawk_ooch_t* file, /**< file name */
int flags /**< number OR'ed of #hawk_sio_flag_t */
);
HAWK_EXPORT hawk_sio_t* hawk_sio_openstd (
hawk_gem_t* gem,
hawk_oow_t xtnsize, /**< extension size in bytes */
hawk_sio_std_t std, /**< standard I/O identifier */
int flags /**< number OR'ed of #hawk_sio_flag_t */
);
/**
* The hawk_sio_close() function destroys a stream object.
*/
HAWK_EXPORT void hawk_sio_close (
hawk_sio_t* sio /**< stream */
);
HAWK_EXPORT int hawk_sio_init (
hawk_sio_t* sio,
hawk_gem_t* gem,
const hawk_ooch_t* file,
int flags
);
HAWK_EXPORT int hawk_sio_initstd (
hawk_sio_t* sio,
hawk_gem_t* gem,
hawk_sio_std_t std,
int flags
);
HAWK_EXPORT void hawk_sio_fini (
hawk_sio_t* sio
);
#if defined(HAWK_HAVE_INLINE)
static HAWK_INLINE void* hawk_sio_getxtn (hawk_sio_t* sio) { return (void*)(sio + 1); }
#else
#define hawk_sio_getxtn(sio) ((void*)((hawk_sio_t*)(sio) + 1))
#endif
HAWK_EXPORT hawk_cmgr_t* hawk_sio_getcmgr (
hawk_sio_t* sio
);
HAWK_EXPORT void hawk_sio_setcmgr (
hawk_sio_t* sio,
hawk_cmgr_t* cmgr
);
HAWK_EXPORT hawk_sio_hnd_t hawk_sio_gethnd (
const hawk_sio_t* sio
);
/**
* The hawk_sio_getpath() returns the file path used to open the stream.
* It returns #HAWK_NULL if #HAWK_SIO_HANDLE was on or #HAWK_SIO_KEEPPATH
* was off at the time of opening.
*/
HAWK_EXPORT const hawk_ooch_t* hawk_sio_getpath (
hawk_sio_t* sio
);
HAWK_EXPORT hawk_ooi_t hawk_sio_flush (
hawk_sio_t* sio
);
/**
* The hawk_sio_drain() funtion purges all buffered data without writing.
*/
HAWK_EXPORT void hawk_sio_drain (
hawk_sio_t* sio
);
HAWK_EXPORT hawk_ooi_t hawk_sio_getbchar (
hawk_sio_t* sio,
hawk_bch_t* c
);
HAWK_EXPORT hawk_ooi_t hawk_sio_getuchar (
hawk_sio_t* sio,
hawk_uch_t* c
);
HAWK_EXPORT hawk_ooi_t hawk_sio_getbcstr (
hawk_sio_t* sio,
hawk_bch_t* buf,
hawk_oow_t size
);
HAWK_EXPORT hawk_ooi_t hawk_sio_getbchars (
hawk_sio_t* sio,
hawk_bch_t* buf,
hawk_oow_t size
);
/**
* The hawk_sio_getucstr() function reads at most @a size - 1 characters
* from the stream @a sio into the buffer @a buf. If a new line or EOF
* is encountered, it stops reading from the stream. It null-terminates
* the buffer if @a size is greater than 0.
*/
HAWK_EXPORT hawk_ooi_t hawk_sio_getucstr (
hawk_sio_t* sio,
hawk_uch_t* buf,
hawk_oow_t size
);
/**
* The hawk_sio_getuchars() function reads at most @a size characters
* from the stream @a sio into the buffer @a buf. If a new line or EOF
* is encountered, it stops reading from the stream.
*/
HAWK_EXPORT hawk_ooi_t hawk_sio_getuchars (
hawk_sio_t* sio,
hawk_uch_t* buf,
hawk_oow_t size
);
#if defined(HAWK_OOCH_IS_BCH)
# define hawk_sio_getoochar hawk_sio_getbchar
# define hawk_sio_getoocstr hawk_sio_getbcstr
# define hawk_sio_getoochars hawk_sio_getbchars
#else
# define hawk_sio_getoochar hawk_sio_getuchar
# define hawk_sio_getoocstr hawk_sio_getucstr
# define hawk_sio_getoochars hawk_sio_getuchars
#endif
HAWK_EXPORT hawk_ooi_t hawk_sio_putbchar (
hawk_sio_t* sio,
hawk_bch_t c
);
HAWK_EXPORT hawk_ooi_t hawk_sio_putuchar (
hawk_sio_t* sio,
hawk_uch_t c
);
HAWK_EXPORT hawk_ooi_t hawk_sio_putbcstr (
hawk_sio_t* sio,
const hawk_bch_t* str
);
HAWK_EXPORT hawk_ooi_t hawk_sio_putucstr (
hawk_sio_t* sio,
const hawk_uch_t* str
);
HAWK_EXPORT hawk_ooi_t hawk_sio_putbchars (
hawk_sio_t* sio,
const hawk_bch_t* str,
hawk_oow_t size
);
HAWK_EXPORT hawk_ooi_t hawk_sio_putuchars (
hawk_sio_t* sio,
const hawk_uch_t* str,
hawk_oow_t size
);
#if defined(HAWK_OOCH_IS_BCH)
# define hawk_sio_putoochar hawk_sio_putbchar
# define hawk_sio_putoocstr hawk_sio_putbcstr
# define hawk_sio_putoochars hawk_sio_putbchars
#else
# define hawk_sio_putoochar hawk_sio_putuchar
# define hawk_sio_putoocstr hawk_sio_putucstr
# define hawk_sio_putoochars hawk_sio_putuchars
#endif
/**
* The hawk_sio_getpos() function gets the current position in a stream.
* Note that it may not return the desired postion due to buffering.
* @return 0 on success, -1 on failure
*/
HAWK_EXPORT int hawk_sio_getpos (
hawk_sio_t* sio, /**< stream */
hawk_sio_pos_t* pos /**< position */
);
/**
* The hawk_sio_setpos() function changes the current position in a stream.
* @return 0 on success, -1 on failure
*/
HAWK_EXPORT int hawk_sio_setpos (
hawk_sio_t* sio, /**< stream */
hawk_sio_pos_t pos /**< position */
);
HAWK_EXPORT int hawk_sio_truncate (
hawk_sio_t* sio,
hawk_sio_pos_t pos
);
/**
* The hawk_sio_seek() function repositions the current file offset.
* Upon success, \a pos is adjusted to the new offset from the beginning
* of the file.
*/
HAWK_EXPORT int hawk_sio_seek (
hawk_sio_t* sio,
hawk_sio_pos_t* pos,
hawk_sio_ori_t origin
);
#if defined(__cplusplus)
}
#endif
#endif