1
0
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:
Patrick Simpson 2017-07-05 17:33:17 +02:00
parent f2b80da909
commit 0d42105f93
2 changed files with 41 additions and 31 deletions

View File

@ -74,6 +74,9 @@ namespace Acacia.Features.DebugSupport
private void RefreshWrappers()
{
if (_tracer == null)
return;
// Wrapper types
listWrapperTypes.Items.Clear();
foreach(KeyValuePair<Type, int> type in _tracer.GetTypes())
@ -146,6 +149,9 @@ namespace Acacia.Features.DebugSupport
private void RefreshItemEvents()
{
if (_tracer == null)
return;
listItemEvents.Items.Clear();
foreach(MailEvents.MailEventDebug events in MailEvents.MailEventsDebug)
{

View File

@ -386,10 +386,11 @@ namespace Acacia.Utils
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 class MailEventHooker : DisposableWrapper
@ -399,9 +400,12 @@ namespace Acacia.Utils
private readonly MailEvents _events;
public MailEventHooker(IItem item, MailEvents events)
{
if (_hookers != null)
{
_debug = new MailEventDebugImpl(Interlocked.Increment(ref _nextHookerId));
_hookers.TryAdd(_debug._id, _debug);
}
this._item = item;
this._events = events;
@ -412,17 +416,21 @@ namespace Acacia.Utils
{
if (_item != null)
{
_debug.RecordEvent(DebugEvent.Dispose);
_item.Dispose();
_item = null;
}
if (_debug != null)
{
_debug.RecordEvent(DebugEvent.Dispose);
MailEventDebugImpl dummy;
_hookers.TryRemove(_debug._id, out dummy);
}
}
~MailEventHooker()
{
_debug.RecordEvent(DebugEvent.GC);
_debug?.RecordEvent(DebugEvent.GC);
}
private void HookEvents(bool add)
@ -456,52 +464,48 @@ namespace Acacia.Utils
private void HandleBeforeDelete(object item, ref bool cancel)
{
_debug.RecordEvent(DebugEvent.BeforeDelete);
//using (IItem wrapped = item.WrapOrDefault<IItem>(false))
// _events.OnBeforeDelete(wrapped, ref cancel);
_debug?.RecordEvent(DebugEvent.BeforeDelete);
using (IItem wrapped = item.WrapOrDefault<IItem>(false))
_events.OnBeforeDelete(wrapped, ref cancel);
}
private void HandleForward(object response, ref bool cancel)
{
_debug.RecordEvent(DebugEvent.Forward);
//using (IItem wrapped = response.WrapOrDefault<IItem>(false))
// _events.OnForward(_item as IMailItem, wrapped as IMailItem);
_debug?.RecordEvent(DebugEvent.Forward);
using (IItem wrapped = response.WrapOrDefault<IItem>(false))
_events.OnForward(_item as IMailItem, wrapped as IMailItem);
}
private void HandlePropertyChange(string name)
{
_debug.RecordEvent(DebugEvent.PropertyChange);
//_events.OnPropertyChange(_item, name);
_debug?.RecordEvent(DebugEvent.PropertyChange);
_events.OnPropertyChange(_item, name);
}
private void HandleRead()
{
_debug.RecordEvent(DebugEvent.Read);
_debug?.RecordEvent(DebugEvent.Read);
// TODO: should this not be simply an IItem?
IMailItem mail = _item as IMailItem;
if (mail != null)
{
_events.OnRead(mail);
}
_events.OnRead(_item as IMailItem);
}
private void HandleReply(object response, ref bool cancel)
{
_debug.RecordEvent(DebugEvent.Reply);
//using (IItem wrapped = response.WrapOrDefault<IItem>(false))
// _events.OnReply(_item as IMailItem, wrapped as IMailItem);
_debug?.RecordEvent(DebugEvent.Reply);
using (IItem wrapped = response.WrapOrDefault<IItem>(false))
_events.OnReply(_item as IMailItem, wrapped as IMailItem);
}
private void HandleReplyAll(object response, ref bool cancel)
{
_debug.RecordEvent(DebugEvent.ReplyAll);
//using (IItem wrapped = response.WrapOrDefault<IItem>(false))
// _events.OnReplyAll(_item as IMailItem, wrapped as IMailItem);
_debug?.RecordEvent(DebugEvent.ReplyAll);
using (IItem wrapped = response.WrapOrDefault<IItem>(false))
_events.OnReplyAll(_item as IMailItem, wrapped as IMailItem);
}
private void HandleUnload()
{
_debug.RecordEvent(DebugEvent.Unload);
_debug?.RecordEvent(DebugEvent.Unload);
// All events must be unhooked on unload, otherwise a resource leak is created.
HookEvents(false);
Dispose();
@ -509,8 +513,8 @@ namespace Acacia.Utils
private void HandleWrite(ref bool cancel)
{
_debug.RecordEvent(DebugEvent.Write);
//_events.OnWrite(_item, ref cancel);
_debug?.RecordEvent(DebugEvent.Write);
_events.OnWrite(_item, ref cancel);
}
}