2009-05-19 22:32:12 +00:00
|
|
|
/*
|
2012-08-16 03:47:55 +00:00
|
|
|
* $Id$
|
2009-05-19 22:32:12 +00:00
|
|
|
*
|
2012-07-20 04:13:39 +00:00
|
|
|
Copyright 2006-2012 Chung, Hyung-Hwan.
|
2009-09-16 04:01:02 +00:00
|
|
|
This file is part of QSE.
|
2009-05-19 22:32:12 +00:00
|
|
|
|
2009-09-16 04:01:02 +00:00
|
|
|
QSE is free software: you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU Lesser General Public License as
|
|
|
|
published by the Free Software Foundation, either version 3 of
|
|
|
|
the License, or (at your option) any later version.
|
2009-05-19 22:32:12 +00:00
|
|
|
|
2009-09-16 04:01:02 +00:00
|
|
|
QSE is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU Lesser General Public License for more details.
|
2009-05-19 22:32:12 +00:00
|
|
|
|
2009-09-16 04:01:02 +00:00
|
|
|
You should have received a copy of the GNU Lesser General Public
|
|
|
|
License along with QSE. If not, see <http://www.gnu.org/licenses/>.
|
2009-05-19 22:32:12 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _QSE_LIB_SED_SED_H_
|
|
|
|
#define _QSE_LIB_SED_SED_H_
|
|
|
|
|
|
|
|
#include <qse/sed/sed.h>
|
|
|
|
#include <qse/cmn/str.h>
|
|
|
|
|
2010-07-15 06:54:48 +00:00
|
|
|
#define QSE_MAP_AS_RBT
|
|
|
|
#include <qse/cmn/map.h>
|
|
|
|
|
2011-09-03 09:27:44 +00:00
|
|
|
/*
|
|
|
|
* Define USE_REX to use rex.h on behalf of tre.h
|
|
|
|
* rex.h currently does not support backreference.
|
|
|
|
*/
|
|
|
|
#ifdef USE_REX
|
|
|
|
enum qse_sed_depth_t
|
|
|
|
{
|
|
|
|
QSE_SED_DEPTH_REX_BUILD = (1 << 0),
|
|
|
|
QSE_SED_DEPTH_REX_MATCH = (1 << 1)
|
|
|
|
};
|
2011-09-07 08:18:36 +00:00
|
|
|
typedef enum qse_sed_depth_t qse_sed_depth_t;
|
2011-09-03 09:27:44 +00:00
|
|
|
#endif
|
|
|
|
|
2011-10-12 00:19:27 +00:00
|
|
|
/* structure to maintain data to append
|
|
|
|
* at the end of each cycle, triggered by r, R, and a */
|
2011-09-26 00:28:58 +00:00
|
|
|
typedef struct qse_sed_app_t qse_sed_app_t;
|
|
|
|
struct qse_sed_app_t
|
|
|
|
{
|
2011-09-27 22:51:26 +00:00
|
|
|
qse_sed_cmd_t* cmd;
|
2011-09-26 00:28:58 +00:00
|
|
|
qse_sed_app_t* next;
|
|
|
|
};
|
|
|
|
|
2011-10-06 00:41:04 +00:00
|
|
|
typedef struct qse_sed_cmd_blk_t qse_sed_cmd_blk_t;
|
2009-05-30 19:19:46 +00:00
|
|
|
struct qse_sed_cmd_blk_t
|
|
|
|
{
|
|
|
|
qse_size_t len;
|
2009-05-30 23:29:06 +00:00
|
|
|
qse_sed_cmd_t buf[256];
|
2009-05-30 19:19:46 +00:00
|
|
|
qse_sed_cmd_blk_t* next;
|
|
|
|
};
|
2009-05-19 22:32:12 +00:00
|
|
|
|
2011-10-12 00:19:27 +00:00
|
|
|
/* structure to maintain list of compiliation
|
|
|
|
* identifiers */
|
2011-10-07 02:01:35 +00:00
|
|
|
typedef struct qse_sed_cid_t qse_sed_cid_t;
|
|
|
|
struct qse_sed_cid_t
|
|
|
|
{
|
|
|
|
qse_sed_cid_t* next;
|
|
|
|
};
|
|
|
|
|
2011-10-12 00:19:27 +00:00
|
|
|
/* special structure to represent an unknown cid
|
|
|
|
* used once the action of setting a new cid fails */
|
2011-10-07 23:09:48 +00:00
|
|
|
typedef struct qse_sed_unknown_cid_t qse_sed_unknown_cid_t;
|
|
|
|
struct qse_sed_unknown_cid_t
|
|
|
|
{
|
|
|
|
qse_sed_cid_t* next;
|
|
|
|
qse_char_t buf[1];
|
|
|
|
};
|
|
|
|
|
2009-05-19 22:32:12 +00:00
|
|
|
/**
|
|
|
|
* The qse_sed_t type defines a stream editor
|
|
|
|
*/
|
|
|
|
struct qse_sed_t
|
|
|
|
{
|
|
|
|
QSE_DEFINE_COMMON_FIELDS (sed)
|
|
|
|
|
2009-05-28 07:55:17 +00:00
|
|
|
qse_sed_errstr_t errstr; /**< error string getter */
|
2009-05-19 22:32:12 +00:00
|
|
|
qse_sed_errnum_t errnum; /**< stores an error number */
|
2009-05-22 00:17:17 +00:00
|
|
|
qse_char_t errmsg[128]; /**< error message holder */
|
2009-08-26 21:03:51 +00:00
|
|
|
qse_sed_loc_t errloc; /**< location of the last error */
|
2009-05-22 00:17:17 +00:00
|
|
|
|
2009-05-19 22:32:12 +00:00
|
|
|
int option; /**< stores options */
|
|
|
|
|
2009-09-03 06:55:55 +00:00
|
|
|
qse_sed_lformatter_t lformatter;
|
|
|
|
|
2009-05-30 23:29:06 +00:00
|
|
|
struct
|
|
|
|
{
|
|
|
|
struct
|
|
|
|
{
|
|
|
|
qse_size_t build;
|
|
|
|
qse_size_t match;
|
|
|
|
} rex;
|
|
|
|
} depth;
|
|
|
|
|
2012-09-07 15:13:55 +00:00
|
|
|
qse_sed_ecb_t* ecb;
|
|
|
|
|
2009-05-19 22:32:12 +00:00
|
|
|
/** source text pointers */
|
|
|
|
struct
|
|
|
|
{
|
2012-10-20 15:58:20 +00:00
|
|
|
qse_sed_io_impl_t fun; /**< input stream handler */
|
2011-10-03 01:25:23 +00:00
|
|
|
qse_sed_io_arg_t arg;
|
|
|
|
qse_char_t buf[1024];
|
|
|
|
int eof;
|
|
|
|
|
2011-10-07 23:09:48 +00:00
|
|
|
qse_sed_cid_t* cid;
|
|
|
|
qse_sed_unknown_cid_t unknown_cid;
|
|
|
|
|
2011-10-03 01:25:23 +00:00
|
|
|
qse_sed_loc_t loc; /**< location */
|
|
|
|
qse_cint_t cc; /**< last character read */
|
2009-05-19 22:32:12 +00:00
|
|
|
const qse_char_t* ptr; /**< beginning of the source text */
|
|
|
|
const qse_char_t* end; /**< end of the source text */
|
|
|
|
const qse_char_t* cur; /**< current source text pointer */
|
|
|
|
} src;
|
|
|
|
|
2009-05-25 07:29:12 +00:00
|
|
|
/** temporary data for compiling */
|
|
|
|
struct
|
|
|
|
{
|
|
|
|
qse_str_t rex; /**< regular expression buffer */
|
|
|
|
qse_str_t lab; /**< label name buffer */
|
|
|
|
|
|
|
|
/** data structure to compile command groups */
|
|
|
|
struct
|
|
|
|
{
|
|
|
|
/** current level of command group nesting */
|
|
|
|
int level;
|
|
|
|
/** keeps track of the begining of nested groups */
|
|
|
|
qse_sed_cmd_t* cmd[128];
|
|
|
|
} grp;
|
|
|
|
|
|
|
|
/** a table storing labels seen */
|
2010-07-15 06:54:48 +00:00
|
|
|
qse_map_t labs;
|
2009-05-25 07:29:12 +00:00
|
|
|
} tmp;
|
2009-05-19 22:32:12 +00:00
|
|
|
|
|
|
|
/** compiled commands */
|
2009-05-30 19:19:46 +00:00
|
|
|
struct
|
|
|
|
{
|
|
|
|
qse_sed_cmd_blk_t fb; /**< the first block is static */
|
|
|
|
qse_sed_cmd_blk_t* lb; /**< points to the last block */
|
2009-05-30 23:29:06 +00:00
|
|
|
|
|
|
|
qse_sed_cmd_t quit;
|
2011-09-09 01:49:53 +00:00
|
|
|
qse_sed_cmd_t quit_quiet;
|
2009-05-30 23:29:06 +00:00
|
|
|
qse_sed_cmd_t again;
|
|
|
|
qse_sed_cmd_t over;
|
2009-05-30 19:19:46 +00:00
|
|
|
} cmd;
|
|
|
|
|
2009-05-19 22:32:12 +00:00
|
|
|
/** data for execution */
|
|
|
|
struct
|
|
|
|
{
|
|
|
|
/** data needed for output streams and files */
|
|
|
|
struct
|
|
|
|
{
|
2012-10-20 15:58:20 +00:00
|
|
|
qse_sed_io_impl_t fun; /**< an output handler */
|
2009-05-19 22:32:12 +00:00
|
|
|
qse_sed_io_arg_t arg; /**< output handling data */
|
|
|
|
|
|
|
|
qse_char_t buf[2048];
|
|
|
|
qse_size_t len;
|
|
|
|
int eof;
|
|
|
|
|
|
|
|
/*****************************************************/
|
|
|
|
/* the following two fields are very tightly-coupled.
|
|
|
|
* don't make any partial changes */
|
2010-07-15 06:54:48 +00:00
|
|
|
qse_map_t files;
|
2009-05-19 22:32:12 +00:00
|
|
|
qse_sed_t* files_ext;
|
|
|
|
/*****************************************************/
|
|
|
|
} out;
|
|
|
|
|
|
|
|
/** data needed for input streams */
|
|
|
|
struct
|
|
|
|
{
|
2012-10-20 15:58:20 +00:00
|
|
|
qse_sed_io_impl_t fun; /**< an input handler */
|
2009-05-19 22:32:12 +00:00
|
|
|
qse_sed_io_arg_t arg; /**< input handling data */
|
|
|
|
|
|
|
|
qse_char_t xbuf[1]; /**< a read-ahead buffer */
|
|
|
|
int xbuf_len; /**< data length in the buffer */
|
|
|
|
|
|
|
|
qse_char_t buf[2048]; /**< input buffer */
|
|
|
|
qse_size_t len; /**< data length in the buffer */
|
|
|
|
qse_size_t pos; /**< current position in the buffer */
|
|
|
|
int eof; /**< EOF indicator */
|
|
|
|
|
|
|
|
qse_str_t line; /**< pattern space */
|
|
|
|
qse_size_t num; /**< current line number */
|
|
|
|
} in;
|
|
|
|
|
|
|
|
struct
|
|
|
|
{
|
2011-09-27 22:51:26 +00:00
|
|
|
qse_size_t count; /* number of append entries in a static buffer. */
|
|
|
|
qse_sed_app_t s[16]; /* handle up to 16 appends in a static buffer */
|
2011-09-26 00:28:58 +00:00
|
|
|
struct
|
|
|
|
{
|
|
|
|
qse_sed_app_t* head;
|
|
|
|
qse_sed_app_t* tail;
|
2011-09-27 22:51:26 +00:00
|
|
|
} d;
|
|
|
|
} append;
|
|
|
|
/** text buffers */
|
|
|
|
struct
|
|
|
|
{
|
2011-09-18 09:41:26 +00:00
|
|
|
qse_str_t hold; /* hold space */
|
2012-08-19 14:20:05 +00:00
|
|
|
qse_str_t scratch;
|
2009-05-19 22:32:12 +00:00
|
|
|
} txt;
|
|
|
|
|
2012-08-19 14:20:05 +00:00
|
|
|
struct
|
|
|
|
{
|
|
|
|
qse_size_t nflds; /**< the number of fields */
|
|
|
|
qse_size_t cflds; /**< capacity of flds field */
|
|
|
|
qse_cstr_t sflds[128]; /**< static field buffer */
|
|
|
|
qse_cstr_t* flds;
|
|
|
|
int delimited;
|
|
|
|
} cutf;
|
|
|
|
|
2009-05-19 22:32:12 +00:00
|
|
|
/** indicates if a successful substitution has been made
|
|
|
|
* since the last read on the input stream. */
|
|
|
|
int subst_done;
|
2011-09-07 08:18:36 +00:00
|
|
|
void* last_rex;
|
2011-09-20 22:40:45 +00:00
|
|
|
|
|
|
|
/** stop requested */
|
|
|
|
int stopreq;
|
2011-09-24 08:52:22 +00:00
|
|
|
|
2011-10-07 23:09:48 +00:00
|
|
|
#ifdef QSE_ENABLE_SEDTRACER
|
2011-10-06 00:41:04 +00:00
|
|
|
/** trace function */
|
|
|
|
qse_sed_exec_tracer_t tracer;
|
2011-10-07 23:09:48 +00:00
|
|
|
#endif
|
2009-05-19 22:32:12 +00:00
|
|
|
} e;
|
|
|
|
};
|
|
|
|
|
2009-06-23 07:01:28 +00:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2011-09-03 09:27:44 +00:00
|
|
|
int qse_sed_init (
|
|
|
|
qse_sed_t* sed,
|
|
|
|
qse_mmgr_t* mmgr
|
|
|
|
);
|
|
|
|
|
|
|
|
void qse_sed_fini (
|
|
|
|
qse_sed_t* sed
|
|
|
|
);
|
|
|
|
|
|
|
|
const qse_char_t* qse_sed_dflerrstr (
|
2012-04-27 14:33:14 +00:00
|
|
|
const qse_sed_t* sed,
|
2011-09-03 09:27:44 +00:00
|
|
|
qse_sed_errnum_t errnum
|
|
|
|
);
|
|
|
|
|
|
|
|
#ifdef USE_REX
|
|
|
|
/**
|
|
|
|
* The qse_sed_getmaxdepth() gets the maximum processing depth.
|
|
|
|
*/
|
|
|
|
qse_size_t qse_sed_getmaxdepth (
|
2012-02-25 14:52:26 +00:00
|
|
|
const qse_sed_t* sed, /**< stream editor */
|
|
|
|
qse_sed_depth_t id /**< one of qse_sed_depth_t values */
|
2011-09-03 09:27:44 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The qse_sed_setmaxdepth() sets the maximum processing depth.
|
|
|
|
*/
|
|
|
|
void qse_sed_setmaxdepth (
|
|
|
|
qse_sed_t* sed, /**< stream editor */
|
|
|
|
int ids, /**< 0 or a number OR'ed of #qse_sed_depth_t values */
|
|
|
|
qse_size_t depth /**< maximum depth level */
|
|
|
|
);
|
|
|
|
#endif
|
2009-06-23 07:01:28 +00:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
2009-10-05 08:08:27 +00:00
|
|
|
|
2009-05-19 22:32:12 +00:00
|
|
|
#endif
|