From d7df634a3d95d1db2ac60c329febd4ca75535e7b Mon Sep 17 00:00:00 2001
From: Patrick Simpson
Date: Thu, 9 Feb 2017 12:20:06 +0100
Subject: [PATCH] Cleaned up MailEvent release. Added debug option to GAB to
prevent MailEvent hooking.
---
.../Features/GAB/FeatureGAB.cs | 18 +++++++++++++++---
.../Stubs/OutlookWrappers/ComWrapper.cs | 1 +
.../AcaciaZPushPlugin/Utils/MailEvents.cs | 16 +++++-----------
3 files changed, 21 insertions(+), 14 deletions(-)
diff --git a/src/AcaciaZPushPlugin/AcaciaZPushPlugin/Features/GAB/FeatureGAB.cs b/src/AcaciaZPushPlugin/AcaciaZPushPlugin/Features/GAB/FeatureGAB.cs
index e53bf0e..2e8d6e9 100644
--- a/src/AcaciaZPushPlugin/AcaciaZPushPlugin/Features/GAB/FeatureGAB.cs
+++ b/src/AcaciaZPushPlugin/AcaciaZPushPlugin/Features/GAB/FeatureGAB.cs
@@ -64,8 +64,11 @@ namespace Acacia.Features.GAB
public override void Startup()
{
- MailEvents.BeforeDelete += SuppressEventHandler_Delete;
- MailEvents.Write += SuppressEventHandler_Modify;
+ if (SuppressModifications)
+ {
+ MailEvents.BeforeDelete += SuppressEventHandler_Delete;
+ MailEvents.Write += SuppressEventHandler_Modify;
+ }
Watcher.AccountDiscovered += AccountDiscovered;
Watcher.AccountRemoved += AccountRemoved;
Watcher.AccountsScanned += AccountsScanned;
@@ -208,7 +211,16 @@ namespace Acacia.Features.GAB
set { SetOption(OPTION_EMPTY_DELETED_ITEMS, value); }
}
private static readonly BoolOption OPTION_EMPTY_DELETED_ITEMS = new BoolOption("EmptyDeletedItems", true);
-
+
+ [AcaciaOption("If enabled, modifications to the GAB folder are suppressed. " +
+ "This should only be disabled for debug purposes.")]
+ public bool SuppressModifications
+ {
+ get { return GetOption(OPTION_SUPPRESS_MODIFICATIONS); }
+ set { SetOption(OPTION_SUPPRESS_MODIFICATIONS, value); }
+ }
+ private static readonly BoolOption OPTION_SUPPRESS_MODIFICATIONS = new BoolOption("SuppressModifications", true);
+
#endregion
#region Modification suppression
diff --git a/src/AcaciaZPushPlugin/AcaciaZPushPlugin/Stubs/OutlookWrappers/ComWrapper.cs b/src/AcaciaZPushPlugin/AcaciaZPushPlugin/Stubs/OutlookWrappers/ComWrapper.cs
index 61cf8cb..4c234c0 100644
--- a/src/AcaciaZPushPlugin/AcaciaZPushPlugin/Stubs/OutlookWrappers/ComWrapper.cs
+++ b/src/AcaciaZPushPlugin/AcaciaZPushPlugin/Stubs/OutlookWrappers/ComWrapper.cs
@@ -35,6 +35,7 @@ namespace Acacia.Stubs.OutlookWrappers
{
Interlocked.Increment(ref Statistics.CreatedWrappers);
this._createdTrace = new System.Diagnostics.StackTrace();
+ MustRelease = true;
}
~ComWrapper()
diff --git a/src/AcaciaZPushPlugin/AcaciaZPushPlugin/Utils/MailEvents.cs b/src/AcaciaZPushPlugin/AcaciaZPushPlugin/Utils/MailEvents.cs
index 2978dae..59569be 100644
--- a/src/AcaciaZPushPlugin/AcaciaZPushPlugin/Utils/MailEvents.cs
+++ b/src/AcaciaZPushPlugin/AcaciaZPushPlugin/Utils/MailEvents.cs
@@ -219,25 +219,22 @@ namespace Acacia.Utils
NSOutlook.ItemEvents_10_Event hasEvents = item as NSOutlook.ItemEvents_10_Event;
if (hasEvents != null)
{
- new MailEventHooker(item, hasEvents, this);
+ new MailEventHooker(hasEvents, this);
}
- else ComRelease.Release(item);
}
private class MailEventHooker : ComWrapper
{
- private object _item;
private NSOutlook.ItemEvents_10_Event _itemEvents;
private readonly MailEvents _events;
// TODO: remove id and debug logging
private int _id;
private static int nextId;
- public MailEventHooker(object item, NSOutlook.ItemEvents_10_Event itemEvents, MailEvents events)
+ public MailEventHooker(NSOutlook.ItemEvents_10_Event itemEvents, MailEvents events)
{
- this._id = ++nextId;
- this._item = item;
this._itemEvents = itemEvents;
+ this._id = ++nextId;
this._events = events;
HookEvents(true);
}
@@ -245,11 +242,8 @@ namespace Acacia.Utils
protected override void DoRelease()
{
Logger.Instance.Debug(this, "DoRelease: {0}", _id);
-
- ComRelease.Release(_item);
- _item = null;
- ComRelease.Release(_itemEvents);
- _itemEvents = null;
+ // TODO: It looks like release _itemEvents is not only not needed, but causes exceptions.
+ // If that is really the case, this doesn't need to be a ComWrapper
}
private void HookEvents(bool add)