// Copyright (C) 2017, The Duplicati Team // http://www.duplicati.com, info@duplicati.com // // This library is free software; you can redistribute it and/or modify // it under the terms of the GNU Lesser General Public License as // published by the Free Software Foundation; either version 2.1 of the // License, or (at your option) any later version. // // This library 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 // Lesser General Public License for more details. // // You should have received a copy of the GNU Lesser General Public // License along with this library; if not, write to the Free Software // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA using System; using System.Linq; namespace Duplicati.Library.Logging { /// /// Internal class for keeping log instance relations /// internal class LogScope : IDisposable { /// /// The unique ID of this log instance /// public readonly string InstanceID = Guid.NewGuid().ToString(); /// /// The log instance assigned to this scope /// private readonly ILogDestination m_log; /// /// The log filter /// private readonly ILogFilter m_filter; /// /// The log scope parent /// public readonly LogScope Parent; /// /// A flag indicating if the scope is disposed /// private bool m_isDisposed = false; /// /// A flag indicating if this is an isolating scope /// public readonly bool IsolatingScope; /// /// Initializes a new instance of the class. /// /// The log instance to wrap. /// The log filter to use /// The parent scope /// A flag indicating if the scope is an isolating scope public LogScope(ILogDestination self, ILogFilter filter, LogScope parent, bool isolatingScope) { Parent = parent; m_log = self; m_filter = filter; IsolatingScope = isolatingScope; if (parent != null) Logging.Log.StartScope(this); } /// /// The function called when a message is logged /// /// The log entry public void WriteMessage(LogEntry entry) { if (m_log != null && (m_filter == null || m_filter.Accepts(entry))) m_log.WriteMessage(entry); } /// /// Releases all resource used by the object. /// /// Call when you are finished using the /// . The method leaves the /// in an unusable state. After calling /// , you must release all references to the /// so the garbage collector can reclaim the memory that the /// was occupying. public void Dispose() { if (!m_isDisposed && Parent != null) { Logging.Log.CloseScope(this); m_isDisposed = true; } } } }