mrDarker
6 天以前 829fe6c6bc33d53fda9c31fd45a37e1df87befff
SourceCode/Bond/Servo/CSlot.cpp
@@ -10,11 +10,17 @@
      m_pContext = nullptr;
      m_bEnable = FALSE;
      m_bLock = FALSE;
      m_pContext = nullptr;
      m_pTempContext = nullptr;
      m_nLinkSignalPath = 0;
   }
   CSlot::~CSlot()
   {
      if (m_pContext != nullptr) {
         m_pContext->release();
         m_pContext = nullptr;
      }
   }
   BOOL CSlot::isEnable()
@@ -92,23 +98,61 @@
      return m_pContext == nullptr;
   }
   void CSlot::setContext(CContext* pContext)
   {
      if (m_pContext != nullptr) {
         m_pContext->release();
      }
      m_pContext = pContext;
      if (m_pContext != nullptr) {
         m_pContext->addRef();
      }
   }
   CContext* CSlot::getContext()
   {
      return m_pContext;
   }
   void CSlot::setContext(CContext* pContext)
   CContext* CSlot::getTempContext()
   {
      m_pContext = pContext;
      return m_pTempContext;
   }
   void CSlot::setLinkSignalPath(int path)
   {
      m_nLinkSignalPath = path;
   }
   int CSlot::getLinkSignalPath()
   {
      return m_nLinkSignalPath;
   }
   void CSlot::serialize(CArchive& ar)
   {
      if (ar.IsStoring()) {
         ar << (__int64)m_pContext;
         ar << m_bLock;
      }
      else {
         __int64 i64;
         ar >> i64; m_pTempContext = (CContext*)i64;
         ar >> m_bLock;
      }
   }
   void CSlot::WriteString(CArchive& ar, std::string& string)
   {
      CString strTemp = string.c_str();
      ar << strTemp;
   }
   void CSlot::ReadString(CArchive& ar, std::string& string)
   {
      CString strTemp;
      ar >> strTemp;
      string = (LPTSTR)(LPCTSTR)strTemp;
   }
}