source: src/Fragmentation/Automation/Listener.hpp@ 9a3f84

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 Candidate_v1.7.0 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
Last change on this file since 9a3f84 was 8036b7, checked in by Frederik Heber <heber@…>, 13 years ago

Refactored Listener out of FragmentScheduler.

  • this is preparatory for creating PoolWorker class, i.e. Worker that listen for jobs sent to them by the server.
  • the connection is just reset() on new initiateSocket().
  • closeSocket() correctly shutdown()s and close()s the socket.
  • Note: As ControllerListener receives new jobs and thus knows when the server is required to listen on worker port again, it needs a bound function to WorkerListener_t::initiateSocket(). This will be removed when the new Pool is in place that handles Worker connections.
  • Property mode set to 100644
File size: 1.7 KB
Line 
1/*
2 * Listener.hpp
3 *
4 * Created on: 22.02.2012
5 * Author: heber
6 */
7
8#ifndef LISTENER_HPP_
9#define LISTENER_HPP_
10
11// include config.h
12#ifdef HAVE_CONFIG_H
13#include <config.h>
14#endif
15
16#include <boost/asio.hpp>
17
18#include "Connection.hpp"
19
20/** Class Listener implements a class listening on a given port for incoming
21 * connections.
22 *
23 * In order to use, inherit it and implement the virtual function handle_Accept().
24 * \code
25 * class foo : public Listener {
26 * ...
27 * void handle_Accept(const boost::system::error_code& e, connection_ptr conn)
28 * {
29 * if (!e) {
30 * conn->async_write(job,
31 * boost::bind(&<functionpointer>,
32 * boost::asio::placeholders::error, conn));
33 * }
34 * ...
35 * }
36 * };
37 * \endcode
38 * where async_write or async_read expect some bound function taking again
39 * the error and the connection as arguments (i.e. a cascade of handlers).
40 *
41 */
42class Listener
43{
44public:
45 Listener(boost::asio::io_service& io_service, unsigned short port);
46 ~Listener();
47
48 void initiateSocket();
49 void closeSocket();
50
51 enum Exitflag_t{
52 OkFlag = 0,
53 ErrorFlag = 255
54 };
55
56 /** Getter for Exitflag.
57 *
58 * @return Exitflag of operations
59 */
60 size_t getExitflag() const
61 {
62 return Exitflag;
63 }
64
65protected:
66 /// Handle completion for initially acceptig connection
67 virtual void handle_Accept(const boost::system::error_code& e, connection_ptr conn)=0;
68
69 // Exit flag on program exit
70 enum Exitflag_t Exitflag;
71
72private:
73 /// The acceptor object used to accept incoming worker socket connections.
74 boost::asio::ip::tcp::acceptor acceptor_;
75
76 //!> Connection object
77 connection_ptr connection;
78};
79
80#endif /* LISTENER_HPP_ */
Note: See TracBrowser for help on using the repository browser.