Changes in src/molecule_pointcloud.cpp [c72112:71b20e]
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
src/molecule_pointcloud.cpp
rc72112 r71b20e 8 8 #include "atom.hpp" 9 9 #include "config.hpp" 10 #include "info.hpp"11 10 #include "memoryallocator.hpp" 12 11 #include "molecule.hpp" … … 32 31 }; 33 32 34 35 /** PointCloud implementation of GoPoint 36 * Uses atoms and STL stuff. 33 /** Return current atom in the list. 34 * \return pointer to atom or NULL if none present 37 35 */ 38 TesselPoint *molecule::GetPoint() const36 TesselPoint *molecule::GetPoint() const 39 37 { 40 Info FunctionInfo(__func__); 41 return (*InternalPointer); 38 if ((InternalPointer != start) && (InternalPointer != end)) 39 return InternalPointer; 40 else 41 return NULL; 42 42 }; 43 43 44 /** PointCloud implementation of GoToNext. 45 * Uses atoms and STL stuff. 44 /** Return pointer to one after last atom in the list. 45 * \return pointer to end marker 46 */ 47 TesselPoint *molecule::GetTerminalPoint() const 48 { 49 return end; 50 }; 51 52 /** Return the greatest index of all atoms in the list. 53 * \return greatest index 54 */ 55 int molecule::GetMaxId() const 56 { 57 return last_atom; 58 }; 59 60 /** Go to next atom. 61 * Stops at last one. 46 62 */ 47 63 void molecule::GoToNext() const 48 64 { 49 Info FunctionInfo(__func__); 50 if (InternalPointer != atoms.end()) 51 InternalPointer++; 65 if (InternalPointer != end) 66 InternalPointer = InternalPointer->next; 52 67 }; 53 68 54 /** PointCloud implementation of GoToFirst. 55 * Uses atoms and STL stuff. 69 /** Go to previous atom. 70 * Stops at first one. 71 */ 72 void molecule::GoToPrevious() const 73 { 74 if (InternalPointer->previous != start) 75 InternalPointer = InternalPointer->previous; 76 }; 77 78 /** Goes to first atom. 56 79 */ 57 80 void molecule::GoToFirst() const 58 81 { 59 Info FunctionInfo(__func__); 60 InternalPointer = atoms.begin(); 82 InternalPointer = start->next; 61 83 }; 62 84 63 /** PointCloud implementation of IsEmpty. 64 * Uses atoms and STL stuff. 85 /** Goes to last atom. 86 */ 87 void molecule::GoToLast() const 88 { 89 InternalPointer = end->previous; 90 }; 91 92 /** Checks whether we have any atoms in molecule. 93 * \return true - no atoms, false - not empty 65 94 */ 66 95 bool molecule::IsEmpty() const 67 96 { 68 Info FunctionInfo(__func__); 69 return (empty()); 97 return (start->next == end); 70 98 }; 71 99 72 /** PointCloud implementation of IsLast.73 * Uses atoms and STL stuff.100 /** Checks whether we are at the last atom 101 * \return true - current atom is last one, false - is not last one 74 102 */ 75 103 bool molecule::IsEnd() const 76 104 { 77 Info FunctionInfo(__func__); 78 return (InternalPointer == atoms.end()); 105 return (InternalPointer == end); 79 106 }; 80 81 int molecule::GetMaxId() const {82 return getAtomCount();83 }
Note:
See TracChangeset
for help on using the changeset viewer.