5 // Ben Maurer (bmaurer@users.sourceforge.net)
6 // Atsushi Enomoto (ginga@kit.hi-ho.ne.jp)
9 // (C) 2003 Atsushi Enomoto
13 // Permission is hereby granted, free of charge, to any person obtaining
14 // a copy of this software and associated documentation files (the
15 // "Software"), to deal in the Software without restriction, including
16 // without limitation the rights to use, copy, modify, merge, publish,
17 // distribute, sublicense, and/or sell copies of the Software, and to
18 // permit persons to whom the Software is furnished to do so, subject to
19 // the following conditions:
21 // The above copyright notice and this permission notice shall be
22 // included in all copies or substantial portions of the Software.
24 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
25 // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
26 // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
27 // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
28 // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
29 // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
30 // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
34 using System.Collections;
35 using System.Globalization;
\r
37 using System.Xml.XPath;
40 namespace Mono.Xml.Xsl {
41 internal class Debug {
42 [System.Diagnostics.Conditional("_DEBUG")]
43 internal static void TraceContext(XPathNavigator context) {
44 string output = "(null)";
46 if (context != null) {
47 context = context.Clone ();
48 switch (context.NodeType) {
49 case XPathNodeType.Element:
50 output = string.Format("<{0}:{1}", context.Prefix, context.LocalName);
51 for (bool attr = context.MoveToFirstAttribute(); attr; attr = context.MoveToNextAttribute()) {
52 output += string.Format(CultureInfo.InvariantCulture, " {0}:{1}={2}", context.Prefix, context.LocalName, context.Value);
64 [System.Diagnostics.Conditional("DEBUG")]
65 internal static void Assert (bool condition, string message)
68 throw new XsltException (message, null);
71 [System.Diagnostics.Conditional("_DEBUG")]
72 internal static void WriteLine (object value)
74 Console.Error.WriteLine (value);
77 [System.Diagnostics.Conditional("_DEBUG")]
78 internal static void WriteLine (string message)
80 Console.Error.WriteLine (message);
83 //static Stack eleStack = new Stack ();
85 [System.Diagnostics.Conditional("DEBUG")]
86 internal static void EnterNavigator (Compiler c)
88 //eleStack.Push (c.Input.Clone ());
91 [System.Diagnostics.Conditional("DEBUG")]
92 internal static void ExitNavigator (Compiler c)
94 //XPathNavigator x = (XPathNavigator)eleStack.Pop();
95 //if (!x.IsSamePosition (c.Input))
96 // throw new Exception ("Position must be the same on enter/exit. Enter node: " + x.Name + " exit node " + c.Input.Name);