Compare commits
5 Commits
be5702b029
...
7b4e127713
Author | SHA1 | Date | |
---|---|---|---|
7b4e127713 | |||
5747de93a8 | |||
9844ad4bd4 | |||
3826dfb41a | |||
0087c41321 |
@ -21,7 +21,7 @@ File to read: "read.xml"
|
|||||||
Reading a file is done like this:
|
Reading a file is done like this:
|
||||||
@snippet read.cpp exml_sample_read_file
|
@snippet read.cpp exml_sample_read_file
|
||||||
|
|
||||||
The file naming is manage by @ref etk::FSNode that provide "DATA:" start string for internal application asset. You can use external path like "./plop/file.xml" too.
|
The file naming is manage by @ref etk::FSNode that provide "DATA:///" start string for internal application asset. You can use external path like "./plop/file.xml" too.
|
||||||
|
|
||||||
|
|
||||||
Read an XML Stream {#exml_tutorial_read_stream}
|
Read an XML Stream {#exml_tutorial_read_stream}
|
||||||
|
@ -7,6 +7,8 @@
|
|||||||
#include <exml/Document.hpp>
|
#include <exml/Document.hpp>
|
||||||
#include <exml/debug.hpp>
|
#include <exml/debug.hpp>
|
||||||
#include <exml/internal/Document.hpp>
|
#include <exml/internal/Document.hpp>
|
||||||
|
#include <etk/path/fileSystem.hpp>
|
||||||
|
#include <etk/uri/uri.hpp>
|
||||||
|
|
||||||
exml::Document::Document(ememory::SharedPtr<exml::internal::Node> _internalNode) :
|
exml::Document::Document(ememory::SharedPtr<exml::internal::Node> _internalNode) :
|
||||||
exml::Element(_internalNode) {
|
exml::Element(_internalNode) {
|
||||||
@ -82,6 +84,35 @@ bool exml::Document::store(const etk::Uri& _uri) {
|
|||||||
return static_cast<exml::internal::Document*>(m_data.get())->store(_uri);
|
return static_cast<exml::internal::Document*>(m_data.get())->store(_uri);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool exml::Document::storeSafe(const etk::Path& _path) {
|
||||||
|
if (m_data == null) {
|
||||||
|
EXML_DEBUG("Can not store (null) ...");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
bool done = static_cast<exml::internal::Document*>(m_data.get())->store(_path+".tmp");
|
||||||
|
if (done == false) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return etk::path::move(_path+".tmp", _path);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool exml::Document::storeSafe(const etk::Uri& _uri) {
|
||||||
|
if (m_data == null) {
|
||||||
|
EXML_DEBUG("Can not store (null) ...");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if (etk::uri::canMove(_uri) == false) {
|
||||||
|
return static_cast<exml::internal::Document*>(m_data.get())->store(_uri);
|
||||||
|
}
|
||||||
|
etk::Uri uriTmp = _uri;
|
||||||
|
uriTmp.setPath(uriTmp.getPath() + ".tmp");
|
||||||
|
bool done = static_cast<exml::internal::Document*>(m_data.get())->store(uriTmp);
|
||||||
|
if (done == false) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return etk::uri::move(uriTmp, _uri);
|
||||||
|
}
|
||||||
|
|
||||||
void exml::Document::display() {
|
void exml::Document::display() {
|
||||||
if (m_data == null) {
|
if (m_data == null) {
|
||||||
EXML_DEBUG("Can not display (null) ...");
|
EXML_DEBUG("Can not display (null) ...");
|
||||||
|
@ -78,6 +78,15 @@ namespace exml {
|
|||||||
bool store(const etk::Path& _path);
|
bool store(const etk::Path& _path);
|
||||||
/// @previous
|
/// @previous
|
||||||
bool store(const etk::Uri& _uri);
|
bool store(const etk::Uri& _uri);
|
||||||
|
/**
|
||||||
|
* @brief Store the Json in the file (safe mode mean that the file is store in a second file xxx.tmp and moved in the file xxx (only one mode to be really safe with filesystem ...)
|
||||||
|
* @param[in] _path/_uri Path/URI of the json
|
||||||
|
* @return false : An error occured
|
||||||
|
* @return true : Parsing is OK
|
||||||
|
*/
|
||||||
|
bool storeSafe(const etk::Path& _path);
|
||||||
|
/// @previous
|
||||||
|
bool storeSafe(const etk::Uri& _uri);
|
||||||
/**
|
/**
|
||||||
* @brief Display the Document on console
|
* @brief Display the Document on console
|
||||||
*/
|
*/
|
||||||
|
@ -84,7 +84,7 @@ bool exml::internal::Document::store(const etk::Uri& _uri) {
|
|||||||
EXML_ERROR("Can not open (r) the file : " << _uri);
|
EXML_ERROR("Can not open (r) the file : " << _uri);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
fileIo->fileWriteAll(createData);
|
fileIo->writeAll(createData);
|
||||||
fileIo->close();
|
fileIo->close();
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
#!/usr/bin/python
|
#!/usr/bin/python
|
||||||
import lutin.debug as debug
|
import realog.debug as debug
|
||||||
import lutin.tools as tools
|
import lutin.tools as tools
|
||||||
|
|
||||||
def get_type():
|
def get_type():
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
#!/usr/bin/python
|
#!/usr/bin/python
|
||||||
import lutin.debug as debug
|
import realog.debug as debug
|
||||||
import lutin.tools as tools
|
import lutin.tools as tools
|
||||||
|
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
#!/usr/bin/python
|
#!/usr/bin/python
|
||||||
import lutin.debug as debug
|
import realog.debug as debug
|
||||||
import lutin.tools as tools
|
import lutin.tools as tools
|
||||||
|
|
||||||
|
|
||||||
|
@ -17,7 +17,7 @@ static void readFromFile() {
|
|||||||
exml::Document doc;
|
exml::Document doc;
|
||||||
//! [exml_sample_declare_doc]
|
//! [exml_sample_declare_doc]
|
||||||
//! [exml_sample_read_file]
|
//! [exml_sample_read_file]
|
||||||
bool retParse = doc.load("DATA:read.xml");
|
bool retParse = doc.load(etk::Uri("DATA:///read.xml"));
|
||||||
//! [exml_sample_read_file]
|
//! [exml_sample_read_file]
|
||||||
TEST_INFO("parse ret = " << retParse);
|
TEST_INFO("parse ret = " << retParse);
|
||||||
TEST_INFO("Debug display of the tree:");
|
TEST_INFO("Debug display of the tree:");
|
||||||
@ -56,7 +56,7 @@ static void readFromString2() {
|
|||||||
static void readFull() {
|
static void readFull() {
|
||||||
exml::Document doc;
|
exml::Document doc;
|
||||||
TEST_INFO("parse");
|
TEST_INFO("parse");
|
||||||
bool retParse = doc.load("DATA:read.xml");
|
bool retParse = doc.load(etk::Uri("DATA:///read.xml"));
|
||||||
TEST_INFO("parse ret = " << retParse);
|
TEST_INFO("parse ret = " << retParse);
|
||||||
TEST_INFO("Debug display of the tree:");
|
TEST_INFO("Debug display of the tree:");
|
||||||
doc.display();
|
doc.display();
|
||||||
|
@ -18,7 +18,7 @@ static void writeToFile() {
|
|||||||
doc.nodes.add(exml::Comment("basic comment"));
|
doc.nodes.add(exml::Comment("basic comment"));
|
||||||
TEST_INFO("store");
|
TEST_INFO("store");
|
||||||
//! [exml_sample_write_file]
|
//! [exml_sample_write_file]
|
||||||
bool retGenerate = doc.store("generate.xml");
|
bool retGenerate = doc.store(etk::Path("generate.xml"));
|
||||||
//! [exml_sample_write_file]
|
//! [exml_sample_write_file]
|
||||||
TEST_INFO("parse ret = " << retGenerate);
|
TEST_INFO("parse ret = " << retGenerate);
|
||||||
TEST_INFO("Debug display of the tree:");
|
TEST_INFO("Debug display of the tree:");
|
||||||
|
Loading…
x
Reference in New Issue
Block a user