blob: 8b41daea6250b47141ed2c0101aa4ec84c7f6fca (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
|
#include "read_directory.h"
#include <xercesc/dom/DOMDocument.hpp>
#include <xercesc/dom/DOMImplementation.hpp>
#include <xercesc/dom/DOMElement.hpp>
#include <xercesc/dom/DOMText.hpp>
#include "support/xerces_string_guard.h"
namespace InputXSLT {
xercesc::DOMDocument* FunctionReadDirectory::constructDocument(
const InputXSLT::FilesystemContext& fsContext,
const boost::filesystem::path& directoryPath
) {
xercesc::DOMDocument* const domDocument(
xercesc::DOMImplementation::getImplementation()->createDocument(
nullptr,
*XercesStringGuard<XMLCh>("content"),
nullptr
)
);
xercesc::DOMNode* const rootNode(
domDocument->getDocumentElement()
);
if ( boost::filesystem::is_directory(directoryPath) ) {
fsContext.iterate(
directoryPath,
[&domDocument, &rootNode](const boost::filesystem::path& p) {
xercesc::DOMElement* const itemNode(
domDocument->createElement(*XercesStringGuard<XMLCh>("result"))
);
switch ( boost::filesystem::status(p).type() ) {
case boost::filesystem::regular_file: {
itemNode->setAttribute(
*XercesStringGuard<XMLCh>("type"),
*XercesStringGuard<XMLCh>("file")
);
break;
};
case boost::filesystem::directory_file: {
itemNode->setAttribute(
*XercesStringGuard<XMLCh>("type"),
*XercesStringGuard<XMLCh>("directory")
);
break;
};
default: {
itemNode->setAttribute(
*XercesStringGuard<XMLCh>("type"),
*XercesStringGuard<XMLCh>("misc")
);
break;
};
}
xercesc::DOMText* const textNode(
domDocument->createTextNode(
*XercesStringGuard<XMLCh>(p.filename().string())
)
);
itemNode->appendChild(textNode);
rootNode->appendChild(itemNode);
});
} else {
xercesc::DOMElement* const resultNode(
domDocument->createElement(*XercesStringGuard<XMLCh>("error"))
);
rootNode->appendChild(resultNode);
}
return domDocument;
}
}
|