fork of https://github.com/oxigraph/rocksdb and https://github.com/facebook/rocksdb for nextgraph and oxigraph
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
84 lines
2.2 KiB
84 lines
2.2 KiB
/*
|
|
* Licensed to the Apache Software Foundation (ASF) under one
|
|
* or more contributor license agreements. See the NOTICE file
|
|
* distributed with this work for additional information
|
|
* regarding copyright ownership. The ASF licenses this file
|
|
* to you under the Apache License, Version 2.0 (the
|
|
* "License"); you may not use this file except in compliance
|
|
* with the License. You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing,
|
|
* software distributed under the License is distributed on an
|
|
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
|
* KIND, either express or implied. See the License for the
|
|
* specific language governing permissions and limitations
|
|
* under the License.
|
|
*/
|
|
|
|
#ifndef _THRIFT_TRANSPORT_TSERVERSOCKET_H_
|
|
#define _THRIFT_TRANSPORT_TSERVERSOCKET_H_ 1
|
|
|
|
#include "thrift/lib/cpp/transport/TServerTransport.h"
|
|
#include <boost/shared_ptr.hpp>
|
|
|
|
namespace apache { namespace thrift { namespace transport {
|
|
|
|
class TSocket;
|
|
|
|
/**
|
|
* Server socket implementation of TServerTransport. Wrapper around a unix
|
|
* socket listen and accept calls.
|
|
*
|
|
*/
|
|
class TServerSocket : public TServerTransport {
|
|
public:
|
|
TServerSocket(int port);
|
|
TServerSocket(int port, int sendTimeout, int recvTimeout);
|
|
|
|
~TServerSocket();
|
|
|
|
int getPort() const { return port_; }
|
|
|
|
void setSendTimeout(int sendTimeout);
|
|
void setRecvTimeout(int recvTimeout);
|
|
|
|
void setAcceptTimeout(int accTimeout);
|
|
|
|
void setRetryLimit(int retryLimit);
|
|
void setRetryDelay(int retryDelay);
|
|
|
|
void setTcpSendBuffer(int tcpSendBuffer);
|
|
void setTcpRecvBuffer(int tcpRecvBuffer);
|
|
|
|
void listen();
|
|
void close();
|
|
|
|
void interrupt();
|
|
|
|
void getAddress(TSocketAddress* address);
|
|
|
|
protected:
|
|
boost::shared_ptr<TRpcTransport> acceptImpl();
|
|
virtual boost::shared_ptr<TSocket> createSocket(int client);
|
|
|
|
private:
|
|
int port_;
|
|
int serverSocket_;
|
|
int acceptBacklog_;
|
|
int sendTimeout_;
|
|
int recvTimeout_;
|
|
int accTimeout_;
|
|
int retryLimit_;
|
|
int retryDelay_;
|
|
int tcpSendBuffer_;
|
|
int tcpRecvBuffer_;
|
|
|
|
int intSock1_;
|
|
int intSock2_;
|
|
};
|
|
|
|
}}} // apache::thrift::transport
|
|
|
|
#endif // #ifndef _THRIFT_TRANSPORT_TSERVERSOCKET_H_
|
|
|