| (* |
| 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. |
| *) |
| |
| open Thrift |
| |
| class t port = |
| object |
| inherit Transport.server_t |
| val mutable sock = None |
| method listen = |
| let s = Unix.socket Unix.PF_INET Unix.SOCK_STREAM 0 in |
| sock <- Some s; |
| Unix.bind s (Unix.ADDR_INET (Unix.inet_addr_any, port)); |
| Unix.listen s 256 |
| method close = |
| match sock with |
| Some s -> Unix.shutdown s Unix.SHUTDOWN_ALL; Unix.close s; |
| sock <- None |
| | _ -> () |
| method acceptImpl = |
| match sock with |
| Some s -> let (fd,_) = Unix.accept s in |
| new TChannelTransport.t (Unix.in_channel_of_descr fd,Unix.out_channel_of_descr fd) |
| | _ -> raise (Transport.E (Transport.NOT_OPEN,"TServerSocket: Not listening but tried to accept")) |
| end |