3 * This file is part of LyX, the document processor.
4 * Licence details can be found in the file COPYING.
7 * \author Lars Gullik Bjønnes
9 * Full author contact details are available in file CREDITS.
14 #include "InsetFoot.h"
17 // the following are needed just to get the layout of the enclosing
18 // paragraph. This seems a bit too much to me (JMarc)
20 #include "OutputParams.h"
21 #include "Paragraph.h"
22 #include "paragraph_funcs.h"
24 #include "support/std_ostream.h"
34 InsetFoot::InsetFoot(BufferParams const & bp)
41 InsetFoot::InsetFoot(InsetFoot const & in)
48 auto_ptr<Inset> InsetFoot::doClone() const
50 return auto_ptr<Inset>(new InsetFoot(*this));
54 docstring const InsetFoot::editMessage() const
56 return _("Opened Footnote Inset");
60 int InsetFoot::latex(Buffer const & buf, odocstream & os,
61 OutputParams const & runparams_in) const
63 OutputParams runparams = runparams_in;
64 // footnotes in titling commands like \title have moving arguments
65 runparams.moving_arg |= runparams_in.intitle;
67 // in titling commands, \thanks should be used instead of \footnote.
68 // some classes (e.g. memoir) do not understand \footnote.
69 if (runparams_in.intitle)
72 os << "%\n\\footnote{";
74 int const i = InsetText::latex(buf, os, runparams);
76 runparams_in.encoding = runparams.encoding;
82 int InsetFoot::plaintext(Buffer const & buf, odocstream & os,
83 OutputParams const & runparams) const
85 os << '[' << _("footnote") << ":\n";
86 InsetText::plaintext(buf, os, runparams);
89 return PLAINTEXT_NEWLINE + 1; // one char on a separate line
93 int InsetFoot::docbook(Buffer const & buf, odocstream & os,
94 OutputParams const & runparams) const
97 int const i = InsetText::docbook(buf, os, runparams);