tex2lyx: support the command \colorbox

support for \fcolorbox will follow soon
This commit is contained in:
Uwe Stöhr 2015-05-17 17:26:51 +02:00
parent b7c53b6017
commit 92b7ee46ed
3 changed files with 69 additions and 8 deletions

View File

@ -83,7 +83,7 @@ Format LaTeX feature LyX feature
\twocolumn[]{}{} Layout Twocolumn, InsetArgument
\item[]<> InsetArgument
\begin{enumerate|itemize|...}[] InsetArgument
492 commands \fcolorbox and \colorbox InsetBox
492 command \fcolorbox InsetBox
General

View File

@ -157,6 +157,18 @@ blabla \doublebox{doublebox} blabla
$\boxed{\int A=B}$
\subsection{Color Boxes}
\colorbox{blue}{www}
\colorbox{blue}{\begin{minipage}[t]{0.9\columnwidth}
www
\end{minipage}}
\colorbox{blue}{\parbox[t]{0.9\columnwidth}{www}}
\colorbox{blue}{\makebox[0.9\columnwidth][l]{www}}
\subsection{LyX Boxes}
\begin{lyxgreyedout}

View File

@ -832,7 +832,8 @@ bool parse_command(string const & command, Parser & p, ostream & os,
void parse_box(Parser & p, ostream & os, unsigned outer_flags,
unsigned inner_flags, bool outer, Context & parent_context,
string const & outer_type, string const & special,
string const & inner_type)
string inner_type, string const & frame_color,
string const & background_color)
{
string position;
string inner_pos;
@ -852,6 +853,44 @@ void parse_box(Parser & p, ostream & os, unsigned outer_flags,
string shadowsize = "4pt";
string framecolor = "black";
string backgroundcolor = "none";
if (frame_color != "")
framecolor = frame_color;
if (background_color != "")
backgroundcolor = background_color;
// if there is a color box around the \begin statements have not yet been parsed
// so do this now
if (frame_color != "" || background_color != "") {
eat_whitespace(p, os, parent_context, false);
p.get_token().asInput(); // the '{'
// parse minipage
if (p.next_token().asInput() == "\\begin") {
p.get_token().asInput();
p.getArg('{', '}');
inner_type = "minipage";
inner_flags = FLAG_END;
}
// parse parbox
else if (p.next_token().asInput() == "\\parbox") {
p.get_token().asInput();
inner_type = "parbox";
inner_flags = FLAG_ITEM;
}
// parse makebox
else if (p.next_token().asInput() == "\\makebox") {
p.get_token().asInput();
inner_type = "makebox";
inner_flags = FLAG_ITEM;
}
// in case there is just \colorbox{color}{text}
else {
latex_width = "";
inner_type = "makebox";
inner_flags = FLAG_BRACE_LAST;
hor_pos = "l";
position = "t";
inner_pos = "t";
}
}
if (!inner_type.empty() && p.hasOpt()) {
if (inner_type != "makebox")
position = p.getArg('[', ']');
@ -963,7 +1002,7 @@ void parse_box(Parser & p, ostream & os, unsigned outer_flags,
// if only \makebox{content} was used we can set its width to 1\width
// because this identic and also identic to \mbox
// this doesn't work for \framebox{content}, thus we have to use ERT for this
if (latex_width.empty() && inner_type == "makebox") {
if (latex_width.empty() && inner_type == "makebox" && background_color == "") {
width_value = "1";
width_unit = "in";
width_special = "width";
@ -1142,6 +1181,10 @@ void parse_box(Parser & p, ostream & os, unsigned outer_flags,
}
#endif
}
if (background_color != "") {
// in this case we have to eat the the closing brace of the color box
p.get_token().asInput(); // the '}'
}
}
@ -1204,14 +1247,14 @@ void parse_outer_box(Parser & p, ostream & os, unsigned flags, bool outer,
eat_whitespace(p, os, parent_context, false);
}
parse_box(p, os, flags, FLAG_END, outer, parent_context,
outer_type, special, inner);
outer_type, special, inner, "", "");
} else {
if (inner_flags == FLAG_ITEM) {
p.get_token();
eat_whitespace(p, os, parent_context, false);
}
parse_box(p, os, flags, inner_flags, outer, parent_context,
outer_type, special, inner);
outer_type, special, inner, "", "");
}
}
@ -1446,7 +1489,7 @@ void parse_environment(Parser & p, ostream & os, bool outer,
parent_context, name, "shaded");
else
parse_box(p, os, 0, FLAG_END, outer, parent_context,
"", "", name);
"", "", name, "", "");
p.skip_spaces();
}
@ -4144,7 +4187,8 @@ void parse_text(Parser & p, ostream & os, unsigned flags, bool outer,
parse_outer_box(p, os, FLAG_ITEM, outer,
context, "parbox", "shaded");
} else
parse_box(p, os, 0, FLAG_ITEM, outer, context, "", "", t.cs());
parse_box(p, os, 0, FLAG_ITEM, outer, context,
"", "", t.cs(), "", "");
}
else if (t.cs() == "fbox" || t.cs() == "mbox" ||
@ -4152,6 +4196,11 @@ void parse_text(Parser & p, ostream & os, unsigned flags, bool outer,
t.cs() == "shadowbox" || t.cs() == "doublebox")
parse_outer_box(p, os, FLAG_ITEM, outer, context, t.cs(), "");
else if (t.cs() == "colorbox") {
string const backgroundcolor = p.getArg('{', '}');
parse_box(p, os, 0, 0, outer, context, "", "", "", "", backgroundcolor);
}
//\framebox() is part of the picture environment and different from \framebox{}
//\framebox{} will be parsed by parse_outer_box
else if (t.cs() == "framebox") {
@ -4188,7 +4237,7 @@ void parse_text(Parser & p, ostream & os, unsigned flags, bool outer,
} else
//the syntax is: \makebox[width][position]{content}
parse_box(p, os, 0, FLAG_ITEM, outer, context,
"", "", t.cs());
"", "", t.cs(), "", "");
}
else if (t.cs() == "smallskip" ||