]> git.lyx.org Git - lyx.git/blob - src/frontends/controllers/ControlDocument.C
prefs/tabular MVC work
[lyx.git] / src / frontends / controllers / ControlDocument.C
1 // -*- C++ -*-
2 /**
3  * \file ControlDocument.C
4  * This file is part of LyX, the document processor.
5  * Licence details can be found in the file COPYING.
6  *
7  * \author Edwin Leuven
8  *
9  * Full author contact details are available in file CREDITS
10  */
11
12 #include <config.h>
13
14 #ifdef __GNUG__
15 #pragma implementation
16 #endif
17
18 #include "BufferView.h"
19 #include "ControlDocument.h"
20 #include "ViewBase.h"
21
22 #include "gettext.h"
23 #include "lyxfind.h"
24
25 #include "buffer.h"
26 #include "language.h"
27 #include "lyx_main.h"
28 #include "lyxtextclass.h"
29 #include "lyxtextclasslist.h"
30 #include "CutAndPaste.h"
31
32 #include "frontends/LyXView.h"
33 #include "frontends/Alert.h"
34
35 #include "support/lstrings.h"
36 #include "support/filetools.h"
37
38
39 ControlDocument::ControlDocument(LyXView & lv, Dialogs & d)
40         : ControlDialogBD(lv, d), bp_(0)
41 {
42 }
43
44 ControlDocument::~ControlDocument()
45 {}
46
47
48 BufferParams & ControlDocument::params()
49 {
50         lyx::Assert(bp_.get());
51         return *bp_;
52 }
53
54
55 LyXTextClass ControlDocument::textClass()
56 {
57         return textclasslist[bp_->textclass];
58 }
59
60
61 void ControlDocument::apply()
62 {
63         if (!bufferIsAvailable())
64                 return;
65
66         setLanguage();
67
68         // FIXME: do we need to use return value from classApply() here? (Lgb)
69         classApply();
70
71         view().apply();
72         buffer()->params = *bp_;
73         
74         lv_.view()->redoCurrentBuffer();
75
76         buffer()->markDirty();
77
78         lv_.message(_("Document settings applied"));
79 }
80
81
82 void ControlDocument::setParams()
83 {
84         if (!bp_.get())
85                 bp_.reset(new BufferParams());
86
87         /// Set the buffer parameters
88         *bp_ = buffer()->params;
89 }
90
91
92 void ControlDocument::setLanguage()
93 {
94         Language const * oldL = buffer()->params.language;
95         Language const * newL = bp_->language;
96
97         if (oldL != newL
98             && oldL->RightToLeft() == newL->RightToLeft()
99             && !lv_.buffer()->isMultiLingual())
100                 lv_.buffer()->changeLanguage(oldL, newL);
101 }
102
103
104 bool ControlDocument::classApply()
105 {
106         BufferParams & params = buffer()->params;
107         unsigned int const old_class = params.textclass;
108         unsigned int const new_class = bp_->textclass;
109
110         // exit if nothing changes
111         if (new_class == old_class) {
112                  return true;
113         }
114
115         // try to load new_class
116         if (!textclasslist[new_class].load()) {
117                 // problem changing class
118                 // -- warn user (to retain old style)
119                 Alert::alert(_("Conversion Errors!"),
120                              _("Errors loading new document class."),
121                              _("Reverting to original document class."));
122                 return false;
123         }
124
125         // successfully loaded
126         view().apply();
127         buffer()->params = *bp_;
128         lv_.message(_("Converting document to new document class..."));
129         int ret = CutAndPaste::SwitchLayoutsBetweenClasses(
130                 old_class, new_class,
131                 &*(lv_.buffer()->paragraphs.begin()),
132                 lv_.buffer()->params);
133         if (ret) {
134                 string s;
135                 if (ret == 1) {
136                         s = _("One paragraph couldn't be converted");
137                 } else {
138                         s += tostr(ret);
139                         s += _(" paragraphs couldn't be converted");
140                 }
141                 Alert::alert(_("Conversion Errors!"),s,
142                              _("into chosen document class"));
143         }
144         return true;
145 }
146
147
148 void ControlDocument::saveAsDefault()
149 {
150         if (!Alert::askQuestion(_("Do you want to save the current settings"),
151                                 _("for the document layout as default?"),
152                                 _("(they will be valid for any new document)")))
153                 return;
154                 
155         lv_.buffer()->params.preamble = bp_->preamble;
156
157         string const fname = AddName(AddPath(user_lyxdir, "templates/"),
158                                      "defaults.lyx");
159         Buffer defaults(fname);
160         defaults.params = params();
161
162         // add an empty paragraph. Is this enough?
163         Paragraph * par = new Paragraph;
164         par->layout(params().getLyXTextClass().defaultLayout());
165         defaults.paragraphs.set(par);
166
167         defaults.writeFile(defaults.fileName());
168
169 }