blob: 58bc0de39909fc9390fcb42987a1fed88cd54313 [file] [log] [blame]
henrike@webrtc.orgf0488722014-05-13 18:00:26 +00001/*
2 * Copyright 2004 The WebRTC Project Authors. All rights reserved.
3 *
4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree.
9 */
10
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020011#ifndef RTC_BASE_SOCKETFACTORY_H_
12#define RTC_BASE_SOCKETFACTORY_H_
henrike@webrtc.orgf0488722014-05-13 18:00:26 +000013
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020014#include "rtc_base/asyncsocket.h"
15#include "rtc_base/socket.h"
henrike@webrtc.orgf0488722014-05-13 18:00:26 +000016
Henrik Kjellanderec78f1c2017-06-29 07:52:50 +020017namespace rtc {
henrike@webrtc.orgf0488722014-05-13 18:00:26 +000018
Henrik Kjellanderec78f1c2017-06-29 07:52:50 +020019class SocketFactory {
20public:
21 virtual ~SocketFactory() {}
22
23 // Returns a new socket for blocking communication. The type can be
24 // SOCK_DGRAM and SOCK_STREAM.
25 // TODO: C++ inheritance rules mean that all users must have both
26 // CreateSocket(int) and CreateSocket(int,int). Will remove CreateSocket(int)
27 // (and CreateAsyncSocket(int) when all callers are changed.
28 virtual Socket* CreateSocket(int type) = 0;
29 virtual Socket* CreateSocket(int family, int type) = 0;
30 // Returns a new socket for nonblocking communication. The type can be
31 // SOCK_DGRAM and SOCK_STREAM.
32 virtual AsyncSocket* CreateAsyncSocket(int type) = 0;
33 virtual AsyncSocket* CreateAsyncSocket(int family, int type) = 0;
34};
35
36} // namespace rtc
37
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020038#endif // RTC_BASE_SOCKETFACTORY_H_