6 #ifndef HEPMC3_ATTRIBUTE_H
7 #define HEPMC3_ATTRIBUTE_H
29 #include "HepMC3/GenParticle_fwd.h"
30 #include "HepMC3/GenVertex_fwd.h"
120 return std::const_pointer_cast<GenParticle>(
m_particle);
130 return std::const_pointer_cast<GenVertex>(
m_vertex);
169 m_val = atoi( att.c_str() );
175 att = std::to_string(
m_val);
210 m_val = atol( att.c_str() );
216 att = std::to_string(
m_val);
253 m_val = atof( att.c_str() );
259 std::ostringstream oss;
260 oss << std::setprecision(std::numeric_limits<double>::digits10)
298 m_val = float(atof( att.c_str() ));
304 std::ostringstream oss;
305 oss << std::setprecision(std::numeric_limits<float>::digits10)
401 att = std::to_string(
m_val);
436 m_val = atoll( att.c_str() );
442 att = std::to_string(
m_val);
479 m_val = strtold( att.c_str(),NULL);
485 std::ostringstream oss;
486 oss << std::setprecision(std::numeric_limits<long double>::digits10)
526 m_val = strtoul(att.c_str(), NULL, 0);
532 att = std::to_string(
m_val);
569 m_val = strtoul(att.c_str(), NULL, 0);
575 att = std::to_string(
m_val);
611 m_val = strtoull(att.c_str(), NULL, 0);
617 att = std::to_string(
m_val);
651 if (att.size()!=1)
return false;
652 if(att==std::string(
"1")) {
m_val =
true;
return true;}
653 if(att==std::string(
"0")) {
m_val =
false;
return true;}
659 att = std::to_string(
m_val);
696 std::stringstream datastream(att);
697 while (datastream >> datafoo)
m_val.push_back(datafoo);
704 for (
auto a:
m_val) {
if (att.length()) att+=
" "; att+=std::to_string(a);}
741 std::stringstream datastream(att);
742 while (datastream >> datafoo)
m_val.push_back(datafoo);
749 for (
auto a:
m_val) {
if (att.length()) att+=
" "; att+=std::to_string(a);}
787 std::stringstream datastream(att);
788 while (datastream >> datafoo)
m_val.push_back(datafoo);
795 for (
auto a:
m_val) {
if (att.length()) att+=
" "; att+=std::to_string(a);}
800 std::vector<long double>
value()
const {
834 std::stringstream datastream(att);
835 while (datastream >> datafoo)
m_val.push_back(datafoo);
842 for (
auto a:
m_val) {
if (att.length()) att+=
" "; att+=std::to_string(a);}
847 std::vector<long long>
value()
const {
877 unsigned int datafoo;
879 std::stringstream datastream(att);
880 while (datastream >> datafoo)
m_val.push_back(datafoo);
887 for (
auto a:
m_val) {
if (att.length()) att+=
" "; att+=std::to_string(a);}
892 std::vector<unsigned int>
value()
const {
922 unsigned long datafoo;
924 std::stringstream datastream(att);
925 while (datastream >> datafoo)
m_val.push_back(datafoo);
932 for (
auto a:
m_val) {
if (att.length()) att+=
" "; att+=std::to_string(a);}
937 std::vector<unsigned long>
value()
const {
968 unsigned long long datafoo;
970 std::stringstream datastream(att);
971 while (datastream >> datafoo)
m_val.push_back(datafoo);
978 for (
auto a:
m_val) {
if (att.length()) att+=
" "; att+=std::to_string(a);}
983 std::vector<unsigned long long>
value()
const {
988 void set_value(
const std::vector<unsigned long long>& i) {
993 std::vector<unsigned long long>
m_val;
1015 std::stringstream datastream(att);
1016 while (datastream >> datafoo)
m_val.push_back(datafoo);
1023 for (
auto a:
m_val) {
if (att.length()) att+=
" "; att+=std::to_string(a);}
1060 std::stringstream datastream(att);
1061 while (datastream >> datafoo)
m_val.push_back(datafoo);
1068 for (
auto a:
m_val) {
if (att.length()) att+=
" "; att+=std::to_string(a);}
1105 std::stringstream datastream(att);
1106 while (datastream >> datafoo)
m_val.push_back(datafoo);
1113 for (
auto a:
m_val) {
if (att.length()) att+=
" "; att+=std::to_string(a);}
1149 size_t posb = att.find_first_not_of(
' ');
1151 size_t pose = att.find_first_of(
' ', posb);
1152 m_val.push_back(att.substr(posb, pose - posb));
1153 posb = att.find_first_not_of(
' ', pose);
1154 }
while (posb != std::string::npos);
1161 for (
auto a:
m_val) {
if (att.length()) att+=
" "; att+=a;}
1166 std::vector<std::string>
value()
const {
Forward declaration of GenParticle.
virtual ~Attribute()
Virtual destructor.
const GenEvent * event() const
Attribute(const std::string &st)
Protected constructor that allows to set string.
bool is_parsed() const
Check if this attribute is parsed.
ConstGenVertexPtr vertex() const
Attribute()
Default constructor.
ConstGenParticlePtr particle() const
std::string m_string
Raw (unparsed) string.
GenParticlePtr particle()
virtual bool from_string(const std::string &att)=0
Fill class content from string.
GenVertexPtr m_vertex
Vertex to which assigned.
void set_unparsed_string(const std::string &st)
Set unparsed string.
virtual bool to_string(std::string &att) const =0
Fill string from class content.
GenParticlePtr m_particle
controlling GenEvent object.
virtual bool init(const GenRunInfo &)
Optionally initialize the attribute after from_string.
virtual bool init()
Optionally initialize the attribute after from_string.
void set_is_parsed(bool flag)
Set is_parsed flag.
const std::string & unparsed_string() const
Get unparsed string.
bool m_is_parsed
Is this attribute parsed?
Attribute that holds an Booleger implemented as an int.
BoolAttribute(bool val)
Constructor initializing attribute value.
BoolAttribute()
Default constructor.
bool value() const
get the value associated to this Attribute.
bool m_val
Attribute value.
bool from_string(const std::string &att) override
Implementation of Attribute::from_string.
void set_value(const bool &i)
set the value associated to this Attribute.
bool to_string(std::string &att) const override
Implementation of Attribute::to_string.
Attribute that holds an Chareger implemented as an int.
CharAttribute(char val)
Constructor initializing attribute value.
CharAttribute()
Default constructor.
void set_value(const char &i)
set the value associated to this Attribute.
char value() const
get the value associated to this Attribute.
bool from_string(const std::string &att) override
Implementation of Attribute::from_string.
bool to_string(std::string &att) const override
Implementation of Attribute::to_string.
char m_val
Attribute value.
Attribute that holds a real number as a double.
double m_val
Attribute value.
void set_value(const double &d)
set the value associated to this Attribute.
double value() const
get the value associated to this Attribute.
DoubleAttribute()
Default constructor.
bool from_string(const std::string &att) override
Implementation of Attribute::from_string.
DoubleAttribute(double val)
Constructor initializing attribute value.
bool to_string(std::string &att) const override
Implementation of Attribute::to_string.
Attribute that holds a real number as a float.
float m_val
Attribute value.
FloatAttribute()
Default constructor.
bool from_string(const std::string &att) override
Implementation of Attribute::from_string.
FloatAttribute(float val)
Constructor initializing attribute value.
void set_value(const float &f)
set the value associated to this Attribute.
float value() const
get the value associated to this Attribute.
bool to_string(std::string &att) const override
Implementation of Attribute::to_string.
Stores event-related information.
Stores run-related information.
Attribute that holds an Integer implemented as an int.
int m_val
Attribute value.
void set_value(const int &i)
set the value associated to this Attribute.
IntAttribute()
Default constructor.
int value() const
get the value associated to this Attribute.
bool from_string(const std::string &att) override
Implementation of Attribute::from_string.
IntAttribute(int val)
Constructor initializing attribute value.
bool to_string(std::string &att) const override
Implementation of Attribute::to_string.
Attribute that holds an Integer implemented as an int.
long m_val
Attribute value.
LongAttribute(long val)
Constructor initializing attribute value.
void set_value(const long &l)
set the value associated to this Attribute.
long value() const
get the value associated to this Attribute.
bool from_string(const std::string &att) override
Implementation of Attribute::from_string.
LongAttribute()
Default constructor.
bool to_string(std::string &att) const override
Implementation of Attribute::to_string.
Attribute that holds a real number as a double.
long double m_val
Attribute value.
LongDoubleAttribute()
Default constructor.
LongDoubleAttribute(long double val)
Constructor initializing attribute value.
bool from_string(const std::string &att) override
Implementation of Attribute::from_string.
void set_value(const long double &d)
set the value associated to this Attribute.
long double value() const
get the value associated to this Attribute.
bool to_string(std::string &att) const override
Implementation of Attribute::to_string.
Attribute that holds an Integer implemented as an int.
long long value() const
get the value associated to this Attribute.
void set_value(const long long &l)
set the value associated to this Attribute.
bool from_string(const std::string &att) override
Implementation of Attribute::from_string.
LongLongAttribute(long long val)
Constructor initializing attribute value.
LongLongAttribute()
Default constructor.
long long m_val
Attribute value.
bool to_string(std::string &att) const override
Implementation of Attribute::to_string.
Attribute that holds a string.
StringAttribute()
Default constructor - empty string.
void set_value(const std::string &s)
set the value associated to this Attribute.
StringAttribute(const std::string &st)
String-based constructor.
bool from_string(const std::string &att) override
Implementation of Attribute::from_string.
std::string value() const
get the value associated to this Attribute.
bool to_string(std::string &att) const override
Implementation of Attribute::to_string.
Attribute that holds an unsigned int.
void set_value(const unsigned int &i)
set the value associated to this Attribute.
unsigned int value() const
get the value associated to this Attribute.
UIntAttribute(unsigned int val)
Constructor initializing attribute value.
bool from_string(const std::string &att) override
Implementation of Attribute::from_string.
unsigned int m_val
Attribute value.
UIntAttribute()
Default constructor.
bool to_string(std::string &att) const override
Implementation of Attribute::to_string.
Attribute that holds an unsigned long.
ULongAttribute()
Default constructor.
ULongAttribute(unsigned long val)
Constructor initializing attribute value.
void set_value(const unsigned long &i)
set the value associated to this Attribute.
unsigned long m_val
Attribute value.
unsigned long value() const
get the value associated to this Attribute.
bool from_string(const std::string &att) override
Implementation of Attribute::from_string.
bool to_string(std::string &att) const override
Implementation of Attribute::to_string.
Attribute that holds an unsigned long long.
unsigned long long m_val
Attribute value.
unsigned long long value() const
get the value associated to this Attribute.
ULongLongAttribute()
Default constructor.
bool from_string(const std::string &att) override
Implementation of Attribute::from_string.
void set_value(const unsigned long long &i)
set the value associated to this Attribute.
bool to_string(std::string &att) const override
Implementation of Attribute::to_string.
ULongLongAttribute(unsigned long long val)
Constructor initializing attribute value.
Attribute that holds a vector of charegers of type char.
VectorCharAttribute(std::vector< char > val)
Constructor initializing attribute value.
std::vector< char > m_val
Attribute value.
std::vector< char > value() const
get the value associated to this Attribute.
void set_value(const std::vector< char > &i)
set the value associated to this Attribute.
bool from_string(const std::string &att) override
Implementation of Attribute::from_string.
VectorCharAttribute()
Default constructor.
bool to_string(std::string &att) const override
Implementation of Attribute::to_string.
void set_value(const std::vector< double > &i)
set the value associated to this Attribute.
bool from_string(const std::string &att) override
Implementation of Attribute::from_string.
std::vector< double > value() const
get the value associated to this Attribute.
std::vector< double > m_val
Attribute value.
VectorDoubleAttribute(std::vector< double > val)
Constructor initializing attribute value.
bool to_string(std::string &att) const override
Implementation of Attribute::to_string.
VectorDoubleAttribute()
Default constructor.
Attribute that holds a vector of floategers of type float.
VectorFloatAttribute(std::vector< float > val)
Constructor initializing attribute value.
void set_value(const std::vector< float > &i)
set the value associated to this Attribute.
bool from_string(const std::string &att) override
Implementation of Attribute::from_string.
VectorFloatAttribute()
Default constructor.
std::vector< float > m_val
Attribute value.
std::vector< float > value() const
get the value associated to this Attribute.
bool to_string(std::string &att) const override
Implementation of Attribute::to_string.
Attribute that holds a vector of integers of type int.
std::vector< int > m_val
Attribute value.
bool from_string(const std::string &att) override
Implementation of Attribute::from_string.
VectorIntAttribute()
Default constructor.
std::vector< int > value() const
get the value associated to this Attribute.
bool to_string(std::string &att) const override
Implementation of Attribute::to_string.
void set_value(const std::vector< int > &i)
set the value associated to this Attribute.
VectorIntAttribute(std::vector< int > val)
Constructor initializing attribute value.
Attribute that holds a vector of long doubleegers of type long double.
void set_value(const std::vector< long double > &i)
set the value associated to this Attribute.
VectorLongDoubleAttribute()
Default constructor.
std::vector< long double > m_val
Attribute value.
VectorLongDoubleAttribute(std::vector< long double > val)
Constructor initializing attribute value.
bool from_string(const std::string &att) override
Implementation of Attribute::from_string.
std::vector< long double > value() const
get the value associated to this Attribute.
bool to_string(std::string &att) const override
Implementation of Attribute::to_string.
std::vector< long int > value() const
get the value associated to this Attribute.
VectorLongIntAttribute(std::vector< long int > val)
Constructor initializing attribute value.
VectorLongIntAttribute()
Default constructor.
bool from_string(const std::string &att) override
Implementation of Attribute::from_string.
std::vector< long int > m_val
Attribute value.
void set_value(const std::vector< long int > &i)
set the value associated to this Attribute.
bool to_string(std::string &att) const override
Implementation of Attribute::to_string.
Attribute that holds a vector of long longegers of type long long.
std::vector< long long > m_val
Attribute value.
bool from_string(const std::string &att) override
Implementation of Attribute::from_string.
VectorLongLongAttribute()
Default constructor.
std::vector< long long > value() const
get the value associated to this Attribute.
void set_value(const std::vector< long long > &i)
set the value associated to this Attribute.
VectorLongLongAttribute(std::vector< long long > val)
Constructor initializing attribute value.
bool to_string(std::string &att) const override
Implementation of Attribute::to_string.
bool from_string(const string &att) override
Implementation of Attribute::from_string.
void set_value(const std::vector< std::string > &i)
set the value associated to this Attribute.
VectorStringAttribute(std::vector< std::string > val)
Constructor initializing attribute value.
std::vector< std::string > value() const
get the value associated to this Attribute.
VectorStringAttribute()
Default constructor.
bool to_string(std::string &att) const override
Implementation of Attribute::to_string.
std::vector< std::string > m_val
Attribute value.
Attribute that holds a vector of unsigned integers of type unsigned int.
VectorUIntAttribute()
Default constructor.
std::vector< unsigned int > value() const
get the value associated to this Attribute.
std::vector< unsigned int > m_val
Attribute value.
VectorUIntAttribute(std::vector< unsigned int > val)
Constructor initializing attribute value.
bool from_string(const std::string &att) override
Implementation of Attribute::from_string.
void set_value(const std::vector< unsigned int > &i)
set the value associated to this Attribute.
bool to_string(std::string &att) const override
Implementation of Attribute::to_string.
Attribute that holds a vector of unsigned longegers of type unsigned long.
void set_value(const std::vector< unsigned long > &i)
set the value associated to this Attribute.
std::vector< unsigned long > m_val
Attribute value.
bool from_string(const std::string &att) override
Implementation of Attribute::from_string.
VectorULongAttribute()
Default constructor.
std::vector< unsigned long > value() const
get the value associated to this Attribute.
VectorULongAttribute(std::vector< unsigned long > val)
Constructor initializing attribute value.
bool to_string(std::string &att) const override
Implementation of Attribute::to_string.
Attribute that holds a vector of unsigned long longegers of type unsigned long long.
VectorULongLongAttribute(std::vector< unsigned long long > val)
Constructor initializing attribute value.
void set_value(const std::vector< unsigned long long > &i)
set the value associated to this Attribute.
bool from_string(const std::string &att) override
Implementation of Attribute::from_string.
std::vector< unsigned long long > m_val
Attribute value.
std::vector< unsigned long long > value() const
get the value associated to this Attribute.
bool to_string(std::string &att) const override
Implementation of Attribute::to_string.
VectorULongLongAttribute()
Default constructor.