blob: 0a34cafaa91001bc736ebe6cc4ec7be9c76ffae3 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
|
/*
task.h - Kopete Groupwise Protocol
Copyright (c) 2004 SUSE Linux AG http://www.suse.com
Based on Iris, Copyright (C) 2003 Justin Karneges
Kopete (c) 2002-2004 by the Kopete developers <[email protected]>
*************************************************************************
* *
* This library is free software; you can redistribute it and/or *
* modify it under the terms of the GNU Lesser General Public *
* License as published by the Free Software Foundation; either *
* version 2 of the License, or (at your option) any later version. *
* *
*************************************************************************
*/
#ifndef GW_TASK_H
#define GW_TASK_H
#include <qobject.h>
#include "gwerror.h"
#include "gwfield.h"
#include "transfer.h"
class Client;
class Request;
class Task : public QObject
{
Q_OBJECT
public:
enum { ErrDisc };
Task(Task *parent);
Task( Client *, bool isRoot );
virtual ~Task();
Task *parent() const;
Client *client() const;
Transfer *transfer() const;
QString id() const;
bool success() const;
int statusCode() const;
const QString & statusString() const;
void go( bool autoDelete=false );
/**
* Allows a task to examine an incoming Transfer and decide whether to 'take' it
* for further processing.
*/
virtual bool take( Transfer* transfer );
void safeDelete();
signals:
void finished();
protected:
virtual void onGo();
virtual void onDisconnect();
void send( Request * request );
void setSuccess( int code=0, const QString &str="" );
/**
* If an empty string is passed, this sets the error string based on the error code using GroupWise::errorCodeToString
*/
void setError( int code=0, const QString &str="" );
// void debug( const char *, ... );
void debug( const QString & );
/**
* Used in take() to check if the offered transfer is for this Task
* @return true if this Task should take the Transfer. Default impl always returns false.
*/
virtual bool forMe( const Transfer * transfer ) const;
/**
* Creates a transfer with the given command and field list
*/
void createTransfer( const QString & command, const Field::FieldList fields );
/**
* Direct setter for Tasks which don't have any fields
*/
void setTransfer( Transfer * transfer );
private slots:
void clientDisconnected();
void done();
private:
void init();
class TaskPrivate;
TaskPrivate *d;
};
#endif
|