How to get class name?

Total Post:27

Points:189
 1103  View(s)
Ratings:
Rate this:

How to get the class-name with caller info attributes.

I strongly say a no to log the class name using reflection.

Was able to get the method name using the [CallerMemberName] like below:

        private void Log(string logMessage, [CallerMemberName]string callerName = null)
        {
            if (logger.IsDebugEnabled)
            {
                logger.DebugFormat("Executing Method = {1};{0}", logMessage, callerName);
            }
        }

How to log the class name here using Caller Info Attributes ?

  1. Post:40

    Points:280
    Re: How to get class name?

    You can't there is no attribute available that does that. However because Log is private no external classes could call the function so you already know which class called it.

    public SomeClass
    {
     
        //(snip)
     
        private void Log(string logMessage, [CallerMemberName]string callerName = null)
        {
     
            if (logger.IsDebugEnabled)
            {
                string className = typeof(SomeClass).Name;
     
                logger.DebugFormat("Executing Method = {1};{2}.{0}", logMessage, callerName, className);
            }
        }
    }

      Modified On Apr-08-2018 11:23:47 PM

Answer