Ignore:
File:
1 edited

Legend:

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

    rd74077 r952f38  
    1111#include "Actions/ActionRegistry.hpp"
    1212#include "atom.hpp"
    13 #include "log.hpp"
     13#include "Helpers/Log.hpp"
    1414#include "molecule.hpp"
    15 #include "vector.hpp"
    16 #include "Matrix.hpp"
    17 #include "verbose.hpp"
     15#include "LinearAlgebra/Vector.hpp"
     16#include "LinearAlgebra/Matrix.hpp"
     17#include "Helpers/Verbose.hpp"
    1818#include "World.hpp"
    1919#include "Box.hpp"
     
    2121#include <iostream>
    2222#include <string>
    23 #include <vector>
    2423
    2524using namespace std;
     
    2726#include "UIElements/UIFactory.hpp"
    2827#include "UIElements/Dialog.hpp"
    29 #include "UIElements/ValueStorage.hpp"
     28#include "Actions/ValueStorage.hpp"
    3029#include "Descriptors/MoleculeDescriptor.hpp"
    3130#include "Descriptors/MoleculePtrDescriptor.hpp"
     
    4544};
    4645
    47 Dialog * WorldRepeatBoxAction::createDialog() {
    48   Dialog *dialog = UIFactory::getInstance().makeDialog();
     46Dialog * WorldRepeatBoxAction::fillDialog(Dialog *dialog) {
     47  ASSERT(dialog,"No Dialog given when filling action dialog");
    4948
    5049  dialog->queryVector(NAME, false, ValueStorage::getInstance().getDescription(NAME));
     
    9190
    9291  molecule *newmol = NULL;
    93   std::vector<Vector> vectors;
     92  Vector ** vectors = NULL;
    9493  for (n[0] = 0; n[0] < Repeater[0]; n[0]++) {
    9594    y[0] = n[0];
     
    106105          if (count != 0) {  // if there is more than none
    107106            Elements = new const element *[count];
    108             vectors.resize(count);
     107            vectors = new Vector *[count];
    109108            j = 0;
    110109            for(molecule::iterator AtomRunner = mol->begin(); AtomRunner != mol->end(); ++AtomRunner) {
    111               Elements[j] = (*AtomRunner)->getType();
    112               vectors[j] = (*AtomRunner)->getPosition();
     110              Elements[j] = (*AtomRunner)->type;
     111              vectors[j] = &(*AtomRunner)->x;
    113112              j++;
    114113            }
     
    121120            for (int k=count;k--;) { // go through every atom of the original cell
    122121              Walker = World::getInstance().createAtom(); // create a new body
    123               Walker->setPosition((vectors[k]) + x);
    124               Walker->setType(Elements[k]);  // insert original element
     122              Walker->x = (*vectors[k]) + x;
     123              Walker->type = Elements[k];  // insert original element
    125124              cout << "new atom is " << *Walker << endl;
    126125              newmol->AddAtom(Walker);        // and add to the molecule (which increments ElementsInMolecule, AtomCount, ...)
     
    128127            // free memory
    129128            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.