Ignore:
Timestamp:
Jul 28, 2010, 9:21:14 AM (15 years ago)
Author:
Tillmann Crueger <crueger@…>
Branches:
Action_Thermostats, Add_AtomRandomPerturbation, Add_FitFragmentPartialChargesAction, Add_RotateAroundBondAction, Add_SelectAtomByNameAction, Added_ParseSaveFragmentResults, AddingActions_SaveParseParticleParameters, Adding_Graph_to_ChangeBondActions, Adding_MD_integration_tests, Adding_ParticleName_to_Atom, Adding_StructOpt_integration_tests, AtomFragments, Automaking_mpqc_open, AutomationFragmentation_failures, Candidate_v1.5.4, Candidate_v1.6.0, Candidate_v1.6.1, ChangeBugEmailaddress, ChangingTestPorts, ChemicalSpaceEvaluator, CombiningParticlePotentialParsing, Combining_Subpackages, Debian_Package_split, Debian_package_split_molecuildergui_only, Disabling_MemDebug, Docu_Python_wait, EmpiricalPotential_contain_HomologyGraph, EmpiricalPotential_contain_HomologyGraph_documentation, Enable_parallel_make_install, Enhance_userguide, Enhanced_StructuralOptimization, Enhanced_StructuralOptimization_continued, Example_ManyWaysToTranslateAtom, Exclude_Hydrogens_annealWithBondGraph, FitPartialCharges_GlobalError, Fix_BoundInBox_CenterInBox_MoleculeActions, Fix_ChargeSampling_PBC, Fix_ChronosMutex, Fix_FitPartialCharges, Fix_FitPotential_needs_atomicnumbers, Fix_ForceAnnealing, Fix_IndependentFragmentGrids, Fix_ParseParticles, Fix_ParseParticles_split_forward_backward_Actions, Fix_PopActions, Fix_QtFragmentList_sorted_selection, Fix_Restrictedkeyset_FragmentMolecule, Fix_StatusMsg, Fix_StepWorldTime_single_argument, Fix_Verbose_Codepatterns, Fix_fitting_potentials, Fixes, ForceAnnealing_goodresults, ForceAnnealing_oldresults, ForceAnnealing_tocheck, ForceAnnealing_with_BondGraph, ForceAnnealing_with_BondGraph_continued, ForceAnnealing_with_BondGraph_continued_betteresults, ForceAnnealing_with_BondGraph_contraction-expansion, FragmentAction_writes_AtomFragments, FragmentMolecule_checks_bonddegrees, GeometryObjects, Gui_Fixes, Gui_displays_atomic_force_velocity, ImplicitCharges, IndependentFragmentGrids, IndependentFragmentGrids_IndividualZeroInstances, IndependentFragmentGrids_IntegrationTest, IndependentFragmentGrids_Sole_NN_Calculation, JobMarket_RobustOnKillsSegFaults, JobMarket_StableWorkerPool, JobMarket_unresolvable_hostname_fix, MoreRobust_FragmentAutomation, ODR_violation_mpqc_open, PartialCharges_OrthogonalSummation, PdbParser_setsAtomName, PythonUI_with_named_parameters, QtGui_reactivate_TimeChanged_changes, Recreated_GuiChecks, Rewrite_FitPartialCharges, RotateToPrincipalAxisSystem_UndoRedo, SaturateAtoms_findBestMatching, SaturateAtoms_singleDegree, StoppableMakroAction, Subpackage_CodePatterns, Subpackage_JobMarket, Subpackage_LinearAlgebra, Subpackage_levmar, Subpackage_mpqc_open, Subpackage_vmg, Switchable_LogView, ThirdParty_MPQC_rebuilt_buildsystem, TrajectoryDependenant_MaxOrder, TremoloParser_IncreasedPrecision, TremoloParser_MultipleTimesteps, TremoloParser_setsAtomName, Ubuntu_1604_changes, stable
Children:
400170, a7b777c
Parents:
7067bd6 (diff), 0430e3 (diff)
Note: this is a merge changeset, the changes displayed below correspond to the merge itself.
Use the (diff) links above to see all the changes relative to each parent.
Message:

Merge branch 'stable' into StructureRefactoring

Conflicts:

src/Makefile.am

Location:
src/Actions/TesselationAction
Files:
4 edited

Legend:

Unmodified
Added
Removed
  • src/Actions/TesselationAction/ConvexEnvelopeAction.cpp

    r7067bd6 r677e13  
    99
    1010#include "Actions/TesselationAction/ConvexEnvelopeAction.hpp"
     11#include "Actions/ActionRegistry.hpp"
     12#include "boundary.hpp"
     13#include "config.hpp"
     14#include "linkedcell.hpp"
     15#include "log.hpp"
     16#include "molecule.hpp"
     17#include "verbose.hpp"
     18#include "World.hpp"
    1119
    1220#include <iostream>
     
    1725#include "UIElements/UIFactory.hpp"
    1826#include "UIElements/Dialog.hpp"
    19 #include "Actions/MapOfActions.hpp"
    20 
    21 #include "atom.hpp"
    22 #include "boundary.hpp"
    23 #include "config.hpp"
    24 #include "linkedcell.hpp"
    25 #include "log.hpp"
    26 #include "molecule.hpp"
    27 #include "verbose.hpp"
    28 #include "World.hpp"
     27#include "UIElements/ValueStorage.hpp"
    2928
    3029/****** TesselationConvexEnvelopeAction *****/
     
    5150{}
    5251
     52void TesselationConvexEnvelope(std::string &filenameConvex, std::string &filenameNonConvex) {
     53  ValueStorage::getInstance().setCurrentValue("convex-file", filenameConvex);
     54  ValueStorage::getInstance().setCurrentValue("nonconvex-file", filenameConvex);
     55  ActionRegistry::getInstance().getActionByName(TesselationConvexEnvelopeAction::NAME)->call(Action::NonInteractive);
     56};
     57
     58Dialog* TesselationConvexEnvelopeAction::createDialog() {
     59  Dialog *dialog = UIFactory::getInstance().makeDialog();
     60
     61  dialog->queryEmpty(NAME, ValueStorage::getInstance().getDescription(NAME));
     62  dialog->queryString("convex-file", ValueStorage::getInstance().getDescription("convex-file"));
     63  dialog->queryString("nonconvex-file", ValueStorage::getInstance().getDescription("nonconvex-file"));
     64
     65  return dialog;
     66}
     67
    5368Action::state_ptr TesselationConvexEnvelopeAction::performCall() {
    5469  string filenameConvex;
    5570  string filenameNonConvex;
    56   Dialog *dialog = UIFactory::getInstance().makeDialog();
    5771  molecule * mol = NULL;
    58   bool Success = false;
     72  bool Success = true;
    5973  config *configuration = World::getInstance().getConfig();
    6074
    61   dialog->queryMolecule(NAME, &mol, MapOfActions::getInstance().getDescription(NAME));
    62   dialog->queryString("convex-file", &filenameConvex, MapOfActions::getInstance().getDescription("convex-file"));
    63   dialog->queryString("nonconvex-file", &filenameNonConvex, MapOfActions::getInstance().getDescription("nonconvex-file"));
     75  ValueStorage::getInstance().queryCurrentValue("convex-file", filenameConvex);
     76  ValueStorage::getInstance().queryCurrentValue("nonconvex-file", filenameNonConvex);
    6477
    65   if(dialog->display()) {
     78  for (World::MoleculeSelectionIterator iter = World::getInstance().beginMoleculeSelection(); iter != World::getInstance().endMoleculeSelection(); ++iter) {
     79    mol = iter->second;
    6680    class Tesselation *TesselStruct = NULL;
    6781    const LinkedCell *LCList = NULL;
     
    8195    delete(TesselStruct);
    8296    delete(LCList);
    83     delete dialog;
    84     if (Success)
    85       return Action::success;
    86     else
    87       return Action::failure;
    8897  }
    89   delete dialog;
    90   return Action::failure;
     98  if (Success)
     99    return Action::success;
     100  else
     101    return Action::failure;
    91102}
    92103
  • src/Actions/TesselationAction/ConvexEnvelopeAction.hpp

    r7067bd6 r677e13  
    1414class TesselationListClass;
    1515
     16void TesselationConvexEnvelope(std::string &filenameConvex, std::string &filenameNonConvex);
     17
    1618class TesselationConvexEnvelopeAction : public Action {
     19  friend void TesselationConvexEnvelope(std::string &filenameConvex, std::string &filenameNonConvex);
     20
    1721public:
    1822  TesselationConvexEnvelopeAction();
     
    2428  virtual const std::string getName();
    2529private:
     30  virtual Dialog * createDialog();
    2631  virtual Action::state_ptr performCall();
    2732  virtual Action::state_ptr performUndo(Action::state_ptr);
  • src/Actions/TesselationAction/NonConvexEnvelopeAction.cpp

    r7067bd6 r677e13  
    99
    1010#include "Actions/TesselationAction/NonConvexEnvelopeAction.hpp"
     11#include "Actions/ActionRegistry.hpp"
     12#include "boundary.hpp"
     13#include "linkedcell.hpp"
     14#include "log.hpp"
     15#include "molecule.hpp"
     16#include "verbose.hpp"
     17#include "World.hpp"
    1118
    1219#include <iostream>
     
    1724#include "UIElements/UIFactory.hpp"
    1825#include "UIElements/Dialog.hpp"
    19 #include "Actions/MapOfActions.hpp"
    20 
    21 #include "atom.hpp"
    22 #include "boundary.hpp"
    23 #include "linkedcell.hpp"
    24 #include "log.hpp"
    25 #include "molecule.hpp"
    26 #include "verbose.hpp"
    27 #include "World.hpp"
     26#include "UIElements/ValueStorage.hpp"
    2827
    2928/****** TesselationNonConvexEnvelopeAction *****/
     
    5049{}
    5150
     51void TesselationNonConvexEnvelope(double radius, std::string &filename) {
     52  ValueStorage::getInstance().setCurrentValue(TesselationNonConvexEnvelopeAction::NAME, radius);
     53  ValueStorage::getInstance().setCurrentValue("nonconvex-file", filename);
     54  ActionRegistry::getInstance().getActionByName(TesselationNonConvexEnvelopeAction::NAME)->call(Action::NonInteractive);
     55};
     56
     57Dialog* TesselationNonConvexEnvelopeAction::createDialog() {
     58  Dialog *dialog = UIFactory::getInstance().makeDialog();
     59
     60  dialog->queryDouble(NAME, MapOfActions::getInstance().getDescription(NAME));
     61  dialog->queryString("nonconvex-file", MapOfActions::getInstance().getDescription("nonconvex-file"));
     62
     63  return dialog;
     64}
     65
    5266Action::state_ptr TesselationNonConvexEnvelopeAction::performCall() {
    5367  string filename;
    54   Dialog *dialog = UIFactory::getInstance().makeDialog();
    5568  molecule * Boundary = NULL;
    5669  double SphereRadius = 0;
     
    5871  clock_t start,end;
    5972
    60   dialog->queryMolecule(NAME, &Boundary, MapOfActions::getInstance().getDescription(NAME));
    61   dialog->queryString("nonconvex-file", &filename, MapOfActions::getInstance().getDescription("nonconvex-file"));
    62   dialog->queryDouble("sphere-radius", &SphereRadius, MapOfActions::getInstance().getDescription("sphere-radius"));
     73  ValueStorage::getInstance().queryCurrentValue(NAME, SphereRadius);
     74  ValueStorage::getInstance().queryCurrentValue("nonconvex-file", filename);
    6375
    64   if(dialog->display()) {
     76  for (World::MoleculeSelectionIterator iter = World::getInstance().beginMoleculeSelection(); iter != World::getInstance().endMoleculeSelection(); ++iter) {
     77    Boundary = iter->second;
    6578    class Tesselation *T = NULL;
    6679    const LinkedCell *LCList = NULL;
     
    7689    delete(LCList);
    7790    delete(T);
    78     delete dialog;
    79     if (Success)
    80       return Action::success;
    81     else
    82       return Action::failure;
    8391  }
    84   delete dialog;
    85   return Action::failure;
     92  if (Success)
     93    return Action::success;
     94  else
     95    return Action::failure;
    8696}
    8797
  • src/Actions/TesselationAction/NonConvexEnvelopeAction.hpp

    r7067bd6 r677e13  
    1414class TesselationListClass;
    1515
     16void TesselationNonConvexEnvelope(double radius, std::string &filename);
     17
    1618class TesselationNonConvexEnvelopeAction : public Action {
     19  friend void TesselationNonConvexEnvelope(double radius, std::string &filename);
     20
    1721public:
    1822  TesselationNonConvexEnvelopeAction();
     
    2428  virtual const std::string getName();
    2529private:
     30  virtual Dialog * createDialog();
    2631  virtual Action::state_ptr performCall();
    2732  virtual Action::state_ptr performUndo(Action::state_ptr);
Note: See TracChangeset for help on using the changeset viewer.