ast_expression.cpp
来自「这是广泛使用的通信开源项目,对于大容量,高并发的通讯要求完全能够胜任,他广泛可用」· C++ 代码 · 共 2,158 行 · 第 1/5 页
CPP
2,158 行
case AST_Expression::EV_bool:
ev->u.cval = (char) ev->u.bval;
ev->et = AST_Expression::EV_char;
return ev;
case AST_Expression::EV_float:
if (ev->u.fval > (float) ACE_CHAR_MAX
|| ev->u.fval < (float) ACE_CHAR_MIN)
{
return 0;
}
ev->u.cval = (char) ev->u.fval;
ev->et = AST_Expression::EV_char;
return ev;
case AST_Expression::EV_double:
if (ev->u.dval > (double) ACE_CHAR_MAX
|| ev->u.dval < (double) ACE_CHAR_MIN)
{
return 0;
}
ev->u.cval = (char) ev->u.dval;
ev->et = AST_Expression::EV_char;
return ev;
case AST_Expression::EV_char:
return ev;
case AST_Expression::EV_wchar:
if (ev->u.wcval > (ACE_CDR::WChar) ACE_CHAR_MAX)
{
return 0;
}
ev->u.cval = (char) ev->u.wcval;
ev->et = AST_Expression::EV_char;
return ev;
case AST_Expression::EV_octet:
if (ev->u.oval > (unsigned char) ACE_CHAR_MAX)
{
return 0;
}
ev->u.cval = (char) ev->u.oval;
ev->et = AST_Expression::EV_char;
return ev;
case AST_Expression::EV_longdouble:
case AST_Expression::EV_wstring:
case AST_Expression::EV_string:
case AST_Expression::EV_enum:
case AST_Expression::EV_void:
case AST_Expression::EV_none:
case AST_Expression::EV_any:
case AST_Expression::EV_object:
return 0;
}
case AST_Expression::EV_wchar:
switch (ev->et)
{
case AST_Expression::EV_short:
if (ev->u.sval < 0)
{
return 0;
}
ev->u.wcval = (ACE_CDR::WChar) ev->u.sval;
ev->et = AST_Expression::EV_wchar;
return ev;
case AST_Expression::EV_ushort:
ev->u.wcval = (ACE_CDR::WChar) ev->u.usval;
ev->et = AST_Expression::EV_char;
return ev;
case AST_Expression::EV_long:
if (ev->u.lval < 0
|| ev->u.lval > ACE_WCHAR_MAX)
{
return 0;
}
ev->u.wcval = (ACE_CDR::WChar) ev->u.lval;
ev->et = AST_Expression::EV_wchar;
return ev;
case AST_Expression::EV_ulong:
if (ev->u.ulval > ACE_WCHAR_MAX)
{
return 0;
}
ev->u.wcval = (ACE_CDR::WChar) ev->u.ulval;
ev->et = AST_Expression::EV_wchar;
return ev;
case AST_Expression::EV_longlong:
#if ! defined (ACE_LACKS_LONGLONG_T)
if (ev->u.llval > (ACE_CDR::LongLong) ACE_WCHAR_MAX
|| ev->u.llval < 0)
{
return 0;
}
ev->u.wcval = (ACE_CDR::WChar) ev->u.llval;
ev->et = AST_Expression::EV_wchar;
return ev;
#else /* ! defined (ACE_LACKS_LONGLONG_T) */
return 0;
#endif /* ! defined (ACE_LACKS_LONGLONG_T) */
case AST_Expression::EV_ulonglong:
#if ! defined (ACE_LACKS_LONGLONG_T)
if (ev->u.ullval > (ACE_CDR::ULongLong) ACE_WCHAR_MAX)
{
return 0;
}
ev->u.wcval = (ACE_CDR::WChar) ev->u.ullval;
ev->et = AST_Expression::EV_wchar;
return ev;
#else /* ! defined (ACE_LACKS_LONGLONG_T) */
return 0;
#endif /* ! defined (ACE_LACKS_LONGLONG_T) */
case AST_Expression::EV_bool:
ev->u.wcval = (ACE_CDR::WChar) ev->u.bval;
ev->et = AST_Expression::EV_wchar;
return ev;
case AST_Expression::EV_float:
if (ev->u.fval > (float) ACE_WCHAR_MAX
|| ev->u.fval < 0)
{
return 0;
}
ev->u.wcval = (ACE_CDR::WChar) ev->u.fval;
ev->et = AST_Expression::EV_wchar;
return ev;
case AST_Expression::EV_double:
if (ev->u.dval > (double) ACE_WCHAR_MAX
|| ev->u.dval < 0)
{
return 0;
}
ev->u.wcval = (ACE_CDR::WChar) ev->u.dval;
ev->et = AST_Expression::EV_wchar;
return ev;
case AST_Expression::EV_char:
if ((signed char) ev->u.cval < 0)
{
return 0;
}
ev->u.wcval = (ACE_CDR::WChar) ev->u.cval;
ev->et = AST_Expression::EV_wchar;
return ev;
case AST_Expression::EV_wchar:
return ev;
case AST_Expression::EV_octet:
ev->u.wcval = (ACE_CDR::WChar) ev->u.oval;
ev->et = AST_Expression::EV_wchar;
return ev;
case AST_Expression::EV_longdouble:
case AST_Expression::EV_wstring:
case AST_Expression::EV_string:
case AST_Expression::EV_enum:
case AST_Expression::EV_void:
case AST_Expression::EV_none:
case AST_Expression::EV_any:
case AST_Expression::EV_object:
return 0;
}
case AST_Expression::EV_octet:
switch (ev->et)
{
case AST_Expression::EV_short:
if (ev->u.sval < 0
|| ev->u.sval > (short) ACE_OCTET_MAX)
{
return 0;
}
ev->u.oval = (unsigned char) ev->u.sval;
ev->et = AST_Expression::EV_octet;
return ev;
case AST_Expression::EV_ushort:
if (ev->u.usval > (unsigned short) ACE_OCTET_MAX)
{
return 0;
}
ev->u.oval = (unsigned char) ev->u.usval;
ev->et = AST_Expression::EV_octet;
return ev;
case AST_Expression::EV_long:
if (ev->u.lval < 0
|| ev->u.lval > (long) ACE_OCTET_MAX)
{
return 0;
}
ev->u.oval = (unsigned char) ev->u.lval;
ev->et = AST_Expression::EV_octet;
return ev;
case AST_Expression::EV_ulong:
if (ev->u.ulval > (unsigned long) ACE_OCTET_MAX)
{
return 0;
}
ev->u.oval = (unsigned char) ev->u.ulval;
ev->et = AST_Expression::EV_octet;
return ev;
case AST_Expression::EV_longlong:
#if ! defined (ACE_LACKS_LONGLONG_T)
if (ev->u.llval < 0
|| ev->u.llval > (ACE_CDR::LongLong) ACE_OCTET_MAX)
{
return 0;
}
ev->u.oval = (unsigned char) ev->u.llval;
ev->et = AST_Expression::EV_octet;
return ev;
#else /* ! defined (ACE_LACKS_LONGLONG_T) */
return 0;
#endif /* ! defined (ACE_LACKS_LONGLONG_T) */
case AST_Expression::EV_ulonglong:
#if ! defined (ACE_LACKS_LONGLONG_T)
if (ev->u.ullval > (ACE_CDR::ULongLong) ACE_OCTET_MAX)
{
return 0;
}
ev->u.oval = (unsigned char) ev->u.ullval;
ev->et = AST_Expression::EV_octet;
return ev;
#else /* ! defined (ACE_LACKS_LONGLONG_T) */
return 0;
#endif /* ! defined (ACE_LACKS_LONGLONG_T) */
case AST_Expression::EV_bool:
ev->u.oval = (unsigned char) ((ev->u.bval == I_FALSE) ? 1 : 0);
ev->et = AST_Expression::EV_octet;
return ev;
case AST_Expression::EV_float:
if (ev->u.fval < 0.0
|| ev->u.fval > (float) ACE_OCTET_MAX)
{
return 0;
}
ev->u.oval = (unsigned char) ev->u.fval;
ev->et = AST_Expression::EV_octet;
return ev;
case AST_Expression::EV_double:
if (ev->u.dval < 0.0
|| ev->u.dval > (double) ACE_OCTET_MAX)
{
return 0;
}
ev->u.oval = (unsigned char) ev->u.dval;
ev->et = AST_Expression::EV_octet;
return ev;
case AST_Expression::EV_char:
if ((signed char) ev->u.cval < 0)
{
return 0;
}
ev->u.oval = (unsigned char) ev->u.cval;
ev->et = AST_Expression::EV_octet;
return ev;
case AST_Expression::EV_wchar:
if (ev->u.wcval > (ACE_CDR::WChar) ACE_OCTET_MAX)
{
return 0;
}
ev->u.oval = (unsigned char) ev->u.wcval;
ev->et = AST_Expression::EV_octet;
return ev;
case AST_Expression::EV_octet:
return ev;
case AST_Expression::EV_longdouble:
case AST_Expression::EV_wstring:
case AST_Expression::EV_string:
case AST_Expression::EV_enum:
case AST_Expression::EV_void:
case AST_Expression::EV_none:
case AST_Expression::EV_any:
case AST_Expression::EV_object:
return 0;
}
case AST_Expression::EV_enum:
switch (ev->et)
{
case AST_Expression::EV_enum:
case AST_Expression::EV_ulong:
return ev;
default:
return 0;
}
case AST_Expression::EV_void:
switch (ev->et)
{
case AST_Expression::EV_void:
return ev;
default:
return 0;
}
case AST_Expression::EV_none:
return 0;
case AST_Expression::EV_string:
switch (ev->et)
{
case AST_Expression::EV_string:
return ev;
default:
return 0;
}
case AST_Expression::EV_longdouble:
case AST_Expression::EV_wstring:
case AST_Expression::EV_any:
case AST_Expression::EV_object:
return 0;
}
return 0;
}
// Integer literals may not be assigned to floating point constants,
// and vice versa.
static idl_bool
incompatible_types (AST_Expression::ExprType t1,
AST_Expression::ExprType t2)
{
switch (t1)
{
case AST_Expression::EV_short:
case AST_Expression::EV_ushort:
case AST_Expression::EV_long:
case AST_Expression::EV_ulong:
case AST_Expression::EV_longlong:
case AST_Expression::EV_ulonglong:
case AST_Expression::EV_octet:
case AST_Expression::EV_bool:
switch (t2)
{
case AST_Expression::EV_short:
case AST_Expression::EV_ushort:
case AST_Expression::EV_long:
case AST_Expression::EV_ulong:
case AST_Expression::EV_longlong:
case AST_Expression::EV_ulonglong:
case AST_Expression::EV_octet:
case AST_Expression::EV_bool:
return 0;
default:
return 1;
}
case AST_Expression::EV_float:
case AST_Expression::EV_double:
case AST_Expression::EV_longdouble:
switch (t2)
{
case AST_Expression::EV_float:
case AST_Expression::EV_double:
case AST_Expression::EV_longdouble:
return 0;
default:
return 1;
}
case AST_Expression::EV_char:
case AST_Expression::EV_wchar:
case AST_Expression::EV_string:
case AST_Expression::EV_wstring:
case AST_Expression::EV_enum:
case AST_Expression::EV_any:
case AST_Expression::EV_object:
case AST_Expression::EV_void:
case AST_Expression::EV_none:
default:
return 0;
}
}
// Evaluate the expression wrt the evaluation kind requested. Supported
// evaluation kinds are
// - EK_const: The expression must evaluate to a constant
// - EK_positive_int: The expression must further evaluate to a
// positive integer
// @@(JP) This just maps one enum to another. It's a temporary fix,
// but AST_Expression::EvalKind should go eventually.
static AST_Expression::AST_ExprValue *
eval_kind(AST_Expression::AST_ExprValue *ev, AST_Expression::EvalKind ek)
{
switch (ek)
{
case AST_Expression::EK_const:
return ev;
case AST_Expression::EK_positive_int:
return coerce_value (ev, AST_Expression::EV_ulong);
case AST_Expression::EK_short:
return coerce_value (ev, AST_Expression::EV_short);
case AST_Expression::EK_ushort:
return coerce_value (ev, AST_Expression::EV_ushort);
case AST_Expression::EK_long:
return coerce_value (ev, AST_Expression::EV_long);
case AST_Expression::EK_ulong:
return coerce_value (ev, AST_Expression::EV_ulong);
#if ! defined (ACE_LACKS_LONGLONG_T)
case AST_Expression::EK_longlong:
return coerce_value (ev, AST_Expression::EV_longlong);
case AST_Expression::EK_ulonglong:
return coerce_value (ev, AST_Expression::EV_ulonglong);
#endif /* ! defined (ACE_LACKS_LONGLONG_T) */
case AST_Expression::EK_octet:
return coerce_value (ev, AST_Expression::EV_octet);
default:
return 0;
}
}
// Private operations.
// Apply binary operators to an AST_Expression after evaluating
// its sub-expressions.
// Operations supported: '+', '-', '*', '/'
AST_Expression::AST_ExprValue *
AST_Expression::eval_bin_op (AST_Expression::EvalKind /* ek */)
{
AST_ExprValue *retval = 0;
if (this->pd_v1 == 0 || this->pd_v2 == 0)
{
return 0;
}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?