* Makefile ($(build_lib)): Make CYCLIC_DEP_FILES depend on this.
[mono.git] / mcs / class / Microsoft.Build.Engine / Microsoft.Build.BuildEngine / MetadataReference.cs
1 //
2 // MetadataReference.cs: Represents a metadata reference in expression.
3 //
4 // Author:
5 //   Marek Sieradzki (marek.sieradzki@gmail.com)
6 // 
7 // (C) 2005 Marek Sieradzki
8 //
9 // Permission is hereby granted, free of charge, to any person obtaining
10 // a copy of this software and associated documentation files (the
11 // "Software"), to deal in the Software without restriction, including
12 // without limitation the rights to use, copy, modify, merge, publish,
13 // distribute, sublicense, and/or sell copies of the Software, and to
14 // permit persons to whom the Software is furnished to do so, subject to
15 // the following conditions:
16 //
17 // The above copyright notice and this permission notice shall be
18 // included in all copies or substantial portions of the Software.
19 //
20 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
21 // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
22 // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
23 // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
24 // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
25 // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
26 // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
27
28 #if NET_2_0
29
30 using System;
31 using System.Collections.Generic;
32 using System.Text;
33 using Microsoft.Build.Framework;
34 using Microsoft.Build.Utilities;
35
36 namespace Microsoft.Build.BuildEngine {
37         internal class MetadataReference : IReference {
38         
39                 string          itemName;
40                 string          metadataName;
41                 int start;
42                 int length;
43         
44                 public MetadataReference (string itemName, string metadataName, int start, int length)
45                 {
46                         this.itemName = itemName;
47                         this.metadataName = metadataName;
48                         this.start = start;
49                         this.length = length;
50                 }
51                 
52                 public string ItemName {
53                         get { return itemName; }
54                 }
55                 
56                 public string MetadataName {
57                         get { return metadataName; }
58                 }
59                 
60                 public bool IsQualified {
61                         get { return (itemName == null) ? false : true; }
62                 }
63
64                 public int Start {
65                         get { return start; }
66                 }
67
68                 public int End {
69                         get { return start + length - 1; }
70                 }
71
72                 public string ConvertToString (Project project)
73                 {
74                         return project.GetMetadataBatched (itemName, metadataName);
75                 }
76
77                 public ITaskItem [] ConvertToITaskItemArray (Project project)
78                 {
79                         List<ITaskItem> items = new List<ITaskItem> ();
80                         if (IsQualified) {
81                                 // Bucket would have item lists with same metadata values,
82                                 // so just get the value from the first item
83                                 BuildItemGroup group;
84                                 if (project.TryGetEvaluatedItemByNameBatched (itemName, out group))
85                                         BuildItemGroupToITaskItems (group, items, true);
86                         } else {
87                                 // Get unique metadata values from _all_ item lists
88                                 foreach (BuildItemGroup group in project.GetAllItemGroups ())
89                                         BuildItemGroupToITaskItems (group, items, false);
90                         }
91
92                         return items.Count == 0 ? null : items.ToArray ();
93                 }
94
95                 // Gets metadata values from build item @group and adds as ITaskItem
96                 // objects to @items
97                 // @only_one: Batched case, all item lists would have same metadata values,
98                 //            just return first one
99                 void BuildItemGroupToITaskItems (BuildItemGroup group, List<ITaskItem> items, bool only_one)
100                 {
101                         foreach (BuildItem item in group) {
102                                 if (!item.HasMetadata (metadataName))
103                                         continue;
104
105                                 string metadata = item.GetMetadata (metadataName);
106                                 if (HasTaskItem (items, metadata))
107                                         //return only unique metadata values
108                                         continue;
109
110                                 items.Add (new TaskItem (metadata));
111                                 if (only_one)
112                                         break;
113                         }
114                 }
115
116                 private bool HasTaskItem (List<ITaskItem> items, string itemspec)
117                 {
118                         foreach (ITaskItem task_item in items)
119                                 if (task_item.ItemSpec == itemspec)
120                                         return true;
121                         return false;
122                 }
123
124                 public override string ToString ()
125                 {
126                         if (IsQualified)
127                                 return String.Format ("%({0}.{1})", itemName, metadataName);
128                         else
129                                 return String.Format ("%({0})", metadataName);
130                 }
131         }
132 }
133
134 #endif