Quassel IRC  Pre-Release
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros
peerfactory.cpp
Go to the documentation of this file.
1 /***************************************************************************
2  * Copyright (C) 2005-2015 by the Quassel Project *
3  * devel@quassel-irc.org *
4  * *
5  * This program is free software; you can redistribute it and/or modify *
6  * it under the terms of the GNU General Public License as published by *
7  * the Free Software Foundation; either version 2 of the License, or *
8  * (at your option) version 3. *
9  * *
10  * This program is distributed in the hope that it will be useful, *
11  * but WITHOUT ANY WARRANTY; without even the implied warranty of *
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
13  * GNU General Public License for more details. *
14  * *
15  * You should have received a copy of the GNU General Public License *
16  * along with this program; if not, write to the *
17  * Free Software Foundation, Inc., *
18  * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. *
19  ***************************************************************************/
20 
21 #include "peerfactory.h"
22 
25 
26 
28 {
29  ProtoList result;
31  result.append(ProtoDescriptor(Protocol::LegacyProtocol, 0));
32  return result;
33 }
34 
35 
36 RemotePeer *PeerFactory::createPeer(const ProtoDescriptor &protocol, AuthHandler *authHandler, QTcpSocket *socket, Compressor::CompressionLevel level, QObject *parent)
37 {
38  return createPeer(ProtoList() << protocol, authHandler, socket, level, parent);
39 }
40 
41 
42 RemotePeer *PeerFactory::createPeer(const ProtoList &protocols, AuthHandler *authHandler, QTcpSocket *socket, Compressor::CompressionLevel level, QObject *parent)
43 {
44  foreach(const ProtoDescriptor &protodesc, protocols) {
45  Protocol::Type proto = protodesc.first;
46  quint16 features = protodesc.second;
47  switch(proto) {
49  return new LegacyPeer(authHandler, socket, level, parent);
51  if (DataStreamPeer::acceptsFeatures(features))
52  return new DataStreamPeer(authHandler, socket, features, level, parent);
53  break;
54  default:
55  break;
56  }
57  }
58 
59  return 0;
60 }