Ignore:
File:
1 edited

Legend:

Unmodified
Added
Removed
  • src/molecule_pointcloud.cpp

    rc72112 r71b20e  
    88#include "atom.hpp"
    99#include "config.hpp"
    10 #include "info.hpp"
    1110#include "memoryallocator.hpp"
    1211#include "molecule.hpp"
     
    3231};
    3332
    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
    3735 */
    38 TesselPoint* molecule::GetPoint() const
     36TesselPoint *molecule::GetPoint() const
    3937{
    40   Info FunctionInfo(__func__);
    41   return (*InternalPointer);
     38  if ((InternalPointer != start) && (InternalPointer != end))
     39    return InternalPointer;
     40  else
     41    return NULL;
    4242};
    4343
    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 */
     47TesselPoint *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 */
     55int molecule::GetMaxId() const
     56{
     57  return last_atom;
     58};
     59
     60/** Go to next atom.
     61 * Stops at last one.
    4662 */
    4763void molecule::GoToNext() const
    4864{
    49   Info FunctionInfo(__func__);
    50   if (InternalPointer != atoms.end())
    51     InternalPointer++;
     65  if (InternalPointer != end)
     66    InternalPointer = InternalPointer->next;
    5267};
    5368
    54 /** PointCloud implementation of GoToFirst.
    55  * Uses atoms and STL stuff.
     69/** Go to previous atom.
     70 * Stops at first one.
     71 */
     72void molecule::GoToPrevious() const
     73{
     74  if (InternalPointer->previous != start)
     75    InternalPointer = InternalPointer->previous;
     76};
     77
     78/** Goes to first atom.
    5679 */
    5780void molecule::GoToFirst() const
    5881{
    59   Info FunctionInfo(__func__);
    60   InternalPointer = atoms.begin();
     82  InternalPointer = start->next;
    6183};
    6284
    63 /** PointCloud implementation of IsEmpty.
    64  * Uses atoms and STL stuff.
     85/** Goes to last atom.
     86 */
     87void 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
    6594 */
    6695bool molecule::IsEmpty() const
    6796{
    68   Info FunctionInfo(__func__);
    69   return (empty());
     97  return (start->next == end);
    7098};
    7199
    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
    74102 */
    75103bool molecule::IsEnd() const
    76104{
    77   Info FunctionInfo(__func__);
    78   return (InternalPointer == atoms.end());
     105  return (InternalPointer == end);
    79106};
    80 
    81 int molecule::GetMaxId() const {
    82   return getAtomCount();
    83 }
Note: See TracChangeset for help on using the changeset viewer.