mrDarker
2025-05-22 5cf5e464a5891c8eb62aafadfce0d204fdc79b02
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
#include "stdafx.h"
#include "CEqVcrEventStep.h"
#include "Log.h"
 
 
namespace SERVO {
    CEqVcrEventStep::CEqVcrEventStep() : CReadStep()
    {
        m_nVcrEventReportDev = 0;
    }
 
    CEqVcrEventStep::~CEqVcrEventStep()
    {
 
    }
 
    void CEqVcrEventStep::setVcrEventReportDev(int nDev)
    {
        m_nVcrEventReportDev = nDev;
    }
 
    void CEqVcrEventStep::getAttributeVector(CAttributeVector& attrubutes)
    {
        CReadStep::getAttributeVector(attrubutes);
 
        unsigned int weight = 31;
        std::string strTemp;
        attrubutes.addAttribute(new CAttribute("Dev",
            ("W" + CToolUnits::toHexString(m_nVcrEventReportDev, strTemp)).c_str(), "", weight++));
        attrubutes.addAttribute(new CAttribute("GlassId",
            m_vcrEventReport.getGlassId().c_str(), "", weight++));
        attrubutes.addAttribute(new CAttribute("CassetteSequenceNo",
            std::to_string(m_vcrEventReport.getCassetteSequenceNo()).c_str(), "", weight++));
        attrubutes.addAttribute(new CAttribute("JobSequenceNo",
            std::to_string(m_vcrEventReport.getJobSequenceNo()).c_str(), "", weight++));
        attrubutes.addAttribute(new CAttribute("UnitNo",
            std::to_string(m_vcrEventReport.getUnitNo()).c_str(), "", weight++));
        attrubutes.addAttribute(new CAttribute("VCR No",
            std::to_string(m_vcrEventReport.getVcrNo()).c_str(), "", weight++));
        attrubutes.addAttribute(new CAttribute("VCR Result",
            m_vcrEventReport.getVcrResultDescription(strTemp).c_str(), "", weight++));
    }
 
    int CEqVcrEventStep::onReadData()
    {
        CReadStep::onReadData();
 
 
        char szBuffer[64];
        int nRet = m_pCclink->ReadData2(m_station, DeviceType::W, m_nVcrEventReportDev,
            30, szBuffer);
        if (0 != nRet) {
            return -1;
        }
 
        m_vcrEventReport.unserialize(szBuffer, 60);
        LOGI("<CEqVcrEventStep-%s>Read VCR Event Report\n", m_strName.c_str());
 
        return 0;
    }
 
    int CEqVcrEventStep::onComplete()
    {
        CReadStep::onComplete();
        LOGI("<CEqVcrEventStep> onComplete.");
 
        return 0;
    }
 
    int CEqVcrEventStep::onTimeout()
    {
        CReadStep::onTimeout();
        LOGI("<CEqVcrEventStep> onTimeout.");
 
        return 0;
    }
 
    CVcrEventReport* CEqVcrEventStep::getVcrEventReport()
    {
        return &m_vcrEventReport;
    }
 
    int CEqVcrEventStep::setReturnCode(short code)
    {
        memcpy(m_szReturnBuf, &code, sizeof(short));
        m_nReturnDataSize = sizeof(short);
 
        return 0;
    }
}