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 16:43]
kmioduszewski
xerces_dom [2008/04/14 19:54]
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]]. ​   ​
 +
 +
 +
 +
 +
 +
 +
 +
  
 ===== Informacje wstępne ===== ===== Informacje wstępne =====
  
 +Nagłówki, które powinniśmy dołączyć w przypadku pisania typowych aplikacji korzystających z Xerces DOM znajdują się poniżej:
 +<code cpp>
 +#include <​xercesc/​util/​PlatformUtils.hpp>​
 +#include <​xercesc/​util/​XMLString.hpp>​
 +#include <​xercesc/​dom/​DOM.hpp> ​
 +#include <​xercesc/​parsers/​XercesDOMParser.hpp>​
 +</​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()''​. ​
 +
 +Przed użyciem jakichkolwiek klas Xerces konieczne jest wywołanie metody ''​XMLPlatformUtils::​Initialize()''​. Po zakończeniu korzystania z Xerces powinno się wywołać ''​XMLPlatformUtils::​Terminate()''​. Poniżej znajduje się uproszczona struktura programu (warto zwrócić uwagę na uzycie ''​transcode()''​).
 +<code cpp>
 +
 +#include <​xercesc/​util/​PlatformUtils.hpp>​
 +#include <​xercesc/​util/​XMLString.hpp>​
 +#include <​xercesc/​dom/​DOM.hpp> ​
 +#include <​xercesc/​parsers/​XercesDOMParser.hpp>​
 +// ...
 +#include <​iostream>  ​
 +
 +int main()
 +{
 + try { 
 + //​incjalizacja Xerces-C++
 + xercesc::​XMLPlatformUtils::​Initialize();​
 + }
 + catch (const xercesc::​XMLException&​ e) {
 + //​konwersja ​ z XMLCh* na char*
 + char* msg = xercesc::​XMLString::​transcode(e.getMessage()) ;
 +
 + std::cerr << "Init Error: " << msg << std::endl;
 + //​zwolnienie pamieci
 + xercesc::​XMLString::​release(&​msg) ;
 + return 1;
 + }
 +
 + // Tutaj korzystamy z mozliwosci Xerces-C++ ​
 +
 + xercesc::​XMLPlatformUtils::​Terminate();​
 +
 + return 0;
 +}
 +</​code>​
 +
 +
 +===== 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>
 +XercesDOMParser* parser = new XercesDOMParser();​
 +parser->​setValidationScheme(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 (...) {
 +    //...
 +}
  
-===== przykład itd. ===== +</​code> ​
-cdn..  ​+
xerces_dom.txt · ostatnio zmienione: 2008/04/16 15:33 przez kmioduszewski