Ignore:
File:
1 edited

Legend:

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

    r952f38 rd74077  
    1111#include "Actions/ActionRegistry.hpp"
    1212#include "atom.hpp"
    13 #include "Helpers/Log.hpp"
     13#include "log.hpp"
    1414#include "molecule.hpp"
    15 #include "LinearAlgebra/Vector.hpp"
    16 #include "LinearAlgebra/Matrix.hpp"
    17 #include "Helpers/Verbose.hpp"
     15#include "vector.hpp"
     16#include "Matrix.hpp"
     17#include "verbose.hpp"
    1818#include "World.hpp"
    1919#include "Box.hpp"
     
    2121#include <iostream>
    2222#include <string>
     23#include <vector>
    2324
    2425using namespace std;
     
    2627#include "UIElements/UIFactory.hpp"
    2728#include "UIElements/Dialog.hpp"
    28 #include "Actions/ValueStorage.hpp"
     29#include "UIElements/ValueStorage.hpp"
    2930#include "Descriptors/MoleculeDescriptor.hpp"
    3031#include "Descriptors/MoleculePtrDescriptor.hpp"
     
    4445};
    4546
    46 Dialog * WorldRepeatBoxAction::fillDialog(Dialog *dialog) {
    47   ASSERT(dialog,"No Dialog given when filling action dialog");
     47Dialog * WorldRepeatBoxAction::createDialog() {
     48  Dialog *dialog = UIFactory::getInstance().makeDialog();
    4849
    4950  dialog->queryVector(NAME, false, ValueStorage::getInstance().getDescription(NAME));
     
    9091
    9192  molecule *newmol = NULL;
    92   Vector ** vectors = NULL;
     93  std::vector<Vector> vectors;
    9394  for (n[0] = 0; n[0] < Repeater[0]; n[0]++) {
    9495    y[0] = n[0];
     
    105106          if (count != 0) {  // if there is more than none
    106107            Elements = new const element *[count];
    107             vectors = new Vector *[count];
     108            vectors.resize(count);
    108109            j = 0;
    109110            for(molecule::iterator AtomRunner = mol->begin(); AtomRunner != mol->end(); ++AtomRunner) {
    110               Elements[j] = (*AtomRunner)->type;
    111               vectors[j] = &(*AtomRunner)->x;
     111              Elements[j] = (*AtomRunner)->getType();
     112              vectors[j] = (*AtomRunner)->getPosition();
    112113              j++;
    113114            }
     
    120121            for (int k=count;k--;) { // go through every atom of the original cell
    121122              Walker = World::getInstance().createAtom(); // create a new body
    122               Walker->x = (*vectors[k]) + x;
    123               Walker->type = Elements[k];  // insert original element
     123              Walker->setPosition((vectors[k]) + x);
     124              Walker->setType(Elements[k]);  // insert original element
    124125              cout << "new atom is " << *Walker << endl;
    125126              newmol->AddAtom(Walker);        // and add to the molecule (which increments ElementsInMolecule, AtomCount, ...)
     
    127128            // free memory
    128129            delete[](Elements);
    129             delete[](vectors);
    130130          } else {
    131131            DoLog(1) && (Log() << Verbose(1) << "\t ... is empty." << endl);
Note: See TracChangeset for help on using the changeset viewer.