OSDN Git Service

Add toppers-jsp/ in nxtOSEK_v205b0.zip. They are licensed under TOPPERS license.
[nxt-jsp/etrobo-atk.git] / nxtOSEK / toppers_jsp / windev / watcher / watcherCP.h
diff --git a/nxtOSEK/toppers_jsp/windev/watcher/watcherCP.h b/nxtOSEK/toppers_jsp/windev/watcher/watcherCP.h
new file mode 100644 (file)
index 0000000..35ccd56
--- /dev/null
@@ -0,0 +1,125 @@
+/*
+ *  TOPPERS/JSP Kernel
+ *      Toyohashi Open Platform for Embedded Real-Time Systems/
+ *      Just Standard Profile Kernel
+ * 
+ *  Copyright (C) 2000-2003 by Embedded and Real-Time Systems Laboratory
+ *                              Toyohashi Univ. of Technology, JAPAN
+ * 
+ *  ¾åµ­Ãøºî¸¢¼Ô¤Ï¡¤°Ê²¼¤Î (1)¡Á(4) ¤Î¾ò·ï¤«¡¤Free Software Foundation 
+ *  ¤Ë¤è¤Ã¤Æ¸øɽ¤µ¤ì¤Æ¤¤¤ë GNU General Public License ¤Î Version 2 ¤Ëµ­
+ *  ½Ò¤µ¤ì¤Æ¤¤¤ë¾ò·ï¤òËþ¤¿¤¹¾ì¹ç¤Ë¸Â¤ê¡¤ËÜ¥½¥Õ¥È¥¦¥§¥¢¡ÊËÜ¥½¥Õ¥È¥¦¥§¥¢
+ *  ¤ò²þÊѤ·¤¿¤â¤Î¤ò´Þ¤à¡¥°Ê²¼Æ±¤¸¡Ë¤ò»ÈÍÑ¡¦Ê£À½¡¦²þÊÑ¡¦ºÆÇÛÉۡʰʲ¼¡¤
+ *  ÍøÍѤȸƤ֡ˤ¹¤ë¤³¤È¤ò̵½þ¤ÇµöÂú¤¹¤ë¡¥
+ *  (1) ËÜ¥½¥Õ¥È¥¦¥§¥¢¤ò¥½¡¼¥¹¥³¡¼¥É¤Î·Á¤ÇÍøÍѤ¹¤ë¾ì¹ç¤Ë¤Ï¡¤¾åµ­¤ÎÃøºî
+ *      ¸¢É½¼¨¡¤¤³¤ÎÍøÍѾò·ï¤ª¤è¤Ó²¼µ­¤Î̵Êݾڵ¬Ä꤬¡¤¤½¤Î¤Þ¤Þ¤Î·Á¤Ç¥½¡¼
+ *      ¥¹¥³¡¼¥ÉÃæ¤Ë´Þ¤Þ¤ì¤Æ¤¤¤ë¤³¤È¡¥
+ *  (2) ËÜ¥½¥Õ¥È¥¦¥§¥¢¤ò¡¤¥é¥¤¥Ö¥é¥ê·Á¼°¤Ê¤É¡¤Â¾¤Î¥½¥Õ¥È¥¦¥§¥¢³«È¯¤Ë»È
+ *      ÍѤǤ­¤ë·Á¤ÇºÆÇÛÉÛ¤¹¤ë¾ì¹ç¤Ë¤Ï¡¤ºÆÇÛÉÛ¤Ëȼ¤¦¥É¥­¥å¥á¥ó¥È¡ÊÍøÍÑ
+ *      ¼Ô¥Þ¥Ë¥å¥¢¥ë¤Ê¤É¡Ë¤Ë¡¤¾åµ­¤ÎÃøºî¸¢É½¼¨¡¤¤³¤ÎÍøÍѾò·ï¤ª¤è¤Ó²¼µ­
+ *      ¤Î̵Êݾڵ¬Äê¤ò·ÇºÜ¤¹¤ë¤³¤È¡¥
+ *  (3) ËÜ¥½¥Õ¥È¥¦¥§¥¢¤ò¡¤µ¡´ï¤ËÁȤ߹þ¤à¤Ê¤É¡¤Â¾¤Î¥½¥Õ¥È¥¦¥§¥¢³«È¯¤Ë»È
+ *      ÍѤǤ­¤Ê¤¤·Á¤ÇºÆÇÛÉÛ¤¹¤ë¾ì¹ç¤Ë¤Ï¡¤¼¡¤Î¤¤¤º¤ì¤«¤Î¾ò·ï¤òËþ¤¿¤¹¤³
+ *      ¤È¡¥
+ *    (a) ºÆÇÛÉÛ¤Ëȼ¤¦¥É¥­¥å¥á¥ó¥È¡ÊÍøÍѼԥޥ˥奢¥ë¤Ê¤É¡Ë¤Ë¡¤¾åµ­¤ÎÃø
+ *        ºî¸¢É½¼¨¡¤¤³¤ÎÍøÍѾò·ï¤ª¤è¤Ó²¼µ­¤Î̵Êݾڵ¬Äê¤ò·ÇºÜ¤¹¤ë¤³¤È¡¥
+ *    (b) ºÆÇÛÉۤηÁÂÖ¤ò¡¤Ê̤ËÄê¤á¤ëÊýË¡¤Ë¤è¤Ã¤Æ¡¤TOPPERS¥×¥í¥¸¥§¥¯¥È¤Ë
+ *        Êó¹ð¤¹¤ë¤³¤È¡¥
+ *  (4) ËÜ¥½¥Õ¥È¥¦¥§¥¢¤ÎÍøÍѤˤè¤êľÀÜŪ¤Þ¤¿¤Ï´ÖÀÜŪ¤ËÀ¸¤¸¤ë¤¤¤«¤Ê¤ë»
+ *      ³²¤«¤é¤â¡¤¾åµ­Ãøºî¸¢¼Ô¤ª¤è¤ÓTOPPERS¥×¥í¥¸¥§¥¯¥È¤òÌÈÀÕ¤¹¤ë¤³¤È¡¥
+ * 
+ *  ËÜ¥½¥Õ¥È¥¦¥§¥¢¤Ï¡¤ÌµÊݾڤÇÄ󶡤µ¤ì¤Æ¤¤¤ë¤â¤Î¤Ç¤¢¤ë¡¥¾åµ­Ãøºî¸¢¼Ô¤ª
+ *  ¤è¤ÓTOPPERS¥×¥í¥¸¥§¥¯¥È¤Ï¡¤ËÜ¥½¥Õ¥È¥¦¥§¥¢¤Ë´Ø¤·¤Æ¡¤¤½¤ÎŬÍѲÄǽÀ­¤â
+ *  ´Þ¤á¤Æ¡¤¤¤¤«¤Ê¤ëÊݾڤâ¹Ô¤ï¤Ê¤¤¡¥¤Þ¤¿¡¤ËÜ¥½¥Õ¥È¥¦¥§¥¢¤ÎÍøÍѤˤè¤êľ
+ *  ÀÜŪ¤Þ¤¿¤Ï´ÖÀÜŪ¤ËÀ¸¤¸¤¿¤¤¤«¤Ê¤ë»³²¤Ë´Ø¤·¤Æ¤â¡¤¤½¤ÎÀÕǤ¤òÉé¤ï¤Ê¤¤¡¥
+ * 
+ *  @(#) $Id: watcherCP.h,v 1.3 2003/06/30 15:58:39 takayuki Exp $
+ */
+
+#ifndef _WATCHERCP_H_
+#define _WATCHERCP_H_
+
+
+
+
+
+
+template <class T>
+class CProxy_IKernelLogControlEvents : public IConnectionPointImpl<T, &DIID__IKernelLogControlEvents, CComDynamicUnkArray>
+{
+       //Warning this class may be recreated by the wizard.
+public:
+       HRESULT Fire_OnKernelStart()
+       {
+               CComVariant varResult;
+               T* pT = static_cast<T*>(this);
+               int nConnectionIndex;
+               int nConnections = m_vec.GetSize();
+               
+               for (nConnectionIndex = 0; nConnectionIndex < nConnections; nConnectionIndex++)
+               {
+                       pT->Lock();
+                       CComPtr<IUnknown> sp = m_vec.GetAt(nConnectionIndex);
+                       pT->Unlock();
+                       IDispatch* pDispatch = reinterpret_cast<IDispatch*>(sp.p);
+                       if (pDispatch != NULL)
+                       {
+                               VariantClear(&varResult);
+                               DISPPARAMS disp = { NULL, NULL, 0, 0 };
+                               pDispatch->Invoke(0x1, IID_NULL, LOCALE_USER_DEFAULT, DISPATCH_METHOD, &disp, &varResult, NULL, NULL);
+                       }
+               }
+               return varResult.scode;
+       
+       }
+       HRESULT Fire_OnKernelExit()
+       {
+               CComVariant varResult;
+               T* pT = static_cast<T*>(this);
+               int nConnectionIndex;
+               int nConnections = m_vec.GetSize();
+               
+               for (nConnectionIndex = 0; nConnectionIndex < nConnections; nConnectionIndex++)
+               {
+                       pT->Lock();
+                       CComPtr<IUnknown> sp = m_vec.GetAt(nConnectionIndex);
+                       pT->Unlock();
+                       IDispatch* pDispatch = reinterpret_cast<IDispatch*>(sp.p);
+                       if (pDispatch != NULL)
+                       {
+                               VariantClear(&varResult);
+                               DISPPARAMS disp = { NULL, NULL, 0, 0 };
+                               pDispatch->Invoke(0x2, IID_NULL, LOCALE_USER_DEFAULT, DISPATCH_METHOD, &disp, &varResult, NULL, NULL);
+                       }
+               }
+               return varResult.scode;
+       
+       }
+       HRESULT Fire_OnLogEvent(INT type)
+       {
+               CComVariant varResult;
+               T* pT = static_cast<T*>(this);
+               int nConnectionIndex;
+               CComVariant* pvars = new CComVariant[1];
+               int nConnections = m_vec.GetSize();
+               
+               for (nConnectionIndex = 0; nConnectionIndex < nConnections; nConnectionIndex++)
+               {
+                       pT->Lock();
+                       CComPtr<IUnknown> sp = m_vec.GetAt(nConnectionIndex);
+                       pT->Unlock();
+                       IDispatch* pDispatch = reinterpret_cast<IDispatch*>(sp.p);
+                       if (pDispatch != NULL)
+                       {
+                               VariantClear(&varResult);
+                               pvars[0] = type;
+                               DISPPARAMS disp = { pvars, NULL, 1, 0 };
+                               pDispatch->Invoke(0x3, IID_NULL, LOCALE_USER_DEFAULT, DISPATCH_METHOD, &disp, &varResult, NULL, NULL);
+                       }
+               }
+               delete[] pvars;
+               return varResult.scode;
+       
+       }
+};
+#endif
\ No newline at end of file