Convert a stream of text lines separated with newline sequences into an XML build result.
//CruiseControl is open source software and is developed and maintained by a group of dedicated volunteers.
//CruiseControl is distributed under a BSD-style license.
//http://cruisecontrol.sourceforge.net/
using System;
using System.Collections;
using System.Collections.Generic;
using System.IO;
using System.Text;
using System.Text.RegularExpressions;
namespace ThoughtWorks.CruiseControl.Core.Util
{
/// <summary>
/// Class with handy stirng routines
/// </summary>
public class StringUtil
{
/// <summary>
/// Convert a stream of text lines separated with newline sequences into an XML build result.
/// </summary>
/// <param name="input">the text stream</param>
/// <param name="msgLevel">the message level, if any. Values are "Error" and "Warning".</param>
/// <returns>the build result string</returns>
/// <remarks>If there are any non-blank lines in the input, they are each wrapped in a
/// <code><message></code> element and the entire set is wrapped in a
/// <code><buildresults></code> element and returned. Each line of the input is encoded
/// as XML CDATA rules require. If the input is empty or contains only whitspace, an
/// empty string is returned.
/// Note: If we can't manage to understand the input, we just return it unchanged.
/// </remarks>
public static string MakeBuildResult(string input, string msgLevel)
{
StringBuilder sb = new StringBuilder();
// Pattern for capturing a line of text, exclusive of the line-ending sequence.
// A "line" is an non-empty unbounded sequence of characters followed by some
// kind of line-ending sequence (CR, LF, or any combination thereof) or
// end-of-string.
Regex linePattern = new Regex(@"([^\r\n]+)");
MatchCollection lines = linePattern.Matches(input);
if (lines.Count > 0)
{
sb.Append(Environment.NewLine);
sb.Append("<buildresults>");
sb.Append(Environment.NewLine);
foreach (Match line in lines)
{
sb.Append(" <message");
if (msgLevel != string.Empty)
sb.AppendFormat(" level=\"{0}\"", msgLevel);
sb.Append(">");
sb.Append(line.ToString());
sb.Append("</message>");
sb.Append(Environment.NewLine);
}
sb.Append("</buildresults>");
sb.Append(Environment.NewLine);
}
else
sb.Append(input); // All of that stuff failed, just return our input
return sb.ToString();
}
}
}
Related examples in the same category
1. | Writing XML with the XmlWriter Class | | |
2. | Reading from an XML file. | | |
3. | Access Attributes | | |
4. | Load Xml Document Sample | | |
5. | Read An XML File | | |
6. | Read XML From URL | | |
7. | Illustrates the XmlTextReader class | | |
8. | Load xml document from xml file | | |
9. | If a Xml node Has Attributes | | |
10. | Convert String To XmlReader | | |
11. | Remove empty tags in the Xml string | | |
12. | Gets an appropriate System.Xml.XmlReader implementation for the supplied System.IO.Stream | | |
13. | XmlNameTable of atomized string objects. | | |
14. | XmlReader represents a reader that provides non-cached, forward-only access to XML data. | | |
15. | XmlReader.AttributeCount Property returns the number of attributes | | |
16. | XmlReader.Create creates a new XmlReader instance using the specified stream. | | |
17. | XmlReader.Create (String) creates a new XmlReader instance with specified URI. | | |
18. | XmlReader.Create (String, XmlReaderSettings) creates XmlReader with URI and XmlReaderSettings. | | |
19. | XmlReader.Create creates a new XmlReader instance. | | |
20. | XmlReader.Create (TextReader) creates a new XmlReader instance with the specified TextReader. | | |
21. | XmlReader.Create (TextReader, XmlReaderSettings, XmlParserContext) | | |
22. | XmlReader.Create (XmlReader, XmlReaderSettings) creates XmlReader with XmlReader and XmlReaderSettings | | |
23. | XmlReader.GetAttribute return the value of the attribute with the specified index. | | |
24. | XmlReader.GetAttribute (String) returns the attribute with the specified Name. | | |
25. | XmlReader.HasAttributes tells whether the current node has any attributes. | | |
26. | XmlReader.IsDefault | | |
27. | XmlReader.IsEmptyElement tells whether the current node is an empty element (for example, ). | | |
28. | XmlReader.IsStartElement (String) tells if the current content node is a start tag or empty element tag. | | |
29. | XmlReader.Item Property returns the value of the attribute with the specified Name. | | |
30. | XmlReader.LocalName Property gets the local name of the current node. | | |
31. | XmlReader.MoveToAttribute (Int32) moves to the attribute with the specified index. | | |
32. | XmlReader.MoveToFirstAttribute moves to the first attribute. | | |
33. | XmlReader.Name Property gets the qualified name of the current node. | | |
34. | XmlReader.ReadContentAs reads the content as an object of the type specified. | | |
35. | XmlReader.ReadContentAsBoolean reads the text content at the current position as a Boolean. | | |
36. | XmlReader.ReadElementContentAs(Type, IXmlNamespaceResolver) reads the element content as the requested type. | | |
37. | XmlReader.ReadElementContentAsBinHex reads the element and decodes the BinHex content. | | |
38. | XmlReader.ReadElementContentAsDateTime reads the element and returns the contents as a DateTime object. | | |
39. | XmlReader.ReadElementContentAsDouble reads element and returns the contents as a double | | |
40. | XmlReader.ReadElementContentAsLong reads the element and returns a 64-bit signed integer. | | |
41. | XmlReader.ReadElementContentAsObject reads the current element and returns the contents as an Object. | | |
42. | XmlReader.ReadElementContentAsString reads the element and returns the contents as a String object. | | |
43. | XmlReader.ReadElementString reads a text-only element. | | |
44. | XmlReader.ReadEndElement checks that the current content node is an end tag | | |
45. | XmlReader.ReadInnerXml reads all the content, including markup, as a string. | | |
46. | XmlReader.ReadSubtree reads the current node, and all its descendants. | | |
47. | XmlReader.ReadToDescendant advances XmlReader to the next descendant element with the specified qualified name. | | |
48. | XmlReader.ReadToNextSibling (String) advances XmlReader to next sibling element with specified qualified name. | | |
49. | XmlReader.Skip skips the children of the current node. | | |
50. | Get value as DateTime | | |
51. | Get Xml value as Integer | | |
52. | Get Xml value as TimeSpan | | |
53. | Convets the value in an XML element to a nullable DateTime | | |