This is an example of using TList with STL algoritms in CINT.
Processing /mnt/vdb/lsf/workspace/root-makedoc/rootspi/rdoc/src/master/tutorials/cont/TListAndSTL.C...
Value: test string #0
The string has been found: test string #4
#include <algorithm>
#include <iostream>
#include <sstream>
struct SEnumFunctor {
if (!aObj)
return false;
if (!str)
return false;
cout << "Value: " << str->String().Data() << endl;
return true;
}
};
struct SFind {
#ifdef __CINT__
SFind(const SFind &oth) : fToFind(oth.fToFind) {}
SFind(
const TString aStr): fToFind(aStr) {
#else
SFind(
const TString &aStr): fToFind(aStr) {
#endif
}
return !str->String().CompareTo(fToFind);
}
private:
};
void TListAndSTL()
{
for (int i = 0; i < size; ++i) {
ss << "test string #" << i;
ss.str("");
}
string strToFind("test string #4");
SFind
func(strToFind.c_str());
#ifdef __CINT__
);
#else // in compilation mode you need to use TIterCategory as an iterator for such a algorithm like find_if
);
#endif
if (!(*found)) {
cerr << "Can't find the string: \"" << strToFind << "\" in the container" << endl;
return;
}
TObjString *str(dynamic_cast<TObjString*>(*found));
if (!str) {
cerr << "Can't find the string: \"" << strToFind << "\" in the container" << endl;
return;
}
cout << "The string has been found: " << str->String().Data() << endl;
}
- Author
- Anar Manafov
Definition in file TListAndSTL.C.