blob: fa6ed9a5567732bf736f05ae56b91d8d55aeae88 [file] [log] [blame]
//
// Licensed to the Apache Software Foundation (ASF) under one or more
// contributor license agreements. See the NOTICE file distributed with
// this work for additional information regarding copyright ownership.
// The ASF licenses this file to you under the Apache License, Version 2.0
// (the "License"); you may not use this file except in compliance with
// the License. You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
//
#using <mscorlib.dll>
#include <tchar.h>
using namespace System;
// Configure log4net using the .config file
[assembly: log4net::Config::XmlConfiguratorAttribute(Watch=true)];
// This will cause log4net to look for a configuration file
// called ConsoleApp.exe.config in the application base
// directory (i.e. the directory containing ConsoleApp.exe)
namespace ConsoleApp
{
/// <summary>
/// Example of how to simply configure and use log4net
/// </summary>
public __gc class LoggingExample
{
private:
// Create a logger for use in this class
static log4net::ILog* log = log4net::LogManager::GetLogger(System::Reflection::MethodBase::GetCurrentMethod()->DeclaringType);
// NOTE that using System.Reflection.MethodBase.GetCurrentMethod().DeclaringType
// is equivalent to typeof(LoggingExample) but is more portable
// i.e. you can copy the code directly into another class without
// needing to edit the code.
public:
/// <summary>
/// Application entry point
/// </summary>
/// <param name="args">command line arguments</param>
static void Main(String* args[])
{
// Log an info level message
if (log->IsInfoEnabled) log->Info(S"Application [ConsoleApp] Start");
// Log a debug message. Test if debug is enabled before
// attempting to log the message. This is not required but
// can make running without logging faster.
if (log->IsDebugEnabled) log->Debug(S"This is a debug message");
try
{
Bar();
}
catch(Exception* ex)
{
// Log an error with an exception
log->Error(S"Exception thrown from method Bar", ex);
}
log->Error(S"Hey this is an error!");
try
{
// Push a message on to the Nested Diagnostic Context stack
log4net::NDC::Push(S"NDC_Message");
log->Warn(S"This should have an NDC message");
// Set a Mapped Diagnostic Context value
log4net::MDC::Set(S"auth", S"auth-none");
log->Warn(S"This should have an MDC message for the key 'auth'");
}
__finally
{
// Pop the NDC message off the stack at the end of the block
log4net::NDC::Pop();
}
log->Warn(S"See the NDC has been popped of! The MDC 'auth' key is still with us.");
// Log an info level message
if (log->IsInfoEnabled) log->Info(S"Application [ConsoleApp] End");
Console::Write(S"Press Enter to exit...");
Console::ReadLine();
}
private:
// Helper methods to demonstrate location information and nested exceptions
static void Bar()
{
Goo();
}
static void Foo()
{
throw new Exception(S"This is an Exception");
}
static void Goo()
{
try
{
Foo();
}
catch(Exception* ex)
{
throw new ArithmeticException(S"Failed in Goo. Calling Foo. Inner Exception provided", ex);
}
}
};
}
// This is the entry point for this application
int _tmain(void)
{
// TODO: Please replace the sample code below with your own.
//Console::WriteLine(S"Hello World");
ConsoleApp::LoggingExample::Main(NULL);
return 0;
}