123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376 |
- #pragma once
- //
- // a delegate
- //
- class UnsafeDelegate
- {
- public:
- inline UnsafeDelegate ()
- {
- m_DelegateID [0] = 0;
- m_bTrace = true;
- }
- inline UnsafeDelegate (const char * DelegateID)
- {
- strncpy (m_DelegateID, DelegateID, sizeof(m_DelegateID));
- m_bTrace = true;
- }
- inline virtual ~UnsafeDelegate ()
- {
- RemoveAll ();
- }
- inline virtual void AddDelegateHandler (DelegateHandler * handler)
- {
- try
- {
- if (! IsExist (handler))
- m_handlers.Add (handler);
- else
- delete handler;
- }
- catch (...)
- {
- }
- }
- inline UnsafeDelegate & operator += (DelegateHandler * handler)
- {
- AddDelegateHandler (handler);
- return *this;
- }
- inline virtual void RemoveDelegateHandler (DelegateHandler * handler)
- {
- try
- {
- RemoveHandler (handler);
- delete handler;
- }
- catch (...)
- {
- }
- }
- inline UnsafeDelegate & operator -= (DelegateHandler * handler)
- {
- RemoveDelegateHandler (handler);
- return *this;
- }
- inline void operator () (const void * sender, DelegateArgs * arg)
- {
- Invoke (sender, arg);
- }
- inline virtual void Invoke (const void * sender, DelegateArgs * arg)
- {
- int Size = GetSize ();
- if (Size == 0)
- return;
- if (m_bTrace)
- {
- if (m_DelegateID[0])
- _info ("Invoking Delegate %s, total %d handles", m_DelegateID, Size);
- else
- _info ("Invoking Delegate 0x%0x, total %d handles", this, Size);
- }
- if (Size <= DelegateMaxHandler)
- {
- DelegateHandler * arTemp [DelegateMaxHandler];
- const Array <DelegateHandler *> & ar = m_handlers;
- int NbOfElem = ar.CopyTo (arTemp, DelegateMaxHandler);
- for (int Index=0; Index<NbOfElem; Index++)
- {
- DelegateHandler * h = arTemp[Index];
- #ifndef _DEBUG
- try
- #endif
- {
- DString msg;
- if (m_bTrace)
- {
- if (h->m_Name[0])
- msg = h->m_Name;
- else
- msg.Format ("0x%0x", h);
- _tinfo ("Invoking " + msg);
- }
- h->Invoke (sender, arg);
- if (m_bTrace)
- _tinfo ("Invoked " + msg);
- }
- #ifndef _DEBUG
- catch (...)
- {
- Beep (1000, 1000);
- OnDelegateInvokeFailed (h);
- }
- #endif
- }
- }
- else
- {
- FixArray <DelegateHandler *> arTemp (m_handlers.GetSize ());
- const Array <DelegateHandler *> & ar = m_handlers;
- int NbOfElem = ar.CopyTo (arTemp);
- for (int Index=0; Index<NbOfElem; Index++)
- {
- DelegateHandler * h = arTemp[Index];
- #ifndef _DEBUG
- try
- #endif
- {
- DString msg;
- if (m_bTrace)
- {
- if (h->m_Name[0])
- msg = h->m_Name;
- else
- msg.Format ("0x%0x", h);
- _tinfo ("Invoking " + msg);
- }
- h->Invoke (sender, arg);
- if (m_bTrace)
- _tinfo ("Invoked " + msg);
- }
- #ifndef _DEBUG
- catch (...)
- {
- Beep (1000, 1000);
- OnDelegateInvokeFailed (h);
- }
- #endif
- }
- }
- }
- inline int GetSize () const
- {
- return m_handlers.GetSize ();
- }
- inline bool IsEmpty () const
- {
- return m_handlers.IsEmpty ();
- }
- inline bool IsExist (const DelegateHandler * handler) const
- {
- for (ArrayOfPtr <DelegateHandler *>::Iterator Iter (m_handlers); Iter; Iter++)
- {
- DelegateHandler * curHandler = Iter ();
- if (curHandler->IsEqual (* handler))
- return true;
- }
- return false;
- }
- inline void RemoveAll ()
- {
- m_handlers.RemoveAll ();
- }
- inline virtual void AddFirst (DelegateHandler * handler)
- {
- try
- {
- if (! IsExist (handler))
- m_handlers.InsertFirst (handler);
- else
- delete handler;
- }
- catch (...)
- {
- }
- }
- inline virtual void AddLast (DelegateHandler * handler)
- {
- try
- {
- if (! IsExist (handler))
- m_handlers.InsertLast (handler);
- else
- delete handler;
- }
- catch (...)
- {
- }
- }
- template <class pfnForEach> void ForEach (pfnForEach pFunction)
- {
- int Size = GetSize ();
- if (Size == 0)
- return;
- DelegateHandler * arTemp [DelegateMaxHandler];
- int NbOfElem = m_handlers.CopyTo (arTemp, DelegateMaxHandler);
- for (int Index=0; Index<NbOfElem; Index++)
- {
- DelegateHandler * h = arTemp[Index];
- try
- {
- pFunction (h);
- }
- catch (...)
- {
- #ifdef _DEBUG
- Beep (1000, 1000);
- OnDelegateInvokeFailed (h);
- #endif
- }
- }
- }
- template <typename class T, class classForEach> void ForEach (T * t, classForEach pFunction)
- {
- int Size = GetSize ();
- if (Size == 0)
- return;
- DelegateHandler * arTemp [DelegateMaxHandler];
- int NbOfElem = m_handlers.CopyTo (arTemp, DelegateMaxHandler);
- for (int Index=0; Index<NbOfElem; Index++)
- {
- DelegateHandler * h = arTemp[Index];
- try
- {
- (*t.*pFunction) (h);
- }
- catch (...)
- {
- #ifdef _DEBUG
- Beep (1000, 1000);
- OnDelegateInvokeFailed (h);
- #endif
- }
- }
- }
- template <class pfnForEach, class Parameter> void ForEach (pfnForEach pFunction, Parameter para)
- {
- int Size = GetSize ();
- if (Size == 0)
- return;
- DelegateHandler * arTemp [DelegateMaxHandler];
- int NbOfElem = m_handlers.CopyTo (arTemp, DelegateMaxHandler);
- for (int Index=0; Index<NbOfElem; Index++)
- {
- DelegateHandler * h = arTemp[Index];
- try
- {
- pFunction (h, para);
- }
- catch (...)
- {
- #ifdef _DEBUG
- Beep (1000, 1000);
- OnDelegateInvokeFailed (h);
- #endif
- }
- }
- }
- inline int TransferTo (UnsafeDelegate & toDelegate)
- {
- m_handlers.TransferTo (toDelegate.m_handlers);
- return toDelegate.m_handlers.GetSize ();
- }
- inline int TransferFrom (UnsafeDelegate & fromDelegate)
- {
- return fromDelegate.TransferTo (*this);
- }
- inline int TransferTo (Array <DelegateHandler *> & toArray)
- {
- m_handlers.TransferTo (toArray);
- return toArray.GetSize ();
- }
- inline int TransferFrom (Array <DelegateHandler *> & fromArray)
- {
- fromArray.TransferTo (m_handlers);
- return m_handlers.GetSize ();
- }
- inline int CopyTo (Array <DelegateHandler *> & toArray) const
- {
- for (ArrayOfPtr <DelegateHandler *>::Iterator Iter (m_handlers); Iter; Iter++)
- {
- DelegateHandler * h = Iter ();
- toArray.Add (h->Clone ());
- }
- return toArray.GetSize ();
- }
- inline int CopyTo (UnsafeDelegate & toDelegate) const
- {
- for (ArrayOfPtr <DelegateHandler *>::Iterator Iter (m_handlers); Iter; Iter++)
- {
- DelegateHandler * h = Iter ();
- toDelegate.AddDelegateHandler (h->Clone ());
- }
- return toDelegate.GetSize ();
- }
- inline DString GetDelegateID (void) const
- {
- return m_DelegateID;
- }
- DString ToString (void) const;
- virtual void SetTrace (bool bEnable)
- {
- m_bTrace = bEnable;
- }
- protected:
- inline bool RemoveHandler (const DelegateHandler * handler)
- {
- for (ArrayOfPtr <DelegateHandler *>::Iterator Iter (m_handlers); Iter; Iter++)
- {
- DelegateHandler * curHandler = Iter ();
- if (curHandler->IsEqual (* handler))
- {
- m_handlers.RemoveAt (Iter);
- return true;
- }
- }
- return false;
- }
- protected:
- char m_DelegateID [64];
- ArrayOfPtr <DelegateHandler *> m_handlers;
- bool m_bTrace;
- protected:
- static const int DelegateMaxHandler = 64;
- };
|