• Skip to content
  • Skip to link menu
Trinity API Reference
  • Trinity API Reference
  • tdecore
 

tdecore

  • tdecore
  • network
kresolverworkerbase.h
1/*
2 * Copyright (C) 2003,2004 Thiago Macieira <thiago.macieira@kdemail.net>
3 *
4 *
5 * Permission is hereby granted, free of charge, to any person obtaining
6 * a copy of this software and associated documentation files (the
7 * "Software"), to deal in the Software without restriction, including
8 * without limitation the rights to use, copy, modify, merge, publish,
9 * distribute, sublicense, and/or sell copies of the Software, and to
10 * permit persons to whom the Software is furnished to do so, subject to
11 * the following conditions:
12 *
13 * The above copyright notice and this permission notice shall be included
14 * in all copies or substantial portions of the Software.
15 *
16 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
17 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
18 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
19 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
20 * LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
21 * OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
22 * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
23 */
24
25#ifndef KRESOLVERWORKERBASE_H
26#define KRESOLVERWORKERBASE_H
27
28#include "kresolver.h"
29
30// forward declarations
31class TQString;
32template <class T> class TQValueList;
33
34namespace KNetwork {
35
36 namespace Internal
37 {
38 class KResolverThread;
39 struct InputData;
40 }
41
60class KResolverWorkerBase
61{
62public:
63
71 class ResolverLocker
72 {
73 public:
77 ResolverLocker(KResolverWorkerBase* parent)
78 : parent( parent )
79 {
80 parent->acquireResolver();
81 }
82
86 ~ResolverLocker()
87 {
88 parent->releaseResolver();
89 }
90
96 void openClose()
97 {
98 parent->releaseResolver();
99 parent->acquireResolver();
100 }
101
102 private:
104 KResolverWorkerBase* parent;
105 };
106private:
107 // this will be like our d pointer
108 KNetwork::Internal::KResolverThread *th;
109 const KNetwork::Internal::InputData *input;
110 friend class KNetwork::Internal::KResolverThread;
111 friend class KNetwork::Internal::KResolverManager;
112 friend class KResolverWorkerBase::ResolverLocker;
113
114 int m_finished : 1;
115 int m_reserved : 31; // reserved
116
117public:
125 KResolverResults results;
126
127public:
128 // default constructor
129 KResolverWorkerBase();
130
131 // virtual destructor
132 virtual ~KResolverWorkerBase();
133
137 TQString nodeName() const;
138
142 TQString serviceName() const;
143
147 int flags() const;
148
152 int familyMask() const;
153
157 int socketType() const;
158
162 int protocol() const;
163
167 TQCString protocolName() const;
168
175 void finished();
176
177protected:
178 // like a QThread
191 virtual bool run() = 0;
192
212 virtual bool preprocess() = 0;
213
222 virtual bool postprocess();
223
227 inline void setError(int errorcode, int syserror = 0)
228 { results.setError(errorcode, syserror); }
229
245 bool enqueue(KResolver* other);
246
250 bool enqueue(KResolverWorkerBase* worker);
251
259 bool checkResolver();
260
272 void acquireResolver();
273
280 void releaseResolver();
281
282};
283
289class KResolverWorkerFactoryBase
290{
291public:
292 // default constructor
293 KResolverWorkerFactoryBase();
294
295 // virtual destructor
296 virtual ~KResolverWorkerFactoryBase();
297
298 virtual KResolverWorkerBase* create() const = 0;
299
305 static void registerNewWorker(KResolverWorkerFactoryBase* factory);
306};
307
313template<class Worker>
314class KResolverWorkerFactory: public KResolverWorkerFactoryBase
315{
316public:
317 virtual KResolverWorkerBase* create() const
318 { return new Worker; }
319};
320
321} // namespace KNetwork
322
323#endif
KNetwork::KResolverResults
Name and service resolution results.
Definition: kresolver.h:198
KNetwork::KResolverResults::setError
void setError(int errorcode, int systemerror=0)
Sets the error codes.
Definition: kresolver.cpp:259
KNetwork::KResolverWorkerBase::ResolverLocker
Helper class for locking the resolver subsystem.
Definition: kresolverworkerbase.h:72
KNetwork::KResolverWorkerBase::ResolverLocker::openClose
void openClose()
Releases the lock and then reacquires it.
Definition: kresolverworkerbase.h:96
KNetwork::KResolverWorkerBase::ResolverLocker::~ResolverLocker
~ResolverLocker()
Destructor.
Definition: kresolverworkerbase.h:86
KNetwork::KResolverWorkerBase::ResolverLocker::ResolverLocker
ResolverLocker(KResolverWorkerBase *parent)
Constructor.
Definition: kresolverworkerbase.h:77
KNetwork
A namespace to store all networking-related (socket) classes.
Definition: kbufferedsocket.h:36
KStdAction::create
TDEAction * create(StdAction id, const char *name, const TQObject *recvr, const char *slot, TDEActionCollection *parent)

tdecore

Skip menu "tdecore"
  • Main Page
  • Modules
  • Namespace List
  • Class Hierarchy
  • Alphabetical List
  • Class List
  • File List
  • Namespace Members
  • Class Members
  • Related Pages

tdecore

Skip menu "tdecore"
  • arts
  • dcop
  • dnssd
  • interfaces
  •   kspeech
  •     interface
  •     library
  •   tdetexteditor
  • kate
  • kded
  • kdoctools
  • kimgio
  • kjs
  • libtdemid
  • libtdescreensaver
  • tdeabc
  • tdecmshell
  • tdecore
  • tdefx
  • tdehtml
  • tdeinit
  • tdeio
  •   bookmarks
  •   httpfilter
  •   kpasswdserver
  •   kssl
  •   tdefile
  •   tdeio
  •   tdeioexec
  • tdeioslave
  •   http
  • tdemdi
  •   tdemdi
  • tdenewstuff
  • tdeparts
  • tdeprint
  • tderandr
  • tderesources
  • tdespell2
  • tdesu
  • tdeui
  • tdeunittest
  • tdeutils
  • tdewallet
Generated for tdecore by doxygen 1.9.4
This website is maintained by Timothy Pearson.