]> git.lyx.org Git - lyx.git/blob - src/insets/insetcaption.C
Copyright notices
[lyx.git] / src / insets / insetcaption.C
1 /**
2  * \file insetcaption.C
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  *
8  * Full author contact details are available in file CREDITS
9  */
10
11 #include <config.h>
12
13 #ifdef __GNUG__
14 #pragma implementation
15 #endif
16
17 #include "insetcaption.h"
18 #include "frontends/Painter.h"
19 #include "frontends/font_metrics.h"
20 #include "BufferView.h"
21 #include "buffer.h"
22 #include "FloatList.h"
23 #include "insets/insetfloat.h"
24 #include "debug.h"
25 #include "gettext.h"
26 #include "support/lstrings.h"
27
28 using std::ostream;
29 using std::endl;
30
31 InsetCaption::InsetCaption(BufferParams const & bp)
32         : InsetText(bp)
33 {
34         setAutoBreakRows(true);
35         setDrawFrame(0, InsetText::LOCKED);
36         setFrameColor(0, LColor::captionframe);
37 }
38
39
40 void InsetCaption::write(Buffer const * buf, ostream & os) const
41 {
42         os << "Caption\n";
43         writeParagraphData(buf, os);
44 }
45
46
47
48 void InsetCaption::read(Buffer const * buf, LyXLex & lex)
49 {
50 #if 0
51         // We will enably this check again when the compability
52         // code is removed from Buffer::Read (Lgb)
53         string const token = lex.GetString();
54         if (token != "Caption") {
55                 lyxerr << "InsetCaption::Read: consistency check failed."
56                        << endl;
57         }
58 #endif
59         InsetText::read(buf, lex);
60 }
61
62
63 string const InsetCaption::editMessage() const
64 {
65         return _("Opened Caption Inset");
66 }
67
68
69 void InsetCaption::draw(BufferView * bv, LyXFont const & f,
70                         int baseline, float & x, bool cleared) const
71 {
72         // We must draw the label, we should get the label string
73         // from the enclosing float inset.
74         // The question is: Who should draw the label, the caption inset,
75         // the text inset or the paragraph?
76         // We should also draw the float number (Lgb)
77
78         // See if we can find the name of the float this caption
79         // belongs to.
80         Inset * i1 = owner();
81         Inset * i2 = i1 ? i1->owner() : 0;
82         string const type = static_cast<InsetFloat *>(i2)->type();
83         FloatList const & floats =
84                 bv->buffer()->params.getLyXTextClass().floats();
85         string const fl = i2 ? floats.getType(type).name() : N_("Float");
86
87         // Discover the number...
88         // ...
89         string const num = "#";
90
91         // Generate the label
92         string const label = _(fl) + " " + num + ":";
93
94         Painter & pain = bv->painter();
95         int const w = font_metrics::width(label, f);
96         pain.text(int(x), baseline, label, f);
97         x += w;
98
99         InsetText::draw(bv, f, baseline, x, cleared);
100 }
101
102
103 int InsetCaption::latex(Buffer const * buf, ostream & os,
104                         bool fragile, bool free_spc) const
105 {
106         // This is a bit too simplistic to take advantage of
107         // caption options we must add more later. (Lgb)
108         // This code is currently only able to handle the simple
109         // \caption{...}, later we will make it take advantage
110         // of the one of the caption packages. (Lgb)
111         ostringstream ost;
112         int const l = InsetText::latex(buf, ost, fragile, free_spc);
113         os << "\\caption{" << ost.str() << "}\n";
114         return l + 1;
115 }
116
117
118 int InsetCaption::ascii(Buffer const * /*buf*/,
119                         ostream & /*os*/, int /*linelen*/) const
120 {
121         // FIX: Implement me!
122         return 0;
123 }
124
125
126 int InsetCaption::docbook(Buffer const * buf, ostream & os, bool mixcont) const
127 {
128         int ret;
129         os << "<title>";
130         ret = InsetText::docbook(buf, os, mixcont);
131         os << "</title>\n";
132         return ret;
133 }