1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
|
// Copyright (C) 2025 The Qt Company Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only WITH Qt-GPL-exception-1.0
#region Task TaskName="DumpItems"
#region Reference
#endregion
#region Using
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using Microsoft.Build.Framework;
#endregion
#region Comment
/////////////////////////////////////////////////////////////////////////////////////////////////
/// TASK DumpItems
/////////////////////////////////////////////////////////////////////////////////////////////////
// Dump contents of items as a log message. The contents are formatted as XML.
// Parameters:
// in string ItemType: type of the items; this is used as the parent node of each
// item dump
// in ITaskItem[] Items: items to dump
// in bool DumpReserved: include MSBuild reserved metadata in dump?
// in string Metadata: list of names of metadata to include in dump; omit to
// include all metadata
#endregion
namespace QtVsTools.QtMsBuild.Tasks
{
public static class DumpItems
{
public static QtMSBuild.ITaskLoggingHelper Log { get; set; }
public static bool Execute(
#region Parameters
System.String ItemType,
Microsoft.Build.Framework.ITaskItem[] Items,
System.Boolean DumpReserved = false,
System.String Metadata = null)
#endregion
{
#region Code
var reserved = new HashSet<string>
{
"AccessedTime", "CreatedTime", "DefiningProjectDirectory",
"DefiningProjectExtension", "DefiningProjectFullPath", "DefiningProjectName",
"Directory", "Extension", "Filename", "FullPath", "Identity", "ModifiedTime",
"RecursiveDir", "RelativeDir", "RootDir"
};
if (Metadata == null)
Metadata = "";
var requestedNames = new HashSet<string>(Metadata.Split(new[] { ';' },
StringSplitOptions.RemoveEmptyEntries));
var itemXml = new StringBuilder();
if (Items.Any()) {
foreach (var item in Items) {
if (itemXml.Length > 0)
itemXml.Append("\r\n");
itemXml.AppendFormat("<{0} Include=\"{1}\"", ItemType, item.ItemSpec);
var names = item.MetadataNames.Cast<string>()
.Where(x => (DumpReserved || !reserved.Contains(x))
&& (!requestedNames.Any() || requestedNames.Contains(x)))
.OrderBy(x => x)
.ToList();
if (names.Any()) {
itemXml.Append(">\r\n");
foreach (string name in names) {
if (!DumpReserved && reserved.Contains(name))
continue;
if (!item.MetadataNames.Cast<string>().Contains(name))
continue;
var value = item.GetMetadata(name);
if (!string.IsNullOrEmpty(value))
itemXml.AppendFormat(" <{0}>{1}</{0}>\r\n", name, value);
else
itemXml.AppendFormat(" <{0}/>\r\n", name);
}
itemXml.AppendFormat("</{0}>", ItemType);
} else {
itemXml.Append("/>");
}
}
} else {
itemXml.AppendFormat("<{0}/>", ItemType);
}
Log.LogMessage(MessageImportance.High, itemXml.ToString());
#endregion
return true;
}
}
}
#endregion
|