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
114
115
116
117
118
119
|
/***************************************************************************
* Copyright (C) 2006-2007 by Rajko Albrecht *
* ral@alwins-world.de *
* *
* 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 SVNREPOSITORY_H
#define SVNREPOSITORY_H
// Ignore MSVC 7, 2005 & 2008 compiler warning: C++ exception specification
#if defined (_MSC_VER) && _MSC_VER > 1200 && _MSC_VER <= 1550
#pragma warning (disable: 4290)
#endif
#include "svnqt/exception.hpp"
#include "svnqt/revision.hpp"
#include "svnqt/svnqt_defines.hpp"
#include <qstring.h>
namespace svn {
namespace repository {
class RepositoryData;
class RepositoryListener;
//! wrapper class for subversions administrative repository functions
/*!
\author Rajko Albrecht <ral@alwins-world.de>
*/
class SVNQT_EXPORT Repository{
public:
enum LOAD_UUID {
UUID_DEFAULT_ACTION = 0,
UUID_IGNORE_ACTION = 1,
UUID_FORCE_ACTION = 2
};
//! constructor
/*!
* \param aListener callback object, the object will NOT take the ownership.
*/
Repository(svn::repository::RepositoryListener*aListener);
//! destructor
virtual ~Repository();
//! open a local repository path for maintainance
/*!
Assigns a repository with that object. If a path was opened before it will closed.
\param path Path to a local repository, must not be an url
\exception ClientException will be thrown in case of an error
*/
void Open(const QString&path) throw (ClientException);
//! Creates and open a new repository
/*!
* Creates a new repository in path with type fstype. If create succeeded open and assigns with the object.
* If a repository was opened before it will closed.
* \param path the path where to create the new repository. Must not be an url.
* \param fstype type of repository ("fsfs" or "bdb"). If wrong is set fsfs is the default.
* \param _bdbnosync disable fsync at transaction commit [Berkeley DB]
* \param _bdbautologremove enable automatic log file removal [Berkeley DB]
* \param _pre_1_4_compat Create repository compatibel to version earlier than 1.4 (only used with subversion 1.4)
*/
void CreateOpen(const QString&path, const QString&fstype, bool _bdbnosync = false,
bool _bdbautologremove = true, bool _pre_1_4_compat=false, bool _pre_1_5_compat=false) throw (ClientException);
//! dump content of repository to a file
/*!
The repository must opend before. Progress message go trough the assigned svn::repository::RepositoryListener object.
The revision parameter must be numbers, no constant values like svn::Revision::HEAD.
\param output where to output the content
\param start Begin on revision. If revision == -1 than start with first entry.
\param end End with revision. If revision == -1 than end with current head.
\param incremental dump incrementally
\param use_deltas use deltas in dump output
\exception ClientException will be thrown in case of an error
*/
void dump(const QString&output,const svn::Revision&start,const svn::Revision&end, bool incremental, bool use_deltas)throw (ClientException);
//! load a dump into repository
/*!
The repository must opened before. Progress message go trough the assigned svn::repository::RepositoryListener object.
\param dump Dumpfile to load
\param uuida what to do with UUIDs
\param parentFolder put content of dumpstream within folder in repository, if empty put into root-folder.
\param usePre use pre-commit-hook
\param usePost use post-commit-hook
\exception ClientException will be thrown in case of an error
*/
void loaddump(const QString&dump,LOAD_UUID uuida, const QString&parentFolder, bool usePre, bool usePost)throw (ClientException);
//! copy a repository to a new location
/*!
\param src the repository path to copy
\param dest where to copy
\param cleanlogs remove redundand log files from source
\exception ClientException will be thrown in case of an error
*/
static void hotcopy(const QString&src,const QString&dest,bool cleanlogs)throw (ClientException);
private:
RepositoryData*m_Data;
};
}
}
#endif
|