2016-12-21 12:53:16 +01:00
|
|
|
|
/// Copyright 2016 Kopano b.v.
|
|
|
|
|
///
|
|
|
|
|
/// This program is free software: you can redistribute it and/or modify
|
|
|
|
|
/// it under the terms of the GNU Affero General Public License, version 3,
|
|
|
|
|
/// as published by the Free Software Foundation.
|
|
|
|
|
///
|
|
|
|
|
/// This program is distributed in the hope that it will be useful,
|
|
|
|
|
/// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
|
/// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.See the
|
|
|
|
|
/// GNU Affero General Public License for more details.
|
|
|
|
|
///
|
|
|
|
|
/// You should have received a copy of the GNU Affero General Public License
|
|
|
|
|
/// along with this program.If not, see<http://www.gnu.org/licenses/>.
|
|
|
|
|
///
|
|
|
|
|
/// Consult LICENSE file for details
|
|
|
|
|
|
|
|
|
|
using Acacia.Features.DebugSupport;
|
|
|
|
|
using Acacia.Utils;
|
|
|
|
|
using System;
|
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
using System.Linq;
|
|
|
|
|
using System.Text;
|
|
|
|
|
using System.Threading;
|
|
|
|
|
using System.Threading.Tasks;
|
|
|
|
|
|
|
|
|
|
namespace Acacia.Stubs.OutlookWrappers
|
|
|
|
|
{
|
2017-02-07 13:49:26 +01:00
|
|
|
|
public abstract class ComWrapper : IComWrapper
|
2016-12-21 12:53:16 +01:00
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Creates a wrapper.
|
|
|
|
|
/// </summary>
|
2017-02-07 13:49:26 +01:00
|
|
|
|
internal ComWrapper()
|
2016-12-21 12:53:16 +01:00
|
|
|
|
{
|
|
|
|
|
Interlocked.Increment(ref Statistics.CreatedWrappers);
|
|
|
|
|
this._createdTrace = new System.Diagnostics.StackTrace();
|
2017-02-09 12:20:06 +01:00
|
|
|
|
MustRelease = true;
|
2016-12-21 12:53:16 +01:00
|
|
|
|
}
|
|
|
|
|
|
2017-02-07 13:49:26 +01:00
|
|
|
|
~ComWrapper()
|
2016-12-21 12:53:16 +01:00
|
|
|
|
{
|
|
|
|
|
Interlocked.Increment(ref Statistics.DeletedWrappers);
|
|
|
|
|
if (!_isDisposed)
|
|
|
|
|
{
|
|
|
|
|
Logger.Instance.Warning(this, "Undisposed wrapper: {0}", _createdTrace);
|
2017-02-08 15:40:48 +01:00
|
|
|
|
// Dispose, but don't count auto disposals, so the stats show it.
|
|
|
|
|
DoRelease();
|
2016-12-21 12:53:16 +01:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private bool _isDisposed;
|
|
|
|
|
private readonly System.Diagnostics.StackTrace _createdTrace;
|
|
|
|
|
|
|
|
|
|
virtual public void Dispose()
|
|
|
|
|
{
|
|
|
|
|
if (!_isDisposed)
|
|
|
|
|
{
|
|
|
|
|
Logger.Instance.TraceExtra(this, "Disposing wrapper: {0}", new System.Diagnostics.StackTrace());
|
|
|
|
|
_isDisposed = true;
|
|
|
|
|
Interlocked.Increment(ref Statistics.DisposedWrappers);
|
|
|
|
|
DoRelease();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public bool MustRelease
|
|
|
|
|
{
|
|
|
|
|
get;
|
|
|
|
|
set;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
abstract protected void DoRelease();
|
|
|
|
|
}
|
|
|
|
|
}
|