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()
|
||||
{
|
||||
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)
|
||||
{
|
||||
|
@ -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);
|
||||
}
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user