#include "FuncStatus.h"
#include "InsetCaption.h"
#include "Language.h"
-#include "MetricsInfo.h"
+#include "LaTeXFeatures.h"
+#include "Lexer.h"
#include "output_latex.h"
#include "output_xhtml.h"
+#include "OutputParams.h"
#include "TextClass.h"
#include "support/debug.h"
#include "frontends/alert.h"
#include "frontends/Application.h"
-#include <boost/regex.hpp>
+#include "support/regex.h"
#include <sstream>
namespace lyx {
-using boost::regex;
char const lstinline_delimiters[] =
"!*()-=+|;:'\"`,<.>/?QWERTYUIOPASDFGHJKLZXCVBNMqwertyuiopasdfghjklzxcvbnm";
}
-void InsetListings::updateLabels(ParIterator const & it, bool out)
+void InsetListings::updateBuffer(ParIterator const & it, UpdateType utype)
{
- Counters & cnts = buffer().masterBuffer()->params().documentClass().counters();
+ Counters & cnts =
+ buffer().masterBuffer()->params().documentClass().counters();
string const saveflt = cnts.current_float();
// Tell to captions what the current float is
cnts.current_float("listing");
- InsetCollapsable::updateLabels(it, out);
+ InsetCollapsable::updateBuffer(it, utype);
//reset afterwards
cnts.current_float(saveflt);
}
-int InsetListings::latex(odocstream & os, OutputParams const & runparams) const
+void InsetListings::latex(otexstream & os, OutputParams const & runparams) const
{
string param_string = params().params();
// NOTE: I use {} to quote text, which is an experimental feature
// of the listings package (see page 25 of the manual)
- int lines = 0;
bool const isInline = params().isInline();
// get the paragraphs. We can not output them directly to given odocstream
// because we can not yet determine the delimiter character of \lstinline
bool encoding_switched = false;
Encoding const * const save_enc = runparams.encoding;
- if (!runparams.encoding->hasFixedWidth()) {
- // We need to switch to a singlebyte encoding, since the listings
- // package cannot deal with multiple-byte-encoded glyphs
+ if (!runparams.isFullUnicode()
+ && !runparams.encoding->hasFixedWidth()) {
+ // We need to switch to a singlebyte encoding, since the
+ // listings package cannot deal with multi-byte-encoded
+ // glyphs (not needed with full-unicode aware backends
+ // such as XeTeX).
Language const * const outer_language =
(runparams.local_font != 0) ?
runparams.local_font->language()
(outer_language->encoding()->hasFixedWidth()) ?
outer_language->encoding()
: encodings.fromLyXName("iso8859-1");
- pair<bool, int> const c = switchEncoding(os, buffer().params(),
- runparams, *lstenc, true);
+ switchEncoding(os.os(), buffer().params(), runparams, *lstenc, true);
runparams.encoding = lstenc;
encoding_switched = true;
}
++par;
// for the inline case, if there are multiple paragraphs
// they are simply joined. Otherwise, expect latex errors.
- if (par != end && !isInline && !captionline) {
+ if (par != end && !isInline && !captionline)
code += "\n";
- ++lines;
- }
}
if (isInline) {
char const * delimiter = lstinline_delimiters;
rp.moving_arg = true;
docstring const caption = getCaption(rp);
if (param_string.empty() && caption.empty())
- os << "\n\\begin{lstlisting}\n";
+ os << breakln << "\\begin{lstlisting}\n";
else {
- os << "\n\\begin{lstlisting}[";
+ os << breakln << "\\begin{lstlisting}[";
if (!caption.empty()) {
os << "caption={" << caption << '}';
if (!param_string.empty())
}
os << from_utf8(param_string) << "]\n";
}
- lines += 2;
- os << code << "\n\\end{lstlisting}\n";
- lines += 2;
+ os << code << breakln << "\\end{lstlisting}\n";
}
if (encoding_switched){
// Switch back
- pair<bool, int> const c = switchEncoding(os, buffer().params(),
- runparams, *save_enc, true);
+ switchEncoding(os.os(), buffer().params(), runparams, *save_enc, true);
runparams.encoding = save_enc;
}
"not representable in the current encoding and have been omitted:\n%1$s."),
uncodable));
}
-
- return lines;
}
bool const isInline = params().isInline();
if (isInline)
- out << CompTag("br");
+ out << html::CompTag("br");
else {
- out << StartTag("div", "class='float float-listings'");
+ out << html::StartTag("div", "class='float float-listings'");
docstring caption = getCaptionHTML(rp);
if (!caption.empty())
- out << StartTag("div", "class='float-caption'")
- << caption << EndTag("div");
+ out << html::StartTag("div", "class='float-caption'")
+ << caption << html::EndTag("div");
}
- out << StartTag("pre");
+ out << html::StartTag("pre");
OutputParams newrp = rp;
newrp.html_disable_captions = true;
- docstring def = InsetText::xhtml(out, newrp);
- out << EndTag("pre");
+ docstring def = InsetText::insetAsXHTML(out, newrp, InsetText::JustText);
+ out << html::EndTag("pre");
if (isInline) {
- out << CompTag("br");
+ out << html::CompTag("br");
// escaping will already have been done
- os << XHTMLStream::NextRaw() << ods.str();
+ os << XHTMLStream::ESCAPE_NONE << ods.str();
} else {
- out << EndTag("div");
+ out << html::EndTag("div");
// In this case, this needs to be deferred, but we'll put it
// before anything the text itself deferred.
def = ods.str() + '\n' + def;
}
-docstring InsetListings::contextMenu(BufferView const &, int, int) const
+string InsetListings::contextMenuName() const
{
- return from_ascii("context-listings");
+ return "context-listings";
}
void InsetListings::doDispatch(Cursor & cur, FuncRequest & cmd)
{
- switch (cmd.action) {
+ switch (cmd.action()) {
case LFUN_INSET_MODIFY: {
+ cur.recordUndoInset(ATOMIC_UNDO, this);
InsetListings::string2params(to_utf8(cmd.argument()), params());
break;
}
bool InsetListings::getStatus(Cursor & cur, FuncRequest const & cmd,
FuncStatus & status) const
{
- switch (cmd.action) {
+ switch (cmd.action()) {
case LFUN_INSET_MODIFY:
case LFUN_INSET_DIALOG_UPDATE:
status.setEnabled(true);
if (ins == 0)
return docstring();
+ TexRow texrow;
odocstringstream ods;
- ins->getOptArg(ods, runparams);
- ins->getArgument(ods, runparams);
+ otexstream os(ods, texrow);
+ ins->getOptArg(os, runparams);
+ ins->getArgument(os, runparams);
// the caption may contain \label{} but the listings
// package prefer caption={}, label={}
docstring cap = ods.str();