hawk/lib/hawk-tio.h

273 lines
6.9 KiB
C
Raw Normal View History

2019-12-13 04:29:58 +00:00
/*
Copyright (c) 2006-2020 Chung, Hyung-Hwan. All rights reserved.
2019-12-13 04:29:58 +00:00
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_TIO_H_
#define _HAWK_TIO_H_
#include <hawk-cmn.h>
enum hawk_tio_cmd_t
{
HAWK_TIO_OPEN,
HAWK_TIO_CLOSE,
HAWK_TIO_DATA
};
typedef enum hawk_tio_cmd_t hawk_tio_cmd_t;
enum hawk_tio_flag_t
{
/**< ignore multibyte/wide-character conversion error by
* inserting a question mark for each error occurrence */
HAWK_TIO_IGNOREECERR = (1 << 0),
/**< do not flush data in the buffer until the buffer gets full. */
HAWK_TIO_NOAUTOFLUSH = (1 << 1)
};
enum hawk_tio_misc_t
{
HAWK_TIO_MININBUFCAPA = 32,
HAWK_TIO_MINOUTBUFCAPA = 32
};
typedef struct hawk_tio_t hawk_tio_t;
/**
* The hawk_tio_io_impl_t types define a text I/O handler.
*/
typedef hawk_ooi_t (*hawk_tio_io_impl_t) (
hawk_tio_t* tio,
hawk_tio_cmd_t cmd,
void* data,
hawk_oow_t size
);
struct hawk_tio_io_t
{
hawk_tio_io_impl_t fun;
struct
{
hawk_oow_t capa;
hawk_bch_t* ptr;
} buf;
};
typedef struct hawk_tio_io_t hawk_tio_io_t;
/**
* The hawk_tio_t type defines a generic type for text IO. If #hawk_ooch_t is
* #hawk_bch_t, it handles any byte streams. If hawk_ooch_t is #hawk_uch_t,
* it handles a multi-byte stream converted to a wide character stream.
*/
struct hawk_tio_t
{
2019-12-18 05:15:03 +00:00
hawk_gem_t* gem;
2019-12-13 04:29:58 +00:00
int flags;
hawk_cmgr_t* cmgr;
hawk_tio_io_t in;
hawk_tio_io_t out;
/* for house keeping from here */
int status;
hawk_oow_t inbuf_cur;
hawk_oow_t inbuf_len;
hawk_oow_t outbuf_len;
};
#if defined(__cplusplus)
extern "C" {
#endif
/**
* The hawk_tio_open() function creates an text stream processoor.
*/
HAWK_EXPORT hawk_tio_t* hawk_tio_open (
2019-12-18 05:15:03 +00:00
hawk_gem_t* gem,
2019-12-13 04:29:58 +00:00
hawk_oow_t xtnsize, /**< extension size in bytes */
int flags /**< ORed of hawk_tio_flag_t enumerators */
);
/**
* The hawk_tio_close() function destroys an text stream processor.
*/
HAWK_EXPORT int hawk_tio_close (
hawk_tio_t* tio
);
/**
* The hawk_tio_init() function initialize a statically declared
* text stream processor.
*/
HAWK_EXPORT int hawk_tio_init (
hawk_tio_t* tio,
2019-12-18 05:15:03 +00:00
hawk_gem_t* gem,
2019-12-13 04:29:58 +00:00
int flags
);
/**
* The hawk_tio_fini() function finalizes a text stream processor
*/
HAWK_EXPORT int hawk_tio_fini (
hawk_tio_t* tio
);
#if defined(HAWK_HAVE_INLINE)
static HAWK_INLINE void* hawk_tio_getxtn (hawk_tio_t* tio) { return (void*)(tio + 1); }
#else
#define hawk_tio_getxtn(tio) ((void*)((hawk_tio_t*)(tio) + 1))
2019-12-13 04:29:58 +00:00
#endif
/**
* The hawk_tio_getcmgr() function returns the character manager.
*/
HAWK_EXPORT hawk_cmgr_t* hawk_tio_getcmgr (
hawk_tio_t* tio
);
/**
* The hawk_tio_setcmgr() function changes the character manager.
*/
HAWK_EXPORT void hawk_tio_setcmgr (
hawk_tio_t* tio,
hawk_cmgr_t* cmgr
);
/**
* The hawk_tio_attachin() function attachs an input handler .
* @return 0 on success, -1 on failure
*/
HAWK_EXPORT int hawk_tio_attachin (
2019-12-18 15:28:31 +00:00
hawk_tio_t* tio,
2019-12-13 04:29:58 +00:00
hawk_tio_io_impl_t input,
2019-12-18 15:28:31 +00:00
hawk_bch_t* bufptr,
hawk_oow_t bufcapa
2019-12-13 04:29:58 +00:00
);
/**
* The hawk_tio_detachin() function detaches an input handler .
* @return 0 on success, -1 on failure
*/
HAWK_EXPORT int hawk_tio_detachin (
hawk_tio_t* tio
);
/**
* The hawk_tio_attachout() function attaches an output handler.
* @return 0 on success, -1 on failure
*/
HAWK_EXPORT int hawk_tio_attachout (
2019-12-18 05:15:03 +00:00
hawk_tio_t* tio,
2019-12-13 04:29:58 +00:00
hawk_tio_io_impl_t output,
2019-12-18 05:15:03 +00:00
hawk_bch_t* bufptr,
hawk_oow_t bufcapa
2019-12-13 04:29:58 +00:00
);
/**
* The hawk_tio_detachout() function detaches an output handler .
* @return 0 on success, -1 on failure
*/
HAWK_EXPORT int hawk_tio_detachout (
hawk_tio_t* tio
);
/**
* The hawk_tio_flush() function flushes the output buffer. It returns the
* number of bytes written on success, -1 on failure.
*/
HAWK_EXPORT hawk_ooi_t hawk_tio_flush (
hawk_tio_t* tio
);
/**
* The hawk_tio_drain() function empties input and output buffers.
*/
HAWK_EXPORT void hawk_tio_drain (
hawk_tio_t* tio
);
HAWK_EXPORT hawk_ooi_t hawk_tio_readbchars (
hawk_tio_t* tio,
hawk_bch_t* buf,
hawk_oow_t size
);
HAWK_EXPORT hawk_ooi_t hawk_tio_readuchars (
hawk_tio_t* tio,
hawk_uch_t* buf,
hawk_oow_t size
);
/**
* The hawk_tio_read() macro is character-type neutral. It maps
* to hawk_tio_readbchars() or hawk_tio_readuchars().
*/
#ifdef HAWK_OOCH_IS_BCH
# define hawk_tio_read(tio,buf,size) hawk_tio_readbchars(tio,buf,size)
#else
# define hawk_tio_read(tio,buf,size) hawk_tio_readuchars(tio,buf,size)
#endif
/**
* The hawk_tio_writebchars() function writes the @a size characters
* from a multibyte string @a str. If @a size is (hawk_oow_t)-1,
* it writes on until a terminating null is found. It doesn't
* write more than HAWK_TYPE_MAX(hawk_ooi_t) characters.
* @return number of characters written on success, -1 on failure.
*/
HAWK_EXPORT hawk_ooi_t hawk_tio_writebchars (
hawk_tio_t* tio,
const hawk_bch_t* str,
2019-12-13 04:29:58 +00:00
hawk_oow_t size
);
/**
* The hawk_tio_writebchars() function writes the @a size characters
* from a wide-character string @a str. If @a size is (hawk_oow_t)-1,
* it writes on until a terminating null is found. It doesn't write
* more than HAWK_TYPE_MAX(hawk_ooi_t) characters.
* @return number of characters written on success, -1 on failure.
*/
HAWK_EXPORT hawk_ooi_t hawk_tio_writeuchars (
hawk_tio_t* tio,
const hawk_uch_t* str,
2019-12-13 04:29:58 +00:00
hawk_oow_t size
);
/**
* The hawk_tio_write() macro is character-type neutral. It maps
* to hawk_tio_writebchars() or hawk_tio_writeuchars().
*/
#ifdef HAWK_OOCH_IS_BCH
# define hawk_tio_write(tio,str,size) hawk_tio_writebchars(tio,str,size)
#else
# define hawk_tio_write(tio,str,size) hawk_tio_writeuchars(tio,str,size)
#endif
#if defined(__cplusplus)
}
#endif
#endif