xpputils.cpp 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160
  1. #include "jlib.hpp"
  2. #include "XmlPullParser.h"
  3. #include "xpputils.h"
  4. using namespace xpp;
  5. IMultiException *xppMakeException(XmlPullParser &xppx)
  6. {
  7. StringBuffer msg;
  8. StringBuffer sourcestr;
  9. int code = -1;
  10. int level = 1;
  11. int type = XmlPullParser::END_TAG;
  12. StartTag stag;
  13. while(level > 0)
  14. {
  15. type = xppx.next();
  16. switch(type)
  17. {
  18. case XmlPullParser::START_TAG:
  19. {
  20. xppx.readStartTag(stag);
  21. ++level;
  22. const char *tag = stag.getLocalName();
  23. if (!stricmp(tag, "Message"))
  24. {
  25. readFullContent(xppx, msg);
  26. }
  27. else if (!stricmp(tag, "Code"))
  28. {
  29. StringBuffer codestr;
  30. readFullContent(xppx, codestr);
  31. code = atoi(codestr.str());
  32. }
  33. else if (!stricmp(tag, "Source"))
  34. {
  35. readFullContent(xppx, sourcestr);
  36. }
  37. break;
  38. }
  39. case XmlPullParser::END_TAG:
  40. --level;
  41. break;
  42. case XmlPullParser::END_DOCUMENT:
  43. level=0;
  44. break;
  45. }
  46. }
  47. IMultiException * me = MakeMultiException(sourcestr.str());
  48. me->append(*MakeStringException(code, msg.str()));
  49. return me;
  50. }
  51. void xppToXmlString(XmlPullParser &xpp, StartTag &stag, StringBuffer & buffer)
  52. {
  53. int level = 1; //assumed due to the way gotonextdataset works.
  54. int type = XmlPullParser::END_TAG;
  55. const char * content = "";
  56. const char *tag = NULL;
  57. EndTag etag;
  58. tag = stag.getLocalName();
  59. if (tag)
  60. {
  61. buffer.appendf("<%s", tag);
  62. for (int idx=0; idx<stag.getLength(); idx++)
  63. {
  64. buffer.appendf(" %s=\"", stag.getRawName(idx));
  65. buffer.append(stag.getValue(idx));
  66. buffer.append('\"');
  67. }
  68. buffer.append(">");
  69. }
  70. do
  71. {
  72. type = xpp.next();
  73. switch(type)
  74. {
  75. case XmlPullParser::START_TAG:
  76. {
  77. xpp.readStartTag(stag);
  78. ++level;
  79. tag = stag.getLocalName();
  80. if (tag)
  81. {
  82. buffer.appendf("<%s", tag);
  83. for (int idx=0; idx<stag.getLength(); idx++)
  84. {
  85. buffer.appendf(" %s=\"", stag.getRawName(idx));
  86. buffer.append(stag.getValue(idx));
  87. buffer.append('\"');
  88. }
  89. buffer.append(">");
  90. }
  91. break;
  92. }
  93. case XmlPullParser::END_TAG:
  94. xpp.readEndTag(etag);
  95. tag = etag.getLocalName();
  96. if (tag)
  97. buffer.appendf("</%s>", tag);
  98. --level;
  99. break;
  100. case XmlPullParser::CONTENT:
  101. content = xpp.readContent();
  102. encodeXML(content, buffer);
  103. break;
  104. case XmlPullParser::END_DOCUMENT:
  105. level=0;
  106. break;
  107. }
  108. }
  109. while (level > 0);
  110. }
  111. bool xppGotoTag(XmlPullParser &xppx, const char *tagname, StartTag &stag)
  112. {
  113. int level = 1;
  114. int type = XmlPullParser::END_TAG;
  115. do
  116. {
  117. type = xppx.next();
  118. switch(type)
  119. {
  120. case XmlPullParser::START_TAG:
  121. {
  122. xppx.readStartTag(stag);
  123. ++level;
  124. const char *tag = stag.getLocalName();
  125. if (!stricmp(tag, tagname))
  126. return true;
  127. else if (!stricmp(tag, "Exception"))
  128. throw xppMakeException(xppx);
  129. break;
  130. }
  131. case XmlPullParser::END_TAG:
  132. --level;
  133. break;
  134. case XmlPullParser::END_DOCUMENT:
  135. level=0;
  136. break;
  137. }
  138. }
  139. while (level > 0);
  140. return false;
  141. }