touched up code a bit
This commit is contained in:
@ -1,19 +1,21 @@
|
||||
/*
|
||||
* $Id: Sed.hpp 127 2009-05-07 13:15:04Z baconevi $
|
||||
*
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
This file is part of QSE.
|
||||
|
||||
Licensed under the Apache License, Version 2.0 (the "License");
|
||||
you may not use this file except in compliance with the License.
|
||||
You may obtain a copy of the License at
|
||||
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.
|
||||
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
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.
|
||||
|
||||
Unless required by applicable law or agreed to in writing, software
|
||||
distributed under the License is distributed on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
See the License for the specific language governing permissions and
|
||||
limitations under the License.
|
||||
You should have received a copy of the GNU Lesser General Public
|
||||
License along with QSE. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#ifndef _QSE_MMGR_HPP_
|
||||
|
@ -1,19 +1,21 @@
|
||||
/*
|
||||
* $Id: Sed.hpp 127 2009-05-07 13:15:04Z baconevi $
|
||||
*
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
This file is part of QSE.
|
||||
|
||||
Licensed under the Apache License, Version 2.0 (the "License");
|
||||
you may not use this file except in compliance with the License.
|
||||
You may obtain a copy of the License at
|
||||
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.
|
||||
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
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.
|
||||
|
||||
Unless required by applicable law or agreed to in writing, software
|
||||
distributed under the License is distributed on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
See the License for the specific language governing permissions and
|
||||
limitations under the License.
|
||||
You should have received a copy of the GNU Lesser General Public
|
||||
License along with QSE. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#ifndef _QSE_TYPES_HPP_
|
||||
|
@ -1,19 +1,21 @@
|
||||
/*
|
||||
* $Id: Awk.hpp 286 2009-09-14 13:29:55Z hyunghwan.chung $
|
||||
* $Id: Awk.hpp 287 2009-09-15 10:01:02Z hyunghwan.chung $
|
||||
*
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
This file is part of QSE.
|
||||
|
||||
Licensed under the Apache License, Version 2.0 (the "License");
|
||||
you may not use this file except in compliance with the License.
|
||||
You may obtain a copy of the License at
|
||||
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.
|
||||
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
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.
|
||||
|
||||
Unless required by applicable law or agreed to in writing, software
|
||||
distributed under the License is distributed on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
See the License for the specific language governing permissions and
|
||||
limitations under the License.
|
||||
You should have received a copy of the GNU Lesser General Public
|
||||
License along with QSE. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#ifndef _QSE_AWK_AWK_HPP_
|
||||
@ -33,9 +35,10 @@
|
||||
QSE_BEGIN_NAMESPACE(QSE)
|
||||
/////////////////////////////////
|
||||
|
||||
/**
|
||||
* Represents the AWK interpreter engine.
|
||||
*/
|
||||
///
|
||||
/// The Awk class implements an AWK interpreter by wrapping around
|
||||
/// #qse_awk_t and #qse_awk_rtx_t.
|
||||
///
|
||||
class Awk: public Mmgr
|
||||
{
|
||||
public:
|
||||
@ -50,8 +53,15 @@ public:
|
||||
typedef qse_awk_errstr_t errstr_t;
|
||||
typedef qse_awk_errinf_t errinf_t;
|
||||
|
||||
/// The depth_t type redefines #qse_awk_depth_t.
|
||||
typedef qse_awk_depth_t depth_t;
|
||||
|
||||
/// The option_t type redefines #qse_awk_option_t.
|
||||
typedef qse_awk_option_t option_t;
|
||||
|
||||
/// The gbl_id_t type redefines #qse_awk_gbl_id_t.
|
||||
typedef qse_awk_gbl_id_t gbl_id_t;
|
||||
|
||||
/** Represents an internal awk value */
|
||||
typedef qse_awk_val_t val_t;
|
||||
|
||||
@ -70,153 +80,30 @@ public:
|
||||
class Run;
|
||||
friend class Run;
|
||||
|
||||
/**
|
||||
* @name Error Handling
|
||||
*/
|
||||
/*@{*/
|
||||
|
||||
///
|
||||
/// The ErrorNumber defines error numbers by redefining enumerators
|
||||
/// of the #qse_awk_errnum_t type.
|
||||
///
|
||||
enum ErrorNumber
|
||||
{
|
||||
ERR_NOERR = QSE_AWK_ENOERR,
|
||||
ERR_UNKNOWN = QSE_AWK_EUNKNOWN,
|
||||
ERR_INVAL = QSE_AWK_EINVAL,
|
||||
ERR_NOMEM = QSE_AWK_ENOMEM,
|
||||
ERR_NOSUP = QSE_AWK_ENOSUP,
|
||||
ERR_NOPER = QSE_AWK_ENOPER,
|
||||
ERR_NOENT = QSE_AWK_ENOENT,
|
||||
ERR_EXIST = QSE_AWK_EEXIST,
|
||||
ERR_IOERR = QSE_AWK_EIOERR,
|
||||
ERR_OPEN = QSE_AWK_EOPEN,
|
||||
ERR_READ = QSE_AWK_EREAD,
|
||||
ERR_WRITE = QSE_AWK_EWRITE,
|
||||
ERR_CLOSE = QSE_AWK_ECLOSE,
|
||||
ERR_INTERN = QSE_AWK_EINTERN,
|
||||
ERR_RUNTIME = QSE_AWK_ERUNTIME,
|
||||
ERR_BLKNST = QSE_AWK_EBLKNST,
|
||||
ERR_EXPRNST = QSE_AWK_EEXPRNST,
|
||||
ERR_LXCHR = QSE_AWK_ELXCHR,
|
||||
ERR_LXDIG = QSE_AWK_ELXDIG,
|
||||
ERR_EOF = QSE_AWK_EEOF,
|
||||
ERR_CMTNC = QSE_AWK_ECMTNC,
|
||||
ERR_STRNC = QSE_AWK_ESTRNC,
|
||||
ERR_LBRACE = QSE_AWK_ELBRACE,
|
||||
ERR_LPAREN = QSE_AWK_ELPAREN,
|
||||
ERR_RPAREN = QSE_AWK_ERPAREN,
|
||||
ERR_RBRACK = QSE_AWK_ERBRACK,
|
||||
ERR_COMMA = QSE_AWK_ECOMMA,
|
||||
ERR_SCOLON = QSE_AWK_ESCOLON,
|
||||
ERR_COLON = QSE_AWK_ECOLON,
|
||||
ERR_STMEND = QSE_AWK_ESTMEND,
|
||||
ERR_KWIN = QSE_AWK_EKWIN,
|
||||
ERR_NOTVAR = QSE_AWK_ENOTVAR,
|
||||
ERR_EXPRNR = QSE_AWK_EEXPRNR,
|
||||
ERR_KWFNC = QSE_AWK_EKWFNC,
|
||||
ERR_KWWHL = QSE_AWK_EKWWHL,
|
||||
ERR_ASSIGN = QSE_AWK_EASSIGN,
|
||||
ERR_IDENT = QSE_AWK_EIDENT,
|
||||
ERR_FUNNAME = QSE_AWK_EFUNNAME,
|
||||
ERR_BLKBEG = QSE_AWK_EBLKBEG,
|
||||
ERR_BLKEND = QSE_AWK_EBLKEND,
|
||||
ERR_KWRED = QSE_AWK_EKWRED,
|
||||
ERR_FNCRED = QSE_AWK_EFNCRED,
|
||||
ERR_FUNRED = QSE_AWK_EFUNRED,
|
||||
ERR_GBLRED = QSE_AWK_EGBLRED,
|
||||
ERR_PARRED = QSE_AWK_EPARRED,
|
||||
ERR_VARRED = QSE_AWK_EVARRED,
|
||||
ERR_DUPPAR = QSE_AWK_EDUPPAR,
|
||||
ERR_DUPGBL = QSE_AWK_EDUPGBL,
|
||||
ERR_DUPLCL = QSE_AWK_EDUPLCL,
|
||||
ERR_BADPAR = QSE_AWK_EBADPAR,
|
||||
ERR_BADVAR = QSE_AWK_EBADVAR,
|
||||
ERR_UNDEF = QSE_AWK_EUNDEF,
|
||||
ERR_LVALUE = QSE_AWK_ELVALUE,
|
||||
ERR_GBLTM = QSE_AWK_EGBLTM,
|
||||
ERR_LCLTM = QSE_AWK_ELCLTM,
|
||||
ERR_PARTM = QSE_AWK_EPARTM,
|
||||
ERR_DELETE = QSE_AWK_EDELETE,
|
||||
ERR_BREAK = QSE_AWK_EBREAK,
|
||||
ERR_CONTINUE = QSE_AWK_ECONTINUE,
|
||||
ERR_NEXTBEG = QSE_AWK_ENEXTBEG,
|
||||
ERR_NEXTEND = QSE_AWK_ENEXTEND,
|
||||
ERR_NEXTFBEG = QSE_AWK_ENEXTFBEG,
|
||||
ERR_NEXTFEND = QSE_AWK_ENEXTFEND,
|
||||
ERR_PRINTFARG = QSE_AWK_EPRINTFARG,
|
||||
ERR_PREPST = QSE_AWK_EPREPST,
|
||||
ERR_INCDECOPR = QSE_AWK_EINCDECOPR,
|
||||
ERR_INCLSTR = QSE_AWK_EINCLSTR,
|
||||
ERR_INCLTD = QSE_AWK_EINCLTD,
|
||||
ERR_DIRECNR = QSE_AWK_EDIRECNR,
|
||||
ERR_DIVBY0 = QSE_AWK_EDIVBY0,
|
||||
ERR_OPERAND = QSE_AWK_EOPERAND,
|
||||
ERR_POSIDX = QSE_AWK_EPOSIDX,
|
||||
ERR_ARGTF = QSE_AWK_EARGTF,
|
||||
ERR_ARGTM = QSE_AWK_EARGTM,
|
||||
ERR_FUNNF = QSE_AWK_EFUNNF,
|
||||
ERR_NOTIDX = QSE_AWK_ENOTIDX,
|
||||
ERR_NOTDEL = QSE_AWK_ENOTDEL,
|
||||
ERR_NOTMAP = QSE_AWK_ENOTMAP,
|
||||
ERR_NOTMAPIN = QSE_AWK_ENOTMAPIN,
|
||||
ERR_NOTMAPNILIN = QSE_AWK_ENOTMAPNILIN,
|
||||
ERR_NOTREF = QSE_AWK_ENOTREF,
|
||||
ERR_NOTASS = QSE_AWK_ENOTASS,
|
||||
ERR_IDXVALASSMAP = QSE_AWK_EIDXVALASSMAP,
|
||||
ERR_POSVALASSMAP = QSE_AWK_EPOSVALASSMAP,
|
||||
ERR_MAPTOSCALAR = QSE_AWK_EMAPTOSCALAR,
|
||||
ERR_SCALARTOMAP = QSE_AWK_ESCALARTOMAP,
|
||||
ERR_MAPNA = QSE_AWK_EMAPNA,
|
||||
ERR_VALTYPE = QSE_AWK_EVALTYPE,
|
||||
ERR_RDELETE = QSE_AWK_ERDELETE,
|
||||
ERR_RRESET = QSE_AWK_ERRESET,
|
||||
ERR_RNEXTBEG = QSE_AWK_ERNEXTBEG,
|
||||
ERR_RNEXTEND = QSE_AWK_ERNEXTEND,
|
||||
ERR_RNEXTFBEG = QSE_AWK_ERNEXTFBEG,
|
||||
ERR_RNEXTFEND = QSE_AWK_ERNEXTFEND,
|
||||
ERR_FNCIMPL = QSE_AWK_EFNCIMPL,
|
||||
ERR_IOUSER = QSE_AWK_EIOUSER,
|
||||
ERR_IOIMPL = QSE_AWK_EIOIMPL,
|
||||
ERR_IONMNF = QSE_AWK_EIONMNF,
|
||||
ERR_IONMEM = QSE_AWK_EIONMEM,
|
||||
ERR_IONMNL = QSE_AWK_EIONMNL,
|
||||
ERR_FMTARG = QSE_AWK_EFMTARG,
|
||||
ERR_FMTCNV = QSE_AWK_EFMTCNV,
|
||||
ERR_CONVFMTCHR = QSE_AWK_ECONVFMTCHR,
|
||||
ERR_OFMTCHR = QSE_AWK_EOFMTCHR,
|
||||
ERR_REXRECUR = QSE_AWK_EREXRECUR,
|
||||
ERR_REXRPAREN = QSE_AWK_EREXRPAREN,
|
||||
ERR_REXRBRACKET = QSE_AWK_EREXRBRACKET,
|
||||
ERR_REXRBRACE = QSE_AWK_EREXRBRACE,
|
||||
ERR_REXUNBALPAREN = QSE_AWK_EREXUNBALPAREN,
|
||||
ERR_REXINVALBRACE = QSE_AWK_EREXINVALBRACE,
|
||||
ERR_REXCOLON = QSE_AWK_EREXCOLON,
|
||||
ERR_REXCRANGE = QSE_AWK_EREXCRANGE,
|
||||
ERR_REXCCLASS = QSE_AWK_EREXCCLASS,
|
||||
ERR_REXBRANGE = QSE_AWK_EREXBRANGE,
|
||||
ERR_REXEND = QSE_AWK_EREXEND,
|
||||
ERR_REXGARBAGE = QSE_AWK_EREXGARBAGE,
|
||||
};
|
||||
|
||||
protected:
|
||||
///
|
||||
/// @name Error Handling
|
||||
///
|
||||
/// @{
|
||||
|
||||
///
|
||||
/// The getErrorString() function returns a formatting string
|
||||
/// for an error code @a num. You can override this function
|
||||
/// to customize an error message. You must include the same numbers
|
||||
/// of ${X}'s as the orginal formatting string. Their order may be
|
||||
/// different. The example below changes the formatting string for
|
||||
/// ERR_NOENT.
|
||||
/// #QSE_AWK_ENOENT.
|
||||
/// @code
|
||||
/// const MyAwk::char_t* MyAwk::getErrorString (ErrorNumber num) const
|
||||
/// const MyAwk::char_t* MyAwk::getErrorString (errnum_t num) const
|
||||
/// {
|
||||
/// if (num == ERR_NOENT) return QSE_T("cannot find '${0}'");
|
||||
/// if (num == QSE_AWK_ENOENT) return QSE_T("cannot find '${0}'");
|
||||
/// return Awk::getErrorString (num);
|
||||
/// }
|
||||
/// @endcode
|
||||
///
|
||||
virtual const char_t* getErrorString (
|
||||
ErrorNumber num
|
||||
errnum_t num
|
||||
) const;
|
||||
|
||||
public:
|
||||
@ -224,7 +111,7 @@ public:
|
||||
/// The getErrorNumber() function returns the number of the last
|
||||
/// error occurred.
|
||||
///
|
||||
ErrorNumber getErrorNumber () const;
|
||||
errnum_t getErrorNumber () const;
|
||||
|
||||
///
|
||||
/// The getErrorLocation() function returns the location of the
|
||||
@ -242,7 +129,7 @@ public:
|
||||
/// The setError() function sets error information.
|
||||
///
|
||||
void setError (
|
||||
ErrorNumber code, ///< error code
|
||||
errnum_t code, ///< error code
|
||||
const cstr_t* args = QSE_NULL, ///< message formatting
|
||||
/// argument array
|
||||
const loc_t* loc = QSE_NULL ///< error location
|
||||
@ -253,7 +140,7 @@ public:
|
||||
/// with a customized error message.
|
||||
///
|
||||
void setErrorWithMessage (
|
||||
ErrorNumber code, ///< error code
|
||||
errnum_t code, ///< error code
|
||||
const char_t* msg, ///< error message
|
||||
const loc_t* loc ///< error location
|
||||
);
|
||||
@ -266,7 +153,7 @@ public:
|
||||
protected:
|
||||
void retrieveError ();
|
||||
void retrieveError (Run* run);
|
||||
/*@}*/
|
||||
/// @}
|
||||
|
||||
protected:
|
||||
class NoSource;
|
||||
@ -370,11 +257,11 @@ protected:
|
||||
};
|
||||
|
||||
public:
|
||||
/**
|
||||
* The RIOBase class is a base class to represent runtime I/O context.
|
||||
* The Console, File, Pipe classes inherit this class to implement
|
||||
* an actual I/O context.
|
||||
*/
|
||||
///
|
||||
/// The RIOBase class is a base class to represent runtime I/O
|
||||
/// operations. The Console, File, Pipe classes implement more specific
|
||||
/// I/O operations by inheriting this class.
|
||||
///
|
||||
class RIOBase
|
||||
{
|
||||
protected:
|
||||
@ -400,10 +287,10 @@ public:
|
||||
RIOBase& operator= (const RIOBase&);
|
||||
};
|
||||
|
||||
/**
|
||||
* The Pipe class encapsulates the pipe operations indicated by
|
||||
* the | and || operators.
|
||||
*/
|
||||
///
|
||||
/// The Pipe class encapsulates the pipe operations indicated by
|
||||
/// the | and || operators.
|
||||
///
|
||||
class Pipe: public RIOBase
|
||||
{
|
||||
public:
|
||||
@ -449,9 +336,9 @@ public:
|
||||
CloseMode getCloseMode () const;
|
||||
};
|
||||
|
||||
/**
|
||||
* File
|
||||
*/
|
||||
///
|
||||
/// The File class encapsulates file operations by inheriting RIOBase.
|
||||
///
|
||||
class File: public RIOBase
|
||||
{
|
||||
public:
|
||||
@ -471,9 +358,10 @@ public:
|
||||
Mode getMode () const;
|
||||
};
|
||||
|
||||
/**
|
||||
* Console
|
||||
*/
|
||||
///
|
||||
/// The Console class encapsulates the console operations by
|
||||
/// inheriting RIOBase.
|
||||
///
|
||||
class Console: public RIOBase
|
||||
{
|
||||
public:
|
||||
@ -498,9 +386,10 @@ public:
|
||||
char_t* filename;
|
||||
};
|
||||
|
||||
/**
|
||||
* Represents a value.
|
||||
*/
|
||||
///
|
||||
/// The Value class wraps around #qse_awk_val_t to provide a more
|
||||
/// comprehensive interface.
|
||||
///
|
||||
class Value
|
||||
{
|
||||
public:
|
||||
@ -520,15 +409,18 @@ public:
|
||||
void operator delete (void* p);
|
||||
void operator delete[] (void* p);
|
||||
|
||||
/**
|
||||
* Represents an index of an arrayed value
|
||||
*/
|
||||
///
|
||||
/// The Index class encapsulates an index of an arrayed value.
|
||||
///
|
||||
class Index
|
||||
{
|
||||
public:
|
||||
friend class Value;
|
||||
|
||||
/// The Index() function creates an empty array index.
|
||||
Index (): ptr (EMPTY_STRING), len (0) {}
|
||||
|
||||
/// The Index() function creates a string array index.
|
||||
Index (const char_t* ptr, size_t len):
|
||||
ptr (ptr), len (len) {}
|
||||
|
||||
@ -536,9 +428,9 @@ public:
|
||||
size_t len;
|
||||
};
|
||||
|
||||
/**
|
||||
* Represents a numeric index of an arrayed value
|
||||
*/
|
||||
///
|
||||
/// Represents a numeric index of an arrayed value
|
||||
///
|
||||
class IntIndex: public Index
|
||||
{
|
||||
public:
|
||||
@ -563,20 +455,32 @@ public:
|
||||
#endif
|
||||
};
|
||||
|
||||
/**
|
||||
* helper class to iterate over array elements
|
||||
*/
|
||||
///
|
||||
/// The IndexIterator class is a helper class to make simple
|
||||
/// iteration over array elements.
|
||||
///
|
||||
class IndexIterator
|
||||
{
|
||||
public:
|
||||
friend class Value;
|
||||
|
||||
///
|
||||
/// The END variable is a special variable to
|
||||
/// represent the end of iteration.
|
||||
///
|
||||
static IndexIterator END;
|
||||
|
||||
///
|
||||
/// The IndexIterator() function creates an iterator
|
||||
/// for an arrayed value.
|
||||
///
|
||||
IndexIterator (): pair (QSE_NULL), buckno (0) {}
|
||||
|
||||
protected:
|
||||
IndexIterator (pair_t* pair, size_t buckno):
|
||||
pair (pair), buckno (buckno) {}
|
||||
|
||||
public:
|
||||
bool operator== (const IndexIterator& ii) const
|
||||
{
|
||||
return pair == ii.pair && buckno == ii.buckno;
|
||||
@ -592,8 +496,24 @@ public:
|
||||
size_t buckno;
|
||||
};
|
||||
|
||||
///
|
||||
/// The Value() function creates an empty value associated
|
||||
/// with no runtime context. To set an actual inner value,
|
||||
/// you must specify a context when calling setXXX() functions.
|
||||
/// i.e., use setInt(run,10) instead of setInt(10).
|
||||
///
|
||||
Value ();
|
||||
|
||||
///
|
||||
/// The Value() function creates an empty value associated
|
||||
/// with a runtime context.
|
||||
///
|
||||
Value (Run& run);
|
||||
|
||||
///
|
||||
/// The Value() function creates an empty value associated
|
||||
/// with a runtime context.
|
||||
///
|
||||
Value (Run* run);
|
||||
|
||||
Value (const Value& v);
|
||||
@ -710,21 +630,42 @@ public:
|
||||
const char_t* str
|
||||
);
|
||||
|
||||
/** determines if a value is arrayed */
|
||||
///
|
||||
/// The isIndexed() function determines if a value is arrayed.
|
||||
/// @return true if indexed, false if not.
|
||||
///
|
||||
bool isIndexed () const;
|
||||
|
||||
///
|
||||
/// The getIndexed() function gets a value at the given
|
||||
/// index @a idx and sets it to @a val.
|
||||
/// @return 0 on success, -1 on failure
|
||||
///
|
||||
int getIndexed (
|
||||
const Index& idx,
|
||||
Value* val
|
||||
const Index& idx, ///< array index
|
||||
Value* val ///< value holder
|
||||
) const;
|
||||
|
||||
///
|
||||
/// The getFirstIndex() function stores the first index of
|
||||
/// an arrayed value into @a idx.
|
||||
/// @return IndexIterator::END if the arrayed value is empty,
|
||||
/// iterator that can be passed to getNextIndex() if not
|
||||
///
|
||||
IndexIterator getFirstIndex (
|
||||
Index* idx
|
||||
Index* idx ///< index holder
|
||||
) const;
|
||||
|
||||
///
|
||||
/// The getNextIndex() function stores into @a idx the next
|
||||
/// index of an array value from the position indicated by
|
||||
/// @a iter.
|
||||
/// @return IndexIterator::END if the arrayed value is empty,
|
||||
/// iterator that can be passed to getNextIndex() if not
|
||||
///
|
||||
IndexIterator getNextIndex (
|
||||
Index* idx,
|
||||
const IndexIterator& iter
|
||||
Index* idx, ///< index holder
|
||||
const IndexIterator& iter ///< current position
|
||||
) const;
|
||||
|
||||
protected:
|
||||
@ -740,32 +681,10 @@ public:
|
||||
};
|
||||
|
||||
public:
|
||||
/**
|
||||
* Defines an identifier of predefined global variables.
|
||||
* Awk::setGlobal and Awk::getGlobal can take one of these enumerators.
|
||||
*/
|
||||
enum Global
|
||||
{
|
||||
GBL_ARGC = QSE_AWK_GBL_ARGC, /**< ARGC */
|
||||
GBL_ARGV = QSE_AWK_GBL_ARGV, /**< ARGV */
|
||||
GBL_CONVFMT = QSE_AWK_GBL_CONVFMT, /**< CONVFMT */
|
||||
GBL_FILENAME = QSE_AWK_GBL_FILENAME, /**< FILENAME */
|
||||
GBL_FNR = QSE_AWK_GBL_FNR, /**< FNR */
|
||||
GBL_FS = QSE_AWK_GBL_FS, /**< FS */
|
||||
GBL_IGNORECASE = QSE_AWK_GBL_IGNORECASE, /**< IGNORECASE */
|
||||
GBL_NF = QSE_AWK_GBL_NF, /**< NF */
|
||||
GBL_NR = QSE_AWK_GBL_NR, /**< NR */
|
||||
GBL_OFILENAME = QSE_AWK_GBL_OFILENAME, /**< OFILENAME */
|
||||
GBL_OFMT = QSE_AWK_GBL_OFMT, /**< OFMT */
|
||||
GBL_OFS = QSE_AWK_GBL_OFS, /**< OFS */
|
||||
GBL_ORS = QSE_AWK_GBL_ORS, /**< ORS */
|
||||
GBL_RLENGTH = QSE_AWK_GBL_RLENGTH, /**< RLENGTH */
|
||||
GBL_RS = QSE_AWK_GBL_RS, /**< RS */
|
||||
GBL_RSTART = QSE_AWK_GBL_RSTART, /**< RSTART */
|
||||
GBL_SUBSEP = QSE_AWK_GBL_SUBSEP /**< SUBSEP */
|
||||
};
|
||||
|
||||
/** Represents the execution context */
|
||||
///
|
||||
/// The Run class wraps around #qse_awk_rtx_t to represent the
|
||||
/// runtime context.
|
||||
///
|
||||
class Run
|
||||
{
|
||||
protected:
|
||||
@ -783,20 +702,20 @@ public:
|
||||
operator rtx_t* () const;
|
||||
|
||||
void stop () const;
|
||||
bool shouldStop () const;
|
||||
bool isStopReq () const;
|
||||
|
||||
ErrorNumber getErrorNumber () const;
|
||||
errnum_t getErrorNumber () const;
|
||||
loc_t getErrorLocation () const;
|
||||
const char_t* getErrorMessage () const;
|
||||
|
||||
void setError (
|
||||
ErrorNumber code,
|
||||
errnum_t code,
|
||||
const cstr_t* args = QSE_NULL,
|
||||
const loc_t* loc = QSE_NULL
|
||||
);
|
||||
|
||||
void setErrorWithMessage (
|
||||
ErrorNumber code,
|
||||
errnum_t code,
|
||||
const char_t* msg,
|
||||
const loc_t* loc
|
||||
);
|
||||
@ -841,50 +760,56 @@ public:
|
||||
rtx_t* rtx;
|
||||
};
|
||||
|
||||
/** Returns the primitive handle */
|
||||
///
|
||||
/// Returns the primitive handle
|
||||
///
|
||||
operator awk_t* () const;
|
||||
|
||||
/**
|
||||
* @name Basic Functions
|
||||
*/
|
||||
/*@{*/
|
||||
/** Constructor */
|
||||
///
|
||||
/// @name Basic Functions
|
||||
/// @{
|
||||
///
|
||||
|
||||
/// Constructor
|
||||
Awk ();
|
||||
|
||||
/**
|
||||
* The Awk::open() function initializes an interpreter.
|
||||
* You must call this function before doing anything meaningful.
|
||||
* @return 0 on success, -1 on failure
|
||||
*/
|
||||
///
|
||||
/// The open() function initializes an interpreter.
|
||||
/// You must call this function before doing anything meaningful.
|
||||
/// @return 0 on success, -1 on failure
|
||||
///
|
||||
int open ();
|
||||
|
||||
/** Closes the interpreter. */
|
||||
///
|
||||
/// The cloase() function closes the interpreter.
|
||||
///
|
||||
void close ();
|
||||
|
||||
/**
|
||||
* The Awk::parse() function parses the source code read from the input
|
||||
* stream @a in and writes the parse tree to the output stream @a out.
|
||||
* To disable deparsing, you may set @a out to Awk::Source::NONE.
|
||||
* However, it is not allowed to specify Awk::Source::NONE for @a in.
|
||||
*
|
||||
* @return Run object on success, #QSE_NULL on failure
|
||||
*/
|
||||
///
|
||||
/// The parse() function parses the source code read from the input
|
||||
/// stream @a in and writes the parse tree to the output stream @a out.
|
||||
/// To disable deparsing, you may set @a out to Awk::Source::NONE.
|
||||
/// However, it is not allowed to specify Awk::Source::NONE for @a in.
|
||||
///
|
||||
/// @return Run object on success, #QSE_NULL on failure
|
||||
///
|
||||
Awk::Run* parse (
|
||||
Source& in, ///< script to parse
|
||||
Source& out ///< deparsing target
|
||||
);
|
||||
|
||||
/**
|
||||
* Executes the BEGIN block, pattern-action blocks, and the END block.
|
||||
* @return 0 on succes, -1 on failure
|
||||
*/
|
||||
///
|
||||
/// The loop() function executes the BEGIN block, pattern-action blocks,
|
||||
/// and the END block. The return value is stored into @a ret.
|
||||
/// @return 0 on succes, -1 on failure
|
||||
///
|
||||
int loop (
|
||||
Value* ret ///< return value holder
|
||||
);
|
||||
|
||||
/**
|
||||
* Calls a function
|
||||
*/
|
||||
///
|
||||
/// The call() function invokes a function named @a name.
|
||||
///
|
||||
int call (
|
||||
const char_t* name, ///< function name
|
||||
Value* ret, ///< return value holder
|
||||
@ -892,149 +817,110 @@ public:
|
||||
size_t nargs ///< number of arguments
|
||||
);
|
||||
|
||||
/**
|
||||
* Makes request to abort execution
|
||||
*/
|
||||
///
|
||||
/// The stop() function makes request to abort execution
|
||||
///
|
||||
void stop ();
|
||||
/*@}*/
|
||||
/// @}
|
||||
|
||||
/**
|
||||
* @name Configuration
|
||||
*/
|
||||
/*@{*/
|
||||
///
|
||||
/// @name Configuration
|
||||
/// @{
|
||||
///
|
||||
|
||||
/** Defines options */
|
||||
enum Option
|
||||
{
|
||||
OPT_IMPLICIT = QSE_AWK_IMPLICIT,
|
||||
OPT_EXPLICIT = QSE_AWK_EXPLICIT,
|
||||
OPT_EXTRAOPS = QSE_AWK_EXTRAOPS,
|
||||
OPT_RIO = QSE_AWK_RIO,
|
||||
OPT_RWPIPE = QSE_AWK_RWPIPE,
|
||||
|
||||
/** Can terminate a statement with a new line */
|
||||
OPT_NEWLINE = QSE_AWK_NEWLINE,
|
||||
|
||||
OPT_STRIPRECSPC = QSE_AWK_STRIPRECSPC,
|
||||
OPT_STRIPSTRSPC = QSE_AWK_STRIPSTRSPC,
|
||||
|
||||
/** Support the nextofile statement */
|
||||
OPT_NEXTOFILE = QSE_AWK_NEXTOFILE,
|
||||
/** Enables the keyword 'reset' */
|
||||
OPT_RESET = QSE_AWK_RESET,
|
||||
/** Use CR+LF instead of LF for line breaking. */
|
||||
OPT_CRLF = QSE_AWK_CRLF,
|
||||
/** Allows the assignment of a map value to a variable */
|
||||
OPT_MAPTOVAR = QSE_AWK_MAPTOVAR,
|
||||
/** Allows BEGIN, END, pattern-action blocks */
|
||||
OPT_PABLOCK = QSE_AWK_PABLOCK,
|
||||
/** Allows {n,m} in a regular expression */
|
||||
OPT_REXBOUND = QSE_AWK_REXBOUND,
|
||||
/**
|
||||
* Performs numeric comparison when a string convertable
|
||||
* to a number is compared with a number or vice versa.
|
||||
*
|
||||
* For an expression (9 > "10.9"),
|
||||
* - 9 is greater if #QSE_AWK_NCMPONSTR is off;
|
||||
* - "10.9" is greater if #QSE_AWK_NCMPONSTR is on
|
||||
*/
|
||||
OPT_NCMPONSTR = QSE_AWK_NCMPONSTR,
|
||||
|
||||
/**
|
||||
* Enables the strict naming rule.
|
||||
* - a parameter name can not be the same as the owning
|
||||
* function name.
|
||||
* - a local variable name can not be the same as the
|
||||
* owning function name.
|
||||
*/
|
||||
|
||||
OPT_STRICTNAMING = QSE_AWK_STRICTNAMING,
|
||||
|
||||
/** Enables 'include' */
|
||||
OPT_INCLUDE = QSE_AWK_INCLUDE
|
||||
};
|
||||
/** Gets the option */
|
||||
///
|
||||
/// The getOption() function gets the current options.
|
||||
/// @return 0 or current options ORed of #option_t enumerators.
|
||||
///
|
||||
int getOption () const;
|
||||
|
||||
/** Sets the option */
|
||||
///
|
||||
/// The setOption() function changes the current options.
|
||||
///
|
||||
void setOption (
|
||||
int opt
|
||||
int opt ///< options ORed of #option_t enumerators.
|
||||
);
|
||||
|
||||
/** Defines the depth ID */
|
||||
enum Depth
|
||||
{
|
||||
DEPTH_BLOCK_PARSE = QSE_AWK_DEPTH_BLOCK_PARSE,
|
||||
DEPTH_BLOCK_RUN = QSE_AWK_DEPTH_BLOCK_RUN,
|
||||
DEPTH_EXPR_PARSE = QSE_AWK_DEPTH_EXPR_PARSE,
|
||||
DEPTH_EXPR_RUN = QSE_AWK_DEPTH_EXPR_RUN,
|
||||
DEPTH_REX_BUILD = QSE_AWK_DEPTH_REX_BUILD,
|
||||
DEPTH_REX_MATCH = QSE_AWK_DEPTH_REX_MATCH
|
||||
};
|
||||
///
|
||||
/// The setMaxDepth() function sets the maximum processing depth
|
||||
/// for operations identified by @a ids.
|
||||
///
|
||||
void setMaxDepth (
|
||||
int ids, ///< number ORed of #depth_t enumerators
|
||||
size_t depth ///< new depth
|
||||
);
|
||||
|
||||
/** Sets the maximum depth */
|
||||
void setMaxDepth (int ids, size_t depth);
|
||||
/** Gets the maximum depth */
|
||||
size_t getMaxDepth (depth_t id) const;
|
||||
///
|
||||
/// The getMaxDepth() function gets the maximum depth for an operation
|
||||
/// type identified by @a id.
|
||||
///
|
||||
size_t getMaxDepth (
|
||||
depth_t id ///< operation identifier
|
||||
) const;
|
||||
|
||||
/**
|
||||
* Adds an ARGV string as long as @a len characters pointed to
|
||||
* by @a arg. loop() and call() make a string added available
|
||||
* to a script through ARGV.
|
||||
* @return 0 on success, -1 on failure
|
||||
*/
|
||||
///
|
||||
/// The addArgument() function adds an ARGV string as long as @a len
|
||||
/// characters pointed to
|
||||
/// by @a arg. loop() and call() make a string added available
|
||||
/// to a script through ARGV.
|
||||
/// @return 0 on success, -1 on failure
|
||||
///
|
||||
int addArgument (
|
||||
const char_t* arg,
|
||||
size_t len
|
||||
const char_t* arg, ///< string pointer
|
||||
size_t len ///< string length
|
||||
);
|
||||
|
||||
/**
|
||||
* Adds a null-terminated string @a arg. loop() and call()
|
||||
* make a string added available to a script through ARGV.
|
||||
* @return 0 on success, -1 on failure
|
||||
*/
|
||||
int addArgument (const char_t* arg);
|
||||
///
|
||||
/// The addArgument() function adds a null-terminated string @a arg.
|
||||
/// loop() and call() make a string added available to a script
|
||||
/// through ARGV.
|
||||
/// @return 0 on success, -1 on failure
|
||||
///
|
||||
int addArgument (
|
||||
const char_t* arg ///< string pointer
|
||||
);
|
||||
|
||||
/**
|
||||
* Deletes all ARGV strings.
|
||||
*/
|
||||
///
|
||||
/// The clearArguments() function deletes all ARGV strings.
|
||||
///
|
||||
void clearArguments ();
|
||||
|
||||
/**
|
||||
* Registers an intrinsic global variable.
|
||||
* @return integer >= 0 on success, -1 on failure.
|
||||
*/
|
||||
///
|
||||
/// The addGlobal() function registers an intrinsic global variable.
|
||||
/// @return integer >= 0 on success, -1 on failure.
|
||||
///
|
||||
int addGlobal (
|
||||
const char_t* name ///< variable name
|
||||
);
|
||||
|
||||
/**
|
||||
* Unregisters an intrinsic global variable.
|
||||
* @return 0 on success, -1 on failure.
|
||||
*/
|
||||
///
|
||||
/// The deleteGlobal() function unregisters an intrinsic global
|
||||
/// variable by name.
|
||||
/// @return 0 on success, -1 on failure.
|
||||
///
|
||||
int deleteGlobal (
|
||||
const char_t* name ///< variable name
|
||||
);
|
||||
|
||||
/**
|
||||
* Sets the value of a global variable identified by @a id.
|
||||
* The @a id is either a value returned by Awk::addGlobal or one of
|
||||
* Awk::Global enumerators. It is not allowed to call this function
|
||||
* prior to Awk::parse.
|
||||
* @return 0 on success, -1 on failure
|
||||
*/
|
||||
///
|
||||
/// The setGlobal() function sets the value of a global variable
|
||||
/// identified by @a id. The @a id is either a value returned by
|
||||
/// addGlobal() or one of the #gbl_id_t enumerators. It is not allowed
|
||||
/// to call this function prior to parse().
|
||||
/// @return 0 on success, -1 on failure
|
||||
///
|
||||
int setGlobal (
|
||||
int id, ///< numeric identifier
|
||||
const Value& v ///< value
|
||||
);
|
||||
|
||||
/**
|
||||
* Gets the value of a global riable identified by @a id.
|
||||
* The @a id is either a value returned by Awk::addGlobal or one of
|
||||
* Awk::::Global enumerators. It is not allowed to call this function
|
||||
* prior to Awk::parse.
|
||||
* @return 0 on success, -1 on failure
|
||||
*/
|
||||
///
|
||||
/// The getGlobal() function gets the value of a global variable
|
||||
/// identified by @a id. The @a id is either a value returned by
|
||||
/// addGlobal() or one of the #gbl_id_t enumerators. It is not allowed
|
||||
/// to call this function before Awk::parse().
|
||||
/// @return 0 on success, -1 on failure
|
||||
///
|
||||
int getGlobal (
|
||||
int id, ///< numeric identifier
|
||||
Value& v ///< value store
|
||||
@ -1051,23 +937,30 @@ public:
|
||||
const cstr_t* name
|
||||
);
|
||||
|
||||
/**
|
||||
* Adds a new user-defined intrinsic function.
|
||||
*/
|
||||
///
|
||||
/// The addFunction() function adds a new user-defined intrinsic
|
||||
/// function.
|
||||
///
|
||||
int addFunction (
|
||||
const char_t* name, size_t minArgs, size_t maxArgs,
|
||||
FunctionHandler handler);
|
||||
const char_t* name, ///< function name
|
||||
size_t minArgs, ///< minimum numbers of arguments
|
||||
size_t maxArgs, ///< maximum numbers of arguments
|
||||
FunctionHandler handler ///< function handler
|
||||
);
|
||||
|
||||
/**
|
||||
* Deletes a user-defined intrinsic function
|
||||
*/
|
||||
int deleteFunction (const char_t* name);
|
||||
/*@}*/
|
||||
///
|
||||
/// The deleteFunction() function deletes a user-defined intrinsic
|
||||
/// function by name.
|
||||
///
|
||||
int deleteFunction (
|
||||
const char_t* name ///< function name
|
||||
);
|
||||
/// @}
|
||||
|
||||
/**
|
||||
* @name Word Substitution
|
||||
*/
|
||||
/*@{*/
|
||||
///
|
||||
/// @name Word Substitution
|
||||
/// @{
|
||||
///
|
||||
int getWord (
|
||||
const cstr_t* ow,
|
||||
cstr_t* nw
|
||||
@ -1083,14 +976,13 @@ public:
|
||||
);
|
||||
|
||||
void unsetAllWords ();
|
||||
/*@}*/
|
||||
/// @}
|
||||
|
||||
protected:
|
||||
/**
|
||||
* @name Pipe I/O handlers
|
||||
* Pipe operations are achieved through the following functions.
|
||||
*/
|
||||
/*@{*/
|
||||
///
|
||||
/// @name Pipe I/O handlers
|
||||
/// Pipe operations are achieved through the following functions.
|
||||
/// @{
|
||||
|
||||
/// The openPipe() function is a pure virtual function that must be
|
||||
/// overridden by a child class to open a pipe. It must return 1
|
||||
@ -1105,31 +997,32 @@ protected:
|
||||
virtual ssize_t readPipe (Pipe& io, char_t* buf, size_t len) = 0;
|
||||
virtual ssize_t writePipe (Pipe& io, const char_t* buf, size_t len) = 0;
|
||||
virtual int flushPipe (Pipe& io) = 0;
|
||||
/*@}*/
|
||||
/// @}
|
||||
|
||||
/**
|
||||
* @name File I/O handlers
|
||||
* File operations are achieved through the following functions.
|
||||
*/
|
||||
/*@{*/
|
||||
///
|
||||
/// @name File I/O handlers
|
||||
/// File operations are achieved through the following functions.
|
||||
/// @{
|
||||
///
|
||||
virtual int openFile (File& io) = 0;
|
||||
virtual int closeFile (File& io) = 0;
|
||||
virtual ssize_t readFile (File& io, char_t* buf, size_t len) = 0;
|
||||
virtual ssize_t writeFile (File& io, const char_t* buf, size_t len) = 0;
|
||||
virtual int flushFile (File& io) = 0;
|
||||
/*@}*/
|
||||
/// @}
|
||||
|
||||
/**
|
||||
* @name Console I/O handlers
|
||||
* Console operations are achieved through the following functions.
|
||||
*/
|
||||
///
|
||||
/// @name Console I/O handlers
|
||||
/// Console operations are achieved through the following functions.
|
||||
/// @{
|
||||
///
|
||||
virtual int openConsole (Console& io) = 0;
|
||||
virtual int closeConsole (Console& io) = 0;
|
||||
virtual ssize_t readConsole (Console& io, char_t* buf, size_t len) = 0;
|
||||
virtual ssize_t writeConsole (Console& io, const char_t* buf, size_t len) = 0;
|
||||
virtual int flushConsole (Console& io) = 0;
|
||||
virtual int nextConsole (Console& io) = 0;
|
||||
/*@}*/
|
||||
/// @}
|
||||
|
||||
// primitive handlers
|
||||
virtual real_t pow (real_t x, real_t y) = 0;
|
||||
|
@ -1,19 +1,21 @@
|
||||
/*
|
||||
* $Id: StdAwk.hpp 275 2009-08-30 13:19:02Z hyunghwan.chung $
|
||||
* $Id: StdAwk.hpp 287 2009-09-15 10:01:02Z hyunghwan.chung $
|
||||
*
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
This file is part of QSE.
|
||||
|
||||
Licensed under the Apache License, Version 2.0 (the "License");
|
||||
you may not use this file except in compliance with the License.
|
||||
You may obtain a copy of the License at
|
||||
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.
|
||||
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
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.
|
||||
|
||||
Unless required by applicable law or agreed to in writing, software
|
||||
distributed under the License is distributed on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
See the License for the specific language governing permissions and
|
||||
limitations under the License.
|
||||
You should have received a copy of the GNU Lesser General Public
|
||||
License along with QSE. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#ifndef _QSE_AWK_STDAWK_HPP_
|
||||
@ -21,46 +23,37 @@
|
||||
|
||||
#include <qse/awk/Awk.hpp>
|
||||
|
||||
/** @file
|
||||
* Standard AWK Interpreter
|
||||
*
|
||||
*/
|
||||
|
||||
/**
|
||||
* @example awk05.cpp
|
||||
* This program demonstrates how to use QSE::StdAwk::loop().
|
||||
*/
|
||||
|
||||
/**
|
||||
* @example awk06.cpp
|
||||
* This program demonstrates how to use QSE::StdAwk::call().
|
||||
*/
|
||||
|
||||
/**
|
||||
* @example awk07.cpp
|
||||
* This program demonstrates how to handle an indexed value.
|
||||
*/
|
||||
|
||||
/**
|
||||
* @example awk08.cpp
|
||||
* This program shows how to add intrinsic functions.
|
||||
*/
|
||||
/// @file
|
||||
/// Standard AWK Interpreter
|
||||
///
|
||||
/// @example awk05.cpp
|
||||
/// This program demonstrates how to use QSE::StdAwk::loop().
|
||||
///
|
||||
/// @example awk06.cpp
|
||||
/// This program demonstrates how to use QSE::StdAwk::call().
|
||||
///
|
||||
/// @example awk07.cpp
|
||||
/// This program demonstrates how to handle an indexed value.
|
||||
///
|
||||
/// @example awk08.cpp
|
||||
/// This program shows how to add intrinsic functions.
|
||||
///
|
||||
|
||||
/////////////////////////////////
|
||||
QSE_BEGIN_NAMESPACE(QSE)
|
||||
////////////////////////////////
|
||||
|
||||
/**
|
||||
* Provides a more useful interpreter by overriding primitive methods,
|
||||
* and implementing the file handler, the pipe handler, and common intrinsic
|
||||
* functions.
|
||||
*/
|
||||
///
|
||||
/// The StdAwk class provides an easier-to-use interface by overriding
|
||||
/// primitive methods, and implementing the file handler, the pipe handler,
|
||||
/// and common intrinsic functions.
|
||||
///
|
||||
class StdAwk: public Awk
|
||||
{
|
||||
public:
|
||||
/**
|
||||
* Implements script I/O from and to a file.
|
||||
*/
|
||||
///
|
||||
/// The SourceFile class implements script I/O from and to a file.
|
||||
///
|
||||
class SourceFile: public Source
|
||||
{
|
||||
public:
|
||||
@ -79,10 +72,10 @@ public:
|
||||
qse_cstr_t dir;
|
||||
};
|
||||
|
||||
/**
|
||||
* Implements script input from a string. The deparsing is not
|
||||
* supported.
|
||||
*/
|
||||
///
|
||||
/// The SourceString class implements script input from a string.
|
||||
/// Deparsing is not supported.
|
||||
///
|
||||
class SourceString: public Source
|
||||
{
|
||||
public:
|
||||
|
@ -1,19 +1,21 @@
|
||||
/*
|
||||
* $Id: awk.h 286 2009-09-14 13:29:55Z hyunghwan.chung $
|
||||
* $Id: awk.h 287 2009-09-15 10:01:02Z hyunghwan.chung $
|
||||
*
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
This file is part of QSE.
|
||||
|
||||
Licensed under the Apache License, Version 2.0 (the "License");
|
||||
you may not use this file except in compliance with the License.
|
||||
You may obtain a copy of the License at
|
||||
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.
|
||||
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
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.
|
||||
|
||||
Unless required by applicable law or agreed to in writing, software
|
||||
distributed under the License is distributed on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
See the License for the specific language governing permissions and
|
||||
limitations under the License.
|
||||
You should have received a copy of the GNU Lesser General Public
|
||||
License along with QSE. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#ifndef _QSE_AWK_AWK_H_
|
||||
@ -26,31 +28,29 @@
|
||||
|
||||
/** @file
|
||||
* An embeddable AWK interpreter is defined in this header file.
|
||||
*
|
||||
* @todo
|
||||
* - make enhancement to treat a function as a value
|
||||
* - add RQ (right quote), LQ (left quote), ES (escaper) for more powerful
|
||||
* record splitting
|
||||
* - improve performance of qse_awk_rtx_readio() if RS is logner than 2 chars.
|
||||
*/
|
||||
|
||||
/**
|
||||
* @example awk.c
|
||||
* This program demonstrates how to build a complete awk interpreter.
|
||||
*/
|
||||
|
||||
/**
|
||||
*
|
||||
* @example awk01.c
|
||||
* This program demonstrates how to use qse_awk_rtx_loop().
|
||||
*/
|
||||
|
||||
/**
|
||||
*
|
||||
* @example awk02.c
|
||||
* The program deparses the source code and prints it before executing it.
|
||||
*/
|
||||
|
||||
/**
|
||||
*
|
||||
* @example awk03.c
|
||||
* This program demonstrates how to use qse_awk_rtx_call().
|
||||
* It parses the program stored in the string src and calls the functions
|
||||
* stated in the array fnc. If no errors occur, it should print 24.
|
||||
*/
|
||||
|
||||
/**
|
||||
*
|
||||
* @example awk04.c
|
||||
* This programs shows how to qse_awk_rtx_call().
|
||||
*/
|
||||
@ -81,7 +81,7 @@
|
||||
*
|
||||
* It provides an interface to change the conventional behavior of the
|
||||
* interpreter; most notably, you can call a particular function with
|
||||
* qse_awk_rtx_call() instead of entering the BEGIN,pattern-action blocks,END
|
||||
* qse_awk_rtx_call() instead of entering the BEGIN, pattern-action blocks, END
|
||||
* loop. By doing this, you may utilize a script in an event-driven way.
|
||||
*
|
||||
* @sa qse_awk_rtx_t qse_awk_open qse_awk_close
|
||||
@ -289,7 +289,6 @@ typedef enum qse_awk_sio_cmd_t qse_awk_sio_cmd_t;
|
||||
* The qse_awk_sio_lxc_t type defines a structure to store a character
|
||||
* with its location information.
|
||||
*/
|
||||
typedef struct qse_awk_sio_lxc_t qse_awk_sio_lxc_t;
|
||||
struct qse_awk_sio_lxc_t
|
||||
{
|
||||
qse_cint_t c; /**< character */
|
||||
@ -297,6 +296,7 @@ struct qse_awk_sio_lxc_t
|
||||
qse_size_t col; /**< column */
|
||||
const qse_char_t* fil; /**< file */
|
||||
};
|
||||
typedef struct qse_awk_sio_lxc_t qse_awk_sio_lxc_t;
|
||||
|
||||
struct qse_awk_sio_arg_t
|
||||
{
|
||||
@ -365,11 +365,15 @@ enum qse_awk_rio_mode_t
|
||||
};
|
||||
typedef enum qse_awk_rio_mode_t qse_awk_rio_mode_t;
|
||||
|
||||
/*
|
||||
* The qse_awk_rio_rwcmode_t type defines I/O closing modes, especially for
|
||||
* a two-way pipe.
|
||||
*/
|
||||
enum qse_awk_rio_rwcmode_t
|
||||
{
|
||||
QSE_AWK_RIO_CLOSE_FULL = 0,
|
||||
QSE_AWK_RIO_CLOSE_READ = 1,
|
||||
QSE_AWK_RIO_CLOSE_WRITE = 2
|
||||
QSE_AWK_RIO_CLOSE_FULL = 0, /**< close both read and write end */
|
||||
QSE_AWK_RIO_CLOSE_READ = 1, /**< close the read end */
|
||||
QSE_AWK_RIO_CLOSE_WRITE = 2 /**< close the write end */
|
||||
};
|
||||
typedef enum qse_awk_rio_rwcmode_t qse_awk_rio_rwcmode_t;
|
||||
|
||||
@ -378,19 +382,18 @@ typedef enum qse_awk_rio_rwcmode_t qse_awk_rio_rwcmode_t;
|
||||
* I/O handler. An I/O handler should inspect the @a mode field and the
|
||||
* @a name field and store an open handle to the @a handle field when
|
||||
* #QSE_AWK_RIO_OPEN is requested. For other request type, it can refer
|
||||
* to the handle field set previously.
|
||||
* to the @a handle field set previously.
|
||||
*/
|
||||
typedef struct qse_awk_rio_arg_t qse_awk_rio_arg_t;
|
||||
struct qse_awk_rio_arg_t
|
||||
{
|
||||
qse_awk_rio_mode_t mode; /**< [IN] opening mode */
|
||||
qse_char_t* name; /**< [IN] name of I/O object */
|
||||
qse_awk_rio_rwcmode_t rwcmode; /**< [IN] closing mode for rwpipe */
|
||||
void* handle; /**< [OUT] I/O handle set by a handler */
|
||||
qse_awk_rio_mode_t mode; /**< opening mode */
|
||||
qse_char_t* name; /**< name of I/O object */
|
||||
qse_awk_rio_rwcmode_t rwcmode; /**< closing mode for rwpipe */
|
||||
void* handle; /**< I/O handle set by a handler */
|
||||
|
||||
/*-- from here down, internal use only --*/
|
||||
int type;
|
||||
int rwcstate; /** closing state for rwpipe */
|
||||
int rwcstate; /* closing state for rwpipe */
|
||||
|
||||
struct
|
||||
{
|
||||
@ -409,6 +412,7 @@ struct qse_awk_rio_arg_t
|
||||
|
||||
struct qse_awk_rio_arg_t* next;
|
||||
};
|
||||
typedef struct qse_awk_rio_arg_t qse_awk_rio_arg_t;
|
||||
|
||||
/**
|
||||
* The qse_awk_rio_fun_t type defines a runtime I/O handler.
|
||||
@ -424,7 +428,6 @@ typedef qse_ssize_t (*qse_awk_rio_fun_t) (
|
||||
/**
|
||||
* The qse_awk_prm_t type defines primitive functions
|
||||
*/
|
||||
typedef struct qse_awk_prm_t qse_awk_prm_t;
|
||||
struct qse_awk_prm_t
|
||||
{
|
||||
qse_awk_pow_t pow;
|
||||
@ -461,17 +464,18 @@ struct qse_awk_prm_t
|
||||
);
|
||||
#endif
|
||||
};
|
||||
typedef struct qse_awk_prm_t qse_awk_prm_t;
|
||||
|
||||
/**
|
||||
* The qse_awk_loc_t type defines a structure to hold location.
|
||||
*/
|
||||
typedef struct qse_awk_loc_t qse_awk_loc_t;
|
||||
struct qse_awk_loc_t
|
||||
{
|
||||
const qse_char_t* fil; /**< file */
|
||||
qse_size_t lin; /**< line */
|
||||
qse_size_t col; /**< column */
|
||||
};
|
||||
typedef struct qse_awk_loc_t qse_awk_loc_t;
|
||||
|
||||
/**
|
||||
* The qse_awk_sio_t type defines a script stream handler set.
|
||||
@ -599,7 +603,7 @@ enum qse_awk_option_t
|
||||
* for (i = 0; i < NF; i++) print i " [" $(i+1) "]";
|
||||
* }
|
||||
* @endcode
|
||||
* " a b c " is split to [a], [b], [c] if #QSE_AWK_STRIPRSPC is on.
|
||||
* " a b c " is split to [a], [b], [c] if #QSE_AWK_STRIPRECSPC is on.
|
||||
* Otherwise, it is split to [], [a], [b], [c], [].
|
||||
*/
|
||||
QSE_AWK_STRIPRECSPC = (1 << 6),
|
||||
@ -658,6 +662,7 @@ enum qse_awk_option_t
|
||||
QSE_AWK_NEWLINE | QSE_AWK_PABLOCK |
|
||||
QSE_AWK_STRIPSTRSPC | QSE_AWK_STRICTNAMING
|
||||
};
|
||||
typedef enum qse_awk_option_t qse_awk_option_t;
|
||||
|
||||
/**
|
||||
* The qse_awk_errnum_t type defines error codes.
|
||||
@ -823,7 +828,10 @@ typedef const qse_char_t* (*qse_awk_errstr_t) (
|
||||
qse_awk_errnum_t num /**< error number */
|
||||
);
|
||||
|
||||
/* depth types */
|
||||
/**
|
||||
* The qse_awk_depth_t type defines operation types requiring recursion depth
|
||||
* control.
|
||||
*/
|
||||
enum qse_awk_depth_t
|
||||
{
|
||||
QSE_AWK_DEPTH_BLOCK_PARSE = (1 << 0),
|
||||
@ -869,6 +877,7 @@ enum qse_awk_gbl_id_t
|
||||
QSE_AWK_MIN_GBL_ID = QSE_AWK_GBL_ARGC,
|
||||
QSE_AWK_MAX_GBL_ID = QSE_AWK_GBL_SUBSEP
|
||||
};
|
||||
typedef enum qse_awk_gbl_id_t qse_awk_gbl_id_t;
|
||||
|
||||
/**
|
||||
* The qse_awk_val_type_t type defines types of AWK values. Each value
|
||||
@ -1411,7 +1420,7 @@ void qse_awk_rtx_close (
|
||||
|
||||
/**
|
||||
* The qse_awk_rtx_loop() function executes the BEGIN block, pattern-action
|
||||
* blocks and the END blocks in an AWk program. It returns the global return
|
||||
* blocks and the END blocks in an AWK program. It returns the global return
|
||||
* value of which the reference count must be decremented when not necessary.
|
||||
* Multiple invocations of the function for the lifetime of a runtime context
|
||||
* is not desirable.
|
||||
@ -1437,7 +1446,7 @@ qse_awk_val_t* qse_awk_rtx_loop (
|
||||
* The qse_awk_rtx_call() function invokes an AWK function. However, it is
|
||||
* not able to invoke an intrinsic function such as split().
|
||||
* The #QSE_AWK_PABLOCK option can be turned off to make illegal the BEGIN
|
||||
* block, pattern-action blocks, and the END block.
|
||||
* block, the pattern-action blocks, and the END block.
|
||||
*
|
||||
* The example shows typical usage of the function.
|
||||
* @code
|
||||
@ -1463,25 +1472,26 @@ qse_awk_val_t* qse_awk_rtx_call (
|
||||
|
||||
/**
|
||||
* The qse_awk_stopall() function aborts all active runtime contexts
|
||||
* invoked with the awk parameter.
|
||||
* associated with @a awk.
|
||||
*/
|
||||
void qse_awk_stopall (
|
||||
qse_awk_t* awk /**< awk */
|
||||
);
|
||||
|
||||
/**
|
||||
* The qse_awk_shouldstop function tests if qse_awk_rtx_stop() has been called.
|
||||
* The qse_awk_isstopreq() function tests if qse_awk_rtx_stop() has been
|
||||
* called.
|
||||
*/
|
||||
qse_bool_t qse_awk_rtx_shouldstop (
|
||||
qse_awk_rtx_t* rtx
|
||||
qse_bool_t qse_awk_rtx_isstopreq (
|
||||
qse_awk_rtx_t* rtx /**< runtime context */
|
||||
);
|
||||
|
||||
/**
|
||||
* The qse_awk_rtx_stop() function causes the active qse_awk_run() function to
|
||||
* The qse_awk_rtx_stop() function causes an active runtime context @a rtx to
|
||||
* be aborted.
|
||||
*/
|
||||
void qse_awk_rtx_stop (
|
||||
qse_awk_rtx_t* rtx
|
||||
qse_awk_rtx_t* rtx /**< runtime context */
|
||||
);
|
||||
|
||||
/**
|
||||
@ -1572,7 +1582,8 @@ int qse_awk_rtx_setofilename (
|
||||
);
|
||||
|
||||
/**
|
||||
* The qse_awk_rtx_getawk() function gets the owning awk object.
|
||||
* The qse_awk_rtx_getawk() function gets the owner of a runtime context @a rtx.
|
||||
* @return owner of a runtime context @a rtx.
|
||||
*/
|
||||
qse_awk_t* qse_awk_rtx_getawk (
|
||||
qse_awk_rtx_t* rtx /**< runtime context */
|
||||
@ -1683,8 +1694,8 @@ void qse_awk_rtx_seterror (
|
||||
* and fields ($1 to $N).
|
||||
*/
|
||||
int qse_awk_rtx_clrrec (
|
||||
qse_awk_rtx_t* rtx, /** runtime context */
|
||||
qse_bool_t skip_inrec_line
|
||||
qse_awk_rtx_t* rtx, /**< runtime context */
|
||||
qse_bool_t skip_inrec_line
|
||||
);
|
||||
|
||||
/**
|
||||
|
@ -1,19 +1,21 @@
|
||||
/*
|
||||
* $Id: std.h 277 2009-09-02 12:55:55Z hyunghwan.chung $
|
||||
* $Id: std.h 287 2009-09-15 10:01:02Z hyunghwan.chung $
|
||||
*
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
This file is part of QSE.
|
||||
|
||||
Licensed under the Apache License, Version 2.0 (the "License");
|
||||
you may not use this file except in compliance with the License.
|
||||
You may obtain a copy of the License at
|
||||
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.
|
||||
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
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.
|
||||
|
||||
Unless required by applicable law or agreed to in writing, software
|
||||
distributed under the License is distributed on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
See the License for the specific language governing permissions and
|
||||
limitations under the License.
|
||||
You should have received a copy of the GNU Lesser General Public
|
||||
License along with QSE. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#ifndef _QSE_AWK_STD_H_
|
||||
@ -29,11 +31,6 @@
|
||||
* The source script handler does not evaluate a file name of the "var=val"
|
||||
* form as an assignment expression. Instead, it just treats it as a
|
||||
* normal file name.
|
||||
*
|
||||
* @todo
|
||||
* - add code to treat a function as a value
|
||||
* - add RQ and LQ for more powerful record splitting
|
||||
* - improve performance in qse_awk_rtx_readio() if RS is logner than 2 chars.
|
||||
*/
|
||||
|
||||
/**
|
||||
|
@ -1,19 +1,21 @@
|
||||
/*
|
||||
* $Id: chr.h 127 2009-05-07 13:15:04Z hyunghwan.chung $
|
||||
* $Id: chr.h 287 2009-09-15 10:01:02Z hyunghwan.chung $
|
||||
*
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
This file is part of QSE.
|
||||
|
||||
Licensed under the Apache License, Version 2.0 (the "License");
|
||||
you may not use this file except in compliance with the License.
|
||||
You may obtain a copy of the License at
|
||||
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.
|
||||
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
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.
|
||||
|
||||
Unless required by applicable law or agreed to in writing, software
|
||||
distributed under the License is distributed on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
See the License for the specific language governing permissions and
|
||||
limitations under the License.
|
||||
You should have received a copy of the GNU Lesser General Public
|
||||
License along with QSE. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#ifndef _QSE_CMN_CHR_H_
|
||||
|
@ -1,19 +1,21 @@
|
||||
/*
|
||||
* $Id: dll.h 75 2009-02-22 14:10:34Z hyunghwan.chung $
|
||||
* $Id: dll.h 287 2009-09-15 10:01:02Z hyunghwan.chung $
|
||||
*
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
This file is part of QSE.
|
||||
|
||||
Licensed under the Apache License, Version 2.0 (the "License");
|
||||
you may not use this file except in compliance with the License.
|
||||
You may obtain a copy of the License at
|
||||
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.
|
||||
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
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.
|
||||
|
||||
Unless required by applicable law or agreed to in writing, software
|
||||
distributed under the License is distributed on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
See the License for the specific language governing permissions and
|
||||
limitations under the License.
|
||||
You should have received a copy of the GNU Lesser General Public
|
||||
License along with QSE. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#ifndef _QSE_CMN_DLL_H_
|
||||
|
@ -1,19 +1,21 @@
|
||||
/*
|
||||
* $Id: fio.h 204 2009-06-18 12:08:06Z hyunghwan.chung $
|
||||
* $Id: fio.h 287 2009-09-15 10:01:02Z hyunghwan.chung $
|
||||
*
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
This file is part of QSE.
|
||||
|
||||
Licensed under the Apache License, Version 2.0 (the "License");
|
||||
you may not use this file except in compliance with the License.
|
||||
You may obtain a copy of the License at
|
||||
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.
|
||||
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
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.
|
||||
|
||||
Unless required by applicable law or agreed to in writing, software
|
||||
distributed under the License is distributed on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
See the License for the specific language governing permissions and
|
||||
limitations under the License.
|
||||
You should have received a copy of the GNU Lesser General Public
|
||||
License along with QSE. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#ifndef _QSE_CMN_FIO_H_
|
||||
|
@ -1,19 +1,21 @@
|
||||
/*
|
||||
* $Id: lda.h 75 2009-02-22 14:10:34Z hyunghwan.chung $
|
||||
* $Id: lda.h 287 2009-09-15 10:01:02Z hyunghwan.chung $
|
||||
*
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
This file is part of QSE.
|
||||
|
||||
Licensed under the Apache License, Version 2.0 (the "License");
|
||||
you may not use this file except in compliance with the License.
|
||||
You may obtain a copy of the License at
|
||||
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.
|
||||
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
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.
|
||||
|
||||
Unless required by applicable law or agreed to in writing, software
|
||||
distributed under the License is distributed on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
See the License for the specific language governing permissions and
|
||||
limitations under the License.
|
||||
You should have received a copy of the GNU Lesser General Public
|
||||
License along with QSE. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#ifndef _QSE_CMN_LDA_H_
|
||||
|
@ -1,19 +1,21 @@
|
||||
/*
|
||||
* $Id$
|
||||
*
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
This file is part of QSE.
|
||||
|
||||
Licensed under the Apache License, Version 2.0 (the "License");
|
||||
you may not use this file except in compliance with the License.
|
||||
You may obtain a copy of the License at
|
||||
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.
|
||||
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
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.
|
||||
|
||||
Unless required by applicable law or agreed to in writing, software
|
||||
distributed under the License is distributed on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
See the License for the specific language governing permissions and
|
||||
limitations under the License.
|
||||
You should have received a copy of the GNU Lesser General Public
|
||||
License along with QSE. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#ifndef _QSE_CMN_MAIN_H_
|
||||
|
@ -1,19 +1,21 @@
|
||||
/*
|
||||
* $Id: map.h 248 2009-08-06 08:27:14Z hyunghwan.chung $
|
||||
* $Id: map.h 287 2009-09-15 10:01:02Z hyunghwan.chung $
|
||||
*
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
This file is part of QSE.
|
||||
|
||||
Licensed under the Apache License, Version 2.0 (the "License");
|
||||
you may not use this file except in compliance with the License.
|
||||
You may obtain a copy of the License at
|
||||
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.
|
||||
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
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.
|
||||
|
||||
Unless required by applicable law or agreed to in writing, software
|
||||
distributed under the License is distributed on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
See the License for the specific language governing permissions and
|
||||
limitations under the License.
|
||||
You should have received a copy of the GNU Lesser General Public
|
||||
License along with QSE. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#ifndef _QSE_CMN_MAP_H_
|
||||
|
@ -1,19 +1,21 @@
|
||||
/*
|
||||
* $Id: mem.h 186 2009-06-06 13:42:57Z hyunghwan.chung $
|
||||
* $Id: mem.h 287 2009-09-15 10:01:02Z hyunghwan.chung $
|
||||
*
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
This file is part of QSE.
|
||||
|
||||
Licensed under the Apache License, Version 2.0 (the "License");
|
||||
you may not use this file except in compliance with the License.
|
||||
You may obtain a copy of the License at
|
||||
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.
|
||||
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
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.
|
||||
|
||||
Unless required by applicable law or agreed to in writing, software
|
||||
distributed under the License is distributed on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
See the License for the specific language governing permissions and
|
||||
limitations under the License.
|
||||
You should have received a copy of the GNU Lesser General Public
|
||||
License along with QSE. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#ifndef _QSE_CMN_MEM_H_
|
||||
|
@ -1,3 +1,23 @@
|
||||
/*
|
||||
* $Id$
|
||||
*
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
This file is part of QSE.
|
||||
|
||||
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.
|
||||
|
||||
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.
|
||||
|
||||
You should have received a copy of the GNU Lesser General Public
|
||||
License along with QSE. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#ifndef _QSE_CMN_MISC_H_
|
||||
#define _QSE_CMN_MISC_H_
|
||||
|
||||
|
@ -1,19 +1,21 @@
|
||||
/*
|
||||
* $Id: opt.h 190 2009-06-07 12:11:56Z hyunghwan.chung $
|
||||
* $Id: opt.h 287 2009-09-15 10:01:02Z hyunghwan.chung $
|
||||
*
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
This file is part of QSE.
|
||||
|
||||
Licensed under the Apache License, Version 2.0 (the "License");
|
||||
you may not use this file except in compliance with the License.
|
||||
You may obtain a copy of the License at
|
||||
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.
|
||||
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
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.
|
||||
|
||||
Unless required by applicable law or agreed to in writing, software
|
||||
distributed under the License is distributed on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
See the License for the specific language governing permissions and
|
||||
limitations under the License.
|
||||
You should have received a copy of the GNU Lesser General Public
|
||||
License along with QSE. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#ifndef _QSE_CMN_OPT_H_
|
||||
|
@ -1,19 +1,21 @@
|
||||
/*
|
||||
* $Id: pio.h 277 2009-09-02 12:55:55Z hyunghwan.chung $
|
||||
* $Id: pio.h 287 2009-09-15 10:01:02Z hyunghwan.chung $
|
||||
*
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
This file is part of QSE.
|
||||
|
||||
Licensed under the Apache License, Version 2.0 (the "License");
|
||||
you may not use this file except in compliance with the License.
|
||||
You may obtain a copy of the License at
|
||||
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.
|
||||
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
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.
|
||||
|
||||
Unless required by applicable law or agreed to in writing, software
|
||||
distributed under the License is distributed on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
See the License for the specific language governing permissions and
|
||||
limitapions under the License.
|
||||
You should have received a copy of the GNU Lesser General Public
|
||||
License along with QSE. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#ifndef _QSE_CMN_PIO_H_
|
||||
|
@ -1,19 +1,21 @@
|
||||
/*
|
||||
* $Id: rex.h 236 2009-07-16 08:27:53Z hyunghwan.chung $
|
||||
* $Id: rex.h 287 2009-09-15 10:01:02Z hyunghwan.chung $
|
||||
*
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
This file is part of QSE.
|
||||
|
||||
Licensed under the Apache License, Version 2.0 (the "License");
|
||||
you may not use this file except in compliance with the License.
|
||||
You may obtain a copy of the License at
|
||||
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.
|
||||
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
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.
|
||||
|
||||
Unless required by applicable law or agreed to in writing, software
|
||||
distributed under the License is distributed on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
See the License for the specific language governing permissions and
|
||||
limitations under the License.
|
||||
You should have received a copy of the GNU Lesser General Public
|
||||
License along with QSE. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#ifndef _QSE_CMN_REX_H_
|
||||
|
@ -1,19 +1,21 @@
|
||||
/*
|
||||
* $Id: sio.h 182 2009-06-03 21:50:32Z hyunghwan.chung $
|
||||
* $Id: sio.h 287 2009-09-15 10:01:02Z hyunghwan.chung $
|
||||
*
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
This file is part of QSE.
|
||||
|
||||
Licensed under the Apache License, Version 2.0 (the "License");
|
||||
you may not use this file except in compliance with the License.
|
||||
You may obtain a copy of the License at
|
||||
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.
|
||||
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
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.
|
||||
|
||||
Unless required by applicable law or agreed to in writing, software
|
||||
distributed under the License is distributed on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
See the License for the specific language governing permissions and
|
||||
limitations under the License.
|
||||
You should have received a copy of the GNU Lesser General Public
|
||||
License along with QSE. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#ifndef _QSE_CMN_SIO_H_
|
||||
|
@ -1,19 +1,21 @@
|
||||
/*
|
||||
* $Id: sll.h 277 2009-09-02 12:55:55Z hyunghwan.chung $
|
||||
* $Id: sll.h 287 2009-09-15 10:01:02Z hyunghwan.chung $
|
||||
*
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
This file is part of QSE.
|
||||
|
||||
Licensed under the Apache License, Version 2.0 (the "License");
|
||||
you may not use this file except in compliance with the License.
|
||||
You may obtain a copy of the License at
|
||||
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.
|
||||
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
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.
|
||||
|
||||
Unless required by applicable law or agreed to in writing, software
|
||||
distributed under the License is distributed on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
See the License for the specific language governing permissions and
|
||||
limitations under the License.
|
||||
You should have received a copy of the GNU Lesser General Public
|
||||
License along with QSE. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#ifndef _QSE_CMN_SLL_H_
|
||||
|
@ -1,19 +1,21 @@
|
||||
/*
|
||||
* $Id: stdio.h 419 2008-10-13 11:32:58Z baconevi $
|
||||
*
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
This file is part of QSE.
|
||||
|
||||
Licensed under the Apache License, Version 2.0 (the "License");
|
||||
you may not use this file except in compliance with the License.
|
||||
You may obtain a copy of the License at
|
||||
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.
|
||||
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
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.
|
||||
|
||||
Unless required by applicable law or agreed to in writing, software
|
||||
distributed under the License is distributed on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
See the License for the specific language governing permissions and
|
||||
limitations under the License.
|
||||
You should have received a copy of the GNU Lesser General Public
|
||||
License along with QSE. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#ifndef _QSE_CMN_STDIO_H_
|
||||
|
@ -1,19 +1,21 @@
|
||||
/*
|
||||
* $Id: str.h 277 2009-09-02 12:55:55Z hyunghwan.chung $
|
||||
* $Id: str.h 287 2009-09-15 10:01:02Z hyunghwan.chung $
|
||||
*
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
This file is part of QSE.
|
||||
|
||||
Licensed under the Apache License, Version 2.0 (the "License");
|
||||
you may not use this file except in compliance with the License.
|
||||
You may obtain a copy of the License at
|
||||
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.
|
||||
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
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.
|
||||
|
||||
Unless required by applicable law or agreed to in writing, software
|
||||
distributed under the License is distributed on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
See the License for the specific language governing permissions and
|
||||
limitations under the License.
|
||||
You should have received a copy of the GNU Lesser General Public
|
||||
License along with QSE. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#ifndef _QSE_CMN_STR_H_
|
||||
|
@ -1,19 +1,21 @@
|
||||
/*
|
||||
* $Id: time.h 187 2009-06-07 05:03:44Z hyunghwan.chung $
|
||||
* $Id: time.h 287 2009-09-15 10:01:02Z hyunghwan.chung $
|
||||
*
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
This file is part of QSE.
|
||||
|
||||
Licensed under the Apache License, Version 2.0 (the "License");
|
||||
you may not use this file except in compliance with the License.
|
||||
You may obtain a copy of the License at
|
||||
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.
|
||||
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
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.
|
||||
|
||||
Unless required by applicable law or agreed to in writing, software
|
||||
distributed under the License is distributed on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
See the License for the specific language governing permissions and
|
||||
limitations under the License.
|
||||
You should have received a copy of the GNU Lesser General Public
|
||||
License along with QSE. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#ifndef _QSE_CMN_TIME_H_
|
||||
|
@ -1,19 +1,21 @@
|
||||
/*
|
||||
* $Id: tio.h 75 2009-02-22 14:10:34Z hyunghwan.chung $
|
||||
* $Id: tio.h 287 2009-09-15 10:01:02Z hyunghwan.chung $
|
||||
*
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
This file is part of QSE.
|
||||
|
||||
Licensed under the Apache License, Version 2.0 (the "License");
|
||||
you may not use this file except in compliance with the License.
|
||||
You may obtain a copy of the License at
|
||||
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.
|
||||
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
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.
|
||||
|
||||
Unless required by applicable law or agreed to in writing, software
|
||||
distributed under the License is distributed on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
See the License for the specific language governing permissions and
|
||||
limitations under the License.
|
||||
You should have received a copy of the GNU Lesser General Public
|
||||
License along with QSE. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#ifndef _QSE_CMN_TIO_H_
|
||||
|
@ -1,7 +1,21 @@
|
||||
/*
|
||||
* $Id: conf_msw.h 75 2009-02-22 14:10:34Z hyunghwan.chung $
|
||||
* $Id: conf_msw.h 287 2009-09-15 10:01:02Z hyunghwan.chung $
|
||||
*
|
||||
* {License}
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
This file is part of QSE.
|
||||
|
||||
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.
|
||||
|
||||
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.
|
||||
|
||||
You should have received a copy of the GNU Lesser General Public
|
||||
License along with QSE. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
/*
|
||||
|
@ -1,7 +1,21 @@
|
||||
/*
|
||||
* $Id: conf_vms.h 75 2009-02-22 14:10:34Z hyunghwan.chung $
|
||||
* $Id: conf_vms.h 287 2009-09-15 10:01:02Z hyunghwan.chung $
|
||||
*
|
||||
* {License}
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
This file is part of QSE.
|
||||
|
||||
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.
|
||||
|
||||
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.
|
||||
|
||||
You should have received a copy of the GNU Lesser General Public
|
||||
License along with QSE. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
/* all of vax, alpha, ia64 are in the little endian. */
|
||||
|
@ -1,19 +1,21 @@
|
||||
/*
|
||||
* $Id: lsp.h 183 2008-06-03 08:18:55Z baconevi $
|
||||
*
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
This file is part of QSE.
|
||||
|
||||
Licensed under the Apache License, Version 2.0 (the "License");
|
||||
you may not use this file except in compliance with the License.
|
||||
You may obtain a copy of the License at
|
||||
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.
|
||||
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
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.
|
||||
|
||||
Unless required by applicable law or agreed to in writing, software
|
||||
distributed under the License is distributed on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
See the License for the specific language governing permissions and
|
||||
limitations under the License.
|
||||
You should have received a copy of the GNU Lesser General Public
|
||||
License along with QSE. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#ifndef _QSE_LSP_LSP_H_
|
||||
|
@ -1,19 +1,21 @@
|
||||
/*
|
||||
* $Id: macros.h 212 2009-06-25 07:39:27Z hyunghwan.chung $
|
||||
* $Id: macros.h 287 2009-09-15 10:01:02Z hyunghwan.chung $
|
||||
*
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
This file is part of QSE.
|
||||
|
||||
Licensed under the Apache License, Version 2.0 (the "License");
|
||||
you may not use this file except in compliance with the License.
|
||||
You may obtain a copy of the License at
|
||||
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.
|
||||
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
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.
|
||||
|
||||
Unless required by applicable law or agreed to in writing, software
|
||||
distributed under the License is distributed on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
See the License for the specific language governing permissions and
|
||||
limitations under the License.
|
||||
You should have received a copy of the GNU Lesser General Public
|
||||
License along with QSE. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#ifndef _QSE_MACROS_H_
|
||||
|
@ -1,19 +1,21 @@
|
||||
/*
|
||||
* $Id: pack1.h 75 2009-02-22 14:10:34Z hyunghwan.chung $
|
||||
* $Id: pack1.h 287 2009-09-15 10:01:02Z hyunghwan.chung $
|
||||
*
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
This file is part of QSE.
|
||||
|
||||
Licensed under the Apache License, Version 2.0 (the "License");
|
||||
you may not use this file except in compliance with the License.
|
||||
You may obtain a copy of the License at
|
||||
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.
|
||||
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
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.
|
||||
|
||||
Unless required by applicable law or agreed to in writing, software
|
||||
distributed under the License is distributed on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
See the License for the specific language governing permissions and
|
||||
limitations under the License.
|
||||
You should have received a copy of the GNU Lesser General Public
|
||||
License along with QSE. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#if defined(__GNUC__)
|
||||
|
@ -1,19 +1,21 @@
|
||||
/*
|
||||
* $Id: pack2.h 75 2009-02-22 14:10:34Z hyunghwan.chung $
|
||||
* $Id: pack2.h 287 2009-09-15 10:01:02Z hyunghwan.chung $
|
||||
*
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
This file is part of QSE.
|
||||
|
||||
Licensed under the Apache License, Version 2.0 (the "License");
|
||||
you may not use this file except in compliance with the License.
|
||||
You may obtain a copy of the License at
|
||||
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.
|
||||
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
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.
|
||||
|
||||
Unless required by applicable law or agreed to in writing, software
|
||||
distributed under the License is distributed on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
See the License for the specific language governing permissions and
|
||||
limitations under the License.
|
||||
You should have received a copy of the GNU Lesser General Public
|
||||
License along with QSE. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#if defined(__GNUC__)
|
||||
|
@ -1,19 +1,21 @@
|
||||
/*
|
||||
* $Id: Sed.hpp 280 2009-09-07 13:34:49Z hyunghwan.chung $
|
||||
* $Id: Sed.hpp 287 2009-09-15 10:01:02Z hyunghwan.chung $
|
||||
*
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
This file is part of QSE.
|
||||
|
||||
Licensed under the Apache License, Version 2.0 (the "License");
|
||||
you may not use this file except in compliance with the License.
|
||||
You may obtain a copy of the License at
|
||||
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.
|
||||
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
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.
|
||||
|
||||
Unless required by applicable law or agreed to in writing, software
|
||||
distributed under the License is distributed on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
See the License for the specific language governing permissions and
|
||||
limitations under the License.
|
||||
You should have received a copy of the GNU Lesser General Public
|
||||
License along with QSE. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#ifndef _QSE_SED_SED_HPP_
|
||||
@ -31,7 +33,7 @@ QSE_BEGIN_NAMESPACE(QSE)
|
||||
/////////////////////////////////
|
||||
|
||||
/**
|
||||
* The Sed class implements a stream editor.
|
||||
* The Sed class implements a stream editor by wrapping around #qse_sed_t.
|
||||
*/
|
||||
class Sed: public Mmgr
|
||||
{
|
||||
@ -53,110 +55,113 @@ public:
|
||||
/// The depth_t type redefines an depth IDs
|
||||
typedef qse_sed_depth_t depth_t;
|
||||
|
||||
/**
|
||||
* The Sed() function creates an uninitialized stream editor.
|
||||
*/
|
||||
///
|
||||
/// The Sed() function creates an uninitialized stream editor.
|
||||
///
|
||||
Sed (): sed (QSE_NULL), dflerrstr (QSE_NULL) {}
|
||||
|
||||
/**
|
||||
* The ~Sed() function destroys a stream editor.
|
||||
* @note The close() function is not called by this destructor.
|
||||
* To avoid resource leaks, You should call close() before
|
||||
* a stream editor is destroyed if it has been initialized
|
||||
* with open().
|
||||
*/
|
||||
///
|
||||
/// The ~Sed() function destroys a stream editor.
|
||||
/// @note The close() function is not called by this destructor.
|
||||
/// To avoid resource leaks, You should call close() before
|
||||
/// a stream editor is destroyed if it has been initialized
|
||||
/// with open().
|
||||
///
|
||||
~Sed () {}
|
||||
|
||||
/**
|
||||
* The open() function initializes a stream editor and makes it
|
||||
* ready for subsequent use.
|
||||
* @return 0 on success, -1 on failure.
|
||||
*/
|
||||
///
|
||||
/// The open() function initializes a stream editor and makes it
|
||||
/// ready for subsequent use.
|
||||
/// @return 0 on success, -1 on failure.
|
||||
///
|
||||
int open ();
|
||||
|
||||
/**
|
||||
* The close() function finalizes a stream editor.
|
||||
*/
|
||||
///
|
||||
/// The close() function finalizes a stream editor.
|
||||
///
|
||||
void close ();
|
||||
|
||||
/**
|
||||
* The compile() function compiles a null-terminated string pointed
|
||||
* to by @a sptr.
|
||||
* @return 0 on success, -1 on failure
|
||||
*/
|
||||
///
|
||||
/// The compile() function compiles a null-terminated string pointed
|
||||
/// to by @a sptr.
|
||||
/// @return 0 on success, -1 on failure
|
||||
///
|
||||
int compile (
|
||||
const char_t* sptr ///< a pointer to a null-terminated string
|
||||
);
|
||||
|
||||
/**
|
||||
* The compile() function compiles a string pointed to by @a sptr
|
||||
* and of the length @a slen.
|
||||
* @return 0 on success, -1 on failure
|
||||
*/
|
||||
///
|
||||
/// The compile() function compiles a string pointed to by @a sptr
|
||||
/// and of the length @a slen.
|
||||
/// @return 0 on success, -1 on failure
|
||||
///
|
||||
int compile (
|
||||
const char_t* sptr, ///< a pointer to a string
|
||||
size_t slen ///< the number of characters in the string
|
||||
);
|
||||
|
||||
/**
|
||||
* The execute() function executes compiled commands over the IO
|
||||
* streams defined through IO handlers
|
||||
* @return 0 on success, -1 on failure
|
||||
*/
|
||||
///
|
||||
/// The execute() function executes compiled commands over the I/O
|
||||
/// streams defined through I/O handlers
|
||||
/// @return 0 on success, -1 on failure
|
||||
///
|
||||
int execute ();
|
||||
|
||||
/**
|
||||
* The getOption() function gets the current options.
|
||||
* @return current option code
|
||||
*/
|
||||
///
|
||||
/// The getOption() function gets the current options.
|
||||
/// @return 0 or current options ORed of #option_t enumerators.
|
||||
///
|
||||
int getOption () const;
|
||||
|
||||
/**
|
||||
* The setOption() function sets options for a stream editor.
|
||||
* The option code @a opt is 0 or OR'ed of #option_t enumerators.
|
||||
*/
|
||||
///
|
||||
/// The setOption() function sets options for a stream editor.
|
||||
/// The option code @a opt is 0 or OR'ed of #option_t enumerators.
|
||||
///
|
||||
void setOption (
|
||||
int opt ///< option code
|
||||
);
|
||||
|
||||
/**
|
||||
* The getMaxDepth() function gets the maximum processing depth.
|
||||
*/
|
||||
size_t getMaxDepth (depth_t id) const;
|
||||
///
|
||||
/// The getMaxDepth() function gets the maximum processing depth for
|
||||
/// an operation type identified by @a id.
|
||||
///
|
||||
size_t getMaxDepth (
|
||||
depth_t id ///< operation type
|
||||
) const;
|
||||
|
||||
/**
|
||||
* The setMaxDepth() function gets the maximum processing depth.
|
||||
*/
|
||||
///
|
||||
/// The setMaxDepth() function gets the maximum processing depth.
|
||||
///
|
||||
void setMaxDepth (
|
||||
int ids, ///< 0 or a number OR'ed of depth_t values
|
||||
size_t depth ///< 0 maximum depth
|
||||
);
|
||||
|
||||
/**
|
||||
* The getErrorMessage() function gets the description of the last
|
||||
* error occurred. It returns an empty string if the stream editor
|
||||
* has not been initialized with the open() function.
|
||||
*/
|
||||
///
|
||||
/// The getErrorMessage() function gets the description of the last
|
||||
/// error occurred. It returns an empty string if the stream editor
|
||||
/// has not been initialized with the open() function.
|
||||
///
|
||||
const char_t* getErrorMessage() const;
|
||||
|
||||
/**
|
||||
* The getErrorLocation() function gets the location where
|
||||
* the last error occurred. The line and the column of the ::loc_t
|
||||
* structure retruend are 0 if the stream editor has not been
|
||||
* initialized with the open() function.
|
||||
*/
|
||||
///
|
||||
/// The getErrorLocation() function gets the location where
|
||||
/// the last error occurred. The line and the column of the #loc_t
|
||||
/// structure retruend are 0 if the stream editor has not been
|
||||
/// initialized with the open() function.
|
||||
///
|
||||
loc_t getErrorLocation () const;
|
||||
|
||||
/**
|
||||
* The getErrorNumber() function gets the number of the last
|
||||
* error occurred. It returns QSE_SED_ENOERR if the stream editor
|
||||
* has not been initialized with the open() function.
|
||||
*/
|
||||
///
|
||||
/// The getErrorNumber() function gets the number of the last
|
||||
/// error occurred. It returns QSE_SED_ENOERR if the stream editor
|
||||
/// has not been initialized with the open() function.
|
||||
///
|
||||
errnum_t getErrorNumber () const;
|
||||
|
||||
/**
|
||||
* The setError() function sets information on an error occurred.
|
||||
*/
|
||||
///
|
||||
/// The setError() function sets information on an error occurred.
|
||||
///
|
||||
void setError (
|
||||
errnum_t num, ///< error number
|
||||
const cstr_t* args = QSE_NULL, ///< string array for formatting
|
||||
@ -164,32 +169,32 @@ public:
|
||||
const loc_t* loc = QSE_NULL ///< error location
|
||||
);
|
||||
|
||||
/**
|
||||
* The getConsoleLine() function returns the current line
|
||||
* number from an input console.
|
||||
* @return current line number
|
||||
*/
|
||||
///
|
||||
/// The getConsoleLine() function returns the current line
|
||||
/// number from an input console.
|
||||
/// @return current line number
|
||||
///
|
||||
size_t getConsoleLine ();
|
||||
|
||||
/**
|
||||
* The setConsoleLine() function changes the current line
|
||||
* number from an input console.
|
||||
*/
|
||||
///
|
||||
/// The setConsoleLine() function changes the current line
|
||||
/// number from an input console.
|
||||
///
|
||||
void setConsoleLine (
|
||||
size_t num ///< a line number
|
||||
);
|
||||
|
||||
protected:
|
||||
/**
|
||||
* The IOBase class is a base class for IO operation. It wraps around
|
||||
* the primitive Sed::io_arg_t type and exposes relevant information to
|
||||
* an IO handler
|
||||
*/
|
||||
///
|
||||
/// The IOBase class is a base class for I/O operations. It wraps around
|
||||
/// the primitive #io_arg_t type and exposes relevant information to
|
||||
/// an I/O handler.
|
||||
///
|
||||
class IOBase
|
||||
{
|
||||
public:
|
||||
/**
|
||||
* The Mode enumerator defines IO operation modes.
|
||||
* The Mode enumerator defines I/O operation modes.
|
||||
*/
|
||||
enum Mode
|
||||
{
|
||||
@ -202,33 +207,33 @@ protected:
|
||||
arg(arg), mode (mode) {}
|
||||
|
||||
public:
|
||||
/**
|
||||
* The getHandle() function gets an IO handle set with the
|
||||
* setHandle() function. Once set, it is maintained until
|
||||
* an assoicated IO handler closes it or changes it with
|
||||
* another call to setHandle().
|
||||
*/
|
||||
///
|
||||
/// The getHandle() function gets an I/O handle set with the
|
||||
/// setHandle() function. Once set, it is maintained until
|
||||
/// an assoicated I/O handler closes it or changes it with
|
||||
/// another call to setHandle().
|
||||
///
|
||||
const void* getHandle () const
|
||||
{
|
||||
return arg->handle;
|
||||
}
|
||||
|
||||
/**
|
||||
* The setHandle() function sets an IO handle and is typically
|
||||
* called in stream opening functions such as Sed::openConsole()
|
||||
* and Sed::openFile(). You can get the handle with the
|
||||
* getHandle() function as needed.
|
||||
*/
|
||||
///
|
||||
/// The setHandle() function sets an I/O handle and is typically
|
||||
/// called in stream opening functions such as openConsole()
|
||||
/// and openFile(). You can get the handle with getHandle()
|
||||
// as needed.
|
||||
///
|
||||
void setHandle (void* handle)
|
||||
{
|
||||
arg->handle = handle;
|
||||
}
|
||||
|
||||
/**
|
||||
* The getMode() function gets the IO operation mode requested.
|
||||
* A stream opening function can inspect the mode requested and
|
||||
* open a stream properly
|
||||
*/
|
||||
///
|
||||
/// The getMode() function gets the I/O mode requested.
|
||||
/// A stream opening function can inspect the mode requested and
|
||||
/// open a stream properly
|
||||
///
|
||||
Mode getMode ()
|
||||
{
|
||||
return this->mode;
|
||||
@ -240,10 +245,10 @@ protected:
|
||||
Mode mode;
|
||||
};
|
||||
|
||||
/**
|
||||
* The Console class inherits the IO class and provides functionality
|
||||
* for console IO operations.
|
||||
*/
|
||||
///
|
||||
/// The Console class inherits the IOBase class and provides
|
||||
/// functionality for console I/O operations.
|
||||
///
|
||||
class Console: public IOBase
|
||||
{
|
||||
protected:
|
||||
@ -252,10 +257,10 @@ protected:
|
||||
IOBase (arg, mode) {}
|
||||
};
|
||||
|
||||
/**
|
||||
* The File class inherits the IO class and provides functionality
|
||||
* for file IO operations.
|
||||
*/
|
||||
///
|
||||
/// The File class inherits the IOBase class and provides functionality
|
||||
/// for file I/O operations.
|
||||
///
|
||||
class File: public IOBase
|
||||
{
|
||||
protected:
|
||||
@ -264,130 +269,130 @@ protected:
|
||||
IOBase (arg, mode) {}
|
||||
|
||||
public:
|
||||
/**
|
||||
* The getName() function gets the file path requested.
|
||||
* You can call this function from the openFile() function
|
||||
* to determine a file to open.
|
||||
*/
|
||||
///
|
||||
/// The getName() function gets the file path requested.
|
||||
/// You can call this function from the openFile() function
|
||||
/// to determine a file to open.
|
||||
///
|
||||
const char_t* getName () const
|
||||
{
|
||||
return arg->path;
|
||||
}
|
||||
};
|
||||
|
||||
/**
|
||||
* The openConsole() function should be implemented by a subclass
|
||||
* to open a console. It can get the mode requested by invoking
|
||||
* the Console::getMode() function over the console object @a io.
|
||||
*
|
||||
* When it comes to the meaning of the return value, 0 may look
|
||||
* a bit tricky. Easygoers can just return 1 on success and never
|
||||
* return 0 from openConsole().
|
||||
* - If 0 is returned for a Console::READ console, the execute()
|
||||
* function returns success after having calle closeConsole() as it
|
||||
* has opened a console but has reached EOF.
|
||||
* - If 0 is returned for a Console::WRITE console and there are any
|
||||
* following writeConsole() requests, the execute() function
|
||||
* returns failure after having called closeConsole() as it cannot
|
||||
* write further on EOF.
|
||||
*
|
||||
* @return -1 on failure, 1 on success, 0 on success but reached EOF.
|
||||
*/
|
||||
///
|
||||
/// The openConsole() function should be implemented by a subclass
|
||||
/// to open a console. It can get the mode requested by invoking
|
||||
/// the Console::getMode() function over the console object @a io.
|
||||
///
|
||||
/// When it comes to the meaning of the return value, 0 may look
|
||||
/// a bit tricky. Easygoers can just return 1 on success and never
|
||||
/// return 0 from openConsole().
|
||||
/// - If 0 is returned for a Console::READ console, the execute()
|
||||
/// function returns success after having calle closeConsole() as it
|
||||
/// has opened a console but has reached EOF.
|
||||
/// - If 0 is returned for a Console::WRITE console and there are any
|
||||
/// following writeConsole() requests, the execute() function
|
||||
/// returns failure after having called closeConsole() as it cannot
|
||||
/// write further on EOF.
|
||||
///
|
||||
/// @return -1 on failure, 1 on success, 0 on success but reached EOF.
|
||||
///
|
||||
virtual int openConsole (
|
||||
Console& io ///< a console object
|
||||
) = 0;
|
||||
|
||||
/**
|
||||
* The closeConsole() function should be implemented by a subclass
|
||||
* to close a console.
|
||||
*/
|
||||
///
|
||||
/// The closeConsole() function should be implemented by a subclass
|
||||
/// to close a console.
|
||||
///
|
||||
virtual int closeConsole (
|
||||
Console& io ///< a console object
|
||||
) = 0;
|
||||
|
||||
/**
|
||||
* The readConsole() function should be implemented by a subclass
|
||||
* to read from a console. It should fill the memory area pointed to
|
||||
* by @a buf, but at most \a len characters.
|
||||
* @return the number of characters read on success,
|
||||
* 0 on EOF, -1 on failure
|
||||
*/
|
||||
///
|
||||
/// The readConsole() function should be implemented by a subclass
|
||||
/// to read from a console. It should fill the memory area pointed to
|
||||
/// by @a buf, but at most \a len characters.
|
||||
/// @return the number of characters read on success,
|
||||
/// 0 on EOF, -1 on failure
|
||||
///
|
||||
virtual ssize_t readConsole (
|
||||
Console& io, ///< a console object
|
||||
char_t* buf, ///< a buffer pointer
|
||||
size_t len ///< the size of a buffer
|
||||
) = 0;
|
||||
|
||||
/**
|
||||
* The writeConsole() function should be implemented by a subclass
|
||||
* to write to a console. It should write up to @a len characters
|
||||
* from the memory are pointed to by @a data.
|
||||
* @return the number of characters written on success
|
||||
* 0 on EOF, -1 on failure
|
||||
* @note The number of characters written may be less than @a len.
|
||||
* But the return value 0 causes execute() to fail as
|
||||
* writeConsole() is called when there are data to write and
|
||||
* it has indicated EOF.
|
||||
*/
|
||||
///
|
||||
/// The writeConsole() function should be implemented by a subclass
|
||||
/// to write to a console. It should write up to @a len characters
|
||||
/// from the memory are pointed to by @a data.
|
||||
/// @return the number of characters written on success
|
||||
/// 0 on EOF, -1 on failure
|
||||
/// @note The number of characters written may be less than @a len.
|
||||
/// But the return value 0 causes execute() to fail as
|
||||
/// writeConsole() is called when there are data to write and
|
||||
/// it has indicated EOF.
|
||||
///
|
||||
virtual ssize_t writeConsole (
|
||||
Console& io, ///< a console object
|
||||
const char_t* data, ///< a pointer to data to write
|
||||
size_t len ///< the length of data
|
||||
) = 0;
|
||||
|
||||
/**
|
||||
* The openFile() function should be implemented by a subclass
|
||||
* to open a file. It can get the mode requested by invoking
|
||||
* the File::getMode() function over the file object @a io.
|
||||
* @return -1 on failure, 1 on success, 0 on success but reached EOF.
|
||||
*/
|
||||
///
|
||||
/// The openFile() function should be implemented by a subclass
|
||||
/// to open a file. It can get the mode requested by invoking
|
||||
/// the File::getMode() function over the file object @a io.
|
||||
/// @return -1 on failure, 1 on success, 0 on success but reached EOF.
|
||||
///
|
||||
virtual int openFile (
|
||||
File& io ///< a file object
|
||||
) = 0;
|
||||
|
||||
/**
|
||||
* The closeFile() function should be implemented by a subclass
|
||||
* to close a file.
|
||||
*/
|
||||
///
|
||||
/// The closeFile() function should be implemented by a subclass
|
||||
/// to close a file.
|
||||
///
|
||||
virtual int closeFile (
|
||||
File& io ///< a file object
|
||||
) = 0;
|
||||
|
||||
/**
|
||||
* The readFile() function should be implemented by a subclass
|
||||
* to read from a file. It should fill the memory area pointed to
|
||||
* by @a buf, but at most \a len characters.
|
||||
* @return the number of characters read on success,
|
||||
* 0 on EOF, -1 on failure
|
||||
*/
|
||||
///
|
||||
/// The readFile() function should be implemented by a subclass
|
||||
/// to read from a file. It should fill the memory area pointed to
|
||||
/// by @a buf, but at most \a len characters.
|
||||
/// @return the number of characters read on success,
|
||||
/// 0 on EOF, -1 on failure
|
||||
///
|
||||
virtual ssize_t readFile (
|
||||
File& io, ///< a file object
|
||||
char_t* buf, ///< a buffer pointer
|
||||
size_t len ///< the size of a buffer
|
||||
) = 0;
|
||||
|
||||
/**
|
||||
* The writeFile() function should be implemented by a subclass
|
||||
* to write to a file. It should write up to @a len characters
|
||||
* from the memory are pointed to by @a data.
|
||||
* @return the number of characters written on success
|
||||
* 0 on EOF, -1 on failure
|
||||
* @note The number of characters written may be less than @a len.
|
||||
* But the return value 0 causes execute() to fail as
|
||||
* writeFile() is called when there are data to write and
|
||||
* it has indicated EOF.
|
||||
*/
|
||||
///
|
||||
/// The writeFile() function should be implemented by a subclass
|
||||
/// to write to a file. It should write up to @a len characters
|
||||
/// from the memory are pointed to by @a data.
|
||||
/// @return the number of characters written on success
|
||||
/// 0 on EOF, -1 on failure
|
||||
/// @note The number of characters written may be less than @a len.
|
||||
/// But the return value 0 causes execute() to fail as
|
||||
/// writeFile() is called when there are data to write and
|
||||
/// it has indicated EOF.
|
||||
///
|
||||
virtual ssize_t writeFile (
|
||||
File& io, ///< a file object
|
||||
const char_t* data, ///< a pointer to data to write
|
||||
size_t len ///< the length of data
|
||||
) = 0;
|
||||
|
||||
/**
|
||||
* The getErrorString() function returns an error formatting string
|
||||
* for the error number @a num. A subclass wishing to customize
|
||||
* an error formatting string may override this function.
|
||||
*/
|
||||
///
|
||||
/// The getErrorString() function returns an error formatting string
|
||||
/// for the error number @a num. A subclass wishing to customize
|
||||
/// an error formatting string may override this function.
|
||||
///
|
||||
virtual const char_t* getErrorString (
|
||||
errnum_t num ///< an error number
|
||||
) const;
|
||||
|
@ -1,19 +1,21 @@
|
||||
/*
|
||||
* $Id: StdSed.hpp 275 2009-08-30 13:19:02Z hyunghwan.chung $
|
||||
* $Id: StdSed.hpp 287 2009-09-15 10:01:02Z hyunghwan.chung $
|
||||
*
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
This file is part of QSE.
|
||||
|
||||
Licensed under the Apache License, Version 2.0 (the "License");
|
||||
you may not use this file except in compliance with the License.
|
||||
You may obtain a copy of the License at
|
||||
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.
|
||||
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
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.
|
||||
|
||||
Unless required by applicable law or agreed to in writing, software
|
||||
distributed under the License is distributed on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
See the License for the specific language governing permissions and
|
||||
limitations under the License.
|
||||
You should have received a copy of the GNU Lesser General Public
|
||||
License along with QSE. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#ifndef _QSE_SED_STDSED_HPP_
|
||||
@ -31,7 +33,7 @@ QSE_BEGIN_NAMESPACE(QSE)
|
||||
|
||||
/**
|
||||
* The StdSed class inherits the Sed class and implements the standard
|
||||
* IO handlers and memory manager for easier use.
|
||||
* I/O handlers and memory manager for easier use.
|
||||
*
|
||||
*/
|
||||
class StdSed: public Sed
|
||||
|
@ -1,19 +1,21 @@
|
||||
/*
|
||||
* $Id: sed.h 280 2009-09-07 13:34:49Z hyunghwan.chung $
|
||||
* $Id: sed.h 287 2009-09-15 10:01:02Z hyunghwan.chung $
|
||||
*
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
This file is part of QSE.
|
||||
|
||||
Licensed under the Apache License, Version 2.0 (the "License");
|
||||
you may not use this file except in compliance with the License.
|
||||
You may obtain a copy of the License at
|
||||
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.
|
||||
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
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.
|
||||
|
||||
Unless required by applicable law or agreed to in writing, software
|
||||
distributed under the License is distributed on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
See the License for the specific language governing permissions and
|
||||
limitations under the License.
|
||||
You should have received a copy of the GNU Lesser General Public
|
||||
License along with QSE. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#ifndef _QSE_SED_SED_H_
|
||||
@ -64,12 +66,12 @@ typedef struct qse_sed_t qse_sed_t;
|
||||
/**
|
||||
* The qse_sed_loc_t defines a structure to store location information.
|
||||
*/
|
||||
typedef struct qse_sed_loc_t qse_sed_loc_t;
|
||||
struct qse_sed_loc_t
|
||||
{
|
||||
qse_size_t lin; /**< line */
|
||||
qse_size_t col; /**< column */
|
||||
};
|
||||
typedef struct qse_sed_loc_t qse_sed_loc_t;
|
||||
|
||||
/**
|
||||
* the qse_sed_errnum_t type defines error numbers.
|
||||
|
@ -1,19 +1,21 @@
|
||||
/*
|
||||
* $Id: types.h 230 2009-07-13 08:51:23Z hyunghwan.chung $
|
||||
* $Id: types.h 287 2009-09-15 10:01:02Z hyunghwan.chung $
|
||||
*
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
This file is part of QSE.
|
||||
|
||||
Licensed under the Apache License, Version 2.0 (the "License");
|
||||
you may not use this file except in compliance with the License.
|
||||
You may obtain a copy of the License at
|
||||
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.
|
||||
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
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.
|
||||
|
||||
Unless required by applicable law or agreed to in writing, software
|
||||
distributed under the License is distributed on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
See the License for the specific language governing permissions and
|
||||
limitations under the License.
|
||||
You should have received a copy of the GNU Lesser General Public
|
||||
License along with QSE. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#ifndef _QSE_TYPES_H_
|
||||
|
@ -1,19 +1,21 @@
|
||||
/*
|
||||
* $Id: unpack.h 75 2009-02-22 14:10:34Z hyunghwan.chung $
|
||||
* $Id: unpack.h 287 2009-09-15 10:01:02Z hyunghwan.chung $
|
||||
*
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
This file is part of QSE.
|
||||
|
||||
Licensed under the Apache License, Version 2.0 (the "License");
|
||||
you may not use this file except in compliance with the License.
|
||||
You may obtain a copy of the License at
|
||||
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.
|
||||
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
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.
|
||||
|
||||
Unless required by applicable law or agreed to in writing, software
|
||||
distributed under the License is distributed on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
See the License for the specific language governing permissions and
|
||||
limitations under the License.
|
||||
You should have received a copy of the GNU Lesser General Public
|
||||
License along with QSE. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#if defined(__GNUC__)
|
||||
|
@ -1,7 +1,5 @@
|
||||
/*
|
||||
* $Id: http.h 223 2008-06-26 06:44:41Z baconevi $
|
||||
*
|
||||
* {License}
|
||||
*/
|
||||
|
||||
#ifndef _QSE_UTL_HTTP_H_
|
||||
|
@ -1,19 +1,5 @@
|
||||
/*
|
||||
* $Id: tgp.h 235 2008-07-05 07:25:54Z baconevi $
|
||||
*
|
||||
Copyright 2006-2009 Chung, Hyung-Hwan.
|
||||
|
||||
Licensed under the Apache License, Version 2.0 (the "License");
|
||||
you may not use this file except in compliance with the License.
|
||||
You may obtain a copy of the License at
|
||||
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
|
||||
Unless required by applicable law or agreed to in writing, software
|
||||
distributed under the License is distributed on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
See the License for the specific language governing permissions and
|
||||
limitations under the License.
|
||||
*/
|
||||
|
||||
#ifndef _QSE_UTL_TGP_H_
|
||||
|
Reference in New Issue
Block a user