After reading an [article on the codeproject][1] about PostSharp and Log4Net.

So I tried to replicate that in VB.Net and hit a bump in the road. But here is how it got solved in the end.

So like the instructions say I downloaded [PostSharp][2] and installed it. I also downloaded the [log4postsharp sourcecode][3].

Then I created a consoleapplication.

I set the references Log4PostSharp.dll and PostSharp.Public.dll (you can find this library on the “.NET” tab of the “Add reference…” dialog). And a reference to the log4net dll.

I then added some code to the module.

Imports Log4PostSharp

Module Module1

    Sub Main()
        Console.WriteLine(Add(1, 1))
        Console.ReadLine()
        Dim sum As Integer
        sum = Add(1, 2)
        Console.WriteLine(Add(1, 1))
        Console.ReadLine()
    End Sub

    <Log(EntryLevel:=LogLevel.Debug, EntryText:="Adding {@i1} to {@i2}.", ExitLevel:=LogLevel.Debug, ExitText:="Result of addition is {returnvalue}.")> _
  Private Function Add(ByVal i1 As Integer, ByVal i2 As Integer) As Integer
        Return i1 + i2
    End Function

End Module

Then I added an app.config file.

And added these log4net configurationsetting to it.

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <configSections>
    <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" />
  </configSections>
  <log4net>
    <appender name="MainAppender" type="log4net.Appender.ConsoleAppender">
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%date [%thread] %-5level %logger %ndc - %message%newline" />
      </layout>
    </appender>
    <root>
      <level value="ALL" />
      <appender-ref ref="MainAppender" />
    </root>
  </log4net>
</configuration>

But that did nothing, in the logging sense anyway.

So to make sure I didn’t make a mistake in the log4net configuration, I added this to the main method.

log4net.Config.BasicConfigurator.Configure()
        Dim log As log4net.ILog = log4net.LogManager.GetLogger("logger-name")
        log.Debug("test")
        Console.ReadLine()
        ```
and that made the log line for me. Just the one, not the one from log4postsharp.

So I posted a question on the [postsharp forum][4]. And I got a reply the same day.

So I added this to the AssemblyInfo.vb

```xml
<Assembly: XmlConfigurator(Watch:=True)> 

And then I removed these lines again

log4net.Config.BasicConfigurator.Configure()
        Dim log As log4net.ILog = log4net.LogManager.GetLogger("logger-name")
        log.Debug("test")
        Console.ReadLine()
        ```
and everything works as expected.

 [1]: http://www.codeproject.com/KB/dotnet/log4postsharp-intro.aspx?display=Print
 [2]: http://www.postsharp.org
 [3]: http://code.google.com/p/postsharp-user-plugins/wiki/Log4PostSharp
 [4]: http://www.postsharp.org/forum/post1855.html#p1855