Narzędzia użytkownika

Narzędzia witryny


xerces_dom

Różnice

Różnice między wybraną wersją a wersją aktualną.

Odnośnik do tego porównania

Both sides previous revision Previous revision
Next revision
Previous revision
Next revision Both sides next revision
xerces_dom [2008/04/14 18:20]
kmioduszewski
xerces_dom [2008/04/14 20:15]
kmioduszewski
Linia 14: Linia 14:
 Więcej informacji na stronie projektu http://​xerces.apache.org/​xerces-c/​. ​ Więcej informacji na stronie projektu http://​xerces.apache.org/​xerces-c/​. ​
 Na stronie znajdują się źródła, oraz skompilowane wersje biblioteki na różne platformy. Kompletna instrukcja instalacji na różnych platformach znajduje się [[http://​xerces.apache.org/​xerces-c/​install.html|tutaj]]. ​   ​ Na stronie znajdują się źródła, oraz skompilowane wersje biblioteki na różne platformy. Kompletna instrukcja instalacji na różnych platformach znajduje się [[http://​xerces.apache.org/​xerces-c/​install.html|tutaj]]. ​   ​
 +
 +
  
  
Linia 28: Linia 30:
 #include <​xercesc/​util/​XMLString.hpp>​ #include <​xercesc/​util/​XMLString.hpp>​
 #include <​xercesc/​dom/​DOM.hpp> ​ #include <​xercesc/​dom/​DOM.hpp> ​
-#​include<​xercesc/​parsers/​XercesDOMParser.hpp>​+#include <​xercesc/​parsers/​XercesDOMParser.hpp>​
 </​code>​ </​code>​
 Xerces posiada własny typ znakowy ''​XMLCh'',​ który jest używany zamiast ''​char''​ i ''​std::​string''​. Do konwersji pomiędzy typami ''​char*''​ a ''​XMLCh*''​ (w obie strony) używana jest funkcja ''​XMLString::​transcode()''​. Pamięć zaalokowaną na łańcuchy należy zwalniać za pomocą funkcji ''​XMLString::​release()''​. ​ Xerces posiada własny typ znakowy ''​XMLCh'',​ który jest używany zamiast ''​char''​ i ''​std::​string''​. Do konwersji pomiędzy typami ''​char*''​ a ''​XMLCh*''​ (w obie strony) używana jest funkcja ''​XMLString::​transcode()''​. Pamięć zaalokowaną na łańcuchy należy zwalniać za pomocą funkcji ''​XMLString::​release()''​. ​
Linia 38: Linia 40:
 #include <​xercesc/​util/​XMLString.hpp>​ #include <​xercesc/​util/​XMLString.hpp>​
 #include <​xercesc/​dom/​DOM.hpp> ​ #include <​xercesc/​dom/​DOM.hpp> ​
-#​include<​xercesc/​parsers/​XercesDOMParser.hpp>​+#include <​xercesc/​parsers/​XercesDOMParser.hpp>​
 // ... // ...
 #include <​iostream>  ​ #include <​iostream>  ​
Linia 66: Linia 68:
 </​code>​ </​code>​
  
-===== przykład itd. ===== + 
-cdn..  + 
 + 
 + 
 +===== XercesDOMParser ===== 
 +Jest to parser umożliwiający wczytanie do pamięci struktury pliku XML za pomocą metody ''​parse()''​. Po czym uzyskujemy dostęp do obiektu ''​DOMDocument'',​ po którym możemy poruszać się wykorzystując zaimplementowane w zgodzie z rekomendacjami W3C metody. 
 + 
 +Poniżej ​przykładowe fragmenty kodu dotyczącego inicjalizacji i korzystania z XercesDOMParser. 
 +<code cpp> 
 +xercesc::​XercesDOMParser* parser ​new xercesc::​XercesDOMParser();​ 
 +parser->​setValidationScheme(xercesc::​XercesDOMParser::​Val_Auto); ​ //uruchamia walidację, jeżeli dostępne jest DTD (wewnętrzne/​zewnętrzne) ​   
 +parser->​setDoNamespaces(true); ​  
 + 
 +char* xmlFile ​"​file.xml";​ 
 + 
 +try { 
 +    parser->​parse(xmlFile);​ 
 +
 +catch( const xercesc::​XMLException&​ e ){ 
 +    //...  
 +
 +catch( const xercesc::​DOMException&​ e ){ 
 +    //...  
 +
 +catch (...) { 
 +    //... 
 +
 + 
 +if(parser->​getErrorCount()==0) { 
 +    xercesc::​DOMDocument* XMLdoc ​parser->​getDocument();​ 
 +    //..
 +
 + 
 +</​code> ​
xerces_dom.txt · ostatnio zmienione: 2008/04/16 15:33 przez kmioduszewski