my_xml.h 2.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. /* Copyright (C) 2000 MySQL AB
  2. This program is free software; you can redistribute it and/or modify
  3. it under the terms of the GNU General Public License as published by
  4. the Free Software Foundation; version 2 of the License.
  5. This program is distributed in the hope that it will be useful,
  6. but WITHOUT ANY WARRANTY; without even the implied warranty of
  7. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  8. GNU General Public License for more details.
  9. You should have received a copy of the GNU General Public License
  10. along with this program; if not, write to the Free Software
  11. Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */
  12. #ifndef _my_xml_h
  13. #define _my_xml_h
  14. #ifdef __cplusplus
  15. extern "C" {
  16. #endif
  17. #define MY_XML_OK 0
  18. #define MY_XML_ERROR 1
  19. /*
  20. A flag whether to use absolute tag names in call-back functions,
  21. like "a", "a.b" and "a.b.c" (used in character set file parser),
  22. or relative names like "a", "b" and "c".
  23. */
  24. #define MY_XML_FLAG_RELATIVE_NAMES 1
  25. /*
  26. A flag whether to skip normilization of text values before calling
  27. call-back functions: i.e. skip leading/trailing spaces,
  28. \r, \n, \t characters.
  29. */
  30. #define MY_XML_FLAG_SKIP_TEXT_NORMALIZATION 2
  31. enum my_xml_node_type
  32. {
  33. MY_XML_NODE_TAG, /* can have TAG, ATTR and TEXT children */
  34. MY_XML_NODE_ATTR, /* can have TEXT children */
  35. MY_XML_NODE_TEXT /* cannot have children */
  36. };
  37. typedef struct xml_stack_st
  38. {
  39. int flags;
  40. enum my_xml_node_type current_node_type;
  41. char errstr[128];
  42. char attr[128];
  43. char *attrend;
  44. const char *beg;
  45. const char *cur;
  46. const char *end;
  47. void *user_data;
  48. int (*enter)(struct xml_stack_st *st,const char *val, size_t len);
  49. int (*value)(struct xml_stack_st *st,const char *val, size_t len);
  50. int (*leave_xml)(struct xml_stack_st *st,const char *val, size_t len);
  51. } MY_XML_PARSER;
  52. void my_xml_parser_create(MY_XML_PARSER *st);
  53. void my_xml_parser_free(MY_XML_PARSER *st);
  54. int my_xml_parse(MY_XML_PARSER *st,const char *str, size_t len);
  55. void my_xml_set_value_handler(MY_XML_PARSER *st, int (*)(MY_XML_PARSER *,
  56. const char *,
  57. size_t len));
  58. void my_xml_set_enter_handler(MY_XML_PARSER *st, int (*)(MY_XML_PARSER *,
  59. const char *,
  60. size_t len));
  61. void my_xml_set_leave_handler(MY_XML_PARSER *st, int (*)(MY_XML_PARSER *,
  62. const char *,
  63. size_t len));
  64. void my_xml_set_user_data(MY_XML_PARSER *st, void *);
  65. size_t my_xml_error_pos(MY_XML_PARSER *st);
  66. uint my_xml_error_lineno(MY_XML_PARSER *st);
  67. const char *my_xml_error_string(MY_XML_PARSER *st);
  68. #ifdef __cplusplus
  69. }
  70. #endif
  71. #endif /* _my_xml_h */