| | |
| | | m_pBuddy = nullptr; |
| | | m_nOriginPort = 0; |
| | | m_nOriginSlot = 0; |
| | | m_bScheduledForProcessing = FALSE; |
| | | m_pProcessJob = nullptr; |
| | | } |
| | | |
| | | CGlass::~CGlass() |
| | | { |
| | | |
| | | reset(); |
| | | } |
| | | |
| | | void CGlass::reset() |
| | |
| | | slot = m_nOriginSlot; |
| | | } |
| | | |
| | | BOOL CGlass::isScheduledForProcessing() |
| | | { |
| | | return m_bScheduledForProcessing; |
| | | } |
| | | |
| | | void CGlass::setScheduledForProcessing(BOOL bProcessing) |
| | | { |
| | | m_bScheduledForProcessing = bProcessing; |
| | | } |
| | | |
| | | CProcessJob* CGlass::getProcessJob() |
| | | { |
| | | return m_pProcessJob; |
| | | } |
| | | |
| | | void CGlass::setProcessJob(CProcessJob* pProcessJob) |
| | | { |
| | | m_pProcessJob = pProcessJob; |
| | | } |
| | | |
| | | CPath* CGlass::getPath() |
| | | { |
| | | return m_pPath; |
| | |
| | | WriteString(ar, m_strID); |
| | | ar << m_nOriginPort; |
| | | ar << m_nOriginSlot; |
| | | ar << m_bScheduledForProcessing; |
| | | ar << (ULONGLONG)m_pPath; |
| | | if (m_pPath != nullptr) { |
| | | m_pPath->serialize(ar); |
| | |
| | | ReadString(ar, m_strID); |
| | | ar >> m_nOriginPort; |
| | | ar >> m_nOriginSlot; |
| | | ar >> m_bScheduledForProcessing; |
| | | ar >> ullPath; |
| | | if (ullPath != 0) { |
| | | m_pPath = new CPath(); |
| | |
| | | |
| | | return pPath->getInspResult(); |
| | | } |
| | | |
| | | std::string CGlass::getStateText() |
| | | { |
| | | switch (m_state) |
| | | { |
| | | case SERVO::GlsState::NoState: |
| | | return "NoState"; |
| | | break; |
| | | case SERVO::GlsState::Queued: |
| | | return "Queued"; |
| | | break; |
| | | case SERVO::GlsState::InProcess: |
| | | return "InProcess"; |
| | | break; |
| | | case SERVO::GlsState::Paused: |
| | | return "Queued"; |
| | | break; |
| | | case SERVO::GlsState::Completed: |
| | | return "Queued"; |
| | | break; |
| | | case SERVO::GlsState::Aborted: |
| | | return "Aborted"; |
| | | break; |
| | | case SERVO::GlsState::Failed: |
| | | return "Failed"; |
| | | break; |
| | | default: |
| | | break; |
| | | } |
| | | |
| | | return ""; |
| | | } |
| | | |
| | | bool CGlass::queue() { |
| | | if (m_state != GlsState::NoState) return false; |
| | | markQueued(); |
| | | return true; |
| | | } |
| | | |
| | | bool CGlass::start() { |
| | | if (m_state != GlsState::Queued && m_state != GlsState::Paused) |
| | | return false; |
| | | if (!m_tStart.has_value()) markStart(); |
| | | m_state = GlsState::InProcess; |
| | | return true; |
| | | } |
| | | |
| | | bool CGlass::pause() { |
| | | if (m_state != GlsState::InProcess) return false; |
| | | m_state = GlsState::Paused; |
| | | return true; |
| | | } |
| | | |
| | | bool CGlass::resume() { |
| | | if (m_state != GlsState::Paused) return false; |
| | | m_state = GlsState::InProcess; |
| | | return true; |
| | | } |
| | | |
| | | bool CGlass::complete() { |
| | | if (m_state != GlsState::InProcess && m_state != GlsState::Paused) return false; |
| | | m_state = GlsState::Completed; |
| | | markEnd(); |
| | | return true; |
| | | } |
| | | |
| | | bool CGlass::abort() { |
| | | if (m_state == GlsState::Completed || m_state == GlsState::Aborted || m_state == GlsState::Failed) |
| | | return false; |
| | | m_state = GlsState::Aborted; |
| | | markEnd(); |
| | | return true; |
| | | } |
| | | |
| | | bool CGlass::fail(std::string reason) |
| | | { |
| | | m_failReason = trimCopy(reason); |
| | | clampString(m_failReason, 128); |
| | | m_state = GlsState::Failed; |
| | | markEnd(); |
| | | return true; |
| | | } |
| | | |
| | | std::string CGlass::trimCopy(std::string s) |
| | | { |
| | | auto notspace = [](int ch) { return !std::isspace(ch); }; |
| | | s.erase(s.begin(), std::find_if(s.begin(), s.end(), notspace)); |
| | | s.erase(std::find_if(s.rbegin(), s.rend(), notspace).base(), s.end()); |
| | | return s; |
| | | } |
| | | |
| | | void CGlass::clampString(std::string& s, size_t maxLen) |
| | | { |
| | | if (s.size() > maxLen) s.resize(maxLen); |
| | | } |
| | | |
| | | // —— 时间戳 & 工具 —— |
| | | void CGlass::markQueued() |
| | | { |
| | | m_state = GlsState::Queued; |
| | | m_tQueued = std::chrono::system_clock::now(); |
| | | } |
| | | |
| | | void CGlass::markStart() |
| | | { |
| | | m_tStart = std::chrono::system_clock::now(); |
| | | } |
| | | |
| | | void CGlass::markEnd() |
| | | { |
| | | m_tEnd = std::chrono::system_clock::now(); |
| | | } |
| | | |
| | | void CGlass::addParams(std::vector<CParam>& params) |
| | | { |
| | | m_params.insert(m_params.end(), params.begin(), params.end()); |
| | | } |
| | | |
| | | std::vector<CParam>& CGlass::getParams() |
| | | { |
| | | return m_params; |
| | | } |
| | | } |