Geant4 Cross Reference

Cross-Referencing   Geant4
Geant4/externals/g4tools/include/toolx/raxml

Version: [ ReleaseNotes ] [ 1.0 ] [ 1.1 ] [ 2.0 ] [ 3.0 ] [ 3.1 ] [ 3.2 ] [ 4.0 ] [ 4.0.p1 ] [ 4.0.p2 ] [ 4.1 ] [ 4.1.p1 ] [ 5.0 ] [ 5.0.p1 ] [ 5.1 ] [ 5.1.p1 ] [ 5.2 ] [ 5.2.p1 ] [ 5.2.p2 ] [ 6.0 ] [ 6.0.p1 ] [ 6.1 ] [ 6.2 ] [ 6.2.p1 ] [ 6.2.p2 ] [ 7.0 ] [ 7.0.p1 ] [ 7.1 ] [ 7.1.p1 ] [ 8.0 ] [ 8.0.p1 ] [ 8.1 ] [ 8.1.p1 ] [ 8.1.p2 ] [ 8.2 ] [ 8.2.p1 ] [ 8.3 ] [ 8.3.p1 ] [ 8.3.p2 ] [ 9.0 ] [ 9.0.p1 ] [ 9.0.p2 ] [ 9.1 ] [ 9.1.p1 ] [ 9.1.p2 ] [ 9.1.p3 ] [ 9.2 ] [ 9.2.p1 ] [ 9.2.p2 ] [ 9.2.p3 ] [ 9.2.p4 ] [ 9.3 ] [ 9.3.p1 ] [ 9.3.p2 ] [ 9.4 ] [ 9.4.p1 ] [ 9.4.p2 ] [ 9.4.p3 ] [ 9.4.p4 ] [ 9.5 ] [ 9.5.p1 ] [ 9.5.p2 ] [ 9.6 ] [ 9.6.p1 ] [ 9.6.p2 ] [ 9.6.p3 ] [ 9.6.p4 ] [ 10.0 ] [ 10.0.p1 ] [ 10.0.p2 ] [ 10.0.p3 ] [ 10.0.p4 ] [ 10.1 ] [ 10.1.p1 ] [ 10.1.p2 ] [ 10.1.p3 ] [ 10.2 ] [ 10.2.p1 ] [ 10.2.p2 ] [ 10.2.p3 ] [ 10.3 ] [ 10.3.p1 ] [ 10.3.p2 ] [ 10.3.p3 ] [ 10.4 ] [ 10.4.p1 ] [ 10.4.p2 ] [ 10.4.p3 ] [ 10.5 ] [ 10.5.p1 ] [ 10.6 ] [ 10.6.p1 ] [ 10.6.p2 ] [ 10.6.p3 ] [ 10.7 ] [ 10.7.p1 ] [ 10.7.p2 ] [ 10.7.p3 ] [ 10.7.p4 ] [ 11.0 ] [ 11.0.p1 ] [ 11.0.p2 ] [ 11.0.p3, ] [ 11.0.p4 ] [ 11.1 ] [ 11.1.1 ] [ 11.1.2 ] [ 11.1.3 ] [ 11.2 ] [ 11.2.1 ] [ 11.2.2 ] [ 11.3.0 ]

Diff markup

Differences between /externals/g4tools/include/toolx/raxml (Version 11.3.0) and /externals/g4tools/include/toolx/raxml (Version 11.1.1)


  1 // Copyright (C) 2010, Guy Barrand. All rights      1 // Copyright (C) 2010, Guy Barrand. All rights reserved.
  2 // See the file tools.license for terms.            2 // See the file tools.license for terms.
  3                                                     3 
  4 #ifndef toolx_raxml                                 4 #ifndef toolx_raxml
  5 #define toolx_raxml                                 5 #define toolx_raxml
  6                                                     6 
  7 #include <tools/xml/aidas>                          7 #include <tools/xml/aidas>
  8                                                     8 
  9 #include "xml/loader"                               9 #include "xml/loader"
 10                                                    10 
 11 namespace toolx {                                  11 namespace toolx {
 12                                                    12 
 13 class raxml : public tools::xml::aidas, public     13 class raxml : public tools::xml::aidas, public xml::loader {
 14   typedef tools::xml::aidas parent_aidas;          14   typedef tools::xml::aidas parent_aidas;
 15   typedef xml::loader parent;                      15   typedef xml::loader parent;
 16 public:                                            16 public:
 17   raxml(tools::xml::factory& a_fac,std::ostrea     17   raxml(tools::xml::factory& a_fac,std::ostream& a_out,bool a_verbose = false)
 18   :parent_aidas()                                  18   :parent_aidas()
 19   ,parent(a_fac,a_out,a_verbose)                   19   ,parent(a_fac,a_out,a_verbose)
 20   ,m_read_tag(0)                                   20   ,m_read_tag(0)
 21   {                                                21   {
 22     set_default_tags(parent::m_tags);              22     set_default_tags(parent::m_tags);
 23   }                                                23   }
 24   virtual ~raxml() {}                              24   virtual ~raxml() {}
 25 public:                                            25 public:
 26   void set_read_tag(void* a_tag) {m_read_tag =     26   void set_read_tag(void* a_tag) {m_read_tag = a_tag;}
 27 protected:                                         27 protected:
 28   raxml(const raxml& a_from)                       28   raxml(const raxml& a_from)
 29   :parent_aidas(a_from)                            29   :parent_aidas(a_from)
 30   ,parent(a_from)                                  30   ,parent(a_from)
 31   {}                                               31   {}
 32   raxml& operator=(const raxml& a_from){           32   raxml& operator=(const raxml& a_from){
 33     parent_aidas::operator=(a_from);               33     parent_aidas::operator=(a_from);
 34     parent::operator=(a_from);                     34     parent::operator=(a_from);
 35     return *this;                                  35     return *this;
 36   }                                                36   }
 37 public:                                            37 public:
 38   bool load_file(const std::string& a_file,boo     38   bool load_file(const std::string& a_file,bool a_compressed){
 39     m_objects.clear();                             39     m_objects.clear();
 40     if(!parent::load_file(a_file,a_compressed)     40     if(!parent::load_file(a_file,a_compressed)) return false;
 41     tools::xml::tree* top = top_item();            41     tools::xml::tree* top = top_item();
 42     if(!top) return false;                         42     if(!top) return false;
 43     const std::string& tag_name = top->tag_nam     43     const std::string& tag_name = top->tag_name();
 44     if(tag_name!=s_aida()) return false;           44     if(tag_name!=s_aida()) return false;
 45                                                    45 
 46    {tools::xml::looper _for(*top);                 46    {tools::xml::looper _for(*top);
 47     while(tools::xml::tree* _tree = _for.next_     47     while(tools::xml::tree* _tree = _for.next_tree()) {
 48                                                    48 
 49       const std::string& _tag_name = _tree->ta     49       const std::string& _tag_name = _tree->tag_name();
 50       reader rder = find_reader(_tag_name);        50       reader rder = find_reader(_tag_name);
 51       if(!rder) {                                  51       if(!rder) {
 52         m_out << "toolx::raxml::load_file :"       52         m_out << "toolx::raxml::load_file :"
 53               << " reader not found for " << t     53               << " reader not found for " << tools::sout(_tag_name)
 54               << std::endl;                        54               << std::endl;
 55         //m_objects.clear(); //keep already lo     55         //m_objects.clear(); //keep already loaded objects.
 56         return false;                              56         return false;
 57       } else {                                     57       } else {
 58         tools::raxml_out ro = rder(*_tree,m_ou     58         tools::raxml_out ro = rder(*_tree,m_out,m_verbose,m_read_tag);
 59         if(ro.object()) m_objects.push_back(ro     59         if(ro.object()) m_objects.push_back(ro);
 60       }                                            60       }
 61                                                    61 
 62     }}                                             62     }}
 63                                                    63 
 64     return true;                                   64     return true;
 65   }                                                65   }
 66 protected:                                         66 protected:
 67   void* m_read_tag;                                67   void* m_read_tag;
 68 };                                                 68 };
 69                                                    69 
 70 }                                                  70 }
 71                                                    71 
 72 #endif                                             72 #endif