]> git.lyx.org Git - lyx.git/blob - src/LyXVC.cpp
scanLog for checkout svn in VCS.
[lyx.git] / src / LyXVC.cpp
1 /**
2  * \file LyXVC.cpp
3  * This file is part of LyX, the document processor.
4  * Licence details can be found in the file COPYING.
5  *
6  * \author Lars Gullik Bjønnes
7  * \author Jean-Marc Lasgouttes
8  * \author Angus Leeming
9  * \author John Levon
10  * \author André Pönitz
11  * \author Allan Rae
12  *
13  * Full author contact details are available in file CREDITS.
14  */
15
16 #include <config.h>
17
18 #include "LyXVC.h"
19 #include "VCBackend.h"
20 #include "Buffer.h"
21
22 #include "frontends/alert.h"
23
24 #include "support/debug.h"
25 #include "support/filetools.h"
26 #include "support/gettext.h"
27 #include "support/lstrings.h"
28
29 using namespace std;
30 using namespace lyx::support;
31
32 namespace lyx {
33
34 namespace Alert = frontend::Alert;
35
36
37 LyXVC::LyXVC()
38 {
39         owner_ = 0;
40 }
41
42
43 // for the sake of boost::scoped_ptr
44 LyXVC::~LyXVC()
45 {}
46
47
48 bool LyXVC::file_found_hook(FileName const & fn)
49 {
50         FileName found_file;
51         // Check if file is under RCS
52         if (!(found_file = RCS::findFile(fn)).empty()) {
53                 vcs.reset(new RCS(found_file));
54                 vcs->owner(owner_);
55                 return true;
56         }
57         // Check if file is under CVS
58         if (!(found_file = CVS::findFile(fn)).empty()) {
59                 vcs.reset(new CVS(found_file, fn));
60                 vcs->owner(owner_);
61                 return true;
62         }
63         // Check if file is under SVN
64         if (!(found_file = SVN::findFile(fn)).empty()) {
65                 vcs.reset(new SVN(found_file, fn));
66                 vcs->owner(owner_);
67                 return true;
68         }
69
70         // file is not under any VCS.
71         return false;
72 }
73
74
75 bool LyXVC::file_not_found_hook(FileName const & fn)
76 {
77         // Check if file is under RCS.
78         // This happens if we are trying to load non existent
79         // file on disk, but existent in ,v version.
80         // Seems there is no reasonable scenario for adding implementation
81         // of retrieve for cvs or svn.
82         if (!RCS::findFile(fn).empty())
83                 return true;
84         return false;
85 }
86
87
88 void LyXVC::setBuffer(Buffer * buf)
89 {
90         owner_ = buf;
91 }
92
93
94 void LyXVC::registrer()
95 {
96         FileName const filename = owner_->fileName();
97
98         // there must be a file to save
99         if (!filename.isReadableFile()) {
100                 Alert::error(_("Document not saved"),
101                              _("You must save the document "
102                                             "before it can be registered."));
103                 return;
104         }
105
106         // it is very likely here that the vcs is not created yet...
107         if (!vcs) {
108                 //check in the root directory of the document
109                 FileName const cvs_entries(onlyPath(filename.absFilename()) + "/CVS/Entries");
110                 FileName const svn_entries(onlyPath(filename.absFilename()) + "/.svn/entries");
111
112                 if (svn_entries.isReadableFile()) {
113                         LYXERR(Debug::LYXVC, "LyXVC: registering "
114                                 << to_utf8(filename.displayName()) << " with SVN");
115                         vcs.reset(new SVN(cvs_entries, filename));
116
117                 } else if (cvs_entries.isReadableFile()) {
118                         LYXERR(Debug::LYXVC, "LyXVC: registering "
119                                 << to_utf8(filename.displayName()) << " with CVS");
120                         vcs.reset(new CVS(cvs_entries, filename));
121
122                 } else {
123                         LYXERR(Debug::LYXVC, "LyXVC: registering "
124                                 << to_utf8(filename.displayName()) << " with RCS");
125                         vcs.reset(new RCS(filename));
126                 }
127
128                 vcs->owner(owner_);
129         }
130
131         LYXERR(Debug::LYXVC, "LyXVC: registrer");
132         docstring response;
133         bool ok = Alert::askForText(response, _("LyX VC: Initial description"),
134                         _("(no initial description)"));
135         if (!ok || response.empty()) {
136                 // should we insist on checking response.empty()?
137                 LYXERR(Debug::LYXVC, "LyXVC: user cancelled");
138                 return;
139         }
140
141         vcs->registrer(to_utf8(response));
142 }
143
144
145 void LyXVC::checkIn()
146 {
147         LYXERR(Debug::LYXVC, "LyXVC: checkIn");
148         docstring response;
149         bool ok = Alert::askForText(response, _("LyX VC: Log Message"));
150         if (ok) {
151                 if (response.empty())
152                         response = _("(no log message)");
153                 vcs->checkIn(to_utf8(response));
154         } else {
155                 LYXERR(Debug::LYXVC, "LyXVC: user cancelled");
156         }
157 }
158
159
160 void LyXVC::checkOut()
161 {
162         //RCS allows checkOut only in ReadOnly mode
163         if (vcs->toggleReadOnlyEnabled() && !owner_->isReadonly()) return;
164
165         LYXERR(Debug::LYXVC, "LyXVC: checkOut");
166         vcs->checkOut();
167 }
168
169
170 void LyXVC::revert()
171 {
172         LYXERR(Debug::LYXVC, "LyXVC: revert");
173
174         docstring const file = owner_->fileName().displayName(20);
175         docstring text = bformat(_("Reverting to the stored version of the "
176                                 "document %1$s will lose all current changes.\n\n"
177                                 "Do you want to revert to the older version?"), file);
178         int const ret = Alert::prompt(_("Revert to stored version of document?"),
179                 text, 0, 1, _("&Revert"), _("&Cancel"));
180
181         if (ret == 0)
182                 vcs->revert();
183 }
184
185
186 void LyXVC::undoLast()
187 {
188         vcs->undoLast();
189 }
190
191
192 void LyXVC::toggleReadOnly()
193 {
194         if (!vcs->toggleReadOnlyEnabled())
195                 return;
196
197         switch (vcs->status()) {
198         case VCS::UNLOCKED:
199                 LYXERR(Debug::LYXVC, "LyXVC: toggle to locked");
200                 checkOut();
201                 break;
202         case VCS::LOCKED:
203                 LYXERR(Debug::LYXVC, "LyXVC: toggle to unlocked");
204                 checkIn();
205                 break;
206         }
207 }
208
209
210 bool LyXVC::inUse()
211 {
212         if (vcs)
213                 return true;
214         return false;
215 }
216
217
218 //string const & LyXVC::version() const
219 //{
220 //      return vcs->version();
221 //}
222
223
224 string const LyXVC::versionString() const
225 {
226         return vcs->versionString();
227 }
228
229
230 string const & LyXVC::locker() const
231 {
232         return vcs->locker();
233 }
234
235
236 string const LyXVC::getLogFile() const
237 {
238         if (!vcs)
239                 return string();
240
241         FileName const tmpf = FileName::tempName("lyxvclog");
242         if (tmpf.empty()) {
243                 LYXERR(Debug::LYXVC, "Could not generate logfile " << tmpf);
244                 return string();
245         }
246         LYXERR(Debug::LYXVC, "Generating logfile " << tmpf);
247         vcs->getLog(tmpf);
248         return tmpf.absFilename();
249 }
250
251
252 bool LyXVC::checkOutEnabled()
253 {
254         return vcs && vcs->checkOutEnabled();
255 }
256
257
258 bool LyXVC::checkInEnabled()
259 {
260         return vcs && vcs->checkInEnabled();
261 }
262
263
264 bool LyXVC::undoLastEnabled()
265 {
266         return vcs && vcs->undoLastEnabled();
267 }
268
269
270 } // namespace lyx