qse/qse/lib/awk/awk.c

561 lines
14 KiB
C
Raw Normal View History

/*
* $Id: awk.c 363 2010-10-27 12:54:37Z hyunghwan.chung $
*
2009-09-16 04:01:02 +00:00
Copyright 2006-2009 Chung, Hyung-Hwan.
This file is part of QSE.
2008-12-27 04:35:14 +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.
2008-12-27 04:35:14 +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.
2008-12-27 04:35:14 +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/>.
*/
2008-08-21 03:17:25 +00:00
#include "awk.h"
2009-05-22 00:50:02 +00:00
QSE_IMPLEMENT_COMMON_FUNCTIONS (awk)
static void free_fun (qse_htb_t* map, void* vptr, qse_size_t vlen)
2008-08-29 04:29:53 +00:00
{
2009-02-17 02:11:31 +00:00
qse_awk_t* awk = *(qse_awk_t**)QSE_XTN(map);
qse_awk_fun_t* f = (qse_awk_fun_t*)vptr;
2008-09-05 04:58:08 +00:00
/* f->name doesn't have to be freed */
2008-12-21 21:35:07 +00:00
/*QSE_AWK_FREE (awk, f->name);*/
2008-09-05 04:58:08 +00:00
2008-12-21 21:35:07 +00:00
qse_awk_clrpt (awk, f->body);
QSE_AWK_FREE (awk, f);
2008-08-29 04:29:53 +00:00
}
static void free_fnc (qse_htb_t* map, void* vptr, qse_size_t vlen)
2008-09-05 04:58:08 +00:00
{
2009-02-17 02:11:31 +00:00
qse_awk_t* awk = *(qse_awk_t**)QSE_XTN(map);
qse_awk_fnc_t* f = (qse_awk_fnc_t*)vptr;
2008-12-21 21:35:07 +00:00
QSE_AWK_FREE (awk, f);
2008-09-05 04:58:08 +00:00
}
2009-08-24 06:56:45 +00:00
static int init_token (qse_mmgr_t* mmgr, qse_awk_tok_t* tok)
{
2009-08-24 06:56:45 +00:00
tok->name = qse_str_open (mmgr, 0, 128);
if (tok->name == QSE_NULL) return -1;
2009-08-24 06:56:45 +00:00
tok->type = 0;
tok->loc.file = QSE_NULL;
tok->loc.line = 0;
tok->loc.colm = 0;
return 0;
}
2009-08-24 06:56:45 +00:00
static void fini_token (qse_awk_tok_t* tok)
{
2009-08-24 06:56:45 +00:00
if (tok->name != QSE_NULL)
{
2009-08-24 06:56:45 +00:00
qse_str_close (tok->name);
tok->name = QSE_NULL;
}
}
2009-08-24 06:56:45 +00:00
static void clear_token (qse_awk_tok_t* tok)
2009-07-27 20:31:58 +00:00
{
2009-08-24 06:56:45 +00:00
if (tok->name != QSE_NULL) qse_str_clear (tok->name);
tok->type = 0;
tok->loc.file = QSE_NULL;
tok->loc.line = 0;
tok->loc.colm = 0;
2009-07-27 20:31:58 +00:00
}
2009-02-17 02:11:31 +00:00
qse_awk_t* qse_awk_open (qse_mmgr_t* mmgr, qse_size_t xtn, qse_awk_prm_t* prm)
2008-07-20 02:03:49 +00:00
{
2008-12-21 21:35:07 +00:00
qse_awk_t* awk;
2008-07-20 02:03:49 +00:00
static qse_htb_mancbs_t mancbs1 =
{
{
QSE_HTB_COPIER_INLINE,
QSE_HTB_COPIER_INLINE
},
{
QSE_HTB_FREEER_DEFAULT,
QSE_HTB_FREEER_DEFAULT
},
QSE_HTB_HASHER_DEFAULT,
QSE_HTB_COMPER_DEFAULT,
QSE_HTB_KEEPER_DEFAULT,
QSE_HTB_SIZER_DEFAULT
};
static qse_htb_mancbs_t mancbs2 =
{
{
QSE_HTB_COPIER_INLINE,
QSE_HTB_COPIER_DEFAULT
},
{
QSE_HTB_FREEER_DEFAULT,
QSE_HTB_FREEER_DEFAULT
},
QSE_HTB_HASHER_DEFAULT,
QSE_HTB_COMPER_DEFAULT,
QSE_HTB_KEEPER_DEFAULT,
QSE_HTB_SIZER_DEFAULT
};
static qse_htb_mancbs_t treefuncbs =
{
{
QSE_HTB_COPIER_INLINE,
QSE_HTB_COPIER_DEFAULT
},
{
QSE_HTB_FREEER_DEFAULT,
free_fun
},
QSE_HTB_HASHER_DEFAULT,
QSE_HTB_COMPER_DEFAULT,
QSE_HTB_KEEPER_DEFAULT,
QSE_HTB_SIZER_DEFAULT
};
static qse_htb_mancbs_t fncusercbs =
{
{
QSE_HTB_COPIER_INLINE,
QSE_HTB_COPIER_DEFAULT
},
{
QSE_HTB_FREEER_DEFAULT,
free_fnc
},
QSE_HTB_HASHER_DEFAULT,
QSE_HTB_COMPER_DEFAULT,
QSE_HTB_KEEPER_DEFAULT,
QSE_HTB_SIZER_DEFAULT
};
2008-12-21 21:35:07 +00:00
if (mmgr == QSE_NULL)
2008-08-19 05:21:48 +00:00
{
2008-12-21 21:35:07 +00:00
mmgr = QSE_MMGR_GETDFL();
2008-08-19 05:21:48 +00:00
2008-12-21 21:35:07 +00:00
QSE_ASSERTX (mmgr != QSE_NULL,
"Set the memory manager with QSE_MMGR_SETDFL()");
2008-08-19 05:21:48 +00:00
2008-12-21 21:35:07 +00:00
if (mmgr == QSE_NULL) return QSE_NULL;
2008-08-19 05:21:48 +00:00
}
2008-07-20 02:03:49 +00:00
2009-02-17 02:11:31 +00:00
/* allocate the object */
2009-02-16 08:31:34 +00:00
awk = QSE_MMGR_ALLOC (mmgr, QSE_SIZEOF(qse_awk_t) + xtn);
2008-12-21 21:35:07 +00:00
if (awk == QSE_NULL) return QSE_NULL;
2008-07-20 02:03:49 +00:00
2009-02-17 02:11:31 +00:00
/* zero out the object */
2009-02-16 08:31:34 +00:00
QSE_MEMSET (awk, 0, QSE_SIZEOF(qse_awk_t) + xtn);
2009-02-17 02:11:31 +00:00
/* remember the memory manager */
2008-07-20 23:53:29 +00:00
awk->mmgr = mmgr;
2009-02-17 02:11:31 +00:00
/* progagate the primitive functions */
QSE_ASSERT (prm != QSE_NULL);
2009-02-17 02:11:31 +00:00
QSE_ASSERT (prm->pow != QSE_NULL);
QSE_ASSERT (prm->sprintf != QSE_NULL);
if (prm == QSE_NULL ||
prm->pow == QSE_NULL ||
prm->sprintf == QSE_NULL)
{
QSE_AWK_FREE (awk, awk);
return QSE_NULL;
}
2009-02-17 02:11:31 +00:00
awk->prm = *prm;
2009-08-24 06:56:45 +00:00
if (init_token (mmgr, &awk->ptok) == -1) goto oops;
if (init_token (mmgr, &awk->tok) == -1) goto oops;
if (init_token (mmgr, &awk->ntok) == -1) goto oops;
2008-12-21 21:35:07 +00:00
awk->wtab = qse_htb_open (
mmgr, QSE_SIZEOF(awk),
512, 70, QSE_SIZEOF(qse_char_t), QSE_SIZEOF(qse_char_t)
);
2008-12-21 21:35:07 +00:00
if (awk->wtab == QSE_NULL) goto oops;
2009-02-17 02:11:31 +00:00
*(qse_awk_t**)QSE_XTN(awk->wtab) = awk;
qse_htb_setmancbs (awk->wtab, &mancbs1);
2008-12-21 21:35:07 +00:00
awk->rwtab = qse_htb_open (
mmgr, QSE_SIZEOF(awk),
512, 70, QSE_SIZEOF(qse_char_t), QSE_SIZEOF(qse_char_t)
);
2008-12-21 21:35:07 +00:00
if (awk->rwtab == QSE_NULL) goto oops;
2009-02-17 02:11:31 +00:00
*(qse_awk_t**)QSE_XTN(awk->rwtab) = awk;
qse_htb_setmancbs (awk->rwtab, &mancbs1);
awk->sio.names = qse_htb_open (
mmgr, QSE_SIZEOF(awk), 128, 70, QSE_SIZEOF(qse_char_t), 1
);
2009-08-07 02:27:14 +00:00
if (awk->sio.names == QSE_NULL) goto oops;
*(qse_awk_t**)QSE_XTN(awk->sio.names) = awk;
qse_htb_setmancbs (awk->sio.names, &mancbs2);
2009-08-07 02:27:14 +00:00
awk->sio.inp = &awk->sio.arg;
/* TODO: initial map size?? */
awk->tree.funs = qse_htb_open (
mmgr, QSE_SIZEOF(awk), 512, 70, QSE_SIZEOF(qse_char_t), 1
);
if (awk->tree.funs == QSE_NULL) goto oops;
2009-02-17 02:11:31 +00:00
*(qse_awk_t**)QSE_XTN(awk->tree.funs) = awk;
qse_htb_setmancbs (awk->tree.funs, &treefuncbs);
awk->parse.funs = qse_htb_open (
mmgr, QSE_SIZEOF(awk), 256, 70, QSE_SIZEOF(qse_char_t), 1
);
if (awk->parse.funs == QSE_NULL) goto oops;
2009-02-17 02:11:31 +00:00
*(qse_awk_t**)QSE_XTN(awk->parse.funs) = awk;
qse_htb_setmancbs (awk->parse.funs, &mancbs2);
2008-12-21 21:35:07 +00:00
awk->parse.named = qse_htb_open (
mmgr, QSE_SIZEOF(awk), 256, 70, QSE_SIZEOF(qse_char_t), 1
);
2008-12-21 21:35:07 +00:00
if (awk->parse.named == QSE_NULL) goto oops;
2009-02-17 02:11:31 +00:00
*(qse_awk_t**)QSE_XTN(awk->parse.named) = awk;
qse_htb_setmancbs (awk->parse.named, &mancbs2);
2008-12-21 21:35:07 +00:00
awk->parse.gbls = qse_lda_open (mmgr, QSE_SIZEOF(awk), 128);
awk->parse.lcls = qse_lda_open (mmgr, QSE_SIZEOF(awk), 64);
2008-12-21 21:35:07 +00:00
awk->parse.params = qse_lda_open (mmgr, QSE_SIZEOF(awk), 32);
if (awk->parse.gbls == QSE_NULL ||
awk->parse.lcls == QSE_NULL ||
2008-12-21 21:35:07 +00:00
awk->parse.params == QSE_NULL) goto oops;
2009-02-17 02:11:31 +00:00
*(qse_awk_t**)QSE_XTN(awk->parse.gbls) = awk;
qse_lda_setscale (awk->parse.gbls, QSE_SIZEOF(qse_char_t));
qse_lda_setcopier (awk->parse.gbls, QSE_LDA_COPIER_INLINE);
2008-12-21 21:35:07 +00:00
2009-02-17 02:11:31 +00:00
*(qse_awk_t**)QSE_XTN(awk->parse.lcls) = awk;
qse_lda_setscale (awk->parse.lcls, QSE_SIZEOF(qse_char_t));
qse_lda_setcopier (awk->parse.lcls, QSE_LDA_COPIER_INLINE);
2008-12-21 21:35:07 +00:00
2009-02-17 02:11:31 +00:00
*(qse_awk_t**)QSE_XTN(awk->parse.params) = awk;
2008-12-21 21:35:07 +00:00
qse_lda_setscale (awk->parse.params, QSE_SIZEOF(qse_char_t));
qse_lda_setcopier (awk->parse.params, QSE_LDA_COPIER_INLINE);
2009-02-18 07:55:48 +00:00
awk->option = QSE_AWK_CLASSIC;
awk->errinf.num = QSE_AWK_ENOERR;
awk->errinf.loc.line = 0;
awk->errinf.loc.colm = 0;
awk->errinf.loc.file = QSE_NULL;
awk->errstr = qse_awk_dflerrstr;
2008-12-21 21:35:07 +00:00
awk->stopall = QSE_FALSE;
awk->tree.ngbls = 0;
2009-02-03 03:54:32 +00:00
awk->tree.ngbls_base = 0;
2008-12-21 21:35:07 +00:00
awk->tree.begin = QSE_NULL;
awk->tree.begin_tail = QSE_NULL;
awk->tree.end = QSE_NULL;
awk->tree.end_tail = QSE_NULL;
awk->tree.chain = QSE_NULL;
awk->tree.chain_tail = QSE_NULL;
awk->tree.chain_size = 0;
awk->fnc.sys = QSE_NULL;
awk->fnc.user = qse_htb_open (
mmgr, QSE_SIZEOF(awk), 512, 70, QSE_SIZEOF(qse_char_t), 1
);
if (awk->fnc.user == QSE_NULL) goto oops;
2009-02-17 02:11:31 +00:00
*(qse_awk_t**)QSE_XTN(awk->fnc.user) = awk;
qse_htb_setmancbs (awk->fnc.user, &fncusercbs);
if (qse_awk_initgbls (awk) <= -1) goto oops;
return awk;
oops:
if (awk->fnc.user) qse_htb_close (awk->fnc.user);
2008-12-21 21:35:07 +00:00
if (awk->parse.params) qse_lda_close (awk->parse.params);
if (awk->parse.lcls) qse_lda_close (awk->parse.lcls);
if (awk->parse.gbls) qse_lda_close (awk->parse.gbls);
if (awk->parse.named) qse_htb_close (awk->parse.named);
if (awk->parse.funs) qse_htb_close (awk->parse.funs);
if (awk->tree.funs) qse_htb_close (awk->tree.funs);
if (awk->sio.names) qse_htb_close (awk->sio.names);
if (awk->rwtab) qse_htb_close (awk->rwtab);
if (awk->wtab) qse_htb_close (awk->wtab);
2009-08-24 06:56:45 +00:00
fini_token (&awk->ntok);
fini_token (&awk->tok);
fini_token (&awk->ptok);
2008-12-21 21:35:07 +00:00
QSE_AWK_FREE (awk, awk);
return QSE_NULL;
}
2008-12-21 21:35:07 +00:00
int qse_awk_close (qse_awk_t* awk)
{
if (qse_awk_clear (awk) <= -1) return -1;
/*qse_awk_clrfnc (awk);*/
qse_htb_close (awk->fnc.user);
2008-12-21 21:35:07 +00:00
qse_lda_close (awk->parse.params);
qse_lda_close (awk->parse.lcls);
qse_lda_close (awk->parse.gbls);
qse_htb_close (awk->parse.named);
qse_htb_close (awk->parse.funs);
2007-12-12 08:05:58 +00:00
qse_htb_close (awk->tree.funs);
qse_htb_close (awk->sio.names);
2009-08-07 02:27:14 +00:00
qse_htb_close (awk->rwtab);
qse_htb_close (awk->wtab);
2007-12-12 08:05:58 +00:00
2009-08-24 06:56:45 +00:00
fini_token (&awk->ntok);
fini_token (&awk->tok);
fini_token (&awk->ptok);
2008-12-21 21:35:07 +00:00
/* QSE_AWK_ALLOC, QSE_AWK_FREE, etc can not be used
* from the next line onwards */
2008-12-21 21:35:07 +00:00
QSE_AWK_FREE (awk, awk);
return 0;
}
2008-12-21 21:35:07 +00:00
int qse_awk_clear (qse_awk_t* awk)
{
2008-12-21 21:35:07 +00:00
awk->stopall = QSE_FALSE;
2009-08-24 06:56:45 +00:00
clear_token (&awk->tok);
clear_token (&awk->ntok);
clear_token (&awk->ptok);
QSE_ASSERT (QSE_LDA_SIZE(awk->parse.gbls) == awk->tree.ngbls);
/* delete all non-builtin global variables */
2008-12-21 21:35:07 +00:00
qse_lda_delete (
2009-02-03 03:54:32 +00:00
awk->parse.gbls, awk->tree.ngbls_base,
QSE_LDA_SIZE(awk->parse.gbls) - awk->tree.ngbls_base);
qse_lda_clear (awk->parse.lcls);
2008-12-21 21:35:07 +00:00
qse_lda_clear (awk->parse.params);
qse_htb_clear (awk->parse.named);
qse_htb_clear (awk->parse.funs);
awk->parse.nlcls_max = 0;
awk->parse.depth.cur.block = 0;
awk->parse.depth.cur.loop = 0;
awk->parse.depth.cur.expr = 0;
2009-07-27 20:31:58 +00:00
awk->parse.depth.cur.incl = 0;
/* clear parse trees */
2009-02-03 03:54:32 +00:00
/*awk->tree.ngbls_base = 0;
awk->tree.ngbls = 0; */
2009-02-03 03:54:32 +00:00
awk->tree.ngbls = awk->tree.ngbls_base;
awk->tree.cur_fun.ptr = QSE_NULL;
awk->tree.cur_fun.len = 0;
qse_htb_clear (awk->tree.funs);
2008-12-21 21:35:07 +00:00
if (awk->tree.begin != QSE_NULL)
{
2008-12-21 21:35:07 +00:00
/*QSE_ASSERT (awk->tree.begin->next == QSE_NULL);*/
qse_awk_clrpt (awk, awk->tree.begin);
awk->tree.begin = QSE_NULL;
awk->tree.begin_tail = QSE_NULL;
}
2008-12-21 21:35:07 +00:00
if (awk->tree.end != QSE_NULL)
{
2008-12-21 21:35:07 +00:00
/*QSE_ASSERT (awk->tree.end->next == QSE_NULL);*/
qse_awk_clrpt (awk, awk->tree.end);
awk->tree.end = QSE_NULL;
awk->tree.end_tail = QSE_NULL;
}
2008-12-21 21:35:07 +00:00
while (awk->tree.chain != QSE_NULL)
{
2008-12-21 21:35:07 +00:00
qse_awk_chain_t* next = awk->tree.chain->next;
2008-12-21 21:35:07 +00:00
if (awk->tree.chain->pattern != QSE_NULL)
qse_awk_clrpt (awk, awk->tree.chain->pattern);
if (awk->tree.chain->action != QSE_NULL)
qse_awk_clrpt (awk, awk->tree.chain->action);
QSE_AWK_FREE (awk, awk->tree.chain);
awk->tree.chain = next;
}
2008-12-21 21:35:07 +00:00
awk->tree.chain_tail = QSE_NULL;
awk->tree.chain_size = 0;
2009-08-07 02:27:14 +00:00
QSE_ASSERT (awk->sio.inp == &awk->sio.arg);
/* this table must not be cleared here as there can be a reference
* to an entry of this table from errinf.fil when qse_awk_parse()
* failed. this table is cleared in qse_awk_parse().
* qse_htb_clear (awk->sio.names);
*/
2009-08-07 02:27:14 +00:00
awk->sio.last.c = QSE_CHAR_EOF;
awk->sio.last.line = 0;
awk->sio.last.colm = 0;
awk->sio.last.file = QSE_NULL;
2009-08-07 02:27:14 +00:00
awk->sio.nungots = 0;
awk->sio.arg.line = 1;
awk->sio.arg.colm = 1;
2009-08-07 02:27:14 +00:00
awk->sio.arg.b.pos = 0;
awk->sio.arg.b.len = 0;
return 0;
}
qse_awk_prm_t* qse_awk_getprm (qse_awk_t* awk)
2008-11-27 03:05:00 +00:00
{
return &awk->prm;
2008-11-27 03:05:00 +00:00
}
2008-12-21 21:35:07 +00:00
int qse_awk_getoption (qse_awk_t* awk)
{
return awk->option;
}
2008-12-21 21:35:07 +00:00
void qse_awk_setoption (qse_awk_t* awk, int opt)
{
awk->option = opt;
}
2009-02-02 04:12:49 +00:00
void qse_awk_stopall (qse_awk_t* awk)
{
2008-12-21 21:35:07 +00:00
awk->stopall = QSE_TRUE;
}
2009-07-19 06:02:24 +00:00
int qse_awk_getword (qse_awk_t* awk, const qse_cstr_t* okw, qse_cstr_t* nkw)
{
qse_htb_pair_t* p;
p = qse_htb_search (awk->wtab, okw->ptr, okw->len);
2008-12-21 21:35:07 +00:00
if (p == QSE_NULL) return -1;
2009-07-19 06:02:24 +00:00
nkw->ptr = ((qse_cstr_t*)p->vptr)->ptr;
nkw->len = ((qse_cstr_t*)p->vptr)->len;
return 0;
}
2009-07-19 06:02:24 +00:00
int qse_awk_unsetword (qse_awk_t* awk, const qse_cstr_t* kw)
2008-09-05 04:58:08 +00:00
{
qse_htb_pair_t* p;
2008-09-05 04:58:08 +00:00
2009-07-19 06:02:24 +00:00
QSE_ASSERT (kw->ptr != QSE_NULL);
p = qse_htb_search (awk->wtab, kw->ptr, kw->len);
2008-12-21 21:35:07 +00:00
if (p == QSE_NULL)
2008-09-05 04:58:08 +00:00
{
qse_awk_seterrnum (awk, QSE_AWK_ENOENT, kw);
2008-09-05 04:58:08 +00:00
return -1;
}
qse_htb_delete (awk->rwtab, QSE_HTB_VPTR(p), QSE_HTB_VLEN(p));
qse_htb_delete (awk->wtab, kw->ptr, kw->len);
2008-09-05 04:58:08 +00:00
return 0;
}
2008-12-21 21:35:07 +00:00
void qse_awk_unsetallwords (qse_awk_t* awk)
2008-09-05 04:58:08 +00:00
{
qse_htb_clear (awk->wtab);
qse_htb_clear (awk->rwtab);
2008-09-05 04:58:08 +00:00
}
2009-07-19 06:02:24 +00:00
int qse_awk_setword (
qse_awk_t* awk, const qse_cstr_t* okw, const qse_cstr_t* nkw)
{
2009-07-19 06:02:24 +00:00
if (nkw == QSE_NULL)
{
2009-07-19 06:02:24 +00:00
if (okw == QSE_NULL)
{
/* clear the entire table */
2008-12-21 21:35:07 +00:00
qse_awk_unsetallwords (awk);
return 0;
}
2009-07-19 06:02:24 +00:00
return qse_awk_unsetword (awk, okw);
}
2009-07-19 06:02:24 +00:00
else if (okw == QSE_NULL)
{
2009-08-17 02:08:58 +00:00
qse_awk_seterrnum (awk, QSE_AWK_EINVAL, QSE_NULL);
return -1;
}
2009-07-19 06:02:24 +00:00
QSE_ASSERT (okw->ptr != QSE_NULL);
QSE_ASSERT (nkw->ptr != QSE_NULL);
/* set the word */
if (qse_htb_upsert (
2009-07-19 06:02:24 +00:00
awk->wtab,
(qse_char_t*)okw->ptr, okw->len,
(qse_char_t*)nkw->ptr, nkw->len) == QSE_NULL)
2008-08-29 08:21:25 +00:00
{
2009-08-17 02:08:58 +00:00
qse_awk_seterrnum (awk, QSE_AWK_ENOMEM, QSE_NULL);
2008-08-29 08:21:25 +00:00
return -1;
}
if (qse_htb_upsert (
2009-07-19 06:02:24 +00:00
awk->rwtab,
(qse_char_t*)nkw->ptr, nkw->len,
(qse_char_t*)okw->ptr, okw->len) == QSE_NULL)
2008-08-29 08:21:25 +00:00
{
qse_htb_delete (awk->wtab, okw->ptr, okw->len);
2009-08-17 02:08:58 +00:00
qse_awk_seterrnum (awk, QSE_AWK_ENOMEM, QSE_NULL);
2008-08-29 08:21:25 +00:00
return -1;
}
return 0;
}
2009-09-15 07:29:55 +00:00
qse_size_t qse_awk_getmaxdepth (qse_awk_t* awk, qse_awk_depth_t type)
2009-08-07 02:27:14 +00:00
{
return (type == QSE_AWK_DEPTH_BLOCK_PARSE)? awk->parse.depth.max.block:
(type == QSE_AWK_DEPTH_BLOCK_RUN)? awk->run.depth.max.block:
(type == QSE_AWK_DEPTH_EXPR_PARSE)? awk->parse.depth.max.expr:
(type == QSE_AWK_DEPTH_EXPR_RUN)? awk->run.depth.max.expr:
(type == QSE_AWK_DEPTH_REX_BUILD)? awk->rex.depth.max.build:
(type == QSE_AWK_DEPTH_REX_MATCH)? awk->rex.depth.max.match:
(type == QSE_AWK_DEPTH_INCLUDE)? awk->parse.depth.max.incl: 0;
}
void qse_awk_setmaxdepth (qse_awk_t* awk, int types, qse_size_t depth)
{
if (types & QSE_AWK_DEPTH_BLOCK_PARSE)
{
awk->parse.depth.max.block = depth;
}
if (types & QSE_AWK_DEPTH_EXPR_PARSE)
{
awk->parse.depth.max.expr = depth;
}
if (types & QSE_AWK_DEPTH_BLOCK_RUN)
{
awk->run.depth.max.block = depth;
}
if (types & QSE_AWK_DEPTH_EXPR_RUN)
{
awk->run.depth.max.expr = depth;
}
if (types & QSE_AWK_DEPTH_REX_BUILD)
{
awk->rex.depth.max.build = depth;
}
if (types & QSE_AWK_DEPTH_REX_MATCH)
{
awk->rex.depth.max.match = depth;
}
if (types & QSE_AWK_DEPTH_INCLUDE)
{
awk->parse.depth.max.incl = depth;
}
}