Rev 30 | Blame | Compare with Previous | Last modification | View Log | RSS feed
---- 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.--module Thrift.Server( runBasicServer, runThreadedServer) whereimport Control.Concurrent ( forkIO )import Control.Exceptionimport Control.Monad ( forever, when )import Networkimport System.IOimport Thriftimport Thrift.Transport.Handleimport Thrift.Protocol.Binary-- | A threaded sever that is capable of using any Transport or Protocol-- instances.runThreadedServer :: (Transport t, Protocol i, Protocol o)=> (Socket -> IO (i t, o t))-> h-> (h -> (i t, o t) -> IO Bool)-> PortID-> IO arunThreadedServer accepter hand proc port = dosocket <- listenOn portacceptLoop (accepter socket) (proc hand)-- | A basic threaded binary protocol socket server.runBasicServer :: h-> (h -> (BinaryProtocol Handle, BinaryProtocol Handle) -> IO Bool)-> PortNumber-> IO arunBasicServer hand proc port = runThreadedServer binaryAccept hand proc (PortNumber port)where binaryAccept s = do(h, _, _) <- accept sreturn (BinaryProtocol h, BinaryProtocol h)acceptLoop :: IO t -> (t -> IO Bool) -> IO aacceptLoop accepter proc = forever $do ps <- accepterforkIO $ handle (\(e :: SomeException) -> return ())(loop $ proc ps)where loop m = do { continue <- m; when continue (loop m) }