#include "StdAfx.h" #include "CellBegin.h" #include "IvrFlow.h" #include "FlowDataProvider.h" IMPLEMENT_CELL_AUTOCREATE(CCellBegin, CELL_NAME_START) CCellBegin::CCellBegin(void) : m_NextPos(0) { } CCellBegin::CCellBegin( CCellBegin& cellBegin ) : CCellBase(cellBegin), m_NextPos(cellBegin.m_NextPos) { } CCellBegin::~CCellBegin(void) { } /***************************************************************** **【函数名称】 Operate **【函数功能】 节点执行函数 **【参数】 **【返回值】 下一个节点编号 ****************************************************************/ int CCellBegin::operate( void ) { if(m_pIvrFlow == NULL) return CELL_OP_ERROR; CString Info; _getCellInfo(Info); ILogger::getInstance().log(LOG_CLASS_BUSI, LOG_LEVEL_NORMAL, _T("{Cell}: 开始执行[%s]"), Info); CTime CurTime = CTime::GetCurrentTime(); //BeginTime 摘机时间 YYYY-MM-DD HH:MM:SS CString strBeginTime = CurTime.Format("%Y-%m-%d %H:%M:%S"); m_pIvrFlow->addVar(SYSTEM_VAR_TIME_BEGIN, strBeginTime); //StartTime 摘机时间 yyyymmddhhmmss CString strStartTime = CurTime.Format("%Y%m%d%H%M%S") ; m_pIvrFlow->addVar(SYSTEM_VAR_TIME_START, strStartTime); //HourMinute 摘机时间 HH:MM CString strHoutMinute = CurTime.Format("%H%M"); m_pIvrFlow->addVar(SYSTEM_VAR_TIME_HM, strHoutMinute); //Week 摘机时是星期几 CString strWeek = CurTime.Format("%w"); m_pIvrFlow->addVar(SYSTEM_VAR_TIME_WEEK, strWeek); return m_NextPos; } /***************************************************************** **【函数名称】 copy **【函数功能】 拷贝自身 **【参数】 **【返回值】 拷贝副本 ****************************************************************/ CCellBase * CCellBegin::copy( void ) { CCellBase *pCellBase = new CCellBegin(*this); return pCellBase; } /***************************************************************** **【函数名称】 fillData **【函数功能】 节点解析,填充数据 **【参数】 Provider:数据提供器 **【返回值】 成功true,失败false ****************************************************************/ bool CCellBegin::fillData( IFlowDataProvider& Provider ) { CString Data; do { if(!Provider.getData(CELL_ATTRIBUTE_POS, Data)) { Data = _T("节点号"); break; } else { sscanf_s(Data, _T("%d"), &m_Pos); if(m_Pos < 1) { Data = _T("节点号"); break; } } if(!Provider.getData(CELL_ATTRIBUTE_NEXT, Data)) { Data = _T("下一节点号"); break; } else { sscanf_s(Data, _T("%d"), &m_NextPos); if(m_NextPos < 1) { Data = _T("下一节点号"); break; } } Provider.getData(CELL_ATTRIBUTE_NOTE, m_Note); return true; } while (false); ILogger::getInstance().log(LOG_CLASS_BUSI, LOG_LEVEL_ERROR, _T("{Cell}: 节点[%s]解析失败, '%s'错误"), CELL_NAME_START, Data); return false; }