xmlwf_helpgen.py 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. #! /usr/bin/env python3
  2. # __ __ _
  3. # ___\ \/ /_ __ __ _| |_
  4. # / _ \\ /| '_ \ / _` | __|
  5. # | __// \| |_) | (_| | |_
  6. # \___/_/\_\ .__/ \__,_|\__|
  7. # |_| XML parser
  8. #
  9. # Copyright (c) 2019-2025 Sebastian Pipping <[email protected]>
  10. # Copyright (c) 2021 Tim Bray <[email protected]>
  11. # Licensed under the MIT license:
  12. #
  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 permit
  18. # persons to whom the Software is furnished to do so, subject to the
  19. # following conditions:
  20. #
  21. # The above copyright notice and this permission notice shall be included
  22. # in all copies or substantial portions of the Software.
  23. #
  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 NONINFRINGEMENT. IN
  27. # NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
  28. # DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
  29. # OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
  30. # USE OR OTHER DEALINGS IN THE SOFTWARE.
  31. import argparse
  32. epilog = """
  33. environment variables:
  34. EXPAT_ACCOUNTING_DEBUG=(0|1|2|3)
  35. Control verbosity of accounting debugging (default: 0)
  36. EXPAT_ENTITY_DEBUG=(0|1)
  37. Control verbosity of entity debugging (default: 0)
  38. EXPAT_ENTROPY_DEBUG=(0|1)
  39. Control verbosity of entropy debugging (default: 0)
  40. EXPAT_MALLOC_DEBUG=(0|1|2)
  41. Control verbosity of allocation tracker (default: 0)
  42. exit status:
  43. 0 the input files are well-formed and the output (if requested) was written successfully
  44. 1 could not allocate data structures, signals a serious problem with execution environment
  45. 2 one or more input files were not well-formed
  46. 3 could not create an output file
  47. 4 command-line argument error
  48. xmlwf of libexpat is software libre, licensed under the MIT license.
  49. Please report bugs at https://github.com/libexpat/libexpat/issues -- thank you!
  50. """
  51. usage = """
  52. %(prog)s [OPTIONS] [FILE ...]
  53. %(prog)s -h|--help
  54. %(prog)s -v|--version
  55. """
  56. parser = argparse.ArgumentParser(prog='xmlwf', add_help=False,
  57. usage=usage,
  58. description='xmlwf - Determines if an XML document is well-formed',
  59. formatter_class=argparse.RawTextHelpFormatter,
  60. epilog=epilog)
  61. input_related = parser.add_argument_group('input control arguments')
  62. input_related.add_argument('-s', action='store_true', help='print an error if the document is not [s]tandalone')
  63. input_related.add_argument('-n', action='store_true', help='enable [n]amespace processing')
  64. input_related.add_argument('-p', action='store_true', help='enable processing of external DTDs and [p]arameter entities')
  65. input_related.add_argument('-x', action='store_true', help='enable processing of e[x]ternal entities')
  66. input_related.add_argument('-e', action='store', metavar='ENCODING', help='override any in-document [e]ncoding declaration')
  67. input_related.add_argument('-w', action='store_true', help='enable support for [W]indows code pages')
  68. input_related.add_argument('-r', action='store_true', help='disable memory-mapping and use [r]ead calls instead')
  69. input_related.add_argument('-g', metavar='BYTES', help='buffer size to request per call pair to XML_[G]etBuffer and read (default: 8 KiB)')
  70. input_related.add_argument('-k', action='store_true', help='when processing multiple files, [k]eep processing after first file with error')
  71. output_related = parser.add_argument_group('output control arguments')
  72. output_related.add_argument('-d', action='store', metavar='DIRECTORY', help='output [d]estination directory')
  73. output_mode = output_related.add_mutually_exclusive_group()
  74. output_mode.add_argument('-c', action='store_true', help='write a [c]opy of input XML, not canonical XML')
  75. output_mode.add_argument('-m', action='store_true', help='write [m]eta XML, not canonical XML')
  76. output_mode.add_argument('-t', action='store_true', help='write no XML output for [t]iming of plain parsing')
  77. output_related.add_argument('-N', action='store_true', help='enable adding doctype and [n]otation declarations')
  78. billion_laughs = parser.add_argument_group('amplification attack protection (e.g. billion laughs)',
  79. description='NOTE: '
  80. 'If you ever need to increase these values '
  81. 'for non-attack payload, please file a bug report.')
  82. billion_laughs.add_argument('-a', metavar='FACTOR',
  83. help='set maximum tolerated [a]mplification factor (default: 100.0)')
  84. billion_laughs.add_argument('-b', metavar='BYTES', help='set number of output [b]ytes needed to activate (default: 8 MiB/64 MiB)')
  85. reparse_deferral = parser.add_argument_group('reparse deferral')
  86. reparse_deferral.add_argument('-q', action='store_true',
  87. help='disable reparse deferral, and allow [q]uadratic parse runtime with large tokens')
  88. parser.add_argument('files', metavar='FILE', nargs='*', help='file to process (default: STDIN)')
  89. info = parser.add_argument_group('info arguments')
  90. info = info.add_mutually_exclusive_group()
  91. info.add_argument('-h', '--help', action='store_true', help='show this [h]elp message and exit')
  92. info.add_argument('-v', '--version', action='store_true', help='show program\'s [v]ersion number and exit')
  93. if __name__ == '__main__':
  94. parser.print_help()