// 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;
}
}
}
}