减少NANT + MSBUILD中的冗长

时间:2016-07-11 14:57:14

标签: c# .net msbuild nuget nant

我正在努力减少NANT脚本产生的输出的冗长程度。

我尝试将msbuild命令链接参数设置为:/v:m /clp:ErrorsOnly但我仍然得到如下信息:

RestorePackages:
     [exec]          Restoring NuGet packages...

我还尝试在NANT脚本中设置几乎所有内容,但它仍然在控制台输出中得到它

<delete verbose="true"

我试图谷歌很多,但我无法清除NANT / MSBUILD的日志。

1 个答案:

答案 0 :(得分:1)

您可以创建自己的任务容器来定义内部代码的日志级别

        [TaskName("loglevel")]
        public class LogLevelTask : TaskContainer
        {
            private Level _logLevel;

            protected override void ExecuteTask()
            {
                Level oldLevel = Project.Threshold;
                try
                {
                    SetLogLevel(_logLevel);
                    base.ExecuteTask();
                }
                finally
                {
                    SetLogLevel(oldLevel);
                }
            }

            [TaskAttribute("level", Required = true)]
            public Level LogLevel
            {
                get
                {
                    return _logLevel;
                }
                set
                {
                    _logLevel = value;
                }
            }

            public void SetLogLevel(Level newLevel)
            {
                foreach(IBuildListener listener in Project.BuildListeners)
                {
                    IBuildLogger logger = listener as IBuildLogger;
                    if(logger != null)
                    {
                        logger.Threshold = newLevel;
                    }
                }
            }
        }

然后你可以将它添加到nant脚本

<loglevel level="None"> <!-- You can set any other level -->
    <!-- Do whatever you want -->
</loglevel>

您可以在此处详细了解 http://www.neovolve.com/2008/01/16/loglevel-nant-task/