hd

CellBegin.cpp 2.7KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  1. #include "StdAfx.h"
  2. #include "CellBegin.h"
  3. #include "IvrFlow.h"
  4. #include "FlowDataProvider.h"
  5. IMPLEMENT_CELL_AUTOCREATE(CCellBegin, CELL_NAME_START)
  6. CCellBegin::CCellBegin(void) : m_NextPos(0)
  7. {
  8. }
  9. CCellBegin::CCellBegin( CCellBegin& cellBegin ) : CCellBase(cellBegin), m_NextPos(cellBegin.m_NextPos)
  10. {
  11. }
  12. CCellBegin::~CCellBegin(void)
  13. {
  14. }
  15. /*****************************************************************
  16. **【函数名称】 Operate
  17. **【函数功能】 节点执行函数
  18. **【参数】
  19. **【返回值】 下一个节点编号
  20. ****************************************************************/
  21. int CCellBegin::operate( void )
  22. {
  23. if(m_pIvrFlow == NULL)
  24. return CELL_OP_ERROR;
  25. CString Info;
  26. _getCellInfo(Info);
  27. ILogger::getInstance().log(LOG_CLASS_BUSI, LOG_LEVEL_NORMAL, _T("{Cell}: 开始执行[%s]"), Info);
  28. CTime CurTime = CTime::GetCurrentTime();
  29. //BeginTime 摘机时间 YYYY-MM-DD HH:MM:SS
  30. CString strBeginTime = CurTime.Format("%Y-%m-%d %H:%M:%S");
  31. m_pIvrFlow->addVar(SYSTEM_VAR_TIME_BEGIN, strBeginTime);
  32. //StartTime 摘机时间 yyyymmddhhmmss
  33. CString strStartTime = CurTime.Format("%Y%m%d%H%M%S") ;
  34. m_pIvrFlow->addVar(SYSTEM_VAR_TIME_START, strStartTime);
  35. //HourMinute 摘机时间 HH:MM
  36. CString strHoutMinute = CurTime.Format("%H%M");
  37. m_pIvrFlow->addVar(SYSTEM_VAR_TIME_HM, strHoutMinute);
  38. //Week 摘机时是星期几
  39. CString strWeek = CurTime.Format("%w");
  40. m_pIvrFlow->addVar(SYSTEM_VAR_TIME_WEEK, strWeek);
  41. return m_NextPos;
  42. }
  43. /*****************************************************************
  44. **【函数名称】 copy
  45. **【函数功能】 拷贝自身
  46. **【参数】
  47. **【返回值】 拷贝副本
  48. ****************************************************************/
  49. CCellBase * CCellBegin::copy( void )
  50. {
  51. CCellBase *pCellBase = new CCellBegin(*this);
  52. return pCellBase;
  53. }
  54. /*****************************************************************
  55. **【函数名称】 fillData
  56. **【函数功能】 节点解析,填充数据
  57. **【参数】 Provider:数据提供器
  58. **【返回值】 成功true,失败false
  59. ****************************************************************/
  60. bool CCellBegin::fillData( IFlowDataProvider& Provider )
  61. {
  62. CString Data;
  63. do
  64. {
  65. if(!Provider.getData(CELL_ATTRIBUTE_POS, Data))
  66. {
  67. Data = _T("节点号");
  68. break;
  69. }
  70. else
  71. {
  72. sscanf_s(Data, _T("%d"), &m_Pos);
  73. if(m_Pos < 1)
  74. {
  75. Data = _T("节点号");
  76. break;
  77. }
  78. }
  79. if(!Provider.getData(CELL_ATTRIBUTE_NEXT, Data))
  80. {
  81. Data = _T("下一节点号");
  82. break;
  83. }
  84. else
  85. {
  86. sscanf_s(Data, _T("%d"), &m_NextPos);
  87. if(m_NextPos < 1)
  88. {
  89. Data = _T("下一节点号");
  90. break;
  91. }
  92. }
  93. Provider.getData(CELL_ATTRIBUTE_NOTE, m_Note);
  94. return true;
  95. } while (false);
  96. ILogger::getInstance().log(LOG_CLASS_BUSI, LOG_LEVEL_ERROR, _T("{Cell}: 节点[%s]解析失败, '%s'错误"), CELL_NAME_START, Data);
  97. return false;
  98. }