changed how to compare a map against data of other types.
fixed some problems in handling nonblocking connect and send with watt-32
This commit is contained in:
parent
84798f4fd0
commit
2218670769
@ -1382,10 +1382,9 @@ enum qse_awk_val_type_t
|
|||||||
QSE_AWK_VAL_INT = 1, /**< integer */
|
QSE_AWK_VAL_INT = 1, /**< integer */
|
||||||
QSE_AWK_VAL_FLT = 2, /**< floating-pointer number */
|
QSE_AWK_VAL_FLT = 2, /**< floating-pointer number */
|
||||||
QSE_AWK_VAL_STR = 3, /**< string */
|
QSE_AWK_VAL_STR = 3, /**< string */
|
||||||
|
QSE_AWK_VAL_MAP = 4, /**< map */
|
||||||
|
|
||||||
QSE_AWK_VAL_REX = 4, /**< regular expression */
|
QSE_AWK_VAL_REX = 5, /**< regular expression */
|
||||||
QSE_AWK_VAL_MAP = 5, /**< map */
|
|
||||||
|
|
||||||
QSE_AWK_VAL_REF = 6, /**< reference to other types */
|
QSE_AWK_VAL_REF = 6, /**< reference to other types */
|
||||||
QSE_AWK_VAL_FUN = 7
|
QSE_AWK_VAL_FUN = 7
|
||||||
};
|
};
|
||||||
|
@ -4146,42 +4146,48 @@ static qse_awk_val_t* eval_binop_band (
|
|||||||
return qse_awk_rtx_makeintval (rtx, l1 & l2);
|
return qse_awk_rtx_makeintval (rtx, l1 & l2);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int __cmp_nil_nil (
|
static QSE_INLINE int __cmp_nil_nil (
|
||||||
qse_awk_rtx_t* run, qse_awk_val_t* left, qse_awk_val_t* right)
|
qse_awk_rtx_t* rtx, qse_awk_val_t* left, qse_awk_val_t* right)
|
||||||
{
|
{
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int __cmp_nil_int (
|
static QSE_INLINE int __cmp_nil_int (
|
||||||
qse_awk_rtx_t* rtx, qse_awk_val_t* left, qse_awk_val_t* right)
|
qse_awk_rtx_t* rtx, qse_awk_val_t* left, qse_awk_val_t* right)
|
||||||
{
|
{
|
||||||
qse_awk_int_t v = QSE_AWK_RTX_GETINTFROMVAL (rtx, right);
|
qse_awk_int_t v = QSE_AWK_RTX_GETINTFROMVAL (rtx, right);
|
||||||
return (v < 0)? 1: ((v > 0)? -1: 0);
|
return (v < 0)? 1: ((v > 0)? -1: 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int __cmp_nil_real (
|
static QSE_INLINE int __cmp_nil_flt (
|
||||||
qse_awk_rtx_t* run, qse_awk_val_t* left, qse_awk_val_t* right)
|
qse_awk_rtx_t* rtx, qse_awk_val_t* left, qse_awk_val_t* right)
|
||||||
{
|
{
|
||||||
if (((qse_awk_val_flt_t*)right)->val < 0) return 1;
|
if (((qse_awk_val_flt_t*)right)->val < 0) return 1;
|
||||||
if (((qse_awk_val_flt_t*)right)->val > 0) return -1;
|
if (((qse_awk_val_flt_t*)right)->val > 0) return -1;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int __cmp_nil_str (
|
static QSE_INLINE int __cmp_nil_str (
|
||||||
qse_awk_rtx_t* run, qse_awk_val_t* left, qse_awk_val_t* right)
|
qse_awk_rtx_t* rtx, qse_awk_val_t* left, qse_awk_val_t* right)
|
||||||
{
|
{
|
||||||
return (((qse_awk_val_str_t*)right)->val.len == 0)? 0: -1;
|
return (((qse_awk_val_str_t*)right)->val.len == 0)? 0: -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int __cmp_int_nil (
|
static QSE_INLINE int __cmp_nil_map (
|
||||||
qse_awk_rtx_t* run, qse_awk_val_t* left, qse_awk_val_t* right)
|
qse_awk_rtx_t* rtx, qse_awk_val_t* left, qse_awk_val_t* right)
|
||||||
|
{
|
||||||
|
return (QSE_HTB_SIZE(((qse_awk_val_map_t*)right)->map) == 0)? 0: -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
static QSE_INLINE int __cmp_int_nil (
|
||||||
|
qse_awk_rtx_t* rtx, qse_awk_val_t* left, qse_awk_val_t* right)
|
||||||
{
|
{
|
||||||
qse_awk_int_t v = QSE_AWK_RTX_GETINTFROMVAL (rtx, left);
|
qse_awk_int_t v = QSE_AWK_RTX_GETINTFROMVAL (rtx, left);
|
||||||
return (v > 0)? 1: ((v < 0)? -1: 0);
|
return (v > 0)? 1: ((v < 0)? -1: 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int __cmp_int_int (
|
static QSE_INLINE int __cmp_int_int (
|
||||||
qse_awk_rtx_t* run, qse_awk_val_t* left, qse_awk_val_t* right)
|
qse_awk_rtx_t* rtx, qse_awk_val_t* left, qse_awk_val_t* right)
|
||||||
{
|
{
|
||||||
|
|
||||||
qse_awk_int_t v1 = QSE_AWK_RTX_GETINTFROMVAL (rtx, left);
|
qse_awk_int_t v1 = QSE_AWK_RTX_GETINTFROMVAL (rtx, left);
|
||||||
@ -4189,8 +4195,8 @@ static int __cmp_int_int (
|
|||||||
return (v1 > v2)? 1: ((v1 < v2)? -1: 0);
|
return (v1 > v2)? 1: ((v1 < v2)? -1: 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int __cmp_int_real (
|
static QSE_INLINE int __cmp_int_flt (
|
||||||
qse_awk_rtx_t* run, qse_awk_val_t* left, qse_awk_val_t* right)
|
qse_awk_rtx_t* rtx, qse_awk_val_t* left, qse_awk_val_t* right)
|
||||||
{
|
{
|
||||||
qse_awk_int_t v1 = QSE_AWK_RTX_GETINTFROMVAL (rtx, left);
|
qse_awk_int_t v1 = QSE_AWK_RTX_GETINTFROMVAL (rtx, left);
|
||||||
if (v1 > ((qse_awk_val_flt_t*)right)->val) return 1;
|
if (v1 > ((qse_awk_val_flt_t*)right)->val) return 1;
|
||||||
@ -4198,7 +4204,7 @@ static int __cmp_int_real (
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int __cmp_int_str (
|
static QSE_INLINE int __cmp_int_str (
|
||||||
qse_awk_rtx_t* rtx, qse_awk_val_t* left, qse_awk_val_t* right)
|
qse_awk_rtx_t* rtx, qse_awk_val_t* left, qse_awk_val_t* right)
|
||||||
{
|
{
|
||||||
qse_awk_rtx_valtostr_out_t out;
|
qse_awk_rtx_valtostr_out_t out;
|
||||||
@ -4256,8 +4262,18 @@ static int __cmp_int_str (
|
|||||||
return n;
|
return n;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int __cmp_flt_nil (
|
static QSE_INLINE int __cmp_int_map (
|
||||||
qse_awk_rtx_t* run, qse_awk_val_t* left, qse_awk_val_t* right)
|
qse_awk_rtx_t* rtx, qse_awk_val_t* left, qse_awk_val_t* right)
|
||||||
|
{
|
||||||
|
qse_awk_int_t v1 = QSE_AWK_RTX_GETINTFROMVAL (rtx, left);
|
||||||
|
qse_awk_int_t v2 = QSE_HTB_SIZE(((qse_awk_val_map_t*)right)->map);
|
||||||
|
if (v1 > v2) return 1;
|
||||||
|
if (v1 < v2) return -1;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static QSE_INLINE int __cmp_flt_nil (
|
||||||
|
qse_awk_rtx_t* rtx, qse_awk_val_t* left, qse_awk_val_t* right)
|
||||||
{
|
{
|
||||||
if (((qse_awk_val_flt_t*)left)->val > 0) return 1;
|
if (((qse_awk_val_flt_t*)left)->val > 0) return 1;
|
||||||
if (((qse_awk_val_flt_t*)left)->val < 0) return -1;
|
if (((qse_awk_val_flt_t*)left)->val < 0) return -1;
|
||||||
@ -4265,7 +4281,7 @@ static int __cmp_flt_nil (
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int __cmp_flt_int (
|
static int __cmp_flt_int (
|
||||||
qse_awk_rtx_t* run, qse_awk_val_t* left, qse_awk_val_t* right)
|
qse_awk_rtx_t* rtx, qse_awk_val_t* left, qse_awk_val_t* right)
|
||||||
{
|
{
|
||||||
qse_awk_int_t v2 = QSE_AWK_RTX_GETINTFROMVAL (rtx, right);
|
qse_awk_int_t v2 = QSE_AWK_RTX_GETINTFROMVAL (rtx, right);
|
||||||
if (((qse_awk_val_flt_t*)left)->val > v2) return 1;
|
if (((qse_awk_val_flt_t*)left)->val > v2) return 1;
|
||||||
@ -4273,8 +4289,8 @@ static int __cmp_flt_int (
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int __cmp_flt_real (
|
static int __cmp_flt_flt (
|
||||||
qse_awk_rtx_t* run, qse_awk_val_t* left, qse_awk_val_t* right)
|
qse_awk_rtx_t* rtx, qse_awk_val_t* left, qse_awk_val_t* right)
|
||||||
{
|
{
|
||||||
if (((qse_awk_val_flt_t*)left)->val >
|
if (((qse_awk_val_flt_t*)left)->val >
|
||||||
((qse_awk_val_flt_t*)right)->val) return 1;
|
((qse_awk_val_flt_t*)right)->val) return 1;
|
||||||
@ -4335,25 +4351,34 @@ static int __cmp_flt_str (
|
|||||||
return n;
|
return n;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int __cmp_str_nil (
|
static QSE_INLINE int __cmp_flt_map (
|
||||||
qse_awk_rtx_t* run, qse_awk_val_t* left, qse_awk_val_t* right)
|
qse_awk_rtx_t* rtx, qse_awk_val_t* left, qse_awk_val_t* right)
|
||||||
|
{
|
||||||
|
qse_awk_int_t v2 = QSE_HTB_SIZE(((qse_awk_val_map_t*)right)->map);
|
||||||
|
if (((qse_awk_val_flt_t*)left)->val > v2) return 1;
|
||||||
|
if (((qse_awk_val_flt_t*)left)->val < v2) return -1;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static QSE_INLINE int __cmp_str_nil (
|
||||||
|
qse_awk_rtx_t* rtx, qse_awk_val_t* left, qse_awk_val_t* right)
|
||||||
{
|
{
|
||||||
return (((qse_awk_val_str_t*)left)->val.len == 0)? 0: 1;
|
return (((qse_awk_val_str_t*)left)->val.len == 0)? 0: 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int __cmp_str_int (
|
static QSE_INLINE int __cmp_str_int (
|
||||||
qse_awk_rtx_t* run, qse_awk_val_t* left, qse_awk_val_t* right)
|
qse_awk_rtx_t* rtx, qse_awk_val_t* left, qse_awk_val_t* right)
|
||||||
{
|
{
|
||||||
return -__cmp_int_str (run, right, left);
|
return -__cmp_int_str (rtx, right, left);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int __cmp_str_real (
|
static QSE_INLINE int __cmp_str_flt (
|
||||||
qse_awk_rtx_t* run, qse_awk_val_t* left, qse_awk_val_t* right)
|
qse_awk_rtx_t* rtx, qse_awk_val_t* left, qse_awk_val_t* right)
|
||||||
{
|
{
|
||||||
return -__cmp_flt_str (run, right, left);
|
return -__cmp_flt_str (rtx, right, left);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int __cmp_str_str (
|
static QSE_INLINE int __cmp_str_str (
|
||||||
qse_awk_rtx_t* rtx, qse_awk_val_t* left, qse_awk_val_t* right)
|
qse_awk_rtx_t* rtx, qse_awk_val_t* left, qse_awk_val_t* right)
|
||||||
{
|
{
|
||||||
qse_awk_val_str_t* ls, * rs;
|
qse_awk_val_str_t* ls, * rs;
|
||||||
@ -4433,6 +4458,49 @@ static int __cmp_str_str (
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static QSE_INLINE int __cmp_str_map (
|
||||||
|
qse_awk_rtx_t* rtx, qse_awk_val_t* left, qse_awk_val_t* right)
|
||||||
|
{
|
||||||
|
/* can't compare a map with a string */
|
||||||
|
SETERR_COD (rtx, QSE_AWK_EOPERAND);
|
||||||
|
return CMP_ERROR;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static QSE_INLINE int __cmp_map_nil (
|
||||||
|
qse_awk_rtx_t* rtx, qse_awk_val_t* left, qse_awk_val_t* right)
|
||||||
|
{
|
||||||
|
return -__cmp_nil_map (rtx, right, left);
|
||||||
|
}
|
||||||
|
|
||||||
|
static QSE_INLINE int __cmp_map_int (
|
||||||
|
qse_awk_rtx_t* rtx, qse_awk_val_t* left, qse_awk_val_t* right)
|
||||||
|
{
|
||||||
|
return -__cmp_int_map (rtx, right, left);
|
||||||
|
}
|
||||||
|
|
||||||
|
static QSE_INLINE int __cmp_map_flt (
|
||||||
|
qse_awk_rtx_t* rtx, qse_awk_val_t* left, qse_awk_val_t* right)
|
||||||
|
{
|
||||||
|
return -__cmp_flt_map (rtx, right, left);
|
||||||
|
}
|
||||||
|
|
||||||
|
static QSE_INLINE int __cmp_map_str (
|
||||||
|
qse_awk_rtx_t* rtx, qse_awk_val_t* left, qse_awk_val_t* right)
|
||||||
|
{
|
||||||
|
/* can't compare a map with a string */
|
||||||
|
SETERR_COD (rtx, QSE_AWK_EOPERAND);
|
||||||
|
return CMP_ERROR;
|
||||||
|
}
|
||||||
|
|
||||||
|
static QSE_INLINE int __cmp_map_map (
|
||||||
|
qse_awk_rtx_t* rtx, qse_awk_val_t* left, qse_awk_val_t* right)
|
||||||
|
{
|
||||||
|
/* can't compare a map with a map */
|
||||||
|
SETERR_COD (rtx, QSE_AWK_EOPERAND);
|
||||||
|
return CMP_ERROR;
|
||||||
|
}
|
||||||
|
|
||||||
static int __cmp_val (
|
static int __cmp_val (
|
||||||
qse_awk_rtx_t* rtx, qse_awk_val_t* left, qse_awk_val_t* right)
|
qse_awk_rtx_t* rtx, qse_awk_val_t* left, qse_awk_val_t* right)
|
||||||
{
|
{
|
||||||
@ -4443,26 +4511,34 @@ static int __cmp_val (
|
|||||||
{
|
{
|
||||||
/* this table must be synchronized with
|
/* this table must be synchronized with
|
||||||
* the QSE_AWK_VAL_XXX values in awk.h */
|
* the QSE_AWK_VAL_XXX values in awk.h */
|
||||||
__cmp_nil_nil, __cmp_nil_int, __cmp_nil_real, __cmp_nil_str,
|
__cmp_nil_nil, __cmp_nil_int, __cmp_nil_flt, __cmp_nil_str, __cmp_nil_map,
|
||||||
__cmp_int_nil, __cmp_int_int, __cmp_int_real, __cmp_int_str,
|
__cmp_int_nil, __cmp_int_int, __cmp_int_flt, __cmp_int_str, __cmp_int_map,
|
||||||
__cmp_flt_nil, __cmp_flt_int, __cmp_flt_real, __cmp_flt_str,
|
__cmp_flt_nil, __cmp_flt_int, __cmp_flt_flt, __cmp_flt_str, __cmp_flt_map,
|
||||||
__cmp_str_nil, __cmp_str_int, __cmp_str_real, __cmp_str_str,
|
__cmp_str_nil, __cmp_str_int, __cmp_str_flt, __cmp_str_str, __cmp_str_map,
|
||||||
|
__cmp_map_nil, __cmp_map_int, __cmp_map_flt, __cmp_map_str, __cmp_map_map
|
||||||
};
|
};
|
||||||
|
|
||||||
lvtype = QSE_AWK_RTX_GETVALTYPE(rtx, left);
|
lvtype = QSE_AWK_RTX_GETVALTYPE(rtx, left);
|
||||||
rvtype = QSE_AWK_RTX_GETVALTYPE(rtx, right);
|
rvtype = QSE_AWK_RTX_GETVALTYPE(rtx, right);
|
||||||
if (lvtype == QSE_AWK_VAL_MAP || rvtype == QSE_AWK_VAL_MAP)
|
if (!(rtx->awk->opt.trait & QSE_AWK_FLEXMAP) &&
|
||||||
|
(lvtype == QSE_AWK_VAL_MAP || rvtype == QSE_AWK_VAL_MAP))
|
||||||
{
|
{
|
||||||
/* TODO: get the map size and use it for comparison */
|
|
||||||
/* a map can't be compared againt other values */
|
/* a map can't be compared againt other values */
|
||||||
SETERR_COD (rtx, QSE_AWK_EOPERAND);
|
SETERR_COD (rtx, QSE_AWK_EOPERAND);
|
||||||
return CMP_ERROR;
|
return CMP_ERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
QSE_ASSERT (lvtype >= QSE_AWK_VAL_NIL && lvtype <= QSE_AWK_VAL_STR);
|
QSE_ASSERT (lvtype >= QSE_AWK_VAL_NIL && lvtype <= QSE_AWK_VAL_MAP);
|
||||||
QSE_ASSERT (rvtype >= QSE_AWK_VAL_NIL && rvtype <= QSE_AWK_VAL_STR);
|
QSE_ASSERT (rvtype >= QSE_AWK_VAL_NIL && rvtype <= QSE_AWK_VAL_MAP);
|
||||||
|
|
||||||
return func[lvtype * 4 + rvtype] (rtx, left, right);
|
/* mapping fomula and table layout assume:
|
||||||
|
* QSE_AWK_VAL_NIL = 0
|
||||||
|
* QSE_AWK_VAL_INT = 1
|
||||||
|
* QSE_AWK_VAL_FLT = 2
|
||||||
|
* QSE_AWK_VAL_STR = 3
|
||||||
|
* QSE_AWK_VAL_MAP = 4
|
||||||
|
*/
|
||||||
|
return func[lvtype * 5 + rvtype] (rtx, left, right);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int teq_val (qse_awk_rtx_t* rtx, qse_awk_val_t* left, qse_awk_val_t* right)
|
static int teq_val (qse_awk_rtx_t* rtx, qse_awk_val_t* left, qse_awk_val_t* right)
|
||||||
@ -4514,7 +4590,6 @@ static int teq_val (qse_awk_rtx_t* rtx, qse_awk_val_t* left, qse_awk_val_t* righ
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
return n;
|
return n;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -154,6 +154,7 @@ qse_awk_val_t* qse_awk_rtx_makeintval (qse_awk_rtx_t* rtx, qse_awk_int_t v)
|
|||||||
val->i_val = v;
|
val->i_val = v;
|
||||||
val->nde = QSE_NULL;
|
val->nde = QSE_NULL;
|
||||||
|
|
||||||
|
printf ("makeintval => %p\n", val);
|
||||||
#ifdef DEBUG_VAL
|
#ifdef DEBUG_VAL
|
||||||
qse_errputstrf (QSE_T("makeintval => %jd [%p]\n"), (qse_intmax_t)v, val);
|
qse_errputstrf (QSE_T("makeintval => %jd [%p]\n"), (qse_intmax_t)v, val);
|
||||||
#endif
|
#endif
|
||||||
|
@ -73,15 +73,14 @@ struct qse_awk_val_rchunk_t
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
/* qse_awk_val_t pointer encoding assumes that
|
/* qse_awk_val_t pointer encoding assumes the pointer is an even number.
|
||||||
* the 2 least significant bits of a real pointer are all zeros. */
|
* is this a safe assumption? do i have to use memalign or write my own
|
||||||
#define VAL_NUM_TYPE_BITS 2
|
* aligned malloc()? */
|
||||||
#define VAL_MASK_TYPE_BITS 3
|
#define VAL_NUM_TYPE_BITS 1
|
||||||
|
#define VAL_MASK_TYPE_BITS 1
|
||||||
|
|
||||||
#define VAL_TYPE_BITS_POINTER 0
|
#define VAL_TYPE_BITS_POINTER 0
|
||||||
#define VAL_TYPE_BITS_QUICKINT 1
|
#define VAL_TYPE_BITS_QUICKINT 1
|
||||||
#define VAL_TYPE_BITS_RESERVED_1 2
|
|
||||||
#define VAL_TYPE_BITS_RESERVED_2 3
|
|
||||||
#define VAL_SIGN_BIT ((qse_uintptr_t)1 << (QSE_SIZEOF_UINTPTR_T * 8 - 1))
|
#define VAL_SIGN_BIT ((qse_uintptr_t)1 << (QSE_SIZEOF_UINTPTR_T * 8 - 1))
|
||||||
|
|
||||||
/* shrink the bit range by 1 more bit to ease signbit handling.
|
/* shrink the bit range by 1 more bit to ease signbit handling.
|
||||||
@ -100,7 +99,9 @@ struct qse_awk_val_rchunk_t
|
|||||||
/* sizeof(qse_intptr_t) may not be the same as sizeof(qse_awk_int_t).
|
/* sizeof(qse_intptr_t) may not be the same as sizeof(qse_awk_int_t).
|
||||||
* so step-by-step type conversions are needed.
|
* so step-by-step type conversions are needed.
|
||||||
* e.g) pointer to uintptr_t, uintptr_t to intptr_t, intptr_t to awk_int_t */
|
* e.g) pointer to uintptr_t, uintptr_t to intptr_t, intptr_t to awk_int_t */
|
||||||
#define GET_QUICKINT_FROM_POINTER(p) (((qse_uintptr_t)(p) & VAL_SIGN_BIT)? -(qse_intptr_t)(((qse_uintptr_t)(p) & ~VAL_SIGN_BIT) >> 2): (qse_intptr_t)((qse_uintptr_t)(p) >> 2))
|
#define POSITIVE_QUICKINT_FROM_POINTER(p) ((qse_intptr_t)((qse_uintptr_t)(p) >> VAL_NUM_TYPE_BITS))
|
||||||
|
#define NEGATIVE_QUICKINT_FROM_POINTER(p) (-(qse_intptr_t)(((qse_uintptr_t)(p) & ~VAL_SIGN_BIT) >> VAL_NUM_TYPE_BITS))
|
||||||
|
#define GET_QUICKINT_FROM_POINTER(p) (((qse_uintptr_t)(p) & VAL_SIGN_BIT)? NEGATIVE_QUICKINT_FROM_POINTER(p): POSITIVE_QUICKINT_FROM_POINTER(p))
|
||||||
|
|
||||||
#define QSE_AWK_RTX_GETVALTYPE(rtx,p) (IS_QUICKINT_POINTER(p)? QSE_AWK_VAL_INT: (p)->v_type)
|
#define QSE_AWK_RTX_GETVALTYPE(rtx,p) (IS_QUICKINT_POINTER(p)? QSE_AWK_VAL_INT: (p)->v_type)
|
||||||
#define QSE_AWK_RTX_GETINTFROMVAL(rtx,p) ((IS_QUICKINT_POINTER(p)? (qse_awk_int_t)GET_QUICKINT_FROM_POINTER(p): ((qse_awk_val_int_t*)(p))->i_val))
|
#define QSE_AWK_RTX_GETINTFROMVAL(rtx,p) ((IS_QUICKINT_POINTER(p)? (qse_awk_int_t)GET_QUICKINT_FROM_POINTER(p): ((qse_awk_val_int_t*)(p))->i_val))
|
||||||
|
@ -237,8 +237,19 @@ static qse_mux_errnum_t skerr_to_errnum (int e)
|
|||||||
case EPIPE:
|
case EPIPE:
|
||||||
return QSE_MUX_EPIPE;
|
return QSE_MUX_EPIPE;
|
||||||
|
|
||||||
|
#if defined(EAGAIN) || defined(EWOULDBLOCK)
|
||||||
|
#if defined(EAGAIN) && defined(EWOULDBLOCK)
|
||||||
case EAGAIN:
|
case EAGAIN:
|
||||||
|
#if (EWOULDBLOCK != EAGAIN)
|
||||||
|
case EWOULDBLOCK:
|
||||||
|
#endif
|
||||||
|
#elif defined(EAGAIN)
|
||||||
|
case EAGAIN:
|
||||||
|
#else
|
||||||
|
case EWOULDBLOCK;
|
||||||
|
#endif
|
||||||
return QSE_MUX_EAGAIN;
|
return QSE_MUX_EAGAIN;
|
||||||
|
#endif
|
||||||
|
|
||||||
default:
|
default:
|
||||||
return QSE_MUX_ESYSERR;
|
return QSE_MUX_ESYSERR;
|
||||||
|
@ -176,8 +176,20 @@ static qse_nwio_errnum_t skerr_to_errnum (int e)
|
|||||||
case EPIPE:
|
case EPIPE:
|
||||||
return QSE_NWIO_EPIPE;
|
return QSE_NWIO_EPIPE;
|
||||||
|
|
||||||
|
#if defined(EAGAIN) || defined(EWOULDBLOCK)
|
||||||
|
|
||||||
|
#if defined(EAGAIN) && defined(EWOULDBLOCK)
|
||||||
case EAGAIN:
|
case EAGAIN:
|
||||||
|
#if (EWOULDBLOCK != EAGAIN)
|
||||||
|
case EWOULDBLOCK:
|
||||||
|
#endif
|
||||||
|
#elif defined(EAGAIN)
|
||||||
|
case EAGAIN:
|
||||||
|
#else
|
||||||
|
case EWOULDBLOCK;
|
||||||
|
#endif
|
||||||
return QSE_NWIO_EAGAIN;
|
return QSE_NWIO_EAGAIN;
|
||||||
|
#endif
|
||||||
|
|
||||||
#if defined(ECONNREFUSED) || defined(ENETUNREACH) || defined(EHOSTUNREACH) || defined(EHOSTDOWN)
|
#if defined(ECONNREFUSED) || defined(ENETUNREACH) || defined(EHOSTUNREACH) || defined(EHOSTDOWN)
|
||||||
#if defined(ECONNREFUSED)
|
#if defined(ECONNREFUSED)
|
||||||
|
@ -90,6 +90,7 @@
|
|||||||
} \
|
} \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
#elif defined(__DOS__)
|
#elif defined(__DOS__)
|
||||||
|
|
||||||
#define IMPLEMENT_SYSERR_TO_ERRNUM(obj1,obj2) \
|
#define IMPLEMENT_SYSERR_TO_ERRNUM(obj1,obj2) \
|
||||||
@ -105,6 +106,7 @@
|
|||||||
default: return __SYSERRNUM__ (obj2, ESYSERR); \
|
default: return __SYSERRNUM__ (obj2, ESYSERR); \
|
||||||
} \
|
} \
|
||||||
}
|
}
|
||||||
|
*/
|
||||||
|
|
||||||
#elif defined(vms) || defined(__vms)
|
#elif defined(vms) || defined(__vms)
|
||||||
|
|
||||||
@ -143,7 +145,7 @@
|
|||||||
} \
|
} \
|
||||||
}
|
}
|
||||||
|
|
||||||
#else
|
#elif defined(EAGAIN)
|
||||||
|
|
||||||
#define IMPLEMENT_SYSERR_TO_ERRNUM(obj1,obj2) \
|
#define IMPLEMENT_SYSERR_TO_ERRNUM(obj1,obj2) \
|
||||||
static __SYSERRTYPE__(obj1) syserr_to_errnum (int e) \
|
static __SYSERRTYPE__(obj1) syserr_to_errnum (int e) \
|
||||||
@ -164,6 +166,47 @@
|
|||||||
} \
|
} \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#elif defined(EWOULDBLOCK)
|
||||||
|
|
||||||
|
#define IMPLEMENT_SYSERR_TO_ERRNUM(obj1,obj2) \
|
||||||
|
static __SYSERRTYPE__(obj1) syserr_to_errnum (int e) \
|
||||||
|
{ \
|
||||||
|
switch (e) \
|
||||||
|
{ \
|
||||||
|
case ENOMEM: return __SYSERRNUM__ (obj2, ENOMEM); \
|
||||||
|
case EINVAL: return __SYSERRNUM__ (obj2, EINVAL); \
|
||||||
|
case EBUSY: \
|
||||||
|
case EACCES: return __SYSERRNUM__ (obj2, EACCES); \
|
||||||
|
case ENOTDIR: \
|
||||||
|
case ENOENT: return __SYSERRNUM__ (obj2, ENOENT); \
|
||||||
|
case EEXIST: return __SYSERRNUM__ (obj2, EEXIST); \
|
||||||
|
case EINTR: return __SYSERRNUM__ (obj2, EINTR); \
|
||||||
|
case EPIPE: return __SYSERRNUM__ (obj2, EPIPE); \
|
||||||
|
case EWOULDBLOCK: return __SYSERRNUM__ (obj2, EAGAIN); \
|
||||||
|
default: return __SYSERRNUM__ (obj2, ESYSERR); \
|
||||||
|
} \
|
||||||
|
}
|
||||||
|
|
||||||
|
#else
|
||||||
|
|
||||||
|
#define IMPLEMENT_SYSERR_TO_ERRNUM(obj1,obj2) \
|
||||||
|
static __SYSERRTYPE__(obj1) syserr_to_errnum (int e) \
|
||||||
|
{ \
|
||||||
|
switch (e) \
|
||||||
|
{ \
|
||||||
|
case ENOMEM: return __SYSERRNUM__ (obj2, ENOMEM); \
|
||||||
|
case EINVAL: return __SYSERRNUM__ (obj2, EINVAL); \
|
||||||
|
case EBUSY: \
|
||||||
|
case EACCES: return __SYSERRNUM__ (obj2, EACCES); \
|
||||||
|
case ENOTDIR: \
|
||||||
|
case ENOENT: return __SYSERRNUM__ (obj2, ENOENT); \
|
||||||
|
case EEXIST: return __SYSERRNUM__ (obj2, EEXIST); \
|
||||||
|
case EINTR: return __SYSERRNUM__ (obj2, EINTR); \
|
||||||
|
case EPIPE: return __SYSERRNUM__ (obj2, EPIPE); \
|
||||||
|
default: return __SYSERRNUM__ (obj2, ESYSERR); \
|
||||||
|
} \
|
||||||
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -242,16 +242,6 @@ static qse_httpd_errnum_t skerr_to_errnum (int e)
|
|||||||
|
|
||||||
#define SKERR_TO_ERRNUM() skerr_to_errnum(sock_errno())
|
#define SKERR_TO_ERRNUM() skerr_to_errnum(sock_errno())
|
||||||
|
|
||||||
/*
|
|
||||||
#elif defined(__DOS__)
|
|
||||||
static qse_httpd_errnum_t skerr_to_errnum (int e)
|
|
||||||
{
|
|
||||||
/ * TODO: * /
|
|
||||||
return QSE_HTTPD_ESYSERR;
|
|
||||||
}
|
|
||||||
|
|
||||||
#define SKERR_TO_ERRNUM() skerr_to_errnum(errno)
|
|
||||||
*/
|
|
||||||
#else
|
#else
|
||||||
static qse_httpd_errnum_t skerr_to_errnum (int e)
|
static qse_httpd_errnum_t skerr_to_errnum (int e)
|
||||||
{
|
{
|
||||||
@ -278,11 +268,20 @@ static qse_httpd_errnum_t skerr_to_errnum (int e)
|
|||||||
case EPIPE:
|
case EPIPE:
|
||||||
return QSE_HTTPD_EPIPE;
|
return QSE_HTTPD_EPIPE;
|
||||||
|
|
||||||
|
#if defined(EAGAIN) || defined(EWOULDBLOCK)
|
||||||
|
|
||||||
|
#if defined(EAGAIN) && defined(EWOULDBLOCK)
|
||||||
case EAGAIN:
|
case EAGAIN:
|
||||||
#if defined(EWEOULDBLOCK) && defined(EAGAIN) && (EWOULDBLOCK != EAGAIN)
|
#if (EWOULDBLOCK != EAGAIN)
|
||||||
case EWOULDBLOCK:
|
case EWOULDBLOCK:
|
||||||
|
#endif
|
||||||
|
#elif defined(EAGAIN)
|
||||||
|
case EAGAIN:
|
||||||
|
#else
|
||||||
|
case EWOULDBLOCK;
|
||||||
#endif
|
#endif
|
||||||
return QSE_HTTPD_EAGAIN;
|
return QSE_HTTPD_EAGAIN;
|
||||||
|
#endif
|
||||||
|
|
||||||
#if defined(ECONNREFUSED) || defined(ENETUNREACH) || defined(EHOSTUNREACH) || defined(EHOSTDOWN)
|
#if defined(ECONNREFUSED) || defined(ENETUNREACH) || defined(EHOSTUNREACH) || defined(EHOSTDOWN)
|
||||||
#if defined(ECONNREFUSED)
|
#if defined(ECONNREFUSED)
|
||||||
@ -1362,11 +1361,6 @@ static int is_peer_socket_connected (qse_httpd_t* httpd, qse_httpd_peer_t* peer)
|
|||||||
|
|
||||||
return 1; /* connection completed */
|
return 1; /* connection completed */
|
||||||
|
|
||||||
/*#elif defined(__DOS__)
|
|
||||||
|
|
||||||
qse_httpd_seterrnum (httpd, QSE_HTTPD_ENOIMPL);
|
|
||||||
return -1;*/
|
|
||||||
|
|
||||||
#else
|
#else
|
||||||
|
|
||||||
qse_sck_len_t len;
|
qse_sck_len_t len;
|
||||||
@ -1380,6 +1374,9 @@ static int is_peer_socket_connected (qse_httpd_t* httpd, qse_httpd_peer_t* peer)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (ret == EINPROGRESS) return 0;
|
if (ret == EINPROGRESS) return 0;
|
||||||
|
#if defined(__DOS__)
|
||||||
|
if (ret == EISCONN) return 1; /* watt-32 gives EISCONN when connected */
|
||||||
|
#endif
|
||||||
if (ret != 0)
|
if (ret != 0)
|
||||||
{
|
{
|
||||||
qse_httpd_seterrnum (httpd, skerr_to_errnum (ret));
|
qse_httpd_seterrnum (httpd, skerr_to_errnum (ret));
|
||||||
|
Loading…
x
Reference in New Issue
Block a user