hd

CellDefineVar.cpp 4.1KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182
  1. #include "StdAfx.h"
  2. #include "CellDefineVar.h"
  3. #include "IvrFlow.h"
  4. #include "FlowDataProvider.h"
  5. IMPLEMENT_CELL_AUTOCREATE(CCellDefineVar, CELL_NAME_DEFINE_VAR)
  6. CCellDefineVar::CCellDefineVar(void) : m_NextPos(0)
  7. {
  8. }
  9. CCellDefineVar::CCellDefineVar( CCellDefineVar & cellDefineVar ) : CCellBase(cellDefineVar)
  10. {
  11. m_NextPos = cellDefineVar.m_NextPos;
  12. POSITION pos = cellDefineVar.m_VarList.GetHeadPosition();
  13. while(pos != NULL)
  14. {
  15. VarInfo *pVarInfo = cellDefineVar.m_VarList.GetNext(pos);
  16. ASSERT(pVarInfo != NULL);
  17. VarInfo *pVarInfoTmp = new VarInfo(*pVarInfo);
  18. ASSERT(pVarInfoTmp != NULL);
  19. m_VarList.AddTail(pVarInfoTmp);
  20. }
  21. }
  22. CCellDefineVar::~CCellDefineVar(void)
  23. {
  24. __release();
  25. }
  26. /*****************************************************************
  27. **【函数名称】 __release
  28. **【函数功能】 释放资源
  29. **【参数】
  30. **【返回值】
  31. ****************************************************************/
  32. void CCellDefineVar::__release( void )
  33. {
  34. while(!m_VarList.IsEmpty())
  35. delete m_VarList.RemoveHead();
  36. }
  37. /*****************************************************************
  38. **【函数名称】 addVar
  39. **【函数功能】 添加变量接口
  40. **【参数】 VarType:变量类型
  41. VarName:变量名
  42. VarVal:变量值
  43. **【返回值】
  44. ****************************************************************/
  45. void CCellDefineVar::addVar( int VarType, const CString& VarName, const CString& VarVal )
  46. {
  47. VarInfo *pVarInfo = new VarInfo(VarType, VarName, VarVal);
  48. ASSERT(pVarInfo != NULL);
  49. if(pVarInfo == NULL)
  50. {
  51. CString Info;
  52. _getCellInfo(Info);
  53. ILogger::getInstance().log(LOG_CLASS_BUSI, LOG_LEVEL_WARNING, _T("{Cell}: 执行[%s]时创建变量结构失败"), Info);
  54. }
  55. else
  56. {
  57. m_VarList.AddTail(pVarInfo);
  58. }
  59. }
  60. /*****************************************************************
  61. **【函数名称】 Operate
  62. **【函数功能】 节点执行函数
  63. **【参数】
  64. **【返回值】 下一个节点编号
  65. ****************************************************************/
  66. int CCellDefineVar::operate( void )
  67. {
  68. if(m_pIvrFlow == NULL)
  69. return CELL_OP_ERROR;
  70. CString Info;
  71. _getCellInfo(Info);
  72. ILogger::getInstance().log(LOG_CLASS_BUSI, LOG_LEVEL_NORMAL, _T("{Cell}: 开始执行[%s]"), Info);
  73. POSITION pos = m_VarList.GetHeadPosition();
  74. while(pos != NULL)
  75. {
  76. VarInfo *pVarInfo = m_VarList.GetNext(pos);
  77. ASSERT(pVarInfo != NULL);
  78. CString strVarValue = "";
  79. if(pVarInfo->nVarType == CELL_DATA_VAR)
  80. {
  81. if(!m_pIvrFlow->findVarValue(pVarInfo->szVarValue, strVarValue))
  82. ILogger::getInstance().log(LOG_CLASS_BUSI, LOG_LEVEL_WARNING, _T("{Cell}: 执行[%s]出错,变量[%s]未找到对应值"), Info, pVarInfo->szVarValue);
  83. }
  84. else
  85. {
  86. strVarValue = pVarInfo->szVarValue;
  87. }
  88. m_pIvrFlow->addVar(pVarInfo->szVarName, strVarValue);
  89. }
  90. return m_NextPos;
  91. }
  92. /*****************************************************************
  93. **【函数名称】 copy
  94. **【函数功能】 拷贝自身
  95. **【参数】
  96. **【返回值】 拷贝副本
  97. ****************************************************************/
  98. CCellBase * CCellDefineVar::copy( void )
  99. {
  100. CCellBase * pCellBase = new CCellDefineVar(*this);
  101. return pCellBase;
  102. }
  103. /*****************************************************************
  104. **【函数名称】 fillData
  105. **【函数功能】 节点解析,填充数据
  106. **【参数】 Provider:数据提供器
  107. **【返回值】 成功true,失败false
  108. ****************************************************************/
  109. bool CCellDefineVar::fillData( IFlowDataProvider& Provider )
  110. {
  111. CString Data;
  112. do
  113. {
  114. if(!Provider.getData(CELL_ATTRIBUTE_POS, Data))
  115. {
  116. Data = _T("节点号");
  117. break;
  118. }
  119. else
  120. {
  121. sscanf_s(Data, _T("%d"), &m_Pos);
  122. if(m_Pos < 1)
  123. {
  124. Data = _T("节点号");
  125. break;
  126. }
  127. }
  128. if(!Provider.getData(CELL_ATTRIBUTE_NEXT, Data))
  129. {
  130. Data = _T("跳转节点");
  131. break;
  132. }
  133. else
  134. {
  135. sscanf_s(Data, _T("%d"), &m_NextPos);
  136. if(m_NextPos < 0)
  137. {
  138. Data = _T("跳转节点");
  139. break;
  140. }
  141. }
  142. Data.Format(_T("%s[@%s='%d']/%s"), XPATH_CELL, CELL_ATTRIBUTE_POS, m_Pos, FLOW_SUB_NODE_DEF_VAR);
  143. if(!Provider.getFlowDefVar(Data, *this))
  144. {
  145. Data = _T("定义变量");
  146. break;
  147. }
  148. Provider.getData(CELL_ATTRIBUTE_NOTE, m_Note);
  149. return true;
  150. } while (false);
  151. ILogger::getInstance().log(LOG_CLASS_BUSI, LOG_LEVEL_ERROR, _T("{Cell}: 节点[%s]解析失败, '%s'错误"), CELL_NAME_DEFINE_VAR, Data);
  152. return false;
  153. }