summaryrefslogtreecommitdiffstats
path: root/kitchensync/src/syncprocessmanager.h
blob: 38004977d5ce57ec462253e77681df8c18cf139b (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
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
/*
    This file is part of KitchenSync.

    Copyright (c) 2005 Cornelius Schumacher <[email protected]>

    This program is free software; you can redistribute it and/or modify
    it under the terms of the GNU General Public License as published by
    the Free Software Foundation; either version 2 of the License, or
    (at your option) any later version.

    This program is distributed in the hope that it will be useful,
    but WITHOUT ANY WARRANTY; without even the implied warranty of
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
    GNU General Public License for more details.

    You should have received a copy of the GNU General Public License
    along with this program; if not, write to the Free Software
    Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
    USA.
*/
#ifndef SYNCPROCESSMANAGER_H
#define SYNCPROCESSMANAGER_H

#include <tqobject.h>

#include <libqopensync/group.h>

namespace QSync {
class GroupEnv;
class PluginEnv;
}

class SyncProcess;

class SyncProcessManager : public QObject
{
    Q_OBJECT
  public:
    static SyncProcessManager *self();

    /**
      Destroys the SyncProcessList.
     */
    ~SyncProcessManager();

    /**
      Return OpenSync GroupEnv.
    */
    QSync::GroupEnv *groupEnv() const { return mGroupEnv; }

    /**
      Return OpenSync PluginEnv.
    */
    QSync::PluginEnv *pluginEnv() const { return mPluginEnv; }

    /**
      Returns the number of SyncProcesses.
     */
    int count() const;

    /**
      Returns the SyncProcess at position @param pos.
     */
    SyncProcess* at( int pos ) const;

    /**
      Returns the SyncProcess with the given @param group.
     */
    SyncProcess* byGroup( const QSync::Group &group );

    /**
      Returns the SyncProcess with the given group @param name.
     */
    SyncProcess* byGroupName( const TQString &name );

    /**
      Adds a group with given @param name.
     */
    void addGroup( const TQString &name );

    /**
      Removes the given @param sync process.
     */
    void remove( SyncProcess *syncProcess );

    /**
      Adds @param plugin instance as member to the group of @param process.
     */
    QSync::Result addMember( SyncProcess *process, const QSync::Plugin &plugin );

    /**
      Removes the @param member from the group of @param process.
     */
    void removeMember( SyncProcess *process, const QSync::Member &member );

  signals:
    void changed();
    void syncProcessChanged( SyncProcess *process );

  private:
    SyncProcessManager();

    void initGroup( QSync::GroupEnv *groupEnv );
//    void initPlugin( QSync::PluginEnv *pluginEnv );

    TQValueList<SyncProcess*> mProcesses;
    QSync::GroupEnv *mGroupEnv;
    QSync::PluginEnv *mPluginEnv;

    static SyncProcessManager *mSelf;
};

#endif