mirror of
https://github.com/Kopano-dev/kopano-ol-extension.git
synced 2023-10-10 13:37:40 +02:00
[KOE-130] Cleanup and fixes for disabling wrapper tracing
This commit is contained in:
parent
f2b80da909
commit
0d42105f93
@ -74,6 +74,9 @@ namespace Acacia.Features.DebugSupport
|
|||||||
|
|
||||||
private void RefreshWrappers()
|
private void RefreshWrappers()
|
||||||
{
|
{
|
||||||
|
if (_tracer == null)
|
||||||
|
return;
|
||||||
|
|
||||||
// Wrapper types
|
// Wrapper types
|
||||||
listWrapperTypes.Items.Clear();
|
listWrapperTypes.Items.Clear();
|
||||||
foreach(KeyValuePair<Type, int> type in _tracer.GetTypes())
|
foreach(KeyValuePair<Type, int> type in _tracer.GetTypes())
|
||||||
@ -146,6 +149,9 @@ namespace Acacia.Features.DebugSupport
|
|||||||
|
|
||||||
private void RefreshItemEvents()
|
private void RefreshItemEvents()
|
||||||
{
|
{
|
||||||
|
if (_tracer == null)
|
||||||
|
return;
|
||||||
|
|
||||||
listItemEvents.Items.Clear();
|
listItemEvents.Items.Clear();
|
||||||
foreach(MailEvents.MailEventDebug events in MailEvents.MailEventsDebug)
|
foreach(MailEvents.MailEventDebug events in MailEvents.MailEventsDebug)
|
||||||
{
|
{
|
||||||
|
@ -386,10 +386,11 @@ namespace Acacia.Utils
|
|||||||
|
|
||||||
public static IEnumerable<MailEventDebug> MailEventsDebug
|
public static IEnumerable<MailEventDebug> MailEventsDebug
|
||||||
{
|
{
|
||||||
get { return _hookers.Values; }
|
get { return _hookers?.Values; }
|
||||||
}
|
}
|
||||||
|
|
||||||
private static readonly ConcurrentDictionary<int, MailEventDebugImpl> _hookers = new ConcurrentDictionary<int, MailEventDebugImpl>();
|
private static readonly ConcurrentDictionary<int, MailEventDebugImpl> _hookers =
|
||||||
|
GlobalOptions.INSTANCE.WrapperTrace ? new ConcurrentDictionary<int, MailEventDebugImpl>() : null;
|
||||||
private static int _nextHookerId;
|
private static int _nextHookerId;
|
||||||
|
|
||||||
private class MailEventHooker : DisposableWrapper
|
private class MailEventHooker : DisposableWrapper
|
||||||
@ -399,9 +400,12 @@ namespace Acacia.Utils
|
|||||||
private readonly MailEvents _events;
|
private readonly MailEvents _events;
|
||||||
|
|
||||||
public MailEventHooker(IItem item, MailEvents events)
|
public MailEventHooker(IItem item, MailEvents events)
|
||||||
|
{
|
||||||
|
if (_hookers != null)
|
||||||
{
|
{
|
||||||
_debug = new MailEventDebugImpl(Interlocked.Increment(ref _nextHookerId));
|
_debug = new MailEventDebugImpl(Interlocked.Increment(ref _nextHookerId));
|
||||||
_hookers.TryAdd(_debug._id, _debug);
|
_hookers.TryAdd(_debug._id, _debug);
|
||||||
|
}
|
||||||
|
|
||||||
this._item = item;
|
this._item = item;
|
||||||
this._events = events;
|
this._events = events;
|
||||||
@ -412,17 +416,21 @@ namespace Acacia.Utils
|
|||||||
{
|
{
|
||||||
if (_item != null)
|
if (_item != null)
|
||||||
{
|
{
|
||||||
_debug.RecordEvent(DebugEvent.Dispose);
|
|
||||||
_item.Dispose();
|
_item.Dispose();
|
||||||
_item = null;
|
_item = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (_debug != null)
|
||||||
|
{
|
||||||
|
_debug.RecordEvent(DebugEvent.Dispose);
|
||||||
MailEventDebugImpl dummy;
|
MailEventDebugImpl dummy;
|
||||||
_hookers.TryRemove(_debug._id, out dummy);
|
_hookers.TryRemove(_debug._id, out dummy);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
~MailEventHooker()
|
~MailEventHooker()
|
||||||
{
|
{
|
||||||
_debug.RecordEvent(DebugEvent.GC);
|
_debug?.RecordEvent(DebugEvent.GC);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void HookEvents(bool add)
|
private void HookEvents(bool add)
|
||||||
@ -456,52 +464,48 @@ namespace Acacia.Utils
|
|||||||
|
|
||||||
private void HandleBeforeDelete(object item, ref bool cancel)
|
private void HandleBeforeDelete(object item, ref bool cancel)
|
||||||
{
|
{
|
||||||
_debug.RecordEvent(DebugEvent.BeforeDelete);
|
_debug?.RecordEvent(DebugEvent.BeforeDelete);
|
||||||
//using (IItem wrapped = item.WrapOrDefault<IItem>(false))
|
using (IItem wrapped = item.WrapOrDefault<IItem>(false))
|
||||||
// _events.OnBeforeDelete(wrapped, ref cancel);
|
_events.OnBeforeDelete(wrapped, ref cancel);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void HandleForward(object response, ref bool cancel)
|
private void HandleForward(object response, ref bool cancel)
|
||||||
{
|
{
|
||||||
_debug.RecordEvent(DebugEvent.Forward);
|
_debug?.RecordEvent(DebugEvent.Forward);
|
||||||
//using (IItem wrapped = response.WrapOrDefault<IItem>(false))
|
using (IItem wrapped = response.WrapOrDefault<IItem>(false))
|
||||||
// _events.OnForward(_item as IMailItem, wrapped as IMailItem);
|
_events.OnForward(_item as IMailItem, wrapped as IMailItem);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void HandlePropertyChange(string name)
|
private void HandlePropertyChange(string name)
|
||||||
{
|
{
|
||||||
_debug.RecordEvent(DebugEvent.PropertyChange);
|
_debug?.RecordEvent(DebugEvent.PropertyChange);
|
||||||
//_events.OnPropertyChange(_item, name);
|
_events.OnPropertyChange(_item, name);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void HandleRead()
|
private void HandleRead()
|
||||||
{
|
{
|
||||||
_debug.RecordEvent(DebugEvent.Read);
|
_debug?.RecordEvent(DebugEvent.Read);
|
||||||
// TODO: should this not be simply an IItem?
|
// TODO: should this not be simply an IItem?
|
||||||
IMailItem mail = _item as IMailItem;
|
_events.OnRead(_item as IMailItem);
|
||||||
if (mail != null)
|
|
||||||
{
|
|
||||||
_events.OnRead(mail);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void HandleReply(object response, ref bool cancel)
|
private void HandleReply(object response, ref bool cancel)
|
||||||
{
|
{
|
||||||
_debug.RecordEvent(DebugEvent.Reply);
|
_debug?.RecordEvent(DebugEvent.Reply);
|
||||||
//using (IItem wrapped = response.WrapOrDefault<IItem>(false))
|
using (IItem wrapped = response.WrapOrDefault<IItem>(false))
|
||||||
// _events.OnReply(_item as IMailItem, wrapped as IMailItem);
|
_events.OnReply(_item as IMailItem, wrapped as IMailItem);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void HandleReplyAll(object response, ref bool cancel)
|
private void HandleReplyAll(object response, ref bool cancel)
|
||||||
{
|
{
|
||||||
_debug.RecordEvent(DebugEvent.ReplyAll);
|
_debug?.RecordEvent(DebugEvent.ReplyAll);
|
||||||
//using (IItem wrapped = response.WrapOrDefault<IItem>(false))
|
using (IItem wrapped = response.WrapOrDefault<IItem>(false))
|
||||||
// _events.OnReplyAll(_item as IMailItem, wrapped as IMailItem);
|
_events.OnReplyAll(_item as IMailItem, wrapped as IMailItem);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void HandleUnload()
|
private void HandleUnload()
|
||||||
{
|
{
|
||||||
_debug.RecordEvent(DebugEvent.Unload);
|
_debug?.RecordEvent(DebugEvent.Unload);
|
||||||
// All events must be unhooked on unload, otherwise a resource leak is created.
|
// All events must be unhooked on unload, otherwise a resource leak is created.
|
||||||
HookEvents(false);
|
HookEvents(false);
|
||||||
Dispose();
|
Dispose();
|
||||||
@ -509,8 +513,8 @@ namespace Acacia.Utils
|
|||||||
|
|
||||||
private void HandleWrite(ref bool cancel)
|
private void HandleWrite(ref bool cancel)
|
||||||
{
|
{
|
||||||
_debug.RecordEvent(DebugEvent.Write);
|
_debug?.RecordEvent(DebugEvent.Write);
|
||||||
//_events.OnWrite(_item, ref cancel);
|
_events.OnWrite(_item, ref cancel);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user