Geant4 Cross Reference

Cross-Referencing   Geant4
Geant4/externals/g4tools/include/tools/sg/search

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/tools/sg/search (Version 11.3.0) and /externals/g4tools/include/tools/sg/search (Version 7.1)


  1 // Copyright (C) 2010, Guy Barrand. All rights    
  2 // See the file tools.license for terms.          
  3                                                   
  4 //                                                
  5 // Helper functions to search node(s) in a sce    
  6 //                                                
  7                                                   
  8 #ifndef tools_sg_search                           
  9 #define tools_sg_search                           
 10                                                   
 11 #include "search_action"                          
 12 #include "node"                                   
 13                                                   
 14 namespace tools {                                 
 15 namespace sg {                                    
 16                                                   
 17 template <class NODE>                             
 18 inline NODE* find_first_node_of_class(std::ost    
 19   search_action action(a_out);                    
 20   action.reset();                                 
 21   action.set_what(search_action::search_node_o    
 22   action.set_stop_at_first(true);                 
 23   action.set_class(NODE::s_class());              
 24   a_from.search(action);                          
 25   const std::vector<void*>& _objs = action.obj    
 26   if(_objs.empty()) return 0;                     
 27   return (NODE*)_objs[0];                         
 28 }                                                 
 29                                                   
 30 inline node* find_first_node_with_class(std::o    
 31   search_action action(a_out);                    
 32   action.reset();                                 
 33   action.set_what(search_action::search_node_o    
 34   action.set_stop_at_first(true);                 
 35   action.set_class(a_class);                      
 36   a_from.search(action);                          
 37   const std::vector<void*>& _objs = action.obj    
 38   if(_objs.empty()) return 0;                     
 39   return (node*)_objs[0];                         
 40 }                                                 
 41                                                   
 42 }}                                                
 43                                                   
 44 #include "path"                                   
 45                                                   
 46 namespace tools {                                 
 47 namespace sg {                                    
 48                                                   
 49 inline const path_t& find_path(search_action&     
 50   a_action.reset();                               
 51   a_action.set_what(search_action::search_path    
 52   a_action.set_node(&a_node);                     
 53   a_from.search(a_action);                        
 54   if(!a_action.done()) {                          
 55     if(a_verbose) {                               
 56       a_action.out() << "tools::sg::find_path     
 57             << " not found node of class " <<     
 58             << " from head node of class " <<     
 59             << std::endl;                         
 60     }                                             
 61     a_action.clear_path();                        
 62     return a_action.path();                       
 63   }                                               
 64   if(a_verbose) {                                 
 65     a_action.out() << "tools::sg::find_path :"    
 66           << " found node of class " << a_node    
 67           << " from head node of class " << a_    
 68           << std::endl;                           
 69   }                                               
 70   const path_t& path = a_action.path();           
 71   if(path.empty()) {                              
 72     if(a_verbose) {                               
 73       a_action.out() << "tools::sg::find_path     
 74             << " node has no path !"              
 75             << std::endl;                         
 76     }                                             
 77     return path;                                  
 78   }                                               
 79   if(&a_node!=path[path.size()-1]) {              
 80     a_action.out() << "tools::sg::find_path :"    
 81           << " node / path tail mismatch !"       
 82           << " node " << a_node.s_cls()           
 83           << " tail " << path[path.size()-1]->    
 84           << std::endl;                           
 85     a_action.clear_path();                        
 86     return a_action.path();                       
 87   }                                               
 88   return path;                                    
 89 }                                                 
 90                                                   
 91 inline const search_action::paths_t& find_path    
 92   a_action.reset();                               
 93   a_action.set_what(search_action::search_path    
 94   a_action.set_class(a_class);                    
 95   a_from.search(a_action);                        
 96   return a_action.paths();                        
 97 }                                                 
 98                                                   
 99 template <class NODE>                             
100 inline const search_action::paths_t& find_path    
101   a_action.reset();                               
102   a_action.set_what(search_action::search_path    
103   a_action.set_class(NODE::s_class());            
104   a_from.search(a_action);                        
105   return a_action.paths();                        
106 }                                                 
107                                                   
108 template <class NODE>                             
109 inline NODE* find_ancestor(std::ostream& a_out    
110   search_action action(a_out);                    
111   return rfind<NODE>(find_path(action,a_from,a    
112 }                                                 
113                                                   
114 template <class CONTAINER>                        
115 inline CONTAINER* find_container(std::ostream&    
116   search_action action(a_out);                    
117   return container<CONTAINER>(find_path(action    
118 }                                                 
119                                                   
120 template <class NODE>                             
121 inline NODE* search_node(std::ostream& a_out,n    
122   search_action sa(a_out);                        
123   const paths_t& paths = find_paths<NODE>(sa,a    
124   tools_vforcit(path_t,paths,it) {                
125     NODE* _node = tail<NODE>(*it);                
126     if(_node) return _node;                       
127   }                                               
128   return 0;                                       
129 }                                                 
130                                                   
131 template <class SELECTABLE>                       
132 inline SELECTABLE* search_selectable(std::ostr    
133   search_action sa(a_out);                        
134   const paths_t& paths = find_paths<SELECTABLE    
135   tools_vforcit(path_t,paths,it) {                
136     SELECTABLE* _node = tail<SELECTABLE>(*it);    
137     if(_node && _node->border_visible.value())    
138   }                                               
139 /*                                                
140   tools_vforcit(sg::path_t,paths,it) {            
141     SELECTABLE* _node = sg::tail<SELECTABLE>(*    
142     if(_node) return _node;                       
143   }                                               
144 */                                                
145   return 0;                                       
146 }                                                 
147                                                   
148 }}                                                
149                                                   
150 #endif