ast_expression.cpp
来自「这是广泛使用的通信开源项目,对于大容量,高并发的通讯要求完全能够胜任,他广泛可用」· C++ 代码 · 共 2,158 行 · 第 1/5 页
CPP
2,158 行
{
return 0;
}
ev->u.llval = (ACE_CDR::LongLong) ev->u.fval;
ev->et = AST_Expression::EV_longlong;
return ev;
case AST_Expression::EV_double:
if (ev->u.dval > (double) ACE_INT64_MAX
|| ev->u.dval < (double) ACE_INT64_MIN)
{
return 0;
}
ev->u.llval = (ACE_CDR::LongLong) ev->u.dval;
ev->et = AST_Expression::EV_longlong;
return ev;
case AST_Expression::EV_char:
ev->u.llval = (ACE_CDR::LongLong) ev->u.cval;
ev->et = AST_Expression::EV_longlong;
return ev;
case AST_Expression::EV_wchar:
ev->u.llval = (ACE_CDR::LongLong) ev->u.wcval;
ev->et = AST_Expression::EV_longlong;
return ev;
case AST_Expression::EV_octet:
ev->u.llval = (ACE_CDR::LongLong) ev->u.oval;
ev->et = AST_Expression::EV_longlong;
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;
}
#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)
switch (ev->et)
{
case AST_Expression::EV_short:
if (ev->u.sval < 0)
{
return 0;
}
ev->u.ullval = (ACE_CDR::ULongLong) ev->u.sval;
ev->et = AST_Expression::EV_ulonglong;
return ev;
case AST_Expression::EV_ushort:
ev->u.ullval = (ACE_CDR::ULongLong) ev->u.usval;
ev->et = AST_Expression::EV_ulonglong;
return ev;
case AST_Expression::EV_long:
if (ev->u.lval < 0)
{
return 0;
}
ev->u.ullval = (ACE_CDR::ULongLong) ev->u.lval;
ev->et = AST_Expression::EV_ulonglong;
return ev;
case AST_Expression::EV_ulong:
ev->u.ullval = (ACE_CDR::ULongLong) ev->u.ulval;
ev->et = AST_Expression::EV_ulonglong;
return ev;
case AST_Expression::EV_longlong:
if (ev->u.llval < 0)
{
return 0;
}
ev->u.ullval = (ACE_CDR::LongLong) ev->u.llval;
ev->et = AST_Expression::EV_ulonglong;
return ev;
case AST_Expression::EV_ulonglong:
return ev;
case AST_Expression::EV_bool:
ev->u.ullval = (ACE_CDR::ULongLong) ev->u.bval;
ev->et = AST_Expression::EV_ulonglong;
return ev;
case AST_Expression::EV_float:
if (ev->u.fval < 0.0
|| ev->u.fval > (float) ACE_UINT64_MAX)
{
return 0;
}
ev->u.ullval = (ACE_CDR::ULongLong) ev->u.fval;
ev->et = AST_Expression::EV_ulonglong;
return ev;
case AST_Expression::EV_double:
if (ev->u.dval < 0.0
|| ev->u.dval > (double) ACE_UINT64_MAX)
{
return 0;
}
ev->u.ullval = (ACE_CDR::ULongLong) ev->u.dval;
ev->et = AST_Expression::EV_ulonglong;
return ev;
case AST_Expression::EV_char:
if ((signed char) ev->u.cval < 0)
{
return 0;
}
ev->u.ullval = (ACE_CDR::ULongLong) ev->u.cval;
ev->et = AST_Expression::EV_ulonglong;
return ev;
case AST_Expression::EV_wchar:
ev->u.ullval = (ACE_CDR::ULongLong) ev->u.wcval;
ev->et = AST_Expression::EV_ulonglong;
return ev;
case AST_Expression::EV_octet:
ev->u.ullval = (ACE_CDR::ULongLong) ev->u.oval;
ev->et = AST_Expression::EV_ulonglong;
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;
}
#else /* ! defined (ACE_LACKS_LONGLONG_T) */
return 0;
#endif /* ! defined (ACE_LACKS_LONGLONG_T) */
case AST_Expression::EV_bool:
switch (ev->et)
{
case AST_Expression::EV_short:
ev->u.bval = (ev->u.sval == 0) ? I_FALSE : I_TRUE;
ev->et = AST_Expression::EV_bool;
return ev;
case AST_Expression::EV_ushort:
ev->u.bval = (ev->u.usval == 0) ? I_FALSE : I_TRUE;
ev->et = AST_Expression::EV_bool;
return ev;
case AST_Expression::EV_long:
ev->u.bval = (ev->u.lval == 0) ? I_FALSE : I_TRUE;
ev->et = AST_Expression::EV_bool;
return ev;
case AST_Expression::EV_ulong:
ev->u.bval = (ev->u.ulval == 0) ? I_FALSE : I_TRUE;
ev->et = AST_Expression::EV_bool;
return ev;
case AST_Expression::EV_longlong:
#if ! defined (ACE_LACKS_LONGLONG_T)
ev->u.bval = (ev->u.llval == 0) ? I_FALSE : I_TRUE;
ev->et = AST_Expression::EV_bool;
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)
ev->u.bval = (ev->u.ullval == 0) ? I_FALSE : I_TRUE;
ev->et = AST_Expression::EV_bool;
return ev;
#else /* ! defined (ACE_LACKS_LONGLONG_T) */
return 0;
#endif /* ! defined (ACE_LACKS_LONGLONG_T) */
case AST_Expression::EV_bool:
return ev;
case AST_Expression::EV_float:
ev->u.bval = (ev->u.fval == 0.0) ? I_FALSE : I_TRUE;
ev->et = AST_Expression::EV_bool;
return ev;
case AST_Expression::EV_double:
ev->u.bval = (ev->u.dval == 0.0) ? I_FALSE : I_TRUE;
ev->et = AST_Expression::EV_bool;
return ev;
case AST_Expression::EV_char:
ev->u.bval = (ev->u.cval == 0) ? I_FALSE : I_TRUE;
ev->et = AST_Expression::EV_bool;
return ev;
case AST_Expression::EV_wchar:
ev->u.bval = (ev->u.wcval == 0) ? I_FALSE : I_TRUE;
ev->et = AST_Expression::EV_bool;
return ev;
case AST_Expression::EV_octet:
ev->u.bval = (ev->u.oval == 0) ? I_FALSE : I_TRUE;
ev->et = AST_Expression::EV_bool;
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_float:
switch (ev->et)
{
case AST_Expression::EV_short:
ev->u.fval = (float) ev->u.sval;
ev->et = AST_Expression::EV_float;
return ev;
case AST_Expression::EV_ushort:
ev->u.fval = (float) ev->u.usval;
ev->et = AST_Expression::EV_float;
return ev;
case AST_Expression::EV_long:
ev->u.fval = (float) ev->u.lval;
ev->et = AST_Expression::EV_float;
return ev;
case AST_Expression::EV_ulong:
ev->u.fval = (float) ev->u.ulval;
ev->et = AST_Expression::EV_float;
return ev;
case AST_Expression::EV_longlong:
#if ! defined (ACE_LACKS_LONGLONG_T)
if (ev->u.llval > FLT_MAX
|| ev->u.llval < -(ACE_FLT_MAX))
{
return 0;
}
ev->u.fval = (float) ev->u.llval;
ev->et = AST_Expression::EV_float;
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)
// Some compilers don't implement unsigned 64-bit to float conversions,
// so we are stuck with the signed 64-bit max value.
if (ev->u.ullval > ACE_UINT64_MAX
|| (ACE_CDR::LongLong) ev->u.ullval > ACE_FLT_MAX)
{
return 0;
}
ev->u.fval = (float) ((ACE_CDR::LongLong) ev->u.ullval);
ev->et = AST_Expression::EV_float;
return ev;
#else /* ! defined (ACE_LACKS_LONGLONG_T) */
return 0;
#endif /* ! defined (ACE_LACKS_LONGLONG_T) */
case AST_Expression::EV_bool:
ev->u.fval = (float) ((ev->u.bval == I_TRUE) ? 1.0 : 0.0);
ev->et = AST_Expression::EV_float;
return ev;
case AST_Expression::EV_float:
return ev;
case AST_Expression::EV_double:
if (ev->u.dval > ACE_FLT_MAX
|| ev->u.dval < -(ACE_FLT_MAX))
{
return 0;
}
ev->u.fval = (float) ev->u.dval;
ev->et = AST_Expression::EV_float;
return ev;
case AST_Expression::EV_char:
ev->u.fval = (float) ev->u.cval;
ev->et = AST_Expression::EV_float;
return ev;
case AST_Expression::EV_wchar:
ev->u.fval = (float) ev->u.wcval;
ev->et = AST_Expression::EV_float;
return ev;
case AST_Expression::EV_octet:
ev->u.fval = (float) ev->u.oval;
ev->et = AST_Expression::EV_float;
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_double:
switch (ev->et)
{
case AST_Expression::EV_short:
ev->u.dval = (double) ev->u.sval;
ev->et = AST_Expression::EV_double;
return ev;
case AST_Expression::EV_ushort:
ev->u.dval = (double) ev->u.usval;
ev->et = AST_Expression::EV_double;
return ev;
case AST_Expression::EV_long:
ev->u.dval = (double) ev->u.lval;
ev->et = AST_Expression::EV_double;
return ev;
case AST_Expression::EV_ulong:
ev->u.dval = (double) ev->u.ulval;
ev->et = AST_Expression::EV_double;
return ev;
case AST_Expression::EV_longlong:
#if ! defined (ACE_LACKS_LONGLONG_T)
ev->u.dval = (double) ev->u.llval;
ev->et = AST_Expression::EV_double;
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)
// Some compilers don't implement unsigned 64-bit to double
// conversions, so we are stuck with the signed 64-bit max value.
if (ev->u.ullval > ACE_INT64_MAX)
{
return 0;
}
ev->u.dval = (double) ((ACE_CDR::LongLong) ev->u.ullval);
ev->et = AST_Expression::EV_double;
return ev;
#else /* ! defined (ACE_LACKS_LONGLONG_T) */
return NULL;
#endif /* ! defined (ACE_LACKS_LONGLONG_T) */
case AST_Expression::EV_bool:
ev->u.dval = (ev->u.bval == I_TRUE) ? 1.0 : 0.0;
ev->et = AST_Expression::EV_double;
return ev;
case AST_Expression::EV_float:
ev->u.dval = (double) ev->u.fval;
ev->et = AST_Expression::EV_double;
return ev;
case AST_Expression::EV_double:
return ev;
case AST_Expression::EV_char:
ev->u.dval = (double) ev->u.cval;
ev->et = AST_Expression::EV_double;
return ev;
case AST_Expression::EV_wchar:
ev->u.dval = (double) ev->u.wcval;
ev->et = AST_Expression::EV_double;
return ev;
case AST_Expression::EV_octet:
ev->u.dval = (double) ev->u.oval;
ev->et = AST_Expression::EV_double;
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_char:
switch (ev->et)
{
case AST_Expression::EV_short:
if (ev->u.sval > (short) ACE_CHAR_MAX
|| ev->u.sval < (short) ACE_CHAR_MIN)
{
return 0;
}
ev->u.cval = (char) ev->u.sval;
ev->et = AST_Expression::EV_char;
return ev;
case AST_Expression::EV_ushort:
if (ev->u.usval > (unsigned short) ACE_CHAR_MAX)
{
return 0;
}
ev->u.cval = (char) ev->u.usval;
ev->et = AST_Expression::EV_char;
return ev;
case AST_Expression::EV_long:
if (ev->u.lval > (long) ACE_CHAR_MAX
|| ev->u.lval < (long) ACE_CHAR_MIN)
{
return 0;
}
ev->u.cval = (char) ev->u.lval;
ev->et = AST_Expression::EV_char;
return ev;
case AST_Expression::EV_ulong:
if (ev->u.ulval > (unsigned long) ACE_CHAR_MAX)
{
return 0;
}
ev->u.cval = (char) ev->u.ulval;
ev->et = AST_Expression::EV_char;
return ev;
case AST_Expression::EV_longlong:
#if ! defined (ACE_LACKS_LONGLONG_T)
if (ev->u.llval > (ACE_CDR::LongLong) ACE_CHAR_MAX
|| ev->u.llval < (ACE_CDR::LongLong) ACE_CHAR_MIN)
{
return 0;
}
ev->u.cval = (char) ev->u.llval;
ev->et = AST_Expression::EV_char;
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_CHAR_MAX)
{
return 0;
}
ev->u.cval = (char) ev->u.ullval;
ev->et = AST_Expression::EV_char;
return ev;
#else /* ! defined (ACE_LACKS_LONGLONG_T) */
return 0;
#endif /* ! defined (ACE_LACKS_LONGLONG_T) */
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?