4 // Fraunhofer Institut fuer offene Kommunikationssysteme (FOKUS)
5 // Kompetenzzentrum fuer Satelitenkommunikation (SatCom)
6 // Stefan Bund <stefan.bund@fokus.fraunhofer.de>
8 // This program is free software; you can redistribute it and/or modify
9 // it under the terms of the GNU General Public License as published by
10 // the Free Software Foundation; either version 2 of the License, or
11 // (at your option) any later version.
13 // This program is distributed in the hope that it will be useful,
14 // but WITHOUT ANY WARRANTY; without even the implied warranty of
15 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 // GNU General Public License for more details.
18 // You should have received a copy of the GNU General Public License
19 // along with this program; if not, write to the
20 // Free Software Foundation, Inc.,
21 // 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
23 #ifndef HH_CommunicationPolicy_
24 #define HH_CommunicationPolicy_ 1
27 #include "SocketPolicy.hh"
28 #include "AddressingPolicy.hh"
29 #include "FileHandle.hh"
31 //#include "CommunicationPolicy.mpp"
32 ///////////////////////////////hh.p////////////////////////////////////////
39 template <class Policy> class ServerSocketHandle;
41 struct ConnectedCommunicationPolicy : public CommunicationPolicyBase
43 static void listen(FileHandle handle, unsigned backlog);
44 template <class Policy>
45 static int accept(ServerSocketHandle<Policy> handle,
46 typename ServerSocketHandle<Policy>::Address & address,
47 typename IfAddressingPolicyIsNot<Policy,NoAddressingPolicy>::type * = 0);
49 static int do_accept(FileHandle handle, struct sockaddr * addr, unsigned len);
52 struct UnconnectedCommunicationPolicy : public CommunicationPolicyBase
58 ///////////////////////////////hh.e////////////////////////////////////////
59 //#include "CommunicationPolicy.cci"
60 //#include "CommunicationPolicy.ct"
61 #include "CommunicationPolicy.cti"
67 // c-file-style: "satcom"