Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
eclipse
GitHub Repository: eclipse/sumo
Path: blob/main/src/utils/iodevices/OutputDevice_Network.h
169678 views
1
/****************************************************************************/
2
// Eclipse SUMO, Simulation of Urban MObility; see https://eclipse.dev/sumo
3
// Copyright (C) 2006-2025 German Aerospace Center (DLR) and others.
4
// This program and the accompanying materials are made available under the
5
// terms of the Eclipse Public License 2.0 which is available at
6
// https://www.eclipse.org/legal/epl-2.0/
7
// This Source Code may also be made available under the following Secondary
8
// Licenses when the conditions for such availability set forth in the Eclipse
9
// Public License 2.0 are satisfied: GNU General Public License, version 2
10
// or later which is available at
11
// https://www.gnu.org/licenses/old-licenses/gpl-2.0-standalone.html
12
// SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-or-later
13
/****************************************************************************/
14
/// @file OutputDevice_Network.h
15
/// @author Michael Behrisch
16
/// @author Daniel Krajzewicz
17
/// @author Felix Brack
18
/// @date 2006
19
///
20
// An output device for TCP/IP Network connections
21
/****************************************************************************/
22
#pragma once
23
#include <config.h>
24
25
#include "foreign/tcpip/socket.h"
26
#include "foreign/tcpip/storage.h"
27
#include "OutputDevice.h"
28
#include <utils/common/UtilExceptions.h>
29
#include <string>
30
#include <iostream>
31
#include <sstream>
32
33
34
// ==========================================================================
35
// class definitions
36
// ==========================================================================
37
/**
38
* @class OutputDevice_Network
39
* @brief An output device for TCP/IP network connections
40
*
41
* The implementation uses a portable socket implementation from the Shawn
42
* project (shawn.sf.net) located in src/foreign/tcpip/socket.h. It uses
43
* an internal storage for the messages, which is sent via the socket when
44
* "postWriteHook" is called.
45
* @see postWriteHook
46
*/
47
class OutputDevice_Network : public OutputDevice {
48
public:
49
/** @brief Constructor
50
*
51
* @param[in] host The host to connect
52
* @param[in] port The port to connect
53
* @exception IOError If the connection could not be established
54
*/
55
OutputDevice_Network(const std::string& host,
56
const int port);
57
58
59
/// @brief Destructor
60
~OutputDevice_Network();
61
62
63
protected:
64
/// @name Methods that override/implement OutputDevice-methods
65
/// @{
66
67
/** @brief Returns the associated ostream
68
*
69
* The stream is an ostringstream, actually, into which the message
70
* is written. It is sent when postWriteHook is called.
71
*
72
* @return The used stream
73
* @see postWriteHook
74
*/
75
std::ostream& getOStream();
76
77
78
/** @brief Sends the data which was written to the string stream over the socket.
79
*
80
* Converts the stored message into a vector of chars and sends them via to
81
* the socket implementation. Resets the message, afterwards.
82
*/
83
virtual void postWriteHook();
84
/// @}
85
86
private:
87
/// @brief packet buffer
88
std::ostringstream myMessage;
89
90
/// @brief the socket to transfer the data
91
tcpip::Socket* mySocket;
92
93
};
94
95