270 lines
5.7 KiB
C++
270 lines
5.7 KiB
C++
/*
|
|
* $Id$
|
|
*
|
|
Copyright (c) 2006-2019 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.
|
|
*/
|
|
|
|
#include <qse/sed/Sed.hpp>
|
|
#include <qse/si/sio.h>
|
|
#include "../cmn/mem-prv.h"
|
|
#include "sed-prv.h"
|
|
|
|
/////////////////////////////////
|
|
QSE_BEGIN_NAMESPACE(QSE)
|
|
/////////////////////////////////
|
|
|
|
struct xtn_t
|
|
{
|
|
Sed* sed;
|
|
};
|
|
|
|
#if defined(QSE_HAVE_INLINE)
|
|
static QSE_INLINE xtn_t* GET_XTN(qse_sed_t* sed) { return (xtn_t*)((qse_uint8_t*)qse_sed_getxtn(sed) - QSE_SIZEOF(xtn_t)); }
|
|
#else
|
|
#define GET_XTN(sed) ((xtn_t*)((qse_uint8_t*)qse_sed_getxtn(sed) - QSE_SIZEOF(xtn_t)))
|
|
#endif
|
|
|
|
int Sed::open ()
|
|
{
|
|
qse_sed_errnum_t errnum;
|
|
this->sed = qse_sed_open(this->getMmgr(), QSE_SIZEOF(xtn_t), &errnum);
|
|
if (!this->sed)
|
|
{
|
|
this->setError (errnum);
|
|
return -1;
|
|
}
|
|
|
|
this->sed->_instsize += QSE_SIZEOF(xtn_t);
|
|
|
|
xtn_t* xtn = GET_XTN(this->sed);
|
|
xtn->sed = this;
|
|
|
|
dflerrstr = qse_sed_geterrstr(this->sed);
|
|
qse_sed_seterrstr (sed, xerrstr);
|
|
|
|
return 0;
|
|
}
|
|
|
|
void Sed::close ()
|
|
{
|
|
if (sed)
|
|
{
|
|
qse_sed_close (sed);
|
|
sed = QSE_NULL;
|
|
}
|
|
}
|
|
|
|
int Sed::compile (Stream& sstream)
|
|
{
|
|
QSE_ASSERT (sed != QSE_NULL);
|
|
|
|
this->sstream = &sstream;
|
|
return qse_sed_comp (sed, sin);
|
|
}
|
|
|
|
int Sed::execute (Stream& iostream)
|
|
{
|
|
QSE_ASSERT (sed != QSE_NULL);
|
|
|
|
this->iostream = &iostream;
|
|
return qse_sed_exec (sed, xin, xout);
|
|
}
|
|
|
|
void Sed::halt ()
|
|
{
|
|
QSE_ASSERT (sed != QSE_NULL);
|
|
qse_sed_halt (sed);
|
|
}
|
|
|
|
bool Sed::isHalt () const
|
|
{
|
|
QSE_ASSERT (sed != QSE_NULL);
|
|
return qse_sed_ishalt (sed);
|
|
}
|
|
|
|
int Sed::getTrait () const
|
|
{
|
|
QSE_ASSERT (sed != QSE_NULL);
|
|
int val;
|
|
qse_sed_getopt (sed, QSE_SED_TRAIT, &val);
|
|
return val;
|
|
}
|
|
|
|
void Sed::setTrait (int trait)
|
|
{
|
|
QSE_ASSERT (sed != QSE_NULL);
|
|
qse_sed_setopt (sed, QSE_SED_TRAIT, &trait);
|
|
}
|
|
|
|
const Sed::char_t* Sed::getErrorMessage () const
|
|
{
|
|
return (sed == QSE_NULL)? QSE_T(""): qse_sed_geterrmsg (sed);
|
|
}
|
|
|
|
Sed::loc_t Sed::getErrorLocation () const
|
|
{
|
|
if (sed == QSE_NULL)
|
|
{
|
|
loc_t loc;
|
|
loc.line = 0;
|
|
loc.colm = 0;
|
|
return loc;
|
|
}
|
|
return *qse_sed_geterrloc (sed);
|
|
}
|
|
|
|
Sed::errnum_t Sed::getErrorNumber () const
|
|
{
|
|
return (sed == QSE_NULL)? QSE_SED_ENOERR: qse_sed_geterrnum (sed);
|
|
}
|
|
|
|
void Sed::setError (errnum_t err, const cstr_t* args, const loc_t* loc)
|
|
{
|
|
QSE_ASSERT (sed != QSE_NULL);
|
|
qse_sed_seterror (sed, err, args, loc);
|
|
}
|
|
|
|
const Sed::char_t* Sed::getCompileId () const
|
|
{
|
|
return qse_sed_getcompid (this->sed);
|
|
}
|
|
|
|
const Sed::char_t* Sed::setCompileId (const char_t* id)
|
|
{
|
|
return qse_sed_setcompid (this->sed, id);
|
|
}
|
|
|
|
Sed::size_t Sed::getConsoleLine ()
|
|
{
|
|
QSE_ASSERT (sed != QSE_NULL);
|
|
return qse_sed_getlinenum (this->sed);
|
|
}
|
|
|
|
void Sed::setConsoleLine (size_t num)
|
|
{
|
|
QSE_ASSERT (sed != QSE_NULL);
|
|
qse_sed_setlinenum (this->sed, num);
|
|
}
|
|
|
|
Sed::ssize_t Sed::sin (sed_t* s, io_cmd_t cmd, io_arg_t* arg, char_t* buf, size_t len)
|
|
{
|
|
xtn_t* xtn = GET_XTN(s);
|
|
|
|
Stream::Data iodata (xtn->sed, Stream::READ, arg);
|
|
|
|
try
|
|
{
|
|
switch (cmd)
|
|
{
|
|
case QSE_SED_IO_OPEN:
|
|
return xtn->sed->sstream->open (iodata);
|
|
case QSE_SED_IO_CLOSE:
|
|
return xtn->sed->sstream->close (iodata);
|
|
case QSE_SED_IO_READ:
|
|
return xtn->sed->sstream->read (iodata, buf, len);
|
|
default:
|
|
return -1;
|
|
}
|
|
}
|
|
catch (...)
|
|
{
|
|
return -1;
|
|
}
|
|
}
|
|
|
|
Sed::ssize_t Sed::xin (sed_t* s, io_cmd_t cmd, io_arg_t* arg, char_t* buf, size_t len)
|
|
{
|
|
xtn_t* xtn = GET_XTN(s);
|
|
|
|
Stream::Data iodata (xtn->sed, Stream::READ, arg);
|
|
|
|
try
|
|
{
|
|
switch (cmd)
|
|
{
|
|
case QSE_SED_IO_OPEN:
|
|
return xtn->sed->iostream->open (iodata);
|
|
case QSE_SED_IO_CLOSE:
|
|
return xtn->sed->iostream->close (iodata);
|
|
case QSE_SED_IO_READ:
|
|
return xtn->sed->iostream->read (iodata, buf, len);
|
|
default:
|
|
return -1;
|
|
}
|
|
}
|
|
catch (...)
|
|
{
|
|
return -1;
|
|
}
|
|
}
|
|
|
|
Sed::ssize_t Sed::xout (sed_t* s, io_cmd_t cmd, io_arg_t* arg, char_t* dat, size_t len)
|
|
{
|
|
xtn_t* xtn = GET_XTN(s);
|
|
|
|
Stream::Data iodata (xtn->sed, Stream::WRITE, arg);
|
|
|
|
try
|
|
{
|
|
switch (cmd)
|
|
{
|
|
case QSE_SED_IO_OPEN:
|
|
return xtn->sed->iostream->open (iodata);
|
|
case QSE_SED_IO_CLOSE:
|
|
return xtn->sed->iostream->close (iodata);
|
|
case QSE_SED_IO_WRITE:
|
|
return xtn->sed->iostream->write (iodata, dat, len);
|
|
default:
|
|
return -1;
|
|
}
|
|
}
|
|
catch (...)
|
|
{
|
|
return -1;
|
|
}
|
|
}
|
|
|
|
const Sed::char_t* Sed::getErrorString (errnum_t num) const
|
|
{
|
|
QSE_ASSERT (this->dflerrstr != QSE_NULL);
|
|
return this->dflerrstr (sed, num);
|
|
}
|
|
|
|
const Sed::char_t* Sed::xerrstr (sed_t* s, errnum_t num)
|
|
{
|
|
xtn_t* xtn = GET_XTN(s);
|
|
try
|
|
{
|
|
return xtn->sed->getErrorString (num);
|
|
}
|
|
catch (...)
|
|
{
|
|
return xtn->sed->dflerrstr (s, num);
|
|
}
|
|
}
|
|
|
|
/////////////////////////////////
|
|
QSE_END_NAMESPACE(QSE)
|
|
/////////////////////////////////
|
|
|