|
Gaudi Framework, version v22r4 |
| Home | Generated: Fri Sep 2 2011 |
This class constitutes the core of the XML based FileCatalog API for POOL. More...
#include <XMLFileCatalog.h>


Public Member Functions | |
| XMLFileCatalog (CSTR url, IMessageSvc *m) | |
| Create a catalog file, initialization of XercesC. | |
| virtual | ~XMLFileCatalog () |
| Destructor,. | |
| virtual std::string | createFID () const |
| Catalog interface. | |
| virtual CSTR | connectInfo () const |
| Access to connect string. | |
| virtual void | init () |
| Parse the DOM tree of the XML catalog. | |
| virtual void | commit () |
| Save DOM catalog to file. | |
| virtual void | rollback () |
| Save DOM catalog to file. | |
| virtual bool | readOnly () const |
| Check if the catalog is read-only. | |
| virtual bool | dirty () const |
| Check if the catalog should be updated. | |
| virtual bool | existsPFN (CSTR pfn) const |
| Return the status of a physical file name. | |
| virtual std::string | lookupPFN (CSTR fid) const |
| Lookup file identifier by physical file name. | |
| virtual bool | existsLFN (CSTR lfn) const |
| Return the status of a logical file name. | |
| virtual std::string | lookupLFN (CSTR lfn) const |
| Lookup file identifier by logical file name. | |
| virtual bool | existsFID (CSTR fid) const |
| Return the status of a FileID. | |
| virtual void | getPFN (CSTR fid, Files &files) const |
| Dump all physical file names of the catalog and their attributes associate to the FileID. | |
| virtual void | getLFN (CSTR fid, Files &files) const |
| Dump all logical file names of the catalog associate to the FileID. | |
| virtual void | getFID (Strings &fids) const |
| Dump all file Identifiers. | |
| virtual void | deleteFID (CSTR FileID) const |
| Delete FileID Node from the catalog. | |
| virtual void | registerPFN (CSTR fid, CSTR pfn, CSTR ftype) const |
| Create a FileID and Node of the physical file name with all the attributes. | |
| virtual void | registerLFN (CSTR fid, CSTR lfn) const |
| Create a FileID and Node of the logical file name with all the attributes. | |
| virtual void | registerFID (CSTR fid) const |
| Create a FileID and Node. | |
| virtual void | getMetaData (CSTR fid, Attributes &attr) const |
| Dump all MetaData of the catalog for a given file ID. | |
| virtual std::string | getMetaDataItem (CSTR fid, CSTR name) const |
| Access metadata item. | |
| virtual void | setMetaData (CSTR fid, CSTR name, CSTR value) const |
| Insert/update metadata item. | |
| virtual void | dropMetaData (CSTR fid) const |
| Drop all metadata of one FID. | |
| virtual void | dropMetaData (CSTR fid, CSTR attr) const |
| Drop specified metadata item. | |
Protected Types | |
| typedef const std::string & | CSTR |
Private Member Functions | |
| xercesc::DOMDocument * | getDoc (bool throw_if_no_exists=true) const |
| std::string | getfile (bool create) |
| void | printError (CSTR msg, bool throw_exc=true) const |
| std::string | lookupFID (CSTR lfn) const |
| xercesc::DOMNode * | element (CSTR fid, bool print_err=true) const |
| xercesc::DOMNode * | child (xercesc::DOMNode *par, CSTR tag, CSTR attr="", CSTR val="") const |
| std::pair< xercesc::DOMElement *, xercesc::DOMElement * > | i_registerFID (CSTR fid) const |
Private Attributes | |
| bool | m_rdOnly |
| bool | m_update |
| xercesc::DOMDocument * | m_doc |
| xercesc::XercesDOMParser * | m_parser |
| xercesc::ErrorHandler * | m_errHdlr |
| std::string | m_file |
| IMessageSvc * | m_msgSvc |
This class constitutes the core of the XML based FileCatalog API for POOL.
It uses the DOM model and the external XercesC library for parsing.
Definition at line 25 of file XMLFileCatalog.h.
typedef const std::string& Gaudi::XMLFileCatalog::CSTR [protected] |
Definition at line 27 of file XMLFileCatalog.h.
| XMLFileCatalog::XMLFileCatalog | ( | CSTR | url, |
| IMessageSvc * | m | ||
| ) |
| XMLFileCatalog::~XMLFileCatalog | ( | ) | [virtual] |
| xercesc::DOMNode* Gaudi::XMLFileCatalog::child | ( | xercesc::DOMNode * | par, |
| CSTR | tag, | ||
| CSTR | attr = "", |
||
| CSTR | val = "" |
||
| ) | const [private] |
| void XMLFileCatalog::commit | ( | ) | [virtual] |
Save DOM catalog to file.
Definition at line 466 of file XMLFileCatalog.cpp.
{
try {
if ( dirty() && !readOnly() ) {
string xmlfile = getfile(true);
XMLStr ii("LS");
DOMImplementation *imp = DOMImplementationRegistry::getDOMImplementation(ii);
XMLFormatTarget *tar = new LocalFileFormatTarget(xmlfile.c_str());
#if _XERCES_VERSION <= 30000
DOMWriter *wr = imp->createDOMWriter();
wr->setFeature(XMLUni::fgDOMWRTFormatPrettyPrint, true);
wr->writeNode(tar, *m_doc);
wr->release();
#else
DOMLSOutput *output = imp->createLSOutput();
output->setByteStream(tar);
DOMLSSerializer *wr = imp->createLSSerializer();
wr->getDomConfig()->setParameter(XMLStr("format-pretty-print"), true);
wr->write(m_doc, output);
output->release();
wr->release();
#endif
delete tar;
}
}
catch ( exception& e ) {
printError(string("Cannot open output file:")+e.what());
}
catch (...) {
printError("Unknown IO rrror.");
}
}
| virtual CSTR Gaudi::XMLFileCatalog::connectInfo | ( | ) | const [inline, virtual] |
| std::string XMLFileCatalog::createFID | ( | ) | const [virtual] |
Catalog interface.
Create file identifier using UUID mechanism.
Create file identifier using UUID mechanism
Definition at line 218 of file XMLFileCatalog.cpp.
{
return createGuidAsString();
}
| void XMLFileCatalog::deleteFID | ( | CSTR | FileID ) | const [virtual] |
Delete FileID Node from the catalog.
Definition at line 356 of file XMLFileCatalog.cpp.
{
DOMNode *pn = 0, *fn = element(fid);
if ( fn ) pn = fn->getParentNode();
if ( pn ) pn->removeChild(fn);
}
| virtual bool Gaudi::XMLFileCatalog::dirty | ( | ) | const [inline, virtual] |
Check if the catalog should be updated.
Definition at line 49 of file XMLFileCatalog.h.
{ return m_update; }
| virtual void Gaudi::XMLFileCatalog::dropMetaData | ( | CSTR | fid ) | const [inline, virtual] |
Drop all metadata of one FID.
Definition at line 81 of file XMLFileCatalog.h.
{ dropMetaData(fid,"*"); }
Drop specified metadata item.
Definition at line 341 of file XMLFileCatalog.cpp.
Definition at line 350 of file XMLFileCatalog.cpp.
{
DOMNode* node = getDoc(true)->getElementById(XMLStr(element_name));
if ( !node && print_err ) printError("Cannot find element:"+element_name);
return node;
}
Return the status of a FileID.
Definition at line 59 of file XMLFileCatalog.h.
{ return element(fid,false) != 0; }
Return the status of a logical file name.
Definition at line 55 of file XMLFileCatalog.h.
{ return element(lfn,false) != 0; }
Return the status of a physical file name.
Definition at line 51 of file XMLFileCatalog.h.
{ return element(pfn,false) != 0; }
| DOMDocument * XMLFileCatalog::getDoc | ( | bool | throw_if_no_exists = true ) |
const [private] |
Definition at line 222 of file XMLFileCatalog.cpp.
{
if ( !m_doc && throw_if_no_exists )
printError("The XML catalog was not started.",true);
return m_doc;
}
| void XMLFileCatalog::getFID | ( | Strings & | fids ) | const [virtual] |
| string XMLFileCatalog::getfile | ( | bool | create ) | [private] |
Definition at line 498 of file XMLFileCatalog.cpp.
{
string protocol, path;
XMLURL xerurl;
try{
xerurl = (const XMLCh*)XMLStr(m_file);
protocol = _toString(xerurl.getProtocolName());
path = _toString(xerurl.getPath());
}
catch (const XMLException& e ) {
printError(_toString(e.getMessage()));
}
if ( protocol.empty() ) {
printError("Missing protocol.");
}
else if ( protocol == "http" || protocol == "ftp" ) {
m_rdOnly = true;
}
else if ( protocol == "file" ) {
m_rdOnly = false;
struct stat buff;
int exist = ::stat(path.c_str(),&buff) != -1;
if ( create && !exist ) {
MsgStream log(m_msgSvc,"XMLCatalog");
log << MSG::INFO << "File '" << path << "' does not exist. New file created." << endmsg;
ofstream out(path.c_str());
if( !m_rdOnly && out.is_open() ) {
out << (CSTR)EmptyCatalog << endl;
}
else {
printError("Problem creating file "+path);
}
out.close();
}
else if ( exist ) {
return path;
}
else if ( !create ) {
return "";
}
}
else {
printError(protocol + ": protocol not supported.");
}
return path;
}
| void XMLFileCatalog::getLFN | ( | CSTR | fid, |
| Files & | files | ||
| ) | const [virtual] |
| void XMLFileCatalog::getMetaData | ( | CSTR | fid, |
| Attributes & | attr | ||
| ) | const [virtual] |
Dump all MetaData of the catalog for a given file ID.
Definition at line 302 of file XMLFileCatalog.cpp.
| void XMLFileCatalog::getPFN | ( | CSTR | fid, |
| Files & | files | ||
| ) | const [virtual] |
Dump all physical file names of the catalog and their attributes associate to the FileID.
Definition at line 290 of file XMLFileCatalog.cpp.
It creates a new node File with name = fid in the XML file catalog
Definition at line 373 of file XMLFileCatalog.cpp.
{
if ( !readOnly() ) {
DOMElement *file = (DOMElement*)element(fid,false), *phyelem = 0, *logelem = 0;
DOMDocument* doc = getDoc(true);
if ( !file ) {
DOMNode* fde = doc->getElementsByTagName(XMLStr("*"))->item(0);
file = m_doc->createElement(XMLStr("File"));
file->setAttribute(Attr_ID, XMLStr(fid));
file->setIdAttribute(Attr_ID, true);
fde->appendChild(file);
m_update = true;
}
for(XMLCollection c1(file); c1; ++c1 ) {
char* nam = XMLString::transcode(c1->getNodeName());
if ( nam == PFNCOLL ) phyelem = c1;
if ( nam == LFNCOLL ) logelem = c1;
XMLString::release(&nam);
}
if ( !phyelem ) {
phyelem = doc->createElement(PFNCOLL);
file->appendChild(phyelem);
m_update = true;
}
if ( !logelem ) {
logelem = doc->createElement(LFNCOLL);
file->appendChild(logelem);
m_update = true;
}
return std::make_pair(logelem,phyelem);
}
printError("Cannot update readonly catalog!");
return std::pair<DOMElement*, DOMElement*>(0,0);
}
| void XMLFileCatalog::init | ( | ) | [virtual] |
Parse the DOM tree of the XML catalog.
Definition at line 236 of file XMLFileCatalog.cpp.
{
string xmlFile = getfile(false);
try{
if ( m_parser ) delete m_parser;
m_parser = new XercesDOMParser;
m_parser->setValidationScheme(XercesDOMParser::Val_Auto);
m_parser->setDoNamespaces(false);
DTDRedirect dtdinmem;
m_parser->setEntityResolver(&dtdinmem);
if ( ! m_errHdlr ) m_errHdlr = new ErrHandler(m_msgSvc);
m_parser->setErrorHandler(m_errHdlr);
if ( !xmlFile.empty() ) {
m_parser->parse(xmlFile.c_str());
}
else {
const std::string& s = EmptyCatalog;
MemBufInputSource src((const XMLByte*)s.c_str(),s.length(),"MemCatalog");
m_parser->parse(src);
}
m_doc = m_parser->getDocument();
}
catch (const XMLException& e) {
printError("XML parse error["+xmlFile+"]: "+_toString(e.getMessage()));
}
catch (const DOMException& e) {
printError("XML parse error["+xmlFile+"]: "+_toString(e.getMessage()));
}
catch (...) {
printError("UNKNOWN XML parse error in file "+xmlFile);
}
}
| std::string Gaudi::XMLFileCatalog::lookupFID | ( | CSTR | lfn ) | const [private] |
| virtual std::string Gaudi::XMLFileCatalog::lookupLFN | ( | CSTR | lfn ) | const [inline, virtual] |
Lookup file identifier by logical file name.
Definition at line 57 of file XMLFileCatalog.h.
{ return lookupFID(lfn); }
| virtual std::string Gaudi::XMLFileCatalog::lookupPFN | ( | CSTR | fid ) | const [inline, virtual] |
Lookup file identifier by physical file name.
Definition at line 53 of file XMLFileCatalog.h.
{ return lookupFID(fid); }
Definition at line 228 of file XMLFileCatalog.cpp.
{
MsgStream log(m_msgSvc,"XMLCatalog");
log << MSG::FATAL << msg << endmsg;
if ( rethrow ) {
throw runtime_error("XMLFileCatalog> "+msg);
}
}
| virtual bool Gaudi::XMLFileCatalog::readOnly | ( | ) | const [inline, virtual] |
Check if the catalog is read-only.
Definition at line 47 of file XMLFileCatalog.h.
{ return m_rdOnly; }
| void XMLFileCatalog::registerFID | ( | CSTR | fid ) | const [virtual] |
Create a FileID and Node.
Definition at line 362 of file XMLFileCatalog.cpp.
{
if ( !fid.empty() ) {
std::pair<DOMElement*, DOMElement*> res = i_registerFID(fid);
if ( res.first == 0 || res.second == 0 ) {
printError("Failed to register FID:"+fid);
}
return;
}
throw runtime_error("XMLFileCatalog> Cannot register LFN for invalid FID:"+fid);
}
Create a FileID and Node of the logical file name with all the attributes.
Definition at line 438 of file XMLFileCatalog.cpp.
{
if ( !fid.empty() ) {
std::pair<DOMElement*, DOMElement*> res = i_registerFID(fid);
DOMElement* logelem = res.first, *fnelem = 0;
for(XMLCollection c(logelem); c; ++c ) {
char* nam = XMLString::transcode(c->getNodeName());
if ( nam == LFNNODE ) {
XMLString::release(&nam);
nam = XMLString::transcode(c->getAttribute(Attr_name));
if ( nam == lfn ) {
XMLString::release(&nam);
fnelem = c;
break;
}
}
}
if ( !fnelem ) {
fnelem = getDoc(true)->createElement(LFNNODE);
logelem->appendChild(fnelem);
fnelem->setAttribute(Attr_name,XMLStr(lfn));
fnelem->setIdAttribute(Attr_name, true);
m_update = true;
}
return;
}
throw runtime_error("XMLFileCatalog> Cannot register LFN for invalid FID:"+fid);
}
Create a FileID and Node of the physical file name with all the attributes.
Definition at line 408 of file XMLFileCatalog.cpp.
{
if ( !fid.empty() ) {
std::pair<DOMElement*,DOMElement*> res = i_registerFID(fid);
DOMElement* phyelem = res.second, *fnelem = 0;
for(XMLCollection c(phyelem); c; ++c ) {
char* nam = XMLString::transcode(c->getNodeName());
if ( nam == PFNNODE ) {
XMLString::release(&nam);
nam = XMLString::transcode(c->getAttribute(Attr_name));
if ( nam == pfn ) {
XMLString::release(&nam);
fnelem = c;
break;
}
}
XMLString::release(&nam);
}
if ( !fnelem ) {
fnelem = getDoc(true)->createElement(PFNNODE);
phyelem->appendChild(fnelem);
fnelem->setAttribute(Attr_ftype,XMLStr(ftype));
fnelem->setAttribute(Attr_name,XMLStr(pfn));
fnelem->setIdAttribute(Attr_name, true);
m_update = true;
}
return;
}
throw runtime_error("XMLFileCatalog> Cannot register PFN for invalid FID:"+fid);
}
| virtual void Gaudi::XMLFileCatalog::rollback | ( | ) | [inline, virtual] |
Save DOM catalog to file.
Definition at line 45 of file XMLFileCatalog.h.
Insert/update metadata item.
Definition at line 320 of file XMLFileCatalog.cpp.
{
if ( !readOnly() ) {
DOMNode* node = element(fid);
DOMElement* mnod = (DOMElement*)child(node,MetaNode,Attr_metaName,attr);
if (!mnod){
mnod = getDoc(true)->createElement(MetaNode);
node->appendChild(mnod);
mnod->setAttribute(Attr_metaName,XMLStr(attr));
}
mnod->setAttribute(Attr_metaValue,XMLStr(val));
m_update = true;
return;
}
printError("Cannot update readonly catalog!");
}
xercesc::DOMDocument* Gaudi::XMLFileCatalog::m_doc [private] |
Definition at line 94 of file XMLFileCatalog.h.
xercesc::ErrorHandler* Gaudi::XMLFileCatalog::m_errHdlr [private] |
Definition at line 96 of file XMLFileCatalog.h.
std::string Gaudi::XMLFileCatalog::m_file [private] |
Definition at line 97 of file XMLFileCatalog.h.
IMessageSvc* Gaudi::XMLFileCatalog::m_msgSvc [private] |
Definition at line 98 of file XMLFileCatalog.h.
xercesc::XercesDOMParser* Gaudi::XMLFileCatalog::m_parser [private] |
Definition at line 95 of file XMLFileCatalog.h.
bool Gaudi::XMLFileCatalog::m_rdOnly [private] |
Definition at line 92 of file XMLFileCatalog.h.
bool Gaudi::XMLFileCatalog::m_update [mutable, private] |
Definition at line 93 of file XMLFileCatalog.h.