mirror of
https://github.com/FairRootGroup/FairMQ.git
synced 2025-10-12 16:21:13 +00:00
- Rename Tutorial3 MQ files for uniform naming. - Add search for dylib in FindDDS.cmake (OSX). - Add more detail to the DDS example readme. - MQ Example 3 (DDS): choose network interface via command line option. - Give FairMQ examples their own CMakeLists.txt for clarity. - Remove C++11 checks in Tutorial3 from the code (they are now in CMake). - Add Serializer for device properties (FairMQDevice::ListProperties()).
135 lines
3.5 KiB
C++
135 lines
3.5 KiB
C++
/********************************************************************************
|
|
* Copyright (C) 2014 GSI Helmholtzzentrum fuer Schwerionenforschung GmbH *
|
|
* *
|
|
* This software is distributed under the terms of the *
|
|
* GNU Lesser General Public Licence version 3 (LGPL) version 3, *
|
|
* copied verbatim in the file "LICENSE" *
|
|
********************************************************************************/
|
|
/**
|
|
* FairMQDevice.h
|
|
*
|
|
* @since 2012-10-25
|
|
* @author D. Klein, A. Rybalchenko
|
|
*/
|
|
|
|
#ifndef FAIRMQDEVICE_H_
|
|
#define FAIRMQDEVICE_H_
|
|
|
|
#include <vector>
|
|
#include <memory> // unique_ptr
|
|
#include <string>
|
|
#include <iostream>
|
|
#include <unordered_map>
|
|
|
|
#include "FairMQConfigurable.h"
|
|
#include "FairMQStateMachine.h"
|
|
#include "FairMQTransportFactory.h"
|
|
#include "FairMQSocket.h"
|
|
#include "FairMQChannel.h"
|
|
|
|
class FairMQDevice : public FairMQStateMachine, public FairMQConfigurable
|
|
{
|
|
friend class FairMQChannel;
|
|
|
|
public:
|
|
enum
|
|
{
|
|
Id = FairMQConfigurable::Last,
|
|
NumIoThreads,
|
|
MaxInitializationTime,
|
|
PortRangeMin,
|
|
PortRangeMax,
|
|
LogIntervalInMs,
|
|
Last
|
|
};
|
|
|
|
FairMQDevice();
|
|
|
|
void CatchSignals();
|
|
|
|
virtual void LogSocketRates();
|
|
|
|
void SortChannel(const std::string& name, const bool reindex = true);
|
|
void PrintChannel(const std::string& name);
|
|
|
|
void WaitForInitialValidation();
|
|
|
|
void InteractiveStateLoop();
|
|
void PrintInteractiveStateLoopHelp();
|
|
|
|
virtual void SetProperty(const int key, const std::string& value);
|
|
virtual std::string GetProperty(const int key, const std::string& default_ = "");
|
|
virtual void SetProperty(const int key, const int value);
|
|
virtual int GetProperty(const int key, const int default_ = 0);
|
|
|
|
/// Get property description for a given property name
|
|
/// @param key Property name/key
|
|
/// @return String with the property description
|
|
virtual std::string GetPropertyDescription(const int key);
|
|
/// Print all properties of this and the parent class to LOG(INFO)
|
|
virtual void ListProperties();
|
|
|
|
virtual void SetTransport(FairMQTransportFactory* factory);
|
|
|
|
static bool SortSocketsByAddress(const FairMQChannel &lhs, const FairMQChannel &rhs);
|
|
|
|
virtual ~FairMQDevice();
|
|
|
|
std::unordered_map<std::string, std::vector<FairMQChannel>> fChannels;
|
|
|
|
protected:
|
|
std::string fId;
|
|
|
|
int fMaxInitializationTime;
|
|
|
|
int fNumIoThreads;
|
|
|
|
int fPortRangeMin;
|
|
int fPortRangeMax;
|
|
|
|
int fLogIntervalInMs;
|
|
|
|
FairMQSocket* fCmdSocket;
|
|
|
|
FairMQTransportFactory* fTransportFactory;
|
|
|
|
void InitWrapper();
|
|
virtual void Init();
|
|
|
|
void InitTaskWrapper();
|
|
virtual void InitTask();
|
|
|
|
void RunWrapper();
|
|
virtual void Run();
|
|
|
|
virtual void Pause();
|
|
|
|
void ResetTaskWrapper();
|
|
virtual void ResetTask();
|
|
|
|
void ResetWrapper();
|
|
virtual void Reset();
|
|
|
|
void Shutdown();
|
|
|
|
void Terminate();
|
|
void Unblock();
|
|
|
|
bool InitChannel(FairMQChannel&);
|
|
|
|
private:
|
|
// condition variable to notify parent thread about end of initial validation.
|
|
bool fInitialValidationFinished;
|
|
boost::condition_variable fInitialValidationCondition;
|
|
boost::mutex fInitialValidationMutex;
|
|
|
|
void SignalHandler(int signal);
|
|
bool fCatchingSignals;
|
|
|
|
/// Copy Constructor
|
|
FairMQDevice(const FairMQDevice&);
|
|
FairMQDevice operator=(const FairMQDevice&);
|
|
};
|
|
|
|
#endif /* FAIRMQDEVICE_H_ */
|