debug_print.odin 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. /*
  2. An XML 1.0 / 1.1 parser
  3. Copyright 2021-2022 Jeroen van Rijn <[email protected]>.
  4. Made available under Odin's BSD-3 license.
  5. A from-scratch XML implementation, loosely modeled on the [spec](https://www.w3.org/TR/2006/REC-xml11-20060816).
  6. List of contributors:
  7. Jeroen van Rijn: Initial implementation.
  8. */
  9. package xml
  10. import "core:io"
  11. import "core:fmt"
  12. /*
  13. Just for debug purposes.
  14. */
  15. print :: proc(writer: io.Writer, doc: ^Document) -> (written: int, err: io.Error) {
  16. if doc == nil { return }
  17. using fmt
  18. written += wprintf(writer, "[XML Prolog]\n")
  19. for attr in doc.prologue {
  20. written += wprintf(writer, "\t%v: %v\n", attr.key, attr.val)
  21. }
  22. written += wprintf(writer, "[Encoding] %v\n", doc.encoding)
  23. if len(doc.doctype.ident) > 0 {
  24. written += wprintf(writer, "[DOCTYPE] %v\n", doc.doctype.ident)
  25. if len(doc.doctype.rest) > 0 {
  26. wprintf(writer, "\t%v\n", doc.doctype.rest)
  27. }
  28. }
  29. for comment in doc.comments {
  30. written += wprintf(writer, "[Pre-root comment] %v\n", comment)
  31. }
  32. if len(doc.elements) > 0 {
  33. wprintln(writer, " --- ")
  34. print_element(writer, doc, 0)
  35. wprintln(writer, " --- ")
  36. }
  37. return written, .None
  38. }
  39. print_element :: proc(writer: io.Writer, doc: ^Document, element_id: Element_ID, indent := 0) -> (written: int, err: io.Error) {
  40. using fmt
  41. tab :: proc(writer: io.Writer, indent: int) {
  42. for _ in 0..=indent {
  43. wprintf(writer, "\t")
  44. }
  45. }
  46. tab(writer, indent)
  47. element := doc.elements[element_id]
  48. if element.kind == .Element {
  49. wprintf(writer, "<%v>\n", element.ident)
  50. if len(element.value) > 0 {
  51. tab(writer, indent + 1)
  52. wprintf(writer, "[Value] %v\n", element.value)
  53. }
  54. for attr in element.attribs {
  55. tab(writer, indent + 1)
  56. wprintf(writer, "[Attr] %v: %v\n", attr.key, attr.val)
  57. }
  58. for child in element.children {
  59. print_element(writer, doc, child, indent + 1)
  60. }
  61. } else if element.kind == .Comment {
  62. wprintf(writer, "[COMMENT] %v\n", element.value)
  63. }
  64. return written, .None
  65. }