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 20:32]
kmioduszewski
xerces_dom [2008/04/14 22:12]
kmioduszewski
Linia 1: Linia 1:
 ====== biblioteka dla XML: Xerces (DOM) ===== ====== biblioteka dla XML: Xerces (DOM) =====
-Xerces-C++ DOM jest częścią Xerces-C++ API zaprojektowanego do współpracy z plikami w formacie XML. API umożliwia parsowania, manipulowanie,​ walidowanie oraz generowanie poprawnych dokumentów.  +Xerces-C++ DOM jest częścią Xerces-C++ API zaprojektowanego do współpracy z plikami w formacie XML. API umożliwia parsowania, manipulowanie,​ walidowanie oraz generowanie poprawnych dokumentów. 
 +\\ 
 Biblioteka DOM jest implementacją następujących rekomendacji W3C: Biblioteka DOM jest implementacją następujących rekomendacji W3C:
   * [[http://​www.w3.org/​TR/​1998/​REC-DOM-Level-1-19981001/​|Document Object Model (DOM) Level 1 Specification]]  ​   * [[http://​www.w3.org/​TR/​1998/​REC-DOM-Level-1-19981001/​|Document Object Model (DOM) Level 1 Specification]]  ​
Linia 10: Linia 10:
   * [[http://​www.w3.org/​TR/​2002/​WD-DOM-Level-3-Core-20020409/​|Document Object Model (DOM) Level 3 Core Specification]]   * [[http://​www.w3.org/​TR/​2002/​WD-DOM-Level-3-Core-20020409/​|Document Object Model (DOM) Level 3 Core Specification]]
   * [[http://​www.w3.org/​TR/​2002/​WD-DOM-Level-3-ASLS-20020409/​|Document Object Model (DOM) Level 3 Abstract Schemas and Load and Save Specification]]   * [[http://​www.w3.org/​TR/​2002/​WD-DOM-Level-3-ASLS-20020409/​|Document Object Model (DOM) Level 3 Abstract Schemas and Load and Save Specification]]
 +\\ 
  
 Więcej informacji na stronie projektu http://​xerces.apache.org/​xerces-c/​. ​ Więcej informacji na stronie projektu http://​xerces.apache.org/​xerces-c/​. ​
Linia 67: Linia 67:
 } }
 </​code>​ </​code>​
 +
 +
  
  
Linia 76: Linia 78:
 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. 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.+Poniżej przykładowe fragmenty kodu dotyczącego inicjalizacji i korzystania z ''​XercesDOMParser''​.
 <code cpp> <code cpp>
 xercesc::​XercesDOMParser* parser = new xercesc::​XercesDOMParser();​ xercesc::​XercesDOMParser* parser = new xercesc::​XercesDOMParser();​
Linia 104: Linia 106:
 </​code> ​ </​code> ​
  
-Dobrym pomysłem jest zastosowanie własnego ''​ErrorHandler''​ do wykrywania błędów składniowych w trakcie parsowania i wyświetlania o nich informacji (typ, miejsce wystąpienia). Najprostszy to zaimplementować metody ​z interfejsu ''​HandlerBase'':​+Dobrym pomysłem jest zastosowanie własnego ''​ErrorHandler''​ do wykrywania błędów składniowych w trakcie parsowania i wyświetlania o nich informacji (typ, miejsce wystąpienia). Najprostszy ​sposób ​to zaimplementowanie metod z interfejsu ''​HandlerBase'':​
 <code cpp> <code cpp>
 #include <​xercesc/​sax/​HandlerBase.hpp>​ #include <​xercesc/​sax/​HandlerBase.hpp>​
Linia 112: Linia 114:
  char *msg = xercesc::​XMLString::​transcode(e.getMessage()); ​  char *msg = xercesc::​XMLString::​transcode(e.getMessage()); ​
  std::cout << "​warning:​ " << msg   std::cout << "​warning:​ " << msg 
-   ​<< " | line: " << e.getLineNumber() << std::endl;+           ​<< " | line: " << e.getLineNumber() << std::endl;
  xercesc::​XMLString::​release(&​msg);​  xercesc::​XMLString::​release(&​msg);​
  }  }
  void error( const xercesc::​SAXParseException&​ e ) {  void error( const xercesc::​SAXParseException&​ e ) {
- cout << "​error:​ " << xercesc::​XMLString::​transcode(e.getMessage())  +               // analogicznie jak wyżej
- << " | line: " << e.getLineNumber() << endl;+
  }  }
  void fatalError( const xercesc::​SAXParseException&​ e ) {  void fatalError( const xercesc::​SAXParseException&​ e ) {
- cout << "​fatalError:​ " << xercesc::​XMLString::​transcode(e.getMessage()) ​  +        // j.w.
- << " | line: " <<e.getLineNumber() << endl;+
  }  }
  void resetErrors() {}  void resetErrors() {}
 }; };
 +
 +//...
 +
 +xercesc::​XercesDOMParser* parser = new xercesc::​XercesDOMParser();​
 +parser->​setValidationScheme(xercesc::​XercesDOMParser::​Val_Auto); ​   ​
 +parser->​setDoNamespaces(true);  ​
 +
 +xercesc::​ErrorHandler* errHandler = (xercesc::​ErrorHandler*) new myErrorHandler();​
 +parser->​setErrorHandler(errHandler);​
 +
 </​code> ​ </​code> ​
 +
 +
 +
 +===== DOMDocument,​ operacje na dokumencie=====
 +Gdy dokument zostanie sparsowany bez żadnych błędów możemy swobodnie zacząć na nim pracować. ​
xerces_dom.txt · ostatnio zmienione: 2008/04/16 15:33 przez kmioduszewski