Ignore:
File:
1 edited

Legend:

Unmodified
Added
Removed
  • src/Actions/WorldAction/RepeatBoxAction.cpp

    rbf3817 r952f38  
    55 *      Author: heber
    66 */
    7 
    8 // include config.h
    9 #ifdef HAVE_CONFIG_H
    10 #include <config.h>
    11 #endif
    127
    138#include "Helpers/MemDebug.hpp"
     
    2621#include <iostream>
    2722#include <string>
    28 #include <vector>
    2923
    3024using namespace std;
     
    9690
    9791  molecule *newmol = NULL;
    98   std::vector<Vector> vectors;
     92  Vector ** vectors = NULL;
    9993  for (n[0] = 0; n[0] < Repeater[0]; n[0]++) {
    10094    y[0] = n[0];
     
    111105          if (count != 0) {  // if there is more than none
    112106            Elements = new const element *[count];
    113             vectors.resize(count);
     107            vectors = new Vector *[count];
    114108            j = 0;
    115109            for(molecule::iterator AtomRunner = mol->begin(); AtomRunner != mol->end(); ++AtomRunner) {
    116               Elements[j] = (*AtomRunner)->getType();
    117               vectors[j] = (*AtomRunner)->getPosition();
     110              Elements[j] = (*AtomRunner)->type;
     111              vectors[j] = &(*AtomRunner)->x;
    118112              j++;
    119113            }
     
    126120            for (int k=count;k--;) { // go through every atom of the original cell
    127121              Walker = World::getInstance().createAtom(); // create a new body
    128               Walker->setPosition((vectors[k]) + x);
    129               Walker->setType(Elements[k]);  // insert original element
     122              Walker->x = (*vectors[k]) + x;
     123              Walker->type = Elements[k];  // insert original element
    130124              cout << "new atom is " << *Walker << endl;
    131125              newmol->AddAtom(Walker);        // and add to the molecule (which increments ElementsInMolecule, AtomCount, ...)
     
    133127            // free memory
    134128            delete[](Elements);
     129            delete[](vectors);
    135130          } else {
    136131            DoLog(1) && (Log() << Verbose(1) << "\t ... is empty." << endl);
Note: See TracChangeset for help on using the changeset viewer.