mirror of
https://git.lyx.org/repos/lyx.git
synced 2025-01-04 16:42:57 +00:00
fix lyxalgo.h, dra pagebreak with text on line, change the math_deco_search a bit
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@597 a592a061-630c-0410-9148-cb99ea01b6c8
This commit is contained in:
parent
8dbf9d296e
commit
fa492d6bf0
16
ChangeLog
16
ChangeLog
@ -1,3 +1,19 @@
|
||||
2000-03-10 Lars Gullik Bjønnes <larsbj@lyx.org>
|
||||
|
||||
* src/mathed/math_delim.C (search_deco): return a
|
||||
math_deco_struct* instead of index.
|
||||
|
||||
2000-03-09 Lars Gullik Bjønnes <larsbj@lyx.org>
|
||||
|
||||
* All files with a USE_OSTREAM_ONLY within: removed all code that
|
||||
was unused when USE_OSTREAM_ONLY is defined.
|
||||
|
||||
* src/support/lyxalgo.h (sorted): rewrote to use plain '<' instead
|
||||
of any less. Removed header and using.
|
||||
|
||||
* src/text.C (GetVisibleRow): draw the string "Page Break
|
||||
(top/bottom)" on screen when drawing a pagebreak line.
|
||||
|
||||
2000-03-09 Jean-Marc Lasgouttes <Jean-Marc.Lasgouttes@inria.fr>
|
||||
|
||||
* lib/doc/LaTeXConfig.lyx.in: add description of textclass llncs.
|
||||
|
@ -184,7 +184,7 @@ dnl Check the version of g++
|
||||
elif test $ac_cv_prog_cxx_g = yes; then
|
||||
case $gxx_version in
|
||||
2.95.1) CXXFLAGS="-g $lyx_opt -fpermissive -fno-rtti -fno-exceptions";;
|
||||
2.95.*) CXXFLAGS="-g $lyx_opt -fno-rtti -fno-exceptions";;
|
||||
2.95.*) CXXFLAGS="-g $lyx_opt";;
|
||||
2.96*) CXXFLAGS="-g $lyx_opt -fno-rtti -fno-exceptions";;
|
||||
*2.91.*) CXXFLAGS="-g $lyx_opt -fno-rtti -fno-exceptions";;
|
||||
*) CXXFLAGS="-g $lyx_opt -fno-rtti -fno-exceptions";;
|
||||
|
@ -25,6 +25,7 @@ src/form1.C
|
||||
src/gettext.h
|
||||
src/insets/figinset.C
|
||||
src/insets/figinset.h
|
||||
src/insets/form_graphics.C
|
||||
src/insets/form_url.C
|
||||
src/insets/insetbib.C
|
||||
src/insets/inseterror.C
|
||||
@ -32,6 +33,7 @@ src/insets/inseterror.h
|
||||
src/insets/insetert.C
|
||||
src/insets/insetert.h
|
||||
src/insets/insetfoot.C
|
||||
src/insets/insetgraphics.C
|
||||
src/insets/insetinclude.C
|
||||
src/insets/insetindex.C
|
||||
src/insets/insetinfo.C
|
||||
|
690
src/buffer.C
690
src/buffer.C
@ -1576,7 +1576,6 @@ void Buffer::writeFileAscii(string const & fname, int linelen)
|
||||
}
|
||||
|
||||
|
||||
#ifdef USE_OSTREAM_ONLY
|
||||
void Buffer::makeLaTeXFile(string const & fname,
|
||||
string const & original_path,
|
||||
bool nice, bool only_body)
|
||||
@ -2108,531 +2107,6 @@ void Buffer::makeLaTeXFile(string const & fname,
|
||||
|
||||
lyxerr.debug() << "Finished making latex file." << endl;
|
||||
}
|
||||
#else
|
||||
void Buffer::makeLaTeXFile(string const & fname,
|
||||
string const & original_path,
|
||||
bool nice, bool only_body)
|
||||
{
|
||||
lyxerr[Debug::LATEX] << "makeLaTeXFile..." << endl;
|
||||
|
||||
niceFile = nice; // this will be used by Insetincludes.
|
||||
|
||||
tex_code_break_column = lyxrc->ascii_linelen;
|
||||
|
||||
LyXTextClass const & tclass =
|
||||
textclasslist.TextClass(params.textclass);
|
||||
|
||||
ofstream ofs(fname.c_str());
|
||||
if (!ofs) {
|
||||
WriteFSAlert(_("Error: Cannot open file: "), fname);
|
||||
return;
|
||||
}
|
||||
|
||||
// validate the buffer.
|
||||
lyxerr[Debug::LATEX] << " Validating buffer..." << endl;
|
||||
LaTeXFeatures features(tclass.numLayouts());
|
||||
validate(features);
|
||||
lyxerr[Debug::LATEX] << " Buffer validation done." << endl;
|
||||
|
||||
texrow.reset();
|
||||
// The starting paragraph of the coming rows is the
|
||||
// first paragraph of the document. (Asger)
|
||||
texrow.start(paragraph, 0);
|
||||
|
||||
string LFile;
|
||||
|
||||
if (!only_body && nice) {
|
||||
LFile += "%% " LYX_DOCVERSION " created this file. "
|
||||
"For more info, see http://www.lyx.org/.\n";
|
||||
LFile += "%% Do not edit unless you really know what you are doing.\n";
|
||||
texrow.newline();
|
||||
texrow.newline();
|
||||
}
|
||||
lyxerr.debug() << "lyx header finished" << endl;
|
||||
// There are a few differences between nice LaTeX and usual files:
|
||||
// usual is \batchmode and has a
|
||||
// special input@path to allow the including of figures
|
||||
// with either \input or \includegraphics (what figinsets do).
|
||||
// batchmode is not set if there is a tex_code_break_column.
|
||||
// In this case somebody is interested in the generated LaTeX,
|
||||
// so this is OK. input@path is set when the actual parameter
|
||||
// original_path is set. This is done for usual tex-file, but not
|
||||
// for nice-latex-file. (Matthias 250696)
|
||||
if (!only_body) {
|
||||
if (!nice){
|
||||
// code for usual, NOT nice-latex-file
|
||||
LFile += "\\batchmode\n"; // changed
|
||||
// from \nonstopmode
|
||||
texrow.newline();
|
||||
}
|
||||
if (!original_path.empty()) {
|
||||
LFile += "\\makeatletter\n";
|
||||
texrow.newline();
|
||||
LFile += "\\def\\input@path{{" + original_path
|
||||
+ "/}}\n";
|
||||
texrow.newline();
|
||||
LFile += "\\makeatother\n";
|
||||
texrow.newline();
|
||||
}
|
||||
|
||||
LFile += "\\documentclass";
|
||||
|
||||
string options; // the document class options.
|
||||
|
||||
if (tokenPos(tclass.opt_fontsize(), '|', params.fontsize) >= 0) {
|
||||
// only write if existing in list (and not default)
|
||||
options += params.fontsize;
|
||||
options += "pt,";
|
||||
}
|
||||
|
||||
|
||||
if (!params.use_geometry &&
|
||||
(params.paperpackage == BufferParams::PACKAGE_NONE)) {
|
||||
switch (params.papersize) {
|
||||
case BufferParams::PAPER_A4PAPER:
|
||||
options += "a4paper,";
|
||||
break;
|
||||
case BufferParams::PAPER_USLETTER:
|
||||
options += "letterpaper,";
|
||||
break;
|
||||
case BufferParams::PAPER_A5PAPER:
|
||||
options += "a5paper,";
|
||||
break;
|
||||
case BufferParams::PAPER_B5PAPER:
|
||||
options += "b5paper,";
|
||||
break;
|
||||
case BufferParams::PAPER_EXECUTIVEPAPER:
|
||||
options += "executivepaper,";
|
||||
break;
|
||||
case BufferParams::PAPER_LEGALPAPER:
|
||||
options += "legalpaper,";
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
// if needed
|
||||
if (params.sides != tclass.sides()) {
|
||||
switch (params.sides) {
|
||||
case LyXTextClass::OneSide:
|
||||
options += "oneside,";
|
||||
break;
|
||||
case LyXTextClass::TwoSides:
|
||||
options += "twoside,";
|
||||
break;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
// if needed
|
||||
if (params.columns != tclass.columns()) {
|
||||
if (params.columns == 2)
|
||||
options += "twocolumn,";
|
||||
else
|
||||
options += "onecolumn,";
|
||||
}
|
||||
|
||||
if (!params.use_geometry
|
||||
&& params.orientation == BufferParams::ORIENTATION_LANDSCAPE)
|
||||
options += "landscape,";
|
||||
|
||||
// language should be a parameter to \documentclass
|
||||
if (params.language != "default") {
|
||||
if (params.language == "hebrew")
|
||||
options += "english,";
|
||||
else if (lyxrc->rtl_support)
|
||||
options += "hebrew,";
|
||||
options += params.language + ',';
|
||||
} else if (lyxrc->rtl_support)
|
||||
options += "hebrew,english,";
|
||||
|
||||
// the user-defined options
|
||||
if (!params.options.empty()) {
|
||||
options += params.options + ',';
|
||||
}
|
||||
|
||||
if (!options.empty()){
|
||||
options = strip(options, ',');
|
||||
LFile += '[';
|
||||
LFile += options;
|
||||
LFile += ']';
|
||||
}
|
||||
|
||||
LFile += '{';
|
||||
LFile += textclasslist.LatexnameOfClass(params.textclass);
|
||||
LFile += "}\n";
|
||||
texrow.newline();
|
||||
// end of \documentclass defs
|
||||
|
||||
// font selection must be done before loading fontenc.sty
|
||||
if (params.fonts != "default") {
|
||||
LFile += "\\usepackage{" + params.fonts + "}\n";
|
||||
texrow.newline();
|
||||
}
|
||||
// this one is not per buffer
|
||||
if (lyxrc->fontenc != "default") {
|
||||
LFile += "\\usepackage[" + lyxrc->fontenc
|
||||
+ "]{fontenc}\n";
|
||||
texrow.newline();
|
||||
}
|
||||
if (params.inputenc != "default") {
|
||||
LFile += "\\usepackage[" + params.inputenc
|
||||
+ "]{inputenc}\n";
|
||||
texrow.newline();
|
||||
}
|
||||
|
||||
/* at the very beginning the text parameters */
|
||||
if (params.paperpackage != BufferParams::PACKAGE_NONE) {
|
||||
switch (params.paperpackage) {
|
||||
case BufferParams::PACKAGE_A4:
|
||||
LFile += "\\usepackage{a4}\n";
|
||||
texrow.newline();
|
||||
break;
|
||||
case BufferParams::PACKAGE_A4WIDE:
|
||||
LFile += "\\usepackage{a4wide}\n";
|
||||
texrow.newline();
|
||||
break;
|
||||
case BufferParams::PACKAGE_WIDEMARGINSA4:
|
||||
LFile += "\\usepackage[widemargins]{a4}\n";
|
||||
texrow.newline();
|
||||
break;
|
||||
}
|
||||
}
|
||||
if (params.use_geometry) {
|
||||
LFile += "\\usepackage{geometry}\n";
|
||||
texrow.newline();
|
||||
LFile += "\\geometry{verbose";
|
||||
if (params.orientation == BufferParams::ORIENTATION_LANDSCAPE)
|
||||
LFile += ",landscape";
|
||||
switch (params.papersize2) {
|
||||
case BufferParams::VM_PAPER_CUSTOM:
|
||||
if (!params.paperwidth.empty())
|
||||
LFile += ",paperwidth="
|
||||
+ params.paperwidth;
|
||||
if (!params.paperheight.empty())
|
||||
LFile += ",paperheight="
|
||||
+ params.paperheight;
|
||||
break;
|
||||
case BufferParams::VM_PAPER_USLETTER:
|
||||
LFile += ",letterpaper";
|
||||
break;
|
||||
case BufferParams::VM_PAPER_USLEGAL:
|
||||
LFile += ",legalpaper";
|
||||
break;
|
||||
case BufferParams::VM_PAPER_USEXECUTIVE:
|
||||
LFile += ",executivepaper";
|
||||
break;
|
||||
case BufferParams::VM_PAPER_A3:
|
||||
LFile += ",a3paper";
|
||||
break;
|
||||
case BufferParams::VM_PAPER_A4:
|
||||
LFile += ",a4paper";
|
||||
break;
|
||||
case BufferParams::VM_PAPER_A5:
|
||||
LFile += ",a5paper";
|
||||
break;
|
||||
case BufferParams::VM_PAPER_B3:
|
||||
LFile += ",b3paper";
|
||||
break;
|
||||
case BufferParams::VM_PAPER_B4:
|
||||
LFile += ",b4paper";
|
||||
break;
|
||||
case BufferParams::VM_PAPER_B5:
|
||||
LFile += ",b5paper";
|
||||
break;
|
||||
default:
|
||||
// default papersize ie BufferParams::VM_PAPER_DEFAULT
|
||||
switch (lyxrc->default_papersize) {
|
||||
case BufferParams::PAPER_DEFAULT: // keep compiler happy
|
||||
case BufferParams::PAPER_USLETTER:
|
||||
LFile += ",letterpaper";
|
||||
break;
|
||||
case BufferParams::PAPER_LEGALPAPER:
|
||||
LFile += ",legalpaper";
|
||||
break;
|
||||
case BufferParams::PAPER_EXECUTIVEPAPER:
|
||||
LFile += ",executivepaper";
|
||||
break;
|
||||
case BufferParams::PAPER_A3PAPER:
|
||||
LFile += ",a3paper";
|
||||
break;
|
||||
case BufferParams::PAPER_A4PAPER:
|
||||
LFile += ",a4paper";
|
||||
break;
|
||||
case BufferParams::PAPER_A5PAPER:
|
||||
LFile += ",a5paper";
|
||||
break;
|
||||
case BufferParams::PAPER_B5PAPER:
|
||||
LFile += ",b5paper";
|
||||
break;
|
||||
}
|
||||
}
|
||||
if (!params.topmargin.empty())
|
||||
LFile += ",tmargin=" + params.topmargin;
|
||||
if (!params.bottommargin.empty())
|
||||
LFile += ",bmargin=" + params.bottommargin;
|
||||
if (!params.leftmargin.empty())
|
||||
LFile += ",lmargin=" + params.leftmargin;
|
||||
if (!params.rightmargin.empty())
|
||||
LFile += ",rmargin=" + params.rightmargin;
|
||||
if (!params.headheight.empty())
|
||||
LFile += ",headheight=" + params.headheight;
|
||||
if (!params.headsep.empty())
|
||||
LFile += ",headsep=" + params.headsep;
|
||||
if (!params.footskip.empty())
|
||||
LFile += ",footskip=" + params.footskip;
|
||||
LFile += "}\n";
|
||||
texrow.newline();
|
||||
}
|
||||
if (params.use_amsmath
|
||||
&& !prefixIs(textclasslist.LatexnameOfClass(params.textclass), "ams")) {
|
||||
LFile += "\\usepackage{amsmath}\n";
|
||||
}
|
||||
|
||||
if (tokenPos(tclass.opt_pagestyle(), '|', params.pagestyle) >= 0) {
|
||||
if (params.pagestyle == "fancy") {
|
||||
LFile += "\\usepackage{fancyhdr}\n";
|
||||
texrow.newline();
|
||||
}
|
||||
LFile += "\\pagestyle{" + params.pagestyle + "}\n";
|
||||
texrow.newline();
|
||||
}
|
||||
|
||||
// We try to load babel late, in case it interferes
|
||||
// with other packages.
|
||||
if (params.language != "default" || lyxrc->rtl_support ) {
|
||||
LFile += "\\usepackage{babel}\n";
|
||||
texrow.newline();
|
||||
}
|
||||
|
||||
if (params.secnumdepth != tclass.secnumdepth()) {
|
||||
LFile += "\\setcounter{secnumdepth}{";
|
||||
LFile += tostr(params.secnumdepth);
|
||||
LFile += "}\n";
|
||||
texrow.newline();
|
||||
}
|
||||
if (params.tocdepth != tclass.tocdepth()) {
|
||||
LFile += "\\setcounter{tocdepth}{";
|
||||
LFile += tostr(params.tocdepth);
|
||||
LFile += "}\n";
|
||||
texrow.newline();
|
||||
}
|
||||
|
||||
if (params.paragraph_separation) {
|
||||
switch (params.defskip.kind()) {
|
||||
case VSpace::SMALLSKIP:
|
||||
LFile += "\\setlength\\parskip{\\smallskipamount}\n";
|
||||
break;
|
||||
case VSpace::MEDSKIP:
|
||||
LFile += "\\setlength\\parskip{\\medskipamount}\n";
|
||||
break;
|
||||
case VSpace::BIGSKIP:
|
||||
LFile += "\\setlength\\parskip{\\bigskipamount}\n";
|
||||
break;
|
||||
case VSpace::LENGTH:
|
||||
LFile += "\\setlength\\parskip{"
|
||||
+ params.defskip.length().asLatexString()
|
||||
+ "}\n";
|
||||
break;
|
||||
default: // should never happen // Then delete it.
|
||||
LFile += "\\setlength\\parskip{\\medskipamount}\n";
|
||||
break;
|
||||
}
|
||||
texrow.newline();
|
||||
|
||||
LFile += "\\setlength\\parindent{0pt}\n";
|
||||
texrow.newline();
|
||||
}
|
||||
|
||||
// Write out what we've generated so far...and reset LFile
|
||||
ofs << LFile;
|
||||
LFile.clear();
|
||||
|
||||
// Now insert the LyX specific LaTeX commands...
|
||||
string preamble, tmppreamble;
|
||||
|
||||
// The optional packages;
|
||||
preamble = features.getPackages(params);
|
||||
|
||||
// this might be useful...
|
||||
preamble += "\n\\makeatletter\n\n";
|
||||
|
||||
// Some macros LyX will need
|
||||
tmppreamble = features.getMacros(params);
|
||||
|
||||
if (!tmppreamble.empty()) {
|
||||
preamble += "\n%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% "
|
||||
"LyX specific LaTeX commands.\n"
|
||||
+ tmppreamble + '\n';
|
||||
}
|
||||
|
||||
// the text class specific preamble
|
||||
tmppreamble = features.getTClassPreamble(params);
|
||||
if (!tmppreamble.empty()) {
|
||||
preamble += "%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% "
|
||||
"Textclass specific LaTeX commands.\n"
|
||||
+ tmppreamble + '\n';
|
||||
}
|
||||
|
||||
/* the user-defined preamble */
|
||||
if (!params.preamble.empty()) {
|
||||
preamble += "%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% "
|
||||
"User specified LaTeX commands.\n"
|
||||
+ params.preamble + '\n';
|
||||
}
|
||||
|
||||
preamble += "\\makeatother\n\n";
|
||||
|
||||
// Itemize bullet settings need to be last in case the user
|
||||
// defines their own bullets that use a package included
|
||||
// in the user-defined preamble -- ARRae
|
||||
// Actually it has to be done much later than that
|
||||
// since some packages like frenchb make modifications
|
||||
// at \begin{document} time -- JMarc
|
||||
string bullets_def;
|
||||
for (int i = 0; i < 4; ++i) {
|
||||
if (params.user_defined_bullets[i] != ITEMIZE_DEFAULTS[i]) {
|
||||
if (bullets_def.empty())
|
||||
bullets_def="\\AtBeginDocument{\n";
|
||||
bullets_def += " \\renewcommand{\\labelitemi";
|
||||
switch (i) {
|
||||
// `i' is one less than the item to modify
|
||||
case 0:
|
||||
break;
|
||||
case 1:
|
||||
bullets_def += 'i';
|
||||
break;
|
||||
case 2:
|
||||
bullets_def += "ii";
|
||||
break;
|
||||
case 3:
|
||||
bullets_def += 'v';
|
||||
break;
|
||||
}
|
||||
bullets_def += "}{" +
|
||||
params.user_defined_bullets[i].getText()
|
||||
+ "}\n";
|
||||
}
|
||||
}
|
||||
|
||||
if (!bullets_def.empty())
|
||||
preamble += bullets_def + "}\n\n";
|
||||
|
||||
for (int j = countChar(preamble, '\n'); j-- ;) {
|
||||
texrow.newline();
|
||||
}
|
||||
|
||||
ofs << preamble;
|
||||
|
||||
// make the body.
|
||||
LFile += "\\begin{document}\n\n";
|
||||
texrow.newline();
|
||||
texrow.newline();
|
||||
} // only_body
|
||||
lyxerr.debug() << "preamble finished, now the body." << endl;
|
||||
|
||||
bool was_title = false;
|
||||
bool already_title = false;
|
||||
string ftnote;
|
||||
TexRow ft_texrow;
|
||||
int ftcount = 0;
|
||||
int loop_count = 0;
|
||||
|
||||
LyXParagraph * par = paragraph;
|
||||
|
||||
// if only_body
|
||||
while (par) {
|
||||
++loop_count;
|
||||
if (par->IsDummy())
|
||||
lyxerr[Debug::LATEX] << "Error in MakeLateXFile."
|
||||
<< endl;
|
||||
LyXLayout const & layout =
|
||||
textclasslist.Style(params.textclass,
|
||||
par->layout);
|
||||
|
||||
if (layout.intitle) {
|
||||
if (already_title) {
|
||||
lyxerr <<"Error in MakeLatexFile: You"
|
||||
" should not mix title layouts"
|
||||
" with normal ones." << endl;
|
||||
} else
|
||||
was_title = true;
|
||||
} else if (was_title && !already_title) {
|
||||
LFile += "\\maketitle\n";
|
||||
texrow.newline();
|
||||
already_title = true;
|
||||
was_title = false;
|
||||
}
|
||||
// We are at depth 0 so we can just use
|
||||
// ordinary \footnote{} generation
|
||||
// flag this with ftcount
|
||||
ftcount = -1;
|
||||
if (layout.isEnvironment()
|
||||
|| par->pextra_type != LyXParagraph::PEXTRA_NONE) {
|
||||
par = par->TeXEnvironment(LFile, texrow,
|
||||
ftnote, ft_texrow, ftcount);
|
||||
} else {
|
||||
par = par->TeXOnePar(LFile, texrow,
|
||||
ftnote, ft_texrow, ftcount);
|
||||
}
|
||||
|
||||
// Write out what we've generated...and reset LFile
|
||||
if (ftcount >= 1) {
|
||||
if (ftcount > 1) {
|
||||
LFile += "\\addtocounter{footnote}{-";
|
||||
LFile += tostr(ftcount - 1);
|
||||
LFile += '}';
|
||||
}
|
||||
LFile += ftnote;
|
||||
texrow += ft_texrow;
|
||||
ftnote.clear();
|
||||
ft_texrow.reset();
|
||||
ftcount = 0;
|
||||
}
|
||||
if (loop_count == 2) {
|
||||
// fwrite()ing every second time through the loop
|
||||
// gains a few extra % of speed; going higher than
|
||||
// 2 will slow things down again. I'll look at
|
||||
// LFile.length() in a future revision. ARRae
|
||||
ofs << LFile;
|
||||
LFile.clear();
|
||||
loop_count = 0;
|
||||
}
|
||||
}
|
||||
|
||||
// It might be that we only have a title in this document
|
||||
if (was_title && !already_title) {
|
||||
LFile += "\\maketitle\n";
|
||||
texrow.newline();
|
||||
}
|
||||
|
||||
if (!only_body) {
|
||||
LFile += "\\end{document}\n";
|
||||
texrow.newline();
|
||||
|
||||
lyxerr[Debug::LATEX] << "makeLaTeXFile...done" << endl;
|
||||
} else {
|
||||
lyxerr[Debug::LATEX] << "LaTeXFile for inclusion made."
|
||||
<< endl;
|
||||
}
|
||||
|
||||
// Just to be sure. (Asger)
|
||||
texrow.newline();
|
||||
|
||||
// Write out what we've generated...and reset LFile
|
||||
ofs << LFile;
|
||||
LFile.clear();
|
||||
|
||||
// tex_code_break_column's value is used to decide
|
||||
// if we are in batchmode or not (within mathed_write()
|
||||
// in math_write.C) so we must set it to a non-zero
|
||||
// value when we leave otherwise we save incorrect .lyx files.
|
||||
tex_code_break_column = lyxrc->ascii_linelen;
|
||||
|
||||
// How to check if the close went ok when using fstreams
|
||||
ofs.close();
|
||||
lyxerr.debug() << "Finished making latex file." << endl;
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
bool Buffer::isLatex() const
|
||||
@ -2878,24 +2352,12 @@ void Buffer::DocBookHandleCaption(ostream & os, string & inner_tag,
|
||||
tpar->layout == textclasslist.NumberOfLayout(params.textclass,
|
||||
"Caption").second) {
|
||||
sgmlOpenTag(os, depth + 1, inner_tag);
|
||||
#ifdef USE_OSTREAM_ONLY
|
||||
string extra_par;
|
||||
SimpleDocBookOnePar(os, extra_par, tpar,
|
||||
desc_on, depth + 2);
|
||||
sgmlCloseTag(os, depth+1, inner_tag);
|
||||
if(!extra_par.empty())
|
||||
os << extra_par;
|
||||
#else
|
||||
string tmp_par, extra_par;
|
||||
SimpleDocBookOnePar(tmp_par, extra_par, tpar,
|
||||
desc_on, depth + 2);
|
||||
tmp_par = strip(tmp_par);
|
||||
tmp_par = frontStrip(tmp_par);
|
||||
os << tmp_par;
|
||||
sgmlCloseTag(os, depth+1, inner_tag);
|
||||
if(!extra_par.empty())
|
||||
os << extra_par;
|
||||
#endif
|
||||
}
|
||||
}
|
||||
|
||||
@ -2981,7 +2443,6 @@ void Buffer::DocBookHandleFootnote(ostream & os, LyXParagraph * & par,
|
||||
if (par->layout != textclasslist
|
||||
.NumberOfLayout(params.textclass,
|
||||
"Caption").second) {
|
||||
#ifdef USE_OSTREAM_ONLY
|
||||
#ifdef HAVE_SSTREAM
|
||||
ostringstream ost;
|
||||
#else
|
||||
@ -2996,8 +2457,6 @@ void Buffer::DocBookHandleFootnote(ostream & os, LyXParagraph * & par,
|
||||
char * ctmp = ost.str();
|
||||
tmp_par += ctmp;
|
||||
delete [] ctmp;
|
||||
#endif
|
||||
#else
|
||||
#endif
|
||||
}
|
||||
tmp_par = frontStrip(strip(tmp_par));
|
||||
@ -3209,15 +2668,8 @@ void Buffer::SimpleLinuxDocOnePar(ostream & os, LyXParagraph * par,
|
||||
++char_line_count;
|
||||
} else if (c == LyXParagraph::META_INSET) {
|
||||
inset = par->GetInset(i);
|
||||
#ifdef USE_OSTREAM_ONLY
|
||||
inset->Linuxdoc(os);
|
||||
#else
|
||||
string tmp_out;
|
||||
inset->Linuxdoc(tmp_out);
|
||||
os << tmp_out;
|
||||
#endif
|
||||
}
|
||||
else {
|
||||
} else {
|
||||
string sgml_string;
|
||||
if (par->linuxDocConvertChar(c, sgml_string)
|
||||
&& !style.free_spacing) { // in freespacing
|
||||
@ -3503,24 +2955,12 @@ void Buffer::makeDocBookFile(string const & fname, int column)
|
||||
}
|
||||
|
||||
do {
|
||||
#ifdef USE_OSTREAM_ONLY
|
||||
string extra_par;
|
||||
SimpleDocBookOnePar(ofs, extra_par, par, desc_on,
|
||||
depth + 1 + command_depth);
|
||||
par = par->next;
|
||||
DocBookHandleFootnote(ofs, par,
|
||||
depth + 1 + command_depth);
|
||||
#else
|
||||
string tmp_par, extra_par;
|
||||
|
||||
SimpleDocBookOnePar(tmp_par, extra_par, par, desc_on,
|
||||
depth + 1 + command_depth);
|
||||
ofs << tmp_par;
|
||||
|
||||
par = par->next;
|
||||
DocBookHandleFootnote(ofs, par,
|
||||
depth + 1 + command_depth);
|
||||
#endif
|
||||
}
|
||||
while(par && par->IsDummy());
|
||||
|
||||
@ -3582,7 +3022,6 @@ void Buffer::makeDocBookFile(string const & fname, int column)
|
||||
}
|
||||
|
||||
|
||||
#ifdef USE_OSTREAM_ONLY
|
||||
void Buffer::SimpleDocBookOnePar(ostream & os, string & extra,
|
||||
LyXParagraph * par, int & desc_on,
|
||||
int const depth)
|
||||
@ -3713,133 +3152,6 @@ void Buffer::SimpleDocBookOnePar(ostream & os, string & extra,
|
||||
}
|
||||
os << '\n';
|
||||
}
|
||||
#else
|
||||
void Buffer::SimpleDocBookOnePar(string & file, string & extra,
|
||||
LyXParagraph * par, int & desc_on,
|
||||
int const depth)
|
||||
{
|
||||
if (par->table) {
|
||||
par->SimpleDocBookOneTablePar(file, extra, desc_on, depth);
|
||||
return;
|
||||
}
|
||||
LyXFont font1, font2;
|
||||
char c;
|
||||
Inset * inset;
|
||||
LyXParagraph::size_type main_body;
|
||||
int j;
|
||||
string emph= "emphasis";
|
||||
bool emph_flag= false;
|
||||
|
||||
LyXLayout const & style = textclasslist.Style(params.textclass,
|
||||
par->GetLayout());
|
||||
|
||||
if (style.labeltype != LABEL_MANUAL)
|
||||
main_body = 0;
|
||||
else
|
||||
main_body = par->BeginningOfMainBody();
|
||||
|
||||
/* gets paragraph main font */
|
||||
if (main_body > 0)
|
||||
font1 = style.labelfont;
|
||||
else
|
||||
font1 = style.font;
|
||||
|
||||
int char_line_count = depth;
|
||||
if(!style.free_spacing)
|
||||
for (j = 0; j < depth; ++j)
|
||||
file += ' ';
|
||||
|
||||
/* parsing main loop */
|
||||
for (LyXParagraph::size_type i = 0;
|
||||
i < par->size(); ++i) {
|
||||
font2 = par->getFont(i);
|
||||
|
||||
/* handle <emphasis> tag */
|
||||
if (font1.emph() != font2.emph() && i) {
|
||||
if (font2.emph() == LyXFont::ON) {
|
||||
file += "<emphasis>";
|
||||
emph_flag= true;
|
||||
}else {
|
||||
file += "</emphasis>";
|
||||
emph_flag= false;
|
||||
}
|
||||
}
|
||||
|
||||
c = par->GetChar(i);
|
||||
|
||||
if (c == LyXParagraph::META_INSET) {
|
||||
inset = par->GetInset(i);
|
||||
string tmp_out;
|
||||
inset->DocBook(tmp_out);
|
||||
|
||||
//
|
||||
// This code needs some explanation:
|
||||
// Two insets are treated specially
|
||||
// label if it is the first element in a command paragraph
|
||||
// desc_on == 3
|
||||
// graphics inside tables or figure floats can't go on
|
||||
// title (the equivalente in latex for this case is caption
|
||||
// and title should come first
|
||||
// desc_on == 4
|
||||
//
|
||||
if(desc_on!= 3 || i!= 0) {
|
||||
if(!tmp_out.empty() && tmp_out[0] == '@') {
|
||||
if(desc_on == 4)
|
||||
extra += frontStrip(tmp_out, '@');
|
||||
else
|
||||
file += frontStrip(tmp_out, '@');
|
||||
}
|
||||
else
|
||||
file += tmp_out;
|
||||
}
|
||||
} else if (font2.latex() == LyXFont::ON) {
|
||||
// "TeX"-Mode on ==> SGML-Mode on.
|
||||
if (c!= '\0')
|
||||
file += c;
|
||||
++char_line_count;
|
||||
}
|
||||
else {
|
||||
string sgml_string;
|
||||
if (par->linuxDocConvertChar(c, sgml_string)
|
||||
&& !style.free_spacing) { // in freespacing
|
||||
// mode, spaces are
|
||||
// non-breaking characters
|
||||
// char is ' '
|
||||
if (desc_on == 1) {
|
||||
++char_line_count;
|
||||
file += '\n';
|
||||
file += "</term><listitem><para>";
|
||||
desc_on = 2;
|
||||
}
|
||||
else {
|
||||
file += c;
|
||||
}
|
||||
}
|
||||
else {
|
||||
file += sgml_string;
|
||||
}
|
||||
}
|
||||
font1 = font2;
|
||||
}
|
||||
|
||||
/* needed if there is an optional argument but no contents */
|
||||
if (main_body > 0 && main_body == par->size()) {
|
||||
font1 = style.font;
|
||||
}
|
||||
if (emph_flag) {
|
||||
file += "</emphasis>";
|
||||
}
|
||||
|
||||
/* resets description flag correctly */
|
||||
switch(desc_on){
|
||||
case 1:
|
||||
/* <term> not closed... */
|
||||
file += "</term>";
|
||||
break;
|
||||
}
|
||||
file += '\n';
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
int Buffer::runLaTeX()
|
||||
|
@ -357,17 +357,10 @@ private:
|
||||
///
|
||||
void SimpleLinuxDocOnePar(ostream & os, LyXParagraph * par,
|
||||
int desc_on, int const depth);
|
||||
#ifdef USE_OSTREAM_ONLY
|
||||
///
|
||||
void SimpleDocBookOnePar(ostream &, string & extra,
|
||||
LyXParagraph * par, int & desc_on,
|
||||
int const depth);
|
||||
#else
|
||||
///
|
||||
void SimpleDocBookOnePar(string & file, string & extra,
|
||||
LyXParagraph * par, int & desc_on,
|
||||
int const depth);
|
||||
#endif
|
||||
|
||||
/// LinuxDoc.
|
||||
void push_tag(ostream & os, char const * tag,
|
||||
|
@ -9,6 +9,8 @@ libinsets_la_SOURCES = \
|
||||
BoundingBox.h \
|
||||
figinset.C \
|
||||
figinset.h \
|
||||
form_graphics.C \
|
||||
form_graphics.h \
|
||||
form_url.C \
|
||||
form_url.h \
|
||||
inset.C \
|
||||
|
@ -109,9 +109,6 @@ static int gs_allcolors; // number of all colors
|
||||
|
||||
static list<int> pidwaitlist; // pid wait list
|
||||
|
||||
//extern Colormap color_map;
|
||||
|
||||
|
||||
|
||||
static
|
||||
GC createGC()
|
||||
@ -149,7 +146,8 @@ void addpidwait(int pid)
|
||||
}
|
||||
|
||||
|
||||
extern "C" int GhostscriptMsg(FL_OBJECT *, Window, int, int,
|
||||
extern "C"
|
||||
int GhostscriptMsg(FL_OBJECT *, Window, int, int,
|
||||
XEvent * ev, void *)
|
||||
{
|
||||
char tmp[128];
|
||||
@ -1202,34 +1200,6 @@ int InsetFig::Latex(ostream & os, signed char /* fragile*/, bool /* fs*/) const
|
||||
}
|
||||
|
||||
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
int InsetFig::Latex(string & file, signed char /* fragile*/, bool/* fs*/) const
|
||||
{
|
||||
Regenerate();
|
||||
file += cmd + ' ';
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
int InsetFig::Linuxdoc(string &/*file*/) const
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
int InsetFig::DocBook(string & file) const
|
||||
{
|
||||
string figurename = fname;
|
||||
|
||||
if(suffixIs(figurename, ".eps"))
|
||||
figurename.erase(fname.length() - 5);
|
||||
|
||||
file += "@<graphic fileref=\"" + figurename + "\"></graphic>";
|
||||
return 0;
|
||||
}
|
||||
|
||||
#else
|
||||
|
||||
int InsetFig::Linuxdoc(ostream &) const
|
||||
{
|
||||
return 0;
|
||||
@ -1246,7 +1216,6 @@ int InsetFig::DocBook(ostream & os) const
|
||||
os << "@<graphic fileref=\"" << figurename << "\"></graphic>";
|
||||
return 0;
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
void InsetFig::Validate(LaTeXFeatures & features) const
|
||||
|
@ -39,19 +39,10 @@ public:
|
||||
void Read(LyXLex & lex);
|
||||
///
|
||||
int Latex(ostream &, signed char fragile, bool free_space) const;
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
///
|
||||
int Latex(string & file, signed char fragile, bool free_space) const;
|
||||
///
|
||||
int Linuxdoc(string & file) const;
|
||||
///
|
||||
int DocBook(string & file) const;
|
||||
#else
|
||||
///
|
||||
int Linuxdoc(ostream &) const;
|
||||
///
|
||||
int DocBook(ostream &) const;
|
||||
#endif
|
||||
/// Updates needed features for this inset.
|
||||
void Validate(LaTeXFeatures & features) const;
|
||||
|
||||
|
@ -239,7 +239,6 @@ void InsetBibKey::setCounter(int c)
|
||||
// of time cause LyX3 won't use lyxlex anyway. (ale)
|
||||
void InsetBibKey::Write(ostream & os) const
|
||||
{
|
||||
#ifdef USE_OSTREAM_ONLY
|
||||
os << "\\bibitem ";
|
||||
if (!options.empty()) {
|
||||
os << '['
|
||||
@ -247,16 +246,6 @@ void InsetBibKey::Write(ostream & os) const
|
||||
}
|
||||
os << '{'
|
||||
<< contents << "}\n";
|
||||
#else
|
||||
string s;
|
||||
if (!options.empty()) {
|
||||
s += '[';
|
||||
s += options + ']';
|
||||
}
|
||||
s += '{';
|
||||
s += contents + '}';
|
||||
os << "\\bibitem " << s << "\n";
|
||||
#endif
|
||||
}
|
||||
|
||||
|
||||
@ -323,7 +312,6 @@ string InsetBibtex::getScreenLabel() const
|
||||
|
||||
int InsetBibtex::Latex(ostream & os, signed char /*fragile*/, bool/*fs*/) const
|
||||
{
|
||||
#ifdef USE_OSTREAM_ONLY
|
||||
// this looks like an horrible hack and it is :) The problem
|
||||
// is that owner is not initialized correctly when the bib
|
||||
// inset is cut and pasted. Such hacks will not be needed
|
||||
@ -358,60 +346,9 @@ int InsetBibtex::Latex(ostream & os, signed char /*fragile*/, bool/*fs*/) const
|
||||
os << "\\bibliographystyle{" << style << "}\n"
|
||||
<< "\\bibliography{" << db_out << "}\n";
|
||||
return 2;
|
||||
#else
|
||||
string bib;
|
||||
signed char dummy = 0;
|
||||
int result = Latex(bib, dummy, 0);
|
||||
os << bib;
|
||||
return result;
|
||||
#endif
|
||||
}
|
||||
|
||||
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
int InsetBibtex::Latex(string & file, signed char /*fragile*/, bool/*fs*/) const
|
||||
{
|
||||
// this looks like an horrible hack and it is :) The problem
|
||||
// is that owner is not initialized correctly when the bib
|
||||
// inset is cut and pasted. Such hacks will not be needed
|
||||
// later (JMarc)
|
||||
if (!owner) {
|
||||
owner = current_view->buffer();
|
||||
}
|
||||
// If we generate in a temp dir, we might need to give an
|
||||
// absolute path there. This is a bit complicated since we can
|
||||
// have a comma-separated list of bibliographies
|
||||
string adb, db_out;
|
||||
string db_in = getContents();
|
||||
db_in = split(db_in, adb, ',');
|
||||
while(!adb.empty()) {
|
||||
if (!owner->niceFile &&
|
||||
IsFileReadable(MakeAbsPath(adb, owner->filepath)+".bib"))
|
||||
adb = MakeAbsPath(adb, owner->filepath);
|
||||
db_out += adb;
|
||||
db_out += ',';
|
||||
db_in= split(db_in, adb,',');
|
||||
}
|
||||
db_out = strip(db_out, ',');
|
||||
// Idem, but simpler
|
||||
string style;
|
||||
if (!owner->niceFile
|
||||
&& IsFileReadable(MakeAbsPath(getOptions(), owner->filepath)
|
||||
+ ".bst"))
|
||||
style = MakeAbsPath(getOptions(), owner->filepath);
|
||||
else
|
||||
style = getOptions();
|
||||
|
||||
file += "\\bibliographystyle{";
|
||||
file += style;
|
||||
file += "}\n";
|
||||
file += "\\bibliography{";
|
||||
file += db_out;
|
||||
file += "}\n";
|
||||
return 2;
|
||||
}
|
||||
#endif
|
||||
|
||||
// This method returns a comma separated list of Bibtex entries
|
||||
string InsetBibtex::getKeys(char delim)
|
||||
{
|
||||
|
@ -128,10 +128,6 @@ public:
|
||||
void Edit(BufferView *, int x, int y, unsigned int button);
|
||||
///
|
||||
int Latex(ostream &, signed char, bool) const;
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
///
|
||||
int Latex(string & file, signed char fragile, bool) const;
|
||||
#endif
|
||||
///
|
||||
string getKeys(char delim);
|
||||
///
|
||||
|
@ -251,27 +251,6 @@ int InsetCommand::Latex(ostream & os, signed char /*fragile*/, bool/*fs*/) const
|
||||
}
|
||||
|
||||
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
int InsetCommand::Latex(string & file, signed char /*fragile*/, bool/*fs*/) const
|
||||
{
|
||||
file += getCommand();
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
int InsetCommand::Linuxdoc(string &/*file*/) const
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
int InsetCommand::DocBook(string &/*file*/) const
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
|
||||
#else
|
||||
|
||||
int InsetCommand::Linuxdoc(ostream &) const
|
||||
{
|
||||
return 0;
|
||||
@ -282,7 +261,6 @@ int InsetCommand::DocBook(ostream &) const
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
Inset * InsetCommand::Clone() const
|
||||
|
@ -48,19 +48,10 @@ public:
|
||||
void Read(LyXLex & lex);
|
||||
///
|
||||
virtual int Latex(ostream &, signed char fragile, bool free_spc) const;
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
///
|
||||
virtual int Latex(string & file, signed char fragile, bool free_spc) const;
|
||||
///
|
||||
virtual int Linuxdoc(string & file) const;
|
||||
///
|
||||
virtual int DocBook(string & file) const;
|
||||
#else
|
||||
///
|
||||
virtual int Linuxdoc(ostream &) const;
|
||||
///
|
||||
virtual int DocBook(ostream &) const;
|
||||
#endif
|
||||
///
|
||||
Inset * Clone() const;
|
||||
///
|
||||
|
@ -107,26 +107,6 @@ int InsetError::Latex(ostream &, signed char /*fragile*/, bool /*fs*/) const
|
||||
}
|
||||
|
||||
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
int InsetError::Latex(string &, signed char /*fragile*/, bool /*fs*/) const
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
int InsetError::Linuxdoc(string &) const
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
int InsetError::DocBook(string &) const
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
|
||||
#else
|
||||
|
||||
int InsetError::Linuxdoc(ostream &) const
|
||||
{
|
||||
return 0;
|
||||
@ -137,7 +117,6 @@ int InsetError::DocBook(ostream &) const
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
bool InsetError::AutoDelete() const
|
||||
|
@ -48,19 +48,10 @@ public:
|
||||
void Read(LyXLex & lex);
|
||||
///
|
||||
int Latex(ostream &, signed char fragile, bool free_spc) const;
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
///
|
||||
int Latex(string & file, signed char fragile, bool free_spc) const;
|
||||
///
|
||||
int Linuxdoc(string & file) const;
|
||||
///
|
||||
int DocBook(string & file) const;
|
||||
#else
|
||||
///
|
||||
int Linuxdoc(ostream &) const;
|
||||
///
|
||||
int DocBook(ostream &) const;
|
||||
#endif
|
||||
///
|
||||
bool AutoDelete() const;
|
||||
/// what appears in the minibuffer when opening
|
||||
|
@ -3,7 +3,7 @@
|
||||
*
|
||||
* LyX, The Document Processor
|
||||
*
|
||||
* Copyright (C) 1998 The LyX Team.
|
||||
* Copyright 1998 The LyX Team.
|
||||
*
|
||||
*======================================================*/
|
||||
|
||||
@ -40,62 +40,43 @@ Inset * InsetFoot::Clone() const
|
||||
}
|
||||
|
||||
|
||||
const char * InsetFoot::EditMessage() const
|
||||
char const * InsetFoot::EditMessage() const
|
||||
{
|
||||
return _("Opened Footnote Inset");
|
||||
}
|
||||
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
int InsetFoot::Latex(string & l, signed char fragile) const
|
||||
{
|
||||
int i;
|
||||
|
||||
if (fragile)
|
||||
l += "\\footnotetext{";
|
||||
else
|
||||
l += "\\footnote{";
|
||||
|
||||
i = InsetText::Latex(l, fragile);
|
||||
l += "}";
|
||||
|
||||
return i;
|
||||
}
|
||||
#endif
|
||||
|
||||
int InsetFoot::Latex(ostream & os, signed char fragile, bool fp) const
|
||||
{
|
||||
int i;
|
||||
|
||||
if (fragile)
|
||||
os << "\\footnotetext{";
|
||||
else
|
||||
os << "\\footnote{";
|
||||
|
||||
i = InsetText::Latex(os, fragile, fp);
|
||||
int i = InsetText::Latex(os, fragile, fp);
|
||||
os << "}";
|
||||
|
||||
return i;
|
||||
}
|
||||
|
||||
|
||||
void InsetFoot::Write(ostream & os) const
|
||||
{
|
||||
os << "Foot\n";
|
||||
os << "\ncollapsed ";
|
||||
os << "Foot\n"
|
||||
<< "\ncollapsed ";
|
||||
if (display())
|
||||
os << "false";
|
||||
os << "false\n";
|
||||
else
|
||||
os << "true";
|
||||
os << "\n";
|
||||
os << "true\n";
|
||||
WriteParagraphData(os);
|
||||
}
|
||||
|
||||
|
||||
void InsetFoot::Read(LyXLex & lex)
|
||||
{
|
||||
if (lex.IsOK()) {
|
||||
string token, tmptok;
|
||||
|
||||
lex.next();
|
||||
token = lex.GetString();
|
||||
string token = lex.GetString();
|
||||
if (token == "collapsed") {
|
||||
lex.next();
|
||||
collapsed = lex.GetBool();
|
||||
@ -104,7 +85,8 @@ void InsetFoot::Read(LyXLex & lex)
|
||||
InsetText::Read(lex);
|
||||
}
|
||||
|
||||
bool InsetFoot::InsertInset(BufferView *bv, Inset * inset)
|
||||
|
||||
bool InsetFoot::InsertInset(BufferView * bv, Inset * inset)
|
||||
{
|
||||
if ((inset->LyxCode() == Inset::FOOT_CODE) ||
|
||||
(inset->LyxCode() == Inset::MARGIN_CODE)) {
|
||||
|
@ -36,10 +36,6 @@ public:
|
||||
Inset * Clone() const;
|
||||
///
|
||||
Inset::Code LyxCode() const { return Inset::FOOT_CODE; }
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
///
|
||||
int Latex(string &, signed char) const;
|
||||
#endif
|
||||
///
|
||||
int Latex(ostream &, signed char, bool fp) const;
|
||||
///
|
||||
|
@ -16,6 +16,95 @@
|
||||
|
||||
#include "insets/insetgraphics.h"
|
||||
#include "Painter.h"
|
||||
#include "form_graphics.h"
|
||||
#include "lyx_gui_misc.h"
|
||||
#include "filedlg.h"
|
||||
#include "support/FileInfo.h"
|
||||
#include "support/filetools.h"
|
||||
|
||||
extern string system_lyxdir;
|
||||
extern string user_lyxdir;
|
||||
extern string system_tempdir;
|
||||
|
||||
string browseFile();
|
||||
|
||||
void GraphicxCB(FL_OBJECT * obj, long arg)
|
||||
{
|
||||
lyxerr << "GraphicxCB: obj = " << obj << " arg = " << arg << endl;
|
||||
switch (arg) {
|
||||
case 0: // The graphics file
|
||||
lyxerr << "Set the graphics file in InsetGraphics" << endl;
|
||||
break;
|
||||
case 1: // The file browser
|
||||
browseFile();
|
||||
break;
|
||||
case 2: // The Apply button
|
||||
lyxerr << "Scan the form and set the "
|
||||
"InsetGraphics accordingly." << endl;
|
||||
break;
|
||||
case 3: // The OK button
|
||||
GraphicxCB(obj, 2); // do the apply
|
||||
GraphicxCB(obj, 4); // do the cancel
|
||||
break;
|
||||
case 4: // The Cancel button
|
||||
lyxerr << "Just hide the form and do nothing else!" << endl;
|
||||
break;
|
||||
case 99:
|
||||
lyxerr << "Not implemented yet..." << endl;
|
||||
break;
|
||||
default:
|
||||
lyxerr << "Unknown callback value!" << endl;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
string browseFile()
|
||||
{
|
||||
// This function is probably not good enough yet, and does need some
|
||||
// arguemnts to tell what dir to start looking in.
|
||||
|
||||
static string current_figure_path = ".";
|
||||
|
||||
LyXFileDlg fileDlg;
|
||||
|
||||
// Does user clipart directory exist?
|
||||
string bufclip = AddName (user_lyxdir, "clipart");
|
||||
FileInfo fileInfo(bufclip);
|
||||
if (!(fileInfo.isOK() && fileInfo.isDir()))
|
||||
// No - bail out to system clipart directory
|
||||
bufclip = AddName (system_lyxdir, "clipart");
|
||||
|
||||
|
||||
fileDlg.SetButton(0, _("Clipart"), bufclip);
|
||||
|
||||
bool error = false;
|
||||
string buf;
|
||||
do {
|
||||
string p = fileDlg.Select(_("Graphics"),
|
||||
current_figure_path,
|
||||
"*ps", string());
|
||||
|
||||
if (p.empty()) return p;
|
||||
|
||||
current_figure_path = OnlyPath(p);
|
||||
|
||||
if (p.find_first_of("#~$% ") != string::npos) {
|
||||
WriteAlert(_("Filename can't contain any "
|
||||
"of these characters:"),
|
||||
// xgettext:no-c-format
|
||||
_("space, '#', '~', '$' or '%'."));
|
||||
error = true;
|
||||
}
|
||||
} while (error);
|
||||
|
||||
return buf;
|
||||
}
|
||||
|
||||
|
||||
InsetGraphics::InsetGraphics()
|
||||
: form(0)
|
||||
{}
|
||||
|
||||
|
||||
int InsetGraphics::ascent(Painter &, LyXFont const &) const
|
||||
@ -54,8 +143,22 @@ void InsetGraphics::draw(Painter & pain, LyXFont const & font,
|
||||
|
||||
void InsetGraphics::Edit(BufferView *, int, int, unsigned int)
|
||||
{
|
||||
// Here we want to popup a dialog from which we get the
|
||||
// graphics paramters.
|
||||
lyxerr.debug() << "InsetGraphics::Edit" << endl;
|
||||
|
||||
if (!form) {
|
||||
form = create_form_Graphics();
|
||||
fl_set_form_atclose(form->Graphics, CancelCloseBoxCB, 0);
|
||||
fl_set_object_return(form->Angle, FL_RETURN_ALWAYS);
|
||||
fl_set_object_return(form->Width, FL_RETURN_ALWAYS);
|
||||
fl_set_object_return(form->Height, FL_RETURN_ALWAYS);
|
||||
}
|
||||
|
||||
if (form->Graphics->visible) {
|
||||
fl_raise_form(form->Graphics);
|
||||
} else {
|
||||
fl_show_form(form->Graphics, FL_PLACE_MOUSE | FL_PLACE_SIZE,
|
||||
FL_FULLBORDER, _("Graphics"));
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@ -69,6 +172,8 @@ void InsetGraphics::Write(ostream & os) const
|
||||
{
|
||||
// The question on the file format is still open.
|
||||
// Suggestions?
|
||||
// perhaps a format that is xml-parsable
|
||||
//<graphics name="test.eps"/>
|
||||
os << "GRAPHICS\n";
|
||||
}
|
||||
|
||||
@ -225,26 +330,6 @@ int InsetGraphics::Latex(ostream & os, signed char /*fragile*/, bool/*fs*/) cons
|
||||
}
|
||||
|
||||
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
int InsetGraphics::Latex(string & /*file*/, signed char /*fragile*/, bool/*fs*/) const
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
int InsetGraphics::Linuxdoc(string & /*file*/) const
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
int InsetGraphics::DocBook(string & /*file*/) const
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
|
||||
#else
|
||||
|
||||
int InsetGraphics::Linuxdoc(ostream &) const
|
||||
{
|
||||
return 0;
|
||||
@ -255,7 +340,6 @@ int InsetGraphics::DocBook(ostream &) const
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
void InsetGraphics::Validate(LaTeXFeatures & /*features*/) const
|
||||
|
@ -21,9 +21,13 @@
|
||||
#include "vspace.h"
|
||||
#include "insets/BoundingBox.h"
|
||||
|
||||
struct FD_Graphics;
|
||||
|
||||
///
|
||||
class InsetGraphics : public Inset {
|
||||
public:
|
||||
///
|
||||
InsetGraphics();
|
||||
///
|
||||
int ascent(Painter &, LyXFont const &) const;
|
||||
///
|
||||
@ -46,19 +50,11 @@ public:
|
||||
fragile commands by adding a \protect before.
|
||||
*/
|
||||
int Latex(ostream &, signed char fragile, bool free_spc) const;
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
///
|
||||
int Latex(string & file, signed char fragile, bool free_spc) const;
|
||||
///
|
||||
int Linuxdoc(string & /*file*/) const;
|
||||
///
|
||||
int DocBook(string & /*file*/) const;
|
||||
#else
|
||||
///
|
||||
int Linuxdoc(ostream &) const;
|
||||
///
|
||||
int DocBook(ostream &) const;
|
||||
#endif
|
||||
|
||||
/// Updates needed features for this inset.
|
||||
void Validate(LaTeXFeatures & features) const;
|
||||
|
||||
@ -67,7 +63,17 @@ public:
|
||||
|
||||
///
|
||||
Inset * Clone() const;
|
||||
/// Set the graphics file
|
||||
void graphicsFile(string const & f) {
|
||||
graphicsfile = f;
|
||||
}
|
||||
/// Get the graphics file
|
||||
string const & graphicsFile() const {
|
||||
return graphicsfile;
|
||||
}
|
||||
private:
|
||||
///
|
||||
FD_Graphics * form;
|
||||
///
|
||||
string graphicsfile;
|
||||
///
|
||||
|
@ -317,7 +317,6 @@ bool InsetInclude::loadIfNeeded() const
|
||||
|
||||
int InsetInclude::Latex(ostream & os, signed char /*fragile*/, bool /*fs*/) const
|
||||
{
|
||||
#ifdef USE_OSTREAM_ONLY
|
||||
// Do nothing if no file name has been specified
|
||||
if (contents.empty())
|
||||
return 0;
|
||||
@ -383,94 +382,9 @@ int InsetInclude::Latex(ostream & os, signed char /*fragile*/, bool /*fs*/) cons
|
||||
}
|
||||
|
||||
return 0;
|
||||
#else
|
||||
string include_file;
|
||||
signed char dummy = 0;
|
||||
Latex(include_file, dummy, 0);
|
||||
os << include_file;
|
||||
return 0;
|
||||
#endif
|
||||
}
|
||||
|
||||
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
int InsetInclude::Latex(string & file, signed char /*fragile*/, bool /*fs*/) const
|
||||
{
|
||||
// Do nothing if no file name has been specified
|
||||
if (contents.empty())
|
||||
return 0;
|
||||
|
||||
// Use += to force a copy of contents (JMarc)
|
||||
string incfile += contents;
|
||||
|
||||
if (loadIfNeeded()) {
|
||||
Buffer * tmp = bufferlist.getBuffer(getFileName());
|
||||
|
||||
if (tmp->params.textclass != master->params.textclass) {
|
||||
lyxerr << "ERROR: Cannot handle include file `"
|
||||
<< MakeDisplayPath(getFileName())
|
||||
<< "' which has textclass `"
|
||||
<< textclasslist.NameOfClass(tmp->params.textclass)
|
||||
<< "' instead of `"
|
||||
<< textclasslist.NameOfClass(master->params.textclass)
|
||||
<< "'." << endl;
|
||||
return 0;
|
||||
}
|
||||
|
||||
// write it to a file (so far the complete file)
|
||||
string writefile =
|
||||
ChangeExtension(getFileName(), ".tex", false);
|
||||
if (!master->tmppath.empty()
|
||||
&& !master->niceFile) {
|
||||
incfile = subst(incfile, '/','@');
|
||||
#ifdef __EMX__
|
||||
incfile = subst(incfile, ':', '$');
|
||||
#endif
|
||||
writefile = AddName(master->tmppath, incfile);
|
||||
} else
|
||||
writefile = getFileName();
|
||||
writefile = ChangeExtension(writefile, ".tex", false);
|
||||
lyxerr[Debug::LATEX] << "incfile:" << incfile << endl;
|
||||
lyxerr[Debug::LATEX] << "writefile:" << writefile << endl;
|
||||
|
||||
tmp->markDepClean(master->tmppath);
|
||||
|
||||
tmp->makeLaTeXFile(writefile,
|
||||
OnlyPath(getMasterFilename()),
|
||||
master->niceFile, true);
|
||||
}
|
||||
|
||||
if (isVerb()) {
|
||||
file += '\\';
|
||||
file += command + '{';
|
||||
file += incfile + '}';
|
||||
}
|
||||
else if (isInput()) {
|
||||
// \input wants file with extension (default is .tex)
|
||||
if (!IsLyXFilename(getFileName())) {
|
||||
file += '\\';
|
||||
file += command + '{';
|
||||
file += incfile + '}';
|
||||
} else {
|
||||
file += '\\';
|
||||
file += command + '{';
|
||||
file += ChangeExtension(incfile, ".tex", false)
|
||||
+ '}';
|
||||
}
|
||||
} else {
|
||||
// \include don't want extension and demands that the
|
||||
// file really have .tex
|
||||
file += '\\';
|
||||
file += command + '{';
|
||||
file += ChangeExtension(incfile, string(), false)
|
||||
+ '}';
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
void InsetInclude::Validate(LaTeXFeatures & features) const
|
||||
{
|
||||
if (isVerb())
|
||||
|
@ -59,10 +59,6 @@ public:
|
||||
void Read(LyXLex &);
|
||||
///
|
||||
int Latex(ostream &, signed char fragile, bool free_spc) const;
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
///
|
||||
int Latex(string & file, signed char fragile, bool free_spc) const;
|
||||
#endif
|
||||
///
|
||||
void Validate(LaTeXFeatures &) const;
|
||||
|
||||
|
@ -132,26 +132,6 @@ int InsetInfo::Latex(ostream &, signed char /*fragile*/, bool /*free_spc*/) cons
|
||||
}
|
||||
|
||||
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
int InsetInfo::Latex(string &, signed char /*fragile*/, bool /*free_spc*/) const
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
int InsetInfo::Linuxdoc(string &) const
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
int InsetInfo::DocBook(string &) const
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
|
||||
#else
|
||||
|
||||
int InsetInfo::Linuxdoc(ostream &) const
|
||||
{
|
||||
return 0;
|
||||
@ -162,7 +142,6 @@ int InsetInfo::DocBook(ostream &) const
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
Inset::EDITABLE InsetInfo::Editable() const
|
||||
|
@ -50,19 +50,10 @@ public:
|
||||
void Read(LyXLex & lex);
|
||||
///
|
||||
int Latex(ostream &, signed char fragile, bool free_spc) const;
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
///
|
||||
int Latex(string & file, signed char fragile, bool free_spc) const;
|
||||
///
|
||||
int Linuxdoc(string & file) const;
|
||||
///
|
||||
int DocBook(string & file) const;
|
||||
#else
|
||||
///
|
||||
int Linuxdoc(ostream &) const;
|
||||
///
|
||||
int DocBook(ostream &) const;
|
||||
#endif
|
||||
/// what appears in the minibuffer when opening
|
||||
const char * EditMessage() const {return _("Opened note");}
|
||||
///
|
||||
|
@ -50,29 +50,6 @@ int InsetLabel::Latex(ostream & os, signed char /*fragile*/, bool /*fs*/) const
|
||||
}
|
||||
|
||||
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
int InsetLabel::Latex(string & file, signed char /*fragile*/, bool /*fs*/) const
|
||||
{
|
||||
file += escape(getCommand());
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
int InsetLabel::Linuxdoc(string & file) const
|
||||
{
|
||||
file += "<label id=\"" + getContents() +"\" >";
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
int InsetLabel::DocBook(string & file) const
|
||||
{
|
||||
file += "<anchor id=\"" + getContents() +"\" >";
|
||||
return 0;
|
||||
}
|
||||
|
||||
#else
|
||||
|
||||
int InsetLabel::Linuxdoc(ostream & os) const
|
||||
{
|
||||
os << "<label id=\"" << getContents() << "\" >";
|
||||
@ -85,9 +62,6 @@ int InsetLabel::DocBook(ostream & os) const
|
||||
os << "<anchor id=\"" << getContents() << "\" >";
|
||||
return 0;
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
|
||||
|
||||
// This function escapes 8-bit characters and other problematic characters
|
||||
|
@ -40,19 +40,10 @@ public:
|
||||
EDITABLE Editable() const { return NOT_EDITABLE; }
|
||||
///
|
||||
int Latex(ostream &, signed char fragile, bool free_spc) const;
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
///
|
||||
int Latex(string & file, signed char fragile, bool free_spc) const;
|
||||
///
|
||||
int Linuxdoc(string & file) const;
|
||||
///
|
||||
int DocBook(string & file) const;
|
||||
#else
|
||||
///
|
||||
int Linuxdoc(ostream &) const;
|
||||
///
|
||||
int DocBook(ostream &) const;
|
||||
#endif
|
||||
private:
|
||||
/// This function escapes 8-bit characters
|
||||
string escape(string const &) const;
|
||||
|
@ -752,29 +752,6 @@ int InsetLatexAccent::Latex(ostream & os, signed char /*fragile*/, bool/*fs*/) c
|
||||
}
|
||||
|
||||
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
int InsetLatexAccent::Latex(string & file, signed char /*fragile*/, bool /*fs*/) const
|
||||
{
|
||||
file += contents;
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
int InsetLatexAccent::Linuxdoc(string & file) const
|
||||
{
|
||||
file += contents;
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
int InsetLatexAccent::DocBook(string & file) const
|
||||
{
|
||||
file += contents;
|
||||
return 0;
|
||||
}
|
||||
|
||||
#else
|
||||
|
||||
int InsetLatexAccent::Linuxdoc(ostream & os) const
|
||||
{
|
||||
os << contents;
|
||||
@ -787,7 +764,6 @@ int InsetLatexAccent::DocBook(ostream & os) const
|
||||
os << contents;
|
||||
return 0;
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
bool InsetLatexAccent::Deletable() const
|
||||
|
@ -54,19 +54,10 @@ public:
|
||||
void Read(LyXLex & lex);
|
||||
///
|
||||
int Latex(ostream &, signed char fragile, bool free_spc) const;
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
///
|
||||
int Latex(string & file, signed char fragile, bool free_spc) const;
|
||||
///
|
||||
int Linuxdoc(string & file) const;
|
||||
///
|
||||
int DocBook(string & file) const;
|
||||
#else
|
||||
///
|
||||
int Linuxdoc(ostream &) const;
|
||||
///
|
||||
int DocBook(ostream &) const;
|
||||
#endif
|
||||
///
|
||||
bool Deletable() const;
|
||||
///
|
||||
|
@ -49,14 +49,3 @@ int InsetParent::Latex(ostream & os, signed char fragile, bool free_spc) const
|
||||
InsetCommand::Latex(os, fragile, free_spc);
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
// LaTeX must just ignore this command
|
||||
int InsetParent::Latex(string & file, signed char fragile, bool free_spc) const
|
||||
{
|
||||
file += "%%#{lyx}";
|
||||
InsetCommand::Latex(file, fragile, free_spc);
|
||||
return 0;
|
||||
}
|
||||
#endif
|
||||
|
@ -33,10 +33,6 @@ public:
|
||||
InsetParent(string const & fn, Buffer * owner = 0);
|
||||
///
|
||||
int Latex(ostream &, signed char fragile, bool free_spc) const;
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
///
|
||||
int Latex(string & file, signed char fragile, bool free_spc) const;
|
||||
#endif
|
||||
///
|
||||
Inset * Clone() const { return new InsetParent(getContents()); }
|
||||
///
|
||||
|
@ -226,7 +226,6 @@ void InsetQuotes::Read(LyXLex & lex)
|
||||
|
||||
int InsetQuotes::Latex(ostream & os, signed char /*fragile*/, bool) const
|
||||
{
|
||||
#ifdef USE_OSTREAM_ONLY
|
||||
string doclang =
|
||||
current_view->buffer()->GetLanguage();
|
||||
int quoteind = quote_index[side][language];
|
||||
@ -262,76 +261,9 @@ int InsetQuotes::Latex(ostream & os, signed char /*fragile*/, bool) const
|
||||
|
||||
os << qstr;
|
||||
return 0;
|
||||
#else
|
||||
string quote;
|
||||
int res = Latex(quote, 0, 0);
|
||||
os << quote;
|
||||
return res;
|
||||
#endif
|
||||
}
|
||||
|
||||
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
int InsetQuotes::Latex(string & file, signed char /*fragile*/, bool /*free_spc*/) const
|
||||
{
|
||||
string doclang =
|
||||
current_view->buffer()->GetLanguage();
|
||||
int quoteind = quote_index[side][language];
|
||||
string qstr;
|
||||
|
||||
if (lyxrc->fontenc == "T1") {
|
||||
qstr = latex_quote_t1[times][quoteind];
|
||||
}
|
||||
else if (doclang == "default") {
|
||||
qstr = latex_quote_ot1[times][quoteind];
|
||||
}
|
||||
else if (language == InsetQuotes::FrenchQ
|
||||
&& times == InsetQuotes::DoubleQ
|
||||
&& doclang == "frenchb") {
|
||||
if (side == InsetQuotes::LeftQ)
|
||||
qstr = "\\og{}";
|
||||
else
|
||||
qstr = " \\fg{}";
|
||||
}
|
||||
else
|
||||
qstr = latex_quote_babel[times][quoteind];
|
||||
|
||||
// protect against !` and ?` ligatures.
|
||||
if ((suffixIs(file, '?') || suffixIs(file, '!'))
|
||||
&& qstr[0] == '`')
|
||||
qstr = "{}" + qstr;
|
||||
|
||||
file += qstr;
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
int InsetQuotes::Linuxdoc(string & file) const
|
||||
{
|
||||
file += "\"";
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
int InsetQuotes::DocBook(string & file) const
|
||||
{
|
||||
if(times == InsetQuotes::DoubleQ) {
|
||||
if (side == InsetQuotes::LeftQ)
|
||||
file += "“";
|
||||
else
|
||||
file += "”";
|
||||
} else {
|
||||
if (side == InsetQuotes::LeftQ)
|
||||
file += "‘";
|
||||
else
|
||||
file += "’";
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
#else
|
||||
|
||||
int InsetQuotes::Linuxdoc(ostream & os) const
|
||||
{
|
||||
os << "\"";
|
||||
@ -354,7 +286,6 @@ int InsetQuotes::DocBook(ostream & os) const
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
void InsetQuotes::Validate(LaTeXFeatures & features) const
|
||||
|
@ -86,19 +86,10 @@ public:
|
||||
void Read(LyXLex & lex);
|
||||
///
|
||||
int Latex(ostream &, signed char fragile, bool free_spc) const;
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
///
|
||||
int Latex(string & file, signed char fragile, bool free_spc) const;
|
||||
///
|
||||
int Linuxdoc(string & file) const;
|
||||
///
|
||||
int DocBook(string & file) const;
|
||||
#else
|
||||
///
|
||||
int Linuxdoc(ostream &) const;
|
||||
///
|
||||
int DocBook(ostream &) const;
|
||||
#endif
|
||||
///
|
||||
void Validate(LaTeXFeatures &) const;
|
||||
///
|
||||
|
@ -81,40 +81,6 @@ int InsetRef::Latex(ostream & os, signed char /*fragile*/, bool /*fs*/) const
|
||||
}
|
||||
|
||||
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
int InsetRef::Latex(string & file, signed char /*fragile*/, bool /*fs*/) const
|
||||
{
|
||||
if(getOptions().empty())
|
||||
file += escape(getCommand());
|
||||
else {
|
||||
string ns;
|
||||
InsetCommand clone = InsetCommand(getCmdName(),
|
||||
getContents(), ns);
|
||||
file += escape(clone.getCommand());
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
int InsetRef::Linuxdoc(string & file) const
|
||||
{
|
||||
file += "<ref id=\"" + getContents()
|
||||
+ "\" name=\""+ getOptions() +"\" >" ;
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
int InsetRef::DocBook(string & file) const
|
||||
{
|
||||
file += "<link linkend=\"" + getContents()
|
||||
+ "\">"+ getOptions() +"</link>" ;
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
#else
|
||||
|
||||
int InsetRef::Linuxdoc(ostream & os) const
|
||||
{
|
||||
os << "<ref id=\"" << getContents()
|
||||
@ -129,7 +95,6 @@ int InsetRef::DocBook(ostream & os) const
|
||||
<< "\">" << getOptions() << "</link>";
|
||||
return 0;
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
// This function escapes 8-bit characters and other problematic characters
|
||||
|
@ -62,19 +62,10 @@ public:
|
||||
void gotoLabel();
|
||||
///
|
||||
int Latex(ostream &, signed char fragile, bool free_spc) const;
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
///
|
||||
int Latex(string & file, signed char fragile, bool free_spc) const;
|
||||
///
|
||||
int Linuxdoc(string & file) const;
|
||||
///
|
||||
int DocBook(string & file) const;
|
||||
#else
|
||||
///
|
||||
int Linuxdoc(ostream &) const;
|
||||
///
|
||||
int DocBook(ostream &) const;
|
||||
#endif
|
||||
private:
|
||||
/// This function escapes 8-bit characters
|
||||
string escape(string const &) const;
|
||||
|
@ -191,7 +191,6 @@ void InsetSpecialChar::Read(LyXLex & lex)
|
||||
int InsetSpecialChar::Latex(ostream & os, signed char /*fragile*/,
|
||||
bool free_space) const
|
||||
{
|
||||
#ifdef USE_OSTREAM_ONLY
|
||||
switch (kind) {
|
||||
case HYPHENATION: os << "\\-"; break;
|
||||
case END_OF_SENTENCE: os << "\\@."; break;
|
||||
@ -200,58 +199,9 @@ int InsetSpecialChar::Latex(ostream & os, signed char /*fragile*/,
|
||||
case PROTECTED_SEPARATOR: os << (free_space ? " " : "~"); break;
|
||||
}
|
||||
return 0;
|
||||
#else
|
||||
string command;
|
||||
signed char dummy = 0;
|
||||
Latex(command, dummy, free_space);
|
||||
os << command;
|
||||
return 0;
|
||||
#endif
|
||||
}
|
||||
|
||||
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
int InsetSpecialChar::Latex(string & file, signed char /*fragile*/,
|
||||
bool free_space) const
|
||||
{
|
||||
switch (kind) {
|
||||
case HYPHENATION: file += "\\-"; break;
|
||||
case END_OF_SENTENCE: file += "\\@."; break;
|
||||
case LDOTS: file += "\\ldots{}"; break;
|
||||
case MENU_SEPARATOR: file += "\\lyxarrow{}"; break;
|
||||
case PROTECTED_SEPARATOR: file += (free_space ? " " : "~"); break;
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
int InsetSpecialChar::Linuxdoc(string & file) const
|
||||
{
|
||||
switch (kind) {
|
||||
case HYPHENATION: file += ""; break;
|
||||
case END_OF_SENTENCE: file += ""; break;
|
||||
case LDOTS: file += "..."; break;
|
||||
case MENU_SEPARATOR: file += "->"; break;
|
||||
case PROTECTED_SEPARATOR: file += " "; break;
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
int InsetSpecialChar::DocBook(string & file) const
|
||||
{
|
||||
switch (kind) {
|
||||
case HYPHENATION: file += ""; break;
|
||||
case END_OF_SENTENCE: file += ""; break;
|
||||
case LDOTS: file += "..."; break;
|
||||
case MENU_SEPARATOR: file += "->"; break;
|
||||
case PROTECTED_SEPARATOR: file += " "; break;
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
#else
|
||||
|
||||
int InsetSpecialChar::Linuxdoc(ostream & os) const
|
||||
{
|
||||
switch (kind) {
|
||||
@ -276,7 +226,6 @@ int InsetSpecialChar::DocBook(ostream & os) const
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
Inset * InsetSpecialChar::Clone() const
|
||||
|
@ -60,19 +60,10 @@ public:
|
||||
void Read(LyXLex & lex);
|
||||
///
|
||||
int Latex(ostream &, signed char fragile, bool free_spc) const;
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
///
|
||||
int Latex(string & file, signed char fragile, bool free_spc) const;
|
||||
///
|
||||
int Linuxdoc(string & file) const;
|
||||
///
|
||||
int DocBook(string & file) const;
|
||||
#else
|
||||
///
|
||||
int Linuxdoc(ostream &) const;
|
||||
///
|
||||
int DocBook(ostream &) const;
|
||||
#endif
|
||||
///
|
||||
Inset * Clone() const;
|
||||
///
|
||||
|
@ -626,37 +626,14 @@ InsetText::LocalDispatch(BufferView * bv,
|
||||
}
|
||||
|
||||
|
||||
int InsetText::Latex(ostream & os, signed char /*fragile*/,
|
||||
#ifdef USE_OSTREAM_ONLY
|
||||
bool) const
|
||||
#else
|
||||
bool free_spc) const
|
||||
#endif
|
||||
int InsetText::Latex(ostream & os, signed char /*fragile*/, bool) const
|
||||
{
|
||||
#ifdef USE_OSTREAM_ONLY
|
||||
TexRow texrow;
|
||||
int ret = par->SimpleTeXOnePar(os, texrow);
|
||||
return ret;
|
||||
#else
|
||||
string fstr;
|
||||
|
||||
int i = Latex(fstr, fragile, free_spc);
|
||||
os << fstr;
|
||||
return i;
|
||||
#endif
|
||||
}
|
||||
|
||||
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
int InsetText::Latex(string & file, signed char /* fragile */) const
|
||||
{
|
||||
TexRow texrow;
|
||||
|
||||
return par->SimpleTeXOnePar(file, texrow);
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
void InsetText::Validate(LaTeXFeatures & features) const
|
||||
{
|
||||
par->validate(features);
|
||||
|
@ -78,19 +78,10 @@ public:
|
||||
UpdatableInset::RESULT LocalDispatch(BufferView *, int, string const &);
|
||||
///
|
||||
int Latex(ostream &, signed char, bool free_spc) const;
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
///
|
||||
int Latex(string &, signed char, bool free_spc) const;
|
||||
///
|
||||
int Linuxdoc(string &) const { return 0; }
|
||||
///
|
||||
int DocBook(string &) const { return 0; }
|
||||
#else
|
||||
///
|
||||
int Linuxdoc(ostream &) const { return 0; }
|
||||
///
|
||||
int DocBook(ostream &) const { return 0; }
|
||||
#endif
|
||||
///
|
||||
void Validate(LaTeXFeatures & features) const;
|
||||
///
|
||||
|
@ -17,22 +17,6 @@ void InsetTOC::Edit(BufferView * bv, int, int, unsigned int)
|
||||
bv->owner()->getLyXFunc()->Dispatch(LFUN_TOCVIEW);
|
||||
}
|
||||
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
int InsetTOC::Linuxdoc(string & file) const
|
||||
{
|
||||
file += "<toc>";
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
int InsetTOC::DocBook(string & file) const
|
||||
{
|
||||
file += "<toc></toc>";
|
||||
return 0;
|
||||
}
|
||||
|
||||
#else
|
||||
|
||||
int InsetTOC::Linuxdoc(ostream & os) const
|
||||
{
|
||||
os << "<toc>";
|
||||
@ -45,4 +29,3 @@ int InsetTOC::DocBook(ostream & os) const
|
||||
os << "<toc></toc>";
|
||||
return 0;
|
||||
}
|
||||
#endif
|
||||
|
@ -43,17 +43,10 @@ public:
|
||||
bool display() const { return true; }
|
||||
///
|
||||
Inset::Code LyxCode() const { return Inset::TOC_CODE; }
|
||||
#ifdef USE_OSTREAM_ONLY
|
||||
///
|
||||
int Linuxdoc(ostream &) const;
|
||||
///
|
||||
int DocBook(ostream &) const;
|
||||
#else
|
||||
///
|
||||
int Linuxdoc(string & file) const;
|
||||
///
|
||||
int DocBook(string & file) const;
|
||||
#endif
|
||||
private:
|
||||
///
|
||||
Buffer * owner;
|
||||
|
@ -168,57 +168,15 @@ string InsetUrl::getScreenLabel() const
|
||||
|
||||
int InsetUrl::Latex(ostream & os, signed char fragile, bool free_spc) const
|
||||
{
|
||||
#ifdef USE_OSTREAM_ONLY
|
||||
if (!getOptions().empty())
|
||||
os << getOptions() + ' ';
|
||||
if (fragile)
|
||||
os << "\\protect";
|
||||
os << "\\url{" << getContents() << '}';
|
||||
return 0;
|
||||
#else
|
||||
string latex_output;
|
||||
int res = Latex(latex_output, fragile, free_spc);
|
||||
os << latex_output;
|
||||
|
||||
return res;
|
||||
#endif
|
||||
}
|
||||
|
||||
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
int InsetUrl::Latex(string & file, signed char fragile, bool /*free_spc*/) const
|
||||
{
|
||||
if (!getOptions().empty())
|
||||
file += getOptions() + ' ';
|
||||
if (fragile)
|
||||
file += "\\protect";
|
||||
|
||||
file += "\\url{" + getContents() + '}';
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
int InsetUrl::Linuxdoc(string & file) const
|
||||
{
|
||||
file += "<"+ getCmdName() +
|
||||
" url=\"" + getContents()+"\"" +
|
||||
" name=\"" + getOptions() +"\">";
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
int InsetUrl::DocBook(string & file) const
|
||||
{
|
||||
file += "<ulink url=\"" + getContents() + "\">" +
|
||||
getOptions() +"</ulink>";
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
#else
|
||||
|
||||
int InsetUrl::Linuxdoc(ostream & os) const
|
||||
{
|
||||
os << "<" << getCmdName()
|
||||
@ -235,7 +193,6 @@ int InsetUrl::DocBook(ostream & os) const
|
||||
<< getOptions() << "</ulink>";
|
||||
return 0;
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
void InsetUrl::Validate(LaTeXFeatures & features) const
|
||||
|
@ -71,19 +71,10 @@ public:
|
||||
void gotoLabel();
|
||||
///
|
||||
int Latex(ostream &, signed char fragile, bool free_spc) const;
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
///
|
||||
int Latex(string & file, signed char fragile, bool free_spc) const;
|
||||
///
|
||||
int Linuxdoc(string & file) const;
|
||||
///
|
||||
int DocBook(string & file) const;
|
||||
#else
|
||||
///
|
||||
int Linuxdoc(ostream &) const;
|
||||
///
|
||||
int DocBook(ostream &) const;
|
||||
#endif
|
||||
///
|
||||
static void CloseUrlCB(FL_OBJECT *, long data);
|
||||
private:
|
||||
|
@ -26,7 +26,6 @@ class BufferView;
|
||||
|
||||
struct LaTeXFeatures;
|
||||
|
||||
#define USE_OSTREAM_ONLY 1
|
||||
|
||||
/// Insets
|
||||
class Inset {
|
||||
@ -126,21 +125,13 @@ public:
|
||||
If the freee_spc (freespacing) variable is set, then this inset
|
||||
is in a free-spacing paragraph.
|
||||
*/
|
||||
virtual int Latex(ostream &, signed char fragile, bool free_spc) const = 0;
|
||||
virtual int Latex(ostream &, signed char fragile,
|
||||
bool free_spc) const = 0;
|
||||
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
///
|
||||
virtual int Latex(string & file, signed char fragile, bool free_spc) const = 0;
|
||||
///
|
||||
virtual int Linuxdoc(string & /*file*/) const = 0;
|
||||
///
|
||||
virtual int DocBook(string & /*file*/) const = 0;
|
||||
#else
|
||||
///
|
||||
virtual int Linuxdoc(ostream &) const = 0;
|
||||
///
|
||||
virtual int DocBook(ostream &) const = 0;
|
||||
#endif
|
||||
/// Updates needed features for this inset.
|
||||
virtual void Validate(LaTeXFeatures & features) const;
|
||||
///
|
||||
|
15
src/lyx_cb.C
15
src/lyx_cb.C
@ -3549,18 +3549,3 @@ extern "C" void RefHideCB(FL_OBJECT *, long)
|
||||
{
|
||||
fl_hide_form(fd_form_ref->form_ref);
|
||||
}
|
||||
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
#ifdef WITH_WARNINGS
|
||||
#warning UGLY!!
|
||||
#endif
|
||||
// I know we shouldn't put anything in here but this seems the fastest
|
||||
// way to do this (and the cleanest for now). This function just inserts
|
||||
// a newline in the string and the inserts 'depth'-spaces so that the
|
||||
// code is indented in the right way!!!
|
||||
void addNewlineAndDepth(string & file, int depth)
|
||||
{
|
||||
file += '\n';
|
||||
file.append(depth, ' ');
|
||||
}
|
||||
#endif
|
||||
|
159
src/lyxfont.C
159
src/lyxfont.C
@ -663,7 +663,6 @@ void LyXFont::lyxWriteChanges(LyXFont const & orgfont, ostream & os) const
|
||||
|
||||
/// Writes the head of the LaTeX needed to impose this font
|
||||
// Returns number of chars written.
|
||||
#ifdef USE_OSTREAM_ONLY
|
||||
int LyXFont::latexWriteStartChanges(ostream & os, LyXFont const & base,
|
||||
LyXFont const & prev) const
|
||||
{
|
||||
@ -747,165 +746,8 @@ int LyXFont::latexWriteStartChanges(ostream & os, LyXFont const & base,
|
||||
}
|
||||
return count;
|
||||
}
|
||||
#else
|
||||
int LyXFont::latexWriteStartChanges(string & file, LyXFont const & base,
|
||||
LyXFont const & prev) const
|
||||
{
|
||||
LyXFont f = *this;
|
||||
f.reduce(base);
|
||||
|
||||
if (f.bits == inherit)
|
||||
return 0;
|
||||
|
||||
int count = 0;
|
||||
bool env = false;
|
||||
|
||||
FONT_DIRECTION direction = f.direction();
|
||||
if (direction != prev.direction()) {
|
||||
if (direction == LTR_DIR) {
|
||||
file += "\\L{";
|
||||
count += 3;
|
||||
env = true; //We have opened a new environment
|
||||
}
|
||||
if (direction == RTL_DIR) {
|
||||
file += "\\R{";
|
||||
count += 3;
|
||||
env = true; //We have opened a new environment
|
||||
}
|
||||
}
|
||||
|
||||
if (f.family() != INHERIT_FAMILY) {
|
||||
file += '\\';
|
||||
file += LaTeXFamilyNames[f.family()];
|
||||
file += '{';
|
||||
count += LaTeXFamilyNames[f.family()].length() + 2;
|
||||
env = true; //We have opened a new environment
|
||||
}
|
||||
if (f.series() != INHERIT_SERIES) {
|
||||
file += '\\';
|
||||
file += LaTeXSeriesNames[f.series()];
|
||||
file += '{';
|
||||
count += LaTeXSeriesNames[f.series()].length() + 2;
|
||||
env = true; //We have opened a new environment
|
||||
}
|
||||
if (f.shape() != INHERIT_SHAPE) {
|
||||
file += '\\';
|
||||
file += LaTeXShapeNames[f.shape()];
|
||||
file += '{';
|
||||
count += LaTeXShapeNames[f.shape()].length() + 2;
|
||||
env = true; //We have opened a new environment
|
||||
}
|
||||
if (f.color() != LColor::inherit) {
|
||||
file += "\\textcolor{";
|
||||
file += lcolor.getLaTeXName(f.color());
|
||||
file += "}{";
|
||||
count += lcolor.getLaTeXName(f.color()).length() + 13;
|
||||
env = true; //We have opened a new environment
|
||||
}
|
||||
if (f.emph() == ON) {
|
||||
file += "\\emph{";
|
||||
count += 6;
|
||||
env = true; //We have opened a new environment
|
||||
}
|
||||
if (f.underbar() == ON) {
|
||||
file += "\\underbar{";
|
||||
count += 10;
|
||||
env = true; //We have opened a new environment
|
||||
}
|
||||
// \noun{} is a LyX special macro
|
||||
if (f.noun() == ON) {
|
||||
file += "\\noun{";
|
||||
count += 8;
|
||||
env = true; //We have opened a new environment
|
||||
}
|
||||
if (f.size() != INHERIT_SIZE) {
|
||||
// If we didn't open an environment above, we open one here
|
||||
if (!env) {
|
||||
file += '{';
|
||||
++count;
|
||||
}
|
||||
file += '\\';
|
||||
file += LaTeXSizeNames[f.size()];
|
||||
file += ' ';
|
||||
count += LaTeXSizeNames[f.size()].length() + 2;
|
||||
}
|
||||
return count;
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
/// Writes ending block of LaTeX needed to close use of this font
|
||||
// Returns number of chars written
|
||||
// This one corresponds to latexWriteStartChanges(). (Asger)
|
||||
int LyXFont::latexWriteEndChanges(string & file, LyXFont const & base,
|
||||
LyXFont const & next) const
|
||||
{
|
||||
LyXFont f = *this; // why do you need this?
|
||||
f.reduce(base); // why isn't this just "reduce(base);" (Lgb)
|
||||
// Because this function is const. Everything breaks if this
|
||||
// method changes the font it represents. There is no speed penalty
|
||||
// by using the temporary. (Asger)
|
||||
|
||||
if (f.bits == inherit)
|
||||
return 0;
|
||||
|
||||
int count = 0;
|
||||
bool env = false;
|
||||
|
||||
FONT_DIRECTION direction = f.direction();
|
||||
if ( direction != next.direction()
|
||||
&& (direction == RTL_DIR || direction == LTR_DIR) ) {
|
||||
file += '}';
|
||||
++count;
|
||||
env = true; // Size change need not bother about closing env.
|
||||
}
|
||||
|
||||
if (f.family() != INHERIT_FAMILY) {
|
||||
file += '}';
|
||||
++count;
|
||||
env = true; // Size change need not bother about closing env.
|
||||
}
|
||||
if (f.series() != INHERIT_SERIES) {
|
||||
file += '}';
|
||||
++count;
|
||||
env = true; // Size change need not bother about closing env.
|
||||
}
|
||||
if (f.shape() != INHERIT_SHAPE) {
|
||||
file += '}';
|
||||
++count;
|
||||
env = true; // Size change need not bother about closing env.
|
||||
}
|
||||
if (f.color() != LColor::inherit) {
|
||||
file += '}';
|
||||
++count;
|
||||
env = true; // Size change need not bother about closing env.
|
||||
}
|
||||
if (f.emph() == ON) {
|
||||
file += '}';
|
||||
++count;
|
||||
env = true; // Size change need not bother about closing env.
|
||||
}
|
||||
if (f.underbar() == ON) {
|
||||
file += '}';
|
||||
++count;
|
||||
env = true; // Size change need not bother about closing env.
|
||||
}
|
||||
if (f.noun() == ON) {
|
||||
file += '}';
|
||||
++count;
|
||||
env = true; // Size change need not bother about closing env.
|
||||
}
|
||||
if (f.size() != INHERIT_SIZE) {
|
||||
// We only have to close if only size changed
|
||||
if (!env) {
|
||||
file += '}';
|
||||
++count;
|
||||
}
|
||||
}
|
||||
return count;
|
||||
}
|
||||
#else
|
||||
/// Writes ending block of LaTeX needed to close use of this font
|
||||
// Returns number of chars written
|
||||
// This one corresponds to latexWriteStartChanges(). (Asger)
|
||||
@ -976,7 +818,6 @@ int LyXFont::latexWriteEndChanges(ostream & os, LyXFont const & base,
|
||||
}
|
||||
return count;
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
LColor::color LyXFont::realColor() const
|
||||
|
@ -35,7 +35,6 @@
|
||||
#undef OFF
|
||||
#endif
|
||||
|
||||
#define USE_OSTREAM_ONLY 1
|
||||
|
||||
class LyXLex;
|
||||
|
||||
@ -295,7 +294,6 @@ public:
|
||||
void lyxWriteChanges(LyXFont const & orgfont, ostream &) const;
|
||||
|
||||
|
||||
#ifdef USE_OSTREAM_ONLY
|
||||
/** Writes the head of the LaTeX needed to change to this font.
|
||||
Writes to string, the head of the LaTeX needed to change
|
||||
to this font. Returns number of chars written. Base is the
|
||||
@ -309,21 +307,7 @@ public:
|
||||
*/
|
||||
int latexWriteEndChanges(ostream &, LyXFont const & base,
|
||||
LyXFont const & next) const;
|
||||
#else
|
||||
/** Writes the head of the LaTeX needed to change to this font.
|
||||
Writes to string, the head of the LaTeX needed to change
|
||||
to this font. Returns number of chars written. Base is the
|
||||
font state active now.
|
||||
*/
|
||||
int latexWriteStartChanges(string &, LyXFont const & base,
|
||||
LyXFont const & prev) const;
|
||||
/** Writes tha tail of the LaTeX needed to chagne to this font.
|
||||
Returns number of chars written. Base is the font state we want
|
||||
to achieve.
|
||||
*/
|
||||
int latexWriteEndChanges(string &, LyXFont const & base,
|
||||
LyXFont const & next) const;
|
||||
#endif
|
||||
|
||||
/// Build GUI description of font state
|
||||
string stateText() const;
|
||||
|
||||
|
@ -150,7 +150,6 @@ public:
|
||||
///
|
||||
void readSimpleWholeFile(istream &);
|
||||
|
||||
#ifdef USE_OSTREAM_ONLY
|
||||
///
|
||||
LyXParagraph * TeXOnePar(ostream &, TexRow & texrow,
|
||||
ostream & foot, TexRow & foot_texrow,
|
||||
@ -162,19 +161,6 @@ public:
|
||||
LyXParagraph * TeXEnvironment(ostream &, TexRow & texrow,
|
||||
ostream & foot, TexRow & foot_texrow,
|
||||
int & foot_count);
|
||||
#else
|
||||
///
|
||||
LyXParagraph * TeXOnePar(string & file, TexRow & texrow,
|
||||
string & foot, TexRow & foot_texrow,
|
||||
int & foot_count);
|
||||
///
|
||||
bool SimpleTeXOnePar(string & file, TexRow & texrow);
|
||||
|
||||
///
|
||||
LyXParagraph * TeXEnvironment(string & file, TexRow & texrow,
|
||||
string & foot, TexRow & foot_texrow,
|
||||
int & foot_count);
|
||||
#endif
|
||||
///
|
||||
LyXParagraph * Clone() const;
|
||||
|
||||
@ -484,7 +470,6 @@ public:
|
||||
#endif
|
||||
///
|
||||
bool linuxDocConvertChar(char c, string & sgml_string);
|
||||
#ifdef USE_OSTREAM_ONLY
|
||||
///
|
||||
void DocBookContTableRows(ostream &, string & extra, int & desc_on,
|
||||
size_type i,
|
||||
@ -492,15 +477,6 @@ public:
|
||||
///
|
||||
void SimpleDocBookOneTablePar(ostream &, string & extra,
|
||||
int & desc_on, int depth);
|
||||
#else
|
||||
///
|
||||
void DocBookContTableRows(string & file, string & extra, int & desc_on,
|
||||
size_type i,
|
||||
int current_cell_number, int & column);
|
||||
///
|
||||
void SimpleDocBookOneTablePar(string & file, string & extra,
|
||||
int & desc_on, int depth);
|
||||
#endif
|
||||
private:
|
||||
/** A font entry covers a range of positions. Notice that the
|
||||
entries in the list are inserted in random order.
|
||||
@ -539,7 +515,6 @@ private:
|
||||
typedef list<InsetTable> InsetList;
|
||||
///
|
||||
InsetList insetlist;
|
||||
#ifdef USE_OSTREAM_ONLY
|
||||
///
|
||||
LyXParagraph * TeXDeeper(ostream &, TexRow & texrow,
|
||||
ostream & foot, TexRow & foot_texrow,
|
||||
@ -567,35 +542,6 @@ private:
|
||||
LyXLayout const & style,
|
||||
size_type & i,
|
||||
int & column, char const c);
|
||||
#else
|
||||
///
|
||||
LyXParagraph * TeXDeeper(string & file, TexRow & texrow,
|
||||
string & foot, TexRow & foot_texrow,
|
||||
int & foot_count);
|
||||
///
|
||||
LyXParagraph * TeXFootnote(string & file, TexRow & texrow,
|
||||
string & foot, TexRow & foot_texrow,
|
||||
int & foot_count,
|
||||
LyXDirection par_direction);
|
||||
///
|
||||
bool SimpleTeXOneTablePar(string & file, TexRow & texrow);
|
||||
///
|
||||
bool TeXContTableRows(string & file, size_type i,
|
||||
int current_cell_number,
|
||||
int & column, TexRow & texrow);
|
||||
///
|
||||
void SimpleTeXBlanks(string & file, TexRow & texrow,
|
||||
size_type const i,
|
||||
int & column, LyXFont const & font,
|
||||
LyXLayout const & style);
|
||||
///
|
||||
void SimpleTeXSpecialChars(string & file, TexRow & texrow,
|
||||
LyXFont & font, LyXFont & running_font,
|
||||
LyXFont & basefont, bool & open_font,
|
||||
LyXLayout const & style,
|
||||
size_type & i,
|
||||
int & column, char const c);
|
||||
#endif
|
||||
///
|
||||
unsigned int id_;
|
||||
///
|
||||
|
@ -299,58 +299,19 @@ void InsetFormula::Write(ostream & os) const
|
||||
}
|
||||
|
||||
|
||||
int InsetFormula::Latex(ostream & os, signed char fragile,
|
||||
#ifdef USE_OSTREAM_ONLY
|
||||
bool) const
|
||||
#else
|
||||
bool free_spc) const
|
||||
#endif
|
||||
int InsetFormula::Latex(ostream & os, signed char fragile, bool) const
|
||||
{
|
||||
int ret = 0;
|
||||
//#warning Alejandro, the number of lines is not returned in this case
|
||||
// This problem will disapear at 0.13.
|
||||
#ifdef USE_OSTREAM_ONLY
|
||||
if (fragile < 0)
|
||||
par->Write(os);
|
||||
else
|
||||
mathed_write(par, os, &ret, fragile, label.c_str());
|
||||
|
||||
#else
|
||||
string output;
|
||||
InsetFormula::Latex(output, fragile, free_spc);
|
||||
os << output;
|
||||
#endif
|
||||
return ret;
|
||||
}
|
||||
|
||||
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
int InsetFormula::Latex(string & file, signed char fragile) const
|
||||
{
|
||||
int ret = 0;
|
||||
//#warning Alejandro, the number of lines is not returned in this case
|
||||
// This problem will disapear at 0.13.
|
||||
if (fragile < 0)
|
||||
par->Write(file);
|
||||
else
|
||||
mathed_write(par, file, &ret, fragile, label.c_str());
|
||||
return ret;
|
||||
}
|
||||
|
||||
|
||||
int InsetFormula::Linuxdoc(string &/*file*/) const
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
int InsetFormula::DocBook(string &/*file*/) const
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
|
||||
#else
|
||||
|
||||
int InsetFormula::Linuxdoc(ostream &) const
|
||||
{
|
||||
return 0;
|
||||
@ -361,7 +322,6 @@ int InsetFormula::DocBook(ostream&) const
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
// Check if uses AMS macros
|
||||
|
@ -50,19 +50,10 @@ public:
|
||||
void Read(LyXLex & lex);
|
||||
///
|
||||
int Latex(ostream &, signed char fragile, bool free_spc) const;
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
///
|
||||
int Latex(string & file, signed char fragile, bool free_spc) const;
|
||||
///
|
||||
int Linuxdoc(string & file) const;
|
||||
///
|
||||
int DocBook(string & file) const;
|
||||
#else
|
||||
///
|
||||
int Linuxdoc(ostream &) const;
|
||||
///
|
||||
int DocBook(ostream &) const;
|
||||
#endif
|
||||
///
|
||||
void Validate(LaTeXFeatures &) const;
|
||||
///
|
||||
|
@ -79,29 +79,6 @@ int InsetFormulaMacro::Latex(ostream & os, signed char /*fragile*/,
|
||||
}
|
||||
|
||||
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
int InsetFormulaMacro::Latex(string &file, signed char /*fragile*/,
|
||||
bool /*free_spacing*/) const
|
||||
{
|
||||
int ret = 1;
|
||||
tmacro->WriteDef(file);
|
||||
return ret;
|
||||
}
|
||||
|
||||
|
||||
int InsetFormulaMacro::Linuxdoc(string &/*file*/) const
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
int InsetFormulaMacro::DocBook(string &/*file*/) const
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
|
||||
#else
|
||||
|
||||
int InsetFormulaMacro::Linuxdoc(ostream &) const
|
||||
{
|
||||
return 0;
|
||||
@ -112,7 +89,6 @@ int InsetFormulaMacro::DocBook(ostream &) const
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
void InsetFormulaMacro::Read(LyXLex & lex)
|
||||
|
@ -49,19 +49,10 @@ public:
|
||||
void Write(ostream & os) const;
|
||||
///
|
||||
int Latex(ostream & os, signed char fragile, bool free_spc) const;
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
///
|
||||
int Latex(string & file, signed char fragile, bool free_spc) const;
|
||||
///
|
||||
int Linuxdoc(string & file) const;
|
||||
///
|
||||
int DocBook(string & file) const;
|
||||
#else
|
||||
///
|
||||
int Linuxdoc(ostream &) const;
|
||||
///
|
||||
int DocBook(ostream &) const;
|
||||
#endif
|
||||
///
|
||||
Inset * Clone() const;
|
||||
|
||||
|
@ -33,8 +33,6 @@
|
||||
|
||||
class Painter;
|
||||
|
||||
#define USE_OSTREAM_ONLY 1
|
||||
|
||||
///
|
||||
enum math_align {
|
||||
///
|
||||
@ -234,11 +232,6 @@ class MathedInset {
|
||||
/// Write LaTeX and Lyx code
|
||||
virtual void Write(ostream &) = 0;
|
||||
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
/// Write LaTeX and Lyx code
|
||||
virtual void Write(string & file) = 0;
|
||||
#endif
|
||||
|
||||
/// Reproduces itself
|
||||
virtual MathedInset * Clone() = 0;
|
||||
|
||||
@ -336,11 +329,6 @@ class MathParInset: public MathedInset {
|
||||
/// Write LaTeX code
|
||||
virtual void Write(ostream &);
|
||||
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
/// Write LaTeX code
|
||||
virtual void Write(string & file);
|
||||
#endif
|
||||
|
||||
///
|
||||
virtual void Metrics();
|
||||
///
|
||||
@ -496,12 +484,6 @@ class MathMatrixInset: public MathParInset {
|
||||
void draw(Painter &, int, int);
|
||||
///
|
||||
void Write(ostream &);
|
||||
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
///
|
||||
void Write(string & file);
|
||||
#endif
|
||||
|
||||
///
|
||||
void Metrics();
|
||||
///
|
||||
@ -551,12 +533,6 @@ LyxArrayBase * mathed_parse(unsigned flags, LyxArrayBase * data,
|
||||
void mathed_write(MathParInset *, ostream &, int *, char fragile,
|
||||
char const * label = 0);
|
||||
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
///
|
||||
void mathed_write(MathParInset *, string &, int *, char fragile,
|
||||
char const * label = 0);
|
||||
#endif
|
||||
|
||||
///
|
||||
void mathed_parser_file(istream &, int);
|
||||
///
|
||||
|
@ -331,8 +331,15 @@ private:
|
||||
bool init_deco_table::init = false;
|
||||
static init_deco_table idt;
|
||||
|
||||
// If we had exceptions we could return a reference in stead and not
|
||||
// have to check for a null pointer in mathed_draw_deco
|
||||
|
||||
#define USE_EXCEPTIONS 0
|
||||
#if USE_EXCEPTIONS
|
||||
struct deco_not_found {};
|
||||
|
||||
static
|
||||
int search_deco(int code)
|
||||
math_deco_struct const & search_deco(int code)
|
||||
{
|
||||
math_deco_struct * res =
|
||||
lower_bound(math_deco_table,
|
||||
@ -340,10 +347,25 @@ int search_deco(int code)
|
||||
code, math_deco_compare());
|
||||
if (res != math_deco_table + math_deco_table_size &&
|
||||
res->code == code)
|
||||
return res - math_deco_table;
|
||||
return -1;
|
||||
return *res;
|
||||
throw deco_not_found();
|
||||
}
|
||||
|
||||
#else
|
||||
|
||||
static
|
||||
math_deco_struct const * search_deco(int code)
|
||||
{
|
||||
math_deco_struct * res =
|
||||
lower_bound(math_deco_table,
|
||||
math_deco_table + math_deco_table_size,
|
||||
code, math_deco_compare());
|
||||
if (res != math_deco_table + math_deco_table_size &&
|
||||
res->code == code)
|
||||
return res;
|
||||
return 0;
|
||||
}
|
||||
#endif
|
||||
|
||||
void mathed_draw_deco(Painter & pain, int x, int y, int w, int h, int code)
|
||||
{
|
||||
@ -351,15 +373,39 @@ void mathed_draw_deco(Painter & pain, int x, int y, int w, int h, int code)
|
||||
float xx, yy, x2, y2;
|
||||
int i = 0;
|
||||
|
||||
int j = search_deco(code);
|
||||
if (j < 0) return;
|
||||
#if USE_EXCEPTIONS
|
||||
math_deco_struct mds;
|
||||
try {
|
||||
mds = search_deco(code);
|
||||
}
|
||||
catch (deco_not_found) {
|
||||
// Should this ever happen?
|
||||
lyxerr << "Deco was not found. Programming error?" << endl;
|
||||
return;
|
||||
}
|
||||
|
||||
int r = math_deco_table[j].angle;
|
||||
float * d = math_deco_table[j].data;
|
||||
int r = mds.angle;
|
||||
float * d = mds.data;
|
||||
|
||||
if (h > 70 && (math_deco_table[j].code == int('(')
|
||||
|| math_deco_table[j].code == int(')')))
|
||||
if (h > 70 && (mds.code == int('(')
|
||||
|| mds.code == int(')')))
|
||||
d = parenthHigh;
|
||||
#else
|
||||
math_deco_struct const * mds = search_deco(code);
|
||||
if (!mds) {
|
||||
// Should this ever happen?
|
||||
lyxerr << "Deco was not found. Programming error?" << endl;
|
||||
return;
|
||||
}
|
||||
|
||||
|
||||
int r = mds->angle;
|
||||
float * d = mds->data;
|
||||
|
||||
if (h > 70 && (mds->code == int('(')
|
||||
|| mds->code == int(')')))
|
||||
d = parenthHigh;
|
||||
#endif
|
||||
|
||||
mt.rota(r);
|
||||
mt.escala(w, h);
|
||||
@ -393,7 +439,7 @@ void mathed_draw_deco(Painter & pain, int x, int y, int w, int h, int code)
|
||||
{
|
||||
int xp[32], yp[32];
|
||||
n = int(d[i++]);
|
||||
for (j = 0; j < n; ++j) {
|
||||
for (int j = 0; j < n; ++j) {
|
||||
xx = d[i++]; yy = d[i++];
|
||||
// lyxerr << " " << xx << " " << yy << " ";
|
||||
if (code == 4)
|
||||
|
@ -47,10 +47,6 @@ public:
|
||||
void draw(Painter &, int, int);
|
||||
///
|
||||
void Write(ostream &);
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
///
|
||||
void Write(string & file);
|
||||
#endif
|
||||
///
|
||||
void Metrics();
|
||||
///
|
||||
@ -80,10 +76,6 @@ public:
|
||||
void draw(Painter &, int, int);
|
||||
///
|
||||
void Write(ostream &);
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
///
|
||||
void Write(string & file);
|
||||
#endif
|
||||
///
|
||||
void Metrics();
|
||||
///
|
||||
@ -114,10 +106,6 @@ public:
|
||||
void draw(Painter &, int, int);
|
||||
///
|
||||
void Write(ostream &);
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
///
|
||||
void Write(string & file);
|
||||
#endif
|
||||
///
|
||||
void Metrics();
|
||||
protected:
|
||||
@ -137,10 +125,6 @@ public:
|
||||
void draw(Painter &, int, int);
|
||||
///
|
||||
void Write(ostream &);
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
///
|
||||
void Write(string & file);
|
||||
#endif
|
||||
///
|
||||
inline void Metrics();
|
||||
///
|
||||
@ -164,10 +148,6 @@ public:
|
||||
void draw(Painter &, int, int);
|
||||
///
|
||||
void Write(ostream &);
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
///
|
||||
void Write(string & file);
|
||||
#endif
|
||||
///
|
||||
void Metrics();
|
||||
///
|
||||
@ -195,10 +175,6 @@ public:
|
||||
void draw(Painter &, int x, int baseline);
|
||||
///
|
||||
void Write(ostream &);
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
///
|
||||
void Write(string & file);
|
||||
#endif
|
||||
///
|
||||
void Metrics();
|
||||
///
|
||||
@ -222,10 +198,6 @@ public:
|
||||
void draw(Painter &, int x, int baseline);
|
||||
///
|
||||
void Write(ostream &);
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
///
|
||||
void Write(string & file);
|
||||
#endif
|
||||
///
|
||||
void Metrics();
|
||||
|
||||
@ -272,10 +244,6 @@ public:
|
||||
void draw(Painter &, int, int);
|
||||
///
|
||||
void Write(ostream &);
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
///
|
||||
void Write(string & file);
|
||||
#endif
|
||||
///
|
||||
void Metrics();
|
||||
protected:
|
||||
@ -297,10 +265,6 @@ public:
|
||||
void draw(Painter &, int, int);
|
||||
///
|
||||
void Write(ostream &);
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
///
|
||||
void Write(string & file);
|
||||
#endif
|
||||
///
|
||||
void Metrics();
|
||||
///
|
||||
@ -339,17 +303,6 @@ void MathFuncInset::Write(ostream & os)
|
||||
}
|
||||
|
||||
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
inline
|
||||
void MathFuncInset::Write(string & file)
|
||||
{
|
||||
file += '\\';
|
||||
file += name;
|
||||
file += ' ';
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
inline
|
||||
void MathSpaceInset::Metrics()
|
||||
{
|
||||
|
@ -158,7 +158,6 @@ void MathMacro::SetFocus(int x, int y)
|
||||
|
||||
void MathMacro::Write(ostream & os)
|
||||
{
|
||||
#ifdef USE_OSTREAM_ONLY
|
||||
if (tmplate->flags & MMF_Exp) {
|
||||
lyxerr[Debug::MATHED] << "Expand " << tmplate->flags
|
||||
<< ' ' << MMF_Exp << endl;
|
||||
@ -198,61 +197,9 @@ void MathMacro::Write(ostream & os)
|
||||
os << ' ';
|
||||
}
|
||||
}
|
||||
#else
|
||||
string output;
|
||||
MathMacro::Write(output);
|
||||
os << output;
|
||||
#endif
|
||||
}
|
||||
|
||||
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
void MathMacro::Write(string &file)
|
||||
{
|
||||
if (tmplate->flags & MMF_Exp) {
|
||||
lyxerr[Debug::MATHED] << "Expand " << tmplate->flags
|
||||
<< ' ' << MMF_Exp << endl;
|
||||
tmplate->update(this);
|
||||
tmplate->Write(file);
|
||||
} else {
|
||||
if (tmplate->flags & MMF_Env) {
|
||||
file += "\\begin{";
|
||||
file += name;
|
||||
file += "} ";
|
||||
} else {
|
||||
file += '\\';
|
||||
file += name;
|
||||
}
|
||||
// if (options) {
|
||||
// file += '[';
|
||||
// file += options;
|
||||
// file += ']';
|
||||
// }
|
||||
|
||||
if (!(tmplate->flags & MMF_Env) && nargs > 0)
|
||||
file += '{';
|
||||
|
||||
for (int i = 0; i < nargs; ++i) {
|
||||
array = args[i].array;
|
||||
MathParInset::Write(file);
|
||||
if (i < nargs - 1)
|
||||
file += "}{";
|
||||
}
|
||||
if (tmplate->flags & MMF_Env) {
|
||||
file += "\\end{";
|
||||
file += name;
|
||||
file += '}';
|
||||
} else {
|
||||
if (nargs > 0)
|
||||
file += '}';
|
||||
else
|
||||
file += ' ';
|
||||
}
|
||||
}
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
/*--------------- Macro argument -----------------------------------*/
|
||||
|
||||
MathMacroArgument::MathMacroArgument(int n)
|
||||
@ -314,34 +261,14 @@ void MathMacroArgument::Metrics()
|
||||
|
||||
void MathMacroArgument::Write(ostream & os)
|
||||
{
|
||||
#ifdef USE_OSTREAM_ONLY
|
||||
if (expnd_mode) {
|
||||
MathParInset::Write(os);
|
||||
} else {
|
||||
os << '#' << number << ' ';
|
||||
}
|
||||
#else
|
||||
string output;
|
||||
MathMacroArgument::Write(output);
|
||||
os << output;
|
||||
#endif
|
||||
}
|
||||
|
||||
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
void MathMacroArgument::Write(string & file)
|
||||
{
|
||||
if (expnd_mode) {
|
||||
MathParInset::Write(file);
|
||||
} else {
|
||||
file += '#';
|
||||
file += tostr(number);
|
||||
file += ' ';
|
||||
}
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
/* --------------------- MathMacroTemplate ---------------------------*/
|
||||
|
||||
MathMacroTemplate::MathMacroTemplate(char const * nm, int na, int flg):
|
||||
@ -463,30 +390,6 @@ void MathMacroTemplate::WriteDef(ostream & os)
|
||||
}
|
||||
|
||||
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
void MathMacroTemplate::WriteDef(string & file)
|
||||
{
|
||||
file += "\n\\newcommand{\\";
|
||||
file += name;
|
||||
file += '}';
|
||||
|
||||
if (nargs > 0 ) {
|
||||
file += '[';
|
||||
file += tostr(nargs);
|
||||
file += ']';
|
||||
}
|
||||
|
||||
file += '{';
|
||||
|
||||
for (int i = 0; i < nargs; ++i) {
|
||||
args[i].setExpand(false);
|
||||
}
|
||||
Write(file);
|
||||
file += "}\n";
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
void MathMacroTemplate::setArgument(LyxArrayBase * a, int i)
|
||||
{
|
||||
args[i].SetData(a);
|
||||
|
@ -50,10 +50,6 @@ public:
|
||||
MathedInset * Clone();
|
||||
///
|
||||
void Write(ostream &);
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
///
|
||||
void Write(string &);
|
||||
#endif
|
||||
///
|
||||
bool setArgumentIdx(int);
|
||||
///
|
||||
@ -120,17 +116,12 @@ public:
|
||||
void draw(Painter &, int x, int baseline);
|
||||
///
|
||||
void Write(ostream &);
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
///
|
||||
void Write(string &);
|
||||
#endif
|
||||
///
|
||||
void setNumber(int n) { number = n; }
|
||||
/// Is expanded or not
|
||||
void setExpand(bool e) { expnd_mode = e; }
|
||||
/// Is expanded or not
|
||||
bool getExpand() { return expnd_mode; }
|
||||
|
||||
private:
|
||||
///
|
||||
bool expnd_mode;
|
||||
@ -152,10 +143,6 @@ public:
|
||||
void Metrics();
|
||||
///
|
||||
void WriteDef(ostream &);
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
///
|
||||
void WriteDef(string &);
|
||||
#endif
|
||||
/// useful for special insets
|
||||
void setTCode(MathedTextCodes t) { tcode = t; }
|
||||
///
|
||||
|
@ -136,29 +136,9 @@ void MathRootInset::SetFocus(int x, int)
|
||||
|
||||
void MathRootInset::Write(ostream & os)
|
||||
{
|
||||
#ifdef USE_OSTREAM_ONLY
|
||||
os << '\\' << name << '[';
|
||||
uroot->Write(os);
|
||||
os << "]{";
|
||||
MathParInset::Write(os);
|
||||
os << '}';
|
||||
#else
|
||||
string output;
|
||||
MathRootInset::Write(output);
|
||||
os << output;
|
||||
#endif
|
||||
}
|
||||
|
||||
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
void MathRootInset::Write(string & outf)
|
||||
{
|
||||
outf += '\\';
|
||||
outf += name;
|
||||
outf += '[';
|
||||
uroot->Write(outf);
|
||||
outf += "]{";
|
||||
MathParInset::Write(outf);
|
||||
outf += '}';
|
||||
}
|
||||
#endif
|
||||
|
@ -40,12 +40,6 @@ class MathRootInset: public MathSqrtInset {
|
||||
void draw(Painter &, int x, int baseline);
|
||||
///
|
||||
void Write(ostream &);
|
||||
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
///
|
||||
void Write(string & file);
|
||||
#endif
|
||||
|
||||
///
|
||||
void Metrics();
|
||||
///
|
||||
|
@ -44,86 +44,29 @@ char const * math_font_name[] = {
|
||||
void
|
||||
MathSpaceInset::Write(ostream & os)
|
||||
{
|
||||
#ifdef USE_OSTREAM_ONLY
|
||||
if (space >= 0 && space < 6) {
|
||||
os << '\\' << latex_mathspace[space] << ' ';
|
||||
}
|
||||
#else
|
||||
if (space >= 0 && space < 6) {
|
||||
string output;
|
||||
MathSpaceInset::Write(output);
|
||||
os << output;
|
||||
}
|
||||
#endif
|
||||
}
|
||||
|
||||
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
void
|
||||
MathSpaceInset::Write(string & outf)
|
||||
{
|
||||
if (space >= 0 && space < 6) {
|
||||
outf += '\\';
|
||||
outf += latex_mathspace[space];
|
||||
outf += ' ';
|
||||
}
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
void
|
||||
MathDotsInset::Write(ostream & os)
|
||||
{
|
||||
#ifdef USE_OSTREAM_ONLY
|
||||
os << '\\' << name << ' ';
|
||||
#else
|
||||
string output;
|
||||
MathDotsInset::Write(output);
|
||||
os << output;
|
||||
#endif
|
||||
}
|
||||
|
||||
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
void
|
||||
MathDotsInset::Write(string & outf)
|
||||
{
|
||||
outf += '\\';
|
||||
outf += name;
|
||||
outf += ' ';
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
void MathSqrtInset::Write(ostream & os)
|
||||
{
|
||||
#ifdef USE_OSTREAM_ONLY
|
||||
os << '\\' << name << '{';
|
||||
MathParInset::Write(os);
|
||||
os << '}';
|
||||
#else
|
||||
string output;
|
||||
MathSqrtInset::Write(output);
|
||||
os << output;
|
||||
#endif
|
||||
}
|
||||
|
||||
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
void MathSqrtInset::Write(string & outf)
|
||||
{
|
||||
outf += '\\';
|
||||
outf += name;
|
||||
outf += '{';
|
||||
MathParInset::Write(outf);
|
||||
outf += '}';
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
void MathDelimInset::Write(ostream & os)
|
||||
{
|
||||
#ifdef USE_OSTREAM_ONLY
|
||||
latexkeys * l = (left != '|') ? lm_get_key_by_id(left, LM_TK_SYM): 0;
|
||||
latexkeys * r = (right != '|') ? lm_get_key_by_id(right, LM_TK_SYM): 0;
|
||||
os << "\\left";
|
||||
@ -147,85 +90,20 @@ void MathDelimInset::Write(ostream & os)
|
||||
os << char(right) << ' ';
|
||||
}
|
||||
}
|
||||
#else
|
||||
string output;
|
||||
MathDelimInset::Write(output);
|
||||
os << output;
|
||||
#endif
|
||||
}
|
||||
|
||||
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
void MathDelimInset::Write(string & outf)
|
||||
{
|
||||
latexkeys * l = (left != '|') ? lm_get_key_by_id(left, LM_TK_SYM): 0;
|
||||
latexkeys * r = (right != '|') ? lm_get_key_by_id(right, LM_TK_SYM): 0;
|
||||
outf += "\\left";
|
||||
if (l) {
|
||||
outf += '\\';
|
||||
outf += l->name;
|
||||
outf += ' ';
|
||||
} else {
|
||||
if (left == '{' || left == '}') {
|
||||
outf += '\\';
|
||||
outf += char(left);
|
||||
outf += ' ';
|
||||
} else {
|
||||
outf += char(left);
|
||||
outf += ' ';
|
||||
}
|
||||
}
|
||||
MathParInset::Write(outf);
|
||||
outf += "\\right";
|
||||
if (r) {
|
||||
outf += '\\';
|
||||
outf += r->name;
|
||||
outf += ' ';
|
||||
} else {
|
||||
if (right == '{' || right == '}') {
|
||||
outf += '\\';
|
||||
outf += char(right);
|
||||
outf += ' ';
|
||||
} else {
|
||||
outf += char(right);
|
||||
outf += ' ';
|
||||
}
|
||||
}
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
void MathDecorationInset::Write(ostream & os)
|
||||
{
|
||||
#ifdef USE_OSTREAM_ONLY
|
||||
latexkeys * l = lm_get_key_by_id(deco, LM_TK_WIDE);
|
||||
os << '\\' << l->name << '{';
|
||||
MathParInset::Write(os);
|
||||
os << '}';
|
||||
#else
|
||||
string output;
|
||||
MathDecorationInset::Write(output);
|
||||
os << output;
|
||||
#endif
|
||||
}
|
||||
|
||||
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
void MathDecorationInset::Write(string & outf)
|
||||
{
|
||||
latexkeys * l = lm_get_key_by_id(deco, LM_TK_WIDE);
|
||||
outf += '\\';
|
||||
outf += l->name;
|
||||
outf += '{';
|
||||
MathParInset::Write(outf);
|
||||
outf += '}';
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
void MathAccentInset::Write(ostream & os)
|
||||
{
|
||||
#ifdef USE_OSTREAM_ONLY
|
||||
latexkeys * l = lm_get_key_by_id(code, LM_TK_ACCENT);
|
||||
os << '\\' << l->name;
|
||||
if (code!= LM_not)
|
||||
@ -255,56 +133,11 @@ void MathAccentInset::Write(ostream & os)
|
||||
|
||||
if (code!= LM_not)
|
||||
os << '}';
|
||||
#else
|
||||
string output;
|
||||
MathAccentInset::Write(output);
|
||||
os << output;
|
||||
#endif
|
||||
}
|
||||
|
||||
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
void MathAccentInset::Write(string & outf)
|
||||
{
|
||||
latexkeys * l = lm_get_key_by_id(code, LM_TK_ACCENT);
|
||||
outf += '\\';
|
||||
outf += l->name;
|
||||
if (code!= LM_not)
|
||||
outf += '{';
|
||||
else
|
||||
outf += ' ';
|
||||
|
||||
if (inset) {
|
||||
inset->Write(outf);
|
||||
} else {
|
||||
if (fn>= LM_TC_RM && fn<= LM_TC_TEXTRM) {
|
||||
outf += '\\';
|
||||
outf += math_font_name[fn-LM_TC_RM];
|
||||
outf += '{';
|
||||
}
|
||||
if (MathIsSymbol(fn)) {
|
||||
latexkeys *l = lm_get_key_by_id(c, LM_TK_SYM);
|
||||
if (l) {
|
||||
outf += '\\';
|
||||
outf += l->name;
|
||||
outf += ' ';
|
||||
}
|
||||
} else
|
||||
outf += char(c);
|
||||
|
||||
if (fn>= LM_TC_RM && fn<= LM_TC_TEXTRM)
|
||||
outf += '}';
|
||||
}
|
||||
|
||||
if (code!= LM_not)
|
||||
outf += '}';
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
void MathBigopInset::Write(ostream & os)
|
||||
{
|
||||
#ifdef USE_OSTREAM_ONLY
|
||||
bool limp = GetLimits();
|
||||
|
||||
os << '\\' << name;
|
||||
@ -318,66 +151,21 @@ void MathBigopInset::Write(ostream & os)
|
||||
os << "\\nolimits ";
|
||||
else
|
||||
os << ' ';
|
||||
#else
|
||||
string output;
|
||||
MathBigopInset::Write(output);
|
||||
os << output;
|
||||
#endif
|
||||
}
|
||||
|
||||
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
void MathBigopInset::Write(string & outf)
|
||||
{
|
||||
bool limp = GetLimits();
|
||||
|
||||
outf += '\\';
|
||||
outf += name;
|
||||
|
||||
if (limp && !(sym!= LM_int && sym!= LM_oint && (GetStyle() == LM_ST_DISPLAY)))
|
||||
outf += "\\limits ";
|
||||
else
|
||||
if (!limp && (sym!= LM_int && sym!= LM_oint && (GetStyle() == LM_ST_DISPLAY)))
|
||||
outf += "\\nolimits ";
|
||||
else
|
||||
outf += ' ';
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
void MathFracInset::Write(ostream & os)
|
||||
{
|
||||
#ifdef USE_OSTREAM_ONLY
|
||||
os << '\\' << name << '{';
|
||||
MathParInset::Write(os);
|
||||
os << "}{";
|
||||
den->Write(os);
|
||||
os << '}';
|
||||
#else
|
||||
string output;
|
||||
MathFracInset::Write(output);
|
||||
os << output;
|
||||
#endif
|
||||
}
|
||||
|
||||
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
void MathFracInset::Write(string & outf)
|
||||
{
|
||||
outf += '\\';
|
||||
outf += name;
|
||||
outf += '{';
|
||||
MathParInset::Write(outf);
|
||||
outf += "}{";
|
||||
den->Write(outf);
|
||||
outf += '}';
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
void MathParInset::Write(ostream & os)
|
||||
{
|
||||
#ifdef USE_OSTREAM_ONLY
|
||||
if (!array) return;
|
||||
int brace = 0;
|
||||
latexkeys * l;
|
||||
@ -492,139 +280,11 @@ void MathParInset::Write(ostream & os)
|
||||
// Something like this should work too:
|
||||
os << string(brace, '}'); // not one-off error I hope.
|
||||
#endif
|
||||
#else
|
||||
if (!array) return;
|
||||
string output;
|
||||
MathParInset::Write(output);
|
||||
os << output;
|
||||
#endif
|
||||
}
|
||||
|
||||
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
void MathParInset::Write(string & outf)
|
||||
{
|
||||
if (!array) return;
|
||||
int brace = 0;
|
||||
latexkeys * l;
|
||||
MathedIter data(array);
|
||||
// hack
|
||||
MathedRowSt const * crow = getRowSt();
|
||||
data.Reset();
|
||||
|
||||
if (!Permit(LMPF_FIXED_SIZE)) {
|
||||
l = lm_get_key_by_id(size, LM_TK_STY);
|
||||
if (l) {
|
||||
outf += '\\';
|
||||
outf += l->name;
|
||||
outf += ' ';
|
||||
}
|
||||
}
|
||||
while (data.OK()) {
|
||||
byte cx = data.GetChar();
|
||||
if (cx>= ' ') {
|
||||
int ls;
|
||||
byte * s = data.GetString(ls);
|
||||
|
||||
if (data.FCode()>= LM_TC_RM && data.FCode()<= LM_TC_TEXTRM) {
|
||||
outf += '\\';
|
||||
outf += math_font_name[data.FCode()-LM_TC_RM];
|
||||
outf += '{';
|
||||
}
|
||||
while (ls>0) {
|
||||
if (MathIsSymbol(data.FCode())) {
|
||||
l = lm_get_key_by_id(*s,(data.FCode() == LM_TC_BSYM)?LM_TK_BIGSYM:LM_TK_SYM);
|
||||
if (l) {
|
||||
outf += '\\';
|
||||
outf += l->name;
|
||||
outf += ' ';
|
||||
} else {
|
||||
lyxerr << "Illegal symbol code[" << *s
|
||||
<< " " << ls << " " << data.FCode() << "]";
|
||||
}
|
||||
} else {
|
||||
// Is there a standard logical XOR?
|
||||
if ((data.FCode() == LM_TC_TEX && *s!= '{' && *s!= '}') ||
|
||||
(data.FCode() == LM_TC_SPECIAL))
|
||||
outf += '\\';
|
||||
else {
|
||||
if (*s == '{') ++brace;
|
||||
if (*s == '}') --brace;
|
||||
}
|
||||
if (*s == '}' && data.FCode() == LM_TC_TEX && brace<0)
|
||||
lyxerr <<"Math warning: Unexpected closing brace."
|
||||
<< endl;
|
||||
else
|
||||
outf += char(*s);
|
||||
}
|
||||
++s; --ls;
|
||||
}
|
||||
if (data.FCode()>= LM_TC_RM && data.FCode()<= LM_TC_TEXTRM)
|
||||
outf += '}';
|
||||
} else
|
||||
if (MathIsInset(cx)) {
|
||||
MathedInset *p = data.GetInset();
|
||||
if (cx == LM_TC_UP)
|
||||
outf += "^{";
|
||||
if (cx == LM_TC_DOWN)
|
||||
outf += "_{";
|
||||
p->Write(outf);
|
||||
if (cx == LM_TC_UP || cx == LM_TC_DOWN)
|
||||
outf += '}';
|
||||
data.Next();
|
||||
} else
|
||||
switch(cx) {
|
||||
case LM_TC_TAB:
|
||||
{
|
||||
outf += " & ";
|
||||
data.Next();
|
||||
break;
|
||||
}
|
||||
case LM_TC_CR:
|
||||
{
|
||||
if (crow) {
|
||||
if (!crow->isNumbered()) {
|
||||
outf += "\\nonumber ";
|
||||
}
|
||||
if (crow->getLabel()) {
|
||||
outf += "\\label{";
|
||||
outf += crow->getLabel();
|
||||
outf += "} ";
|
||||
}
|
||||
crow = crow->getNext();
|
||||
}
|
||||
outf += "\\\\\n";
|
||||
++number_of_newlines;
|
||||
data.Next();
|
||||
break;
|
||||
}
|
||||
default:
|
||||
lyxerr << "WMath Error: unrecognized code[" << cx << "]";
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
if (crow) {
|
||||
if (!crow->isNumbered()) {
|
||||
outf += "\\nonumber ";
|
||||
}
|
||||
if (crow->getLabel()) {
|
||||
outf += "\\label{";
|
||||
outf += crow->getLabel();
|
||||
outf += "} ";
|
||||
}
|
||||
}
|
||||
while (brace>0) {
|
||||
outf += '}';
|
||||
--brace;
|
||||
}
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
void MathMatrixInset::Write(ostream & os)
|
||||
{
|
||||
#ifdef USE_OSTREAM_ONLY
|
||||
if (GetType() == LM_OT_MATRIX){
|
||||
os << "\\begin{"
|
||||
<< name
|
||||
@ -646,46 +306,12 @@ void MathMatrixInset::Write(ostream & os)
|
||||
<< '}';
|
||||
++number_of_newlines;
|
||||
}
|
||||
#else
|
||||
string output;
|
||||
MathMatrixInset::Write(output);
|
||||
os << output;
|
||||
#endif
|
||||
}
|
||||
|
||||
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
void MathMatrixInset::Write(string & outf)
|
||||
{
|
||||
if (GetType() == LM_OT_MATRIX){
|
||||
outf += "\\begin{";
|
||||
outf += name;
|
||||
outf += '}';
|
||||
if (v_align == 't' || v_align == 'b') {
|
||||
outf += '[';
|
||||
outf += char(v_align);
|
||||
outf += ']';
|
||||
}
|
||||
outf += '{';
|
||||
outf += h_align;
|
||||
outf += "}\n";
|
||||
++number_of_newlines;
|
||||
}
|
||||
MathParInset::Write(outf);
|
||||
if (GetType() == LM_OT_MATRIX){
|
||||
outf += "\n\\end{";
|
||||
outf += name;
|
||||
outf += '}';
|
||||
++number_of_newlines;
|
||||
}
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
void mathed_write(MathParInset * p, ostream & os, int * newlines,
|
||||
char fragile, char const * label)
|
||||
{
|
||||
#ifdef USE_OSTREAM_ONLY
|
||||
number_of_newlines = 0;
|
||||
short mathed_env = p->GetType();
|
||||
|
||||
@ -744,70 +370,4 @@ void mathed_write(MathParInset * p, ostream & os, int * newlines,
|
||||
number_of_newlines += 2;
|
||||
}
|
||||
*newlines = number_of_newlines;
|
||||
#else
|
||||
string output;
|
||||
mathed_write(p, output, newlines, fragile, label);
|
||||
os << output;
|
||||
#endif
|
||||
}
|
||||
|
||||
|
||||
#ifndef USE_OSTREAM_ONLY
|
||||
void mathed_write(MathParInset * p, string & outf, int * newlines,
|
||||
char fragile, char const * label)
|
||||
{
|
||||
number_of_newlines = 0;
|
||||
short mathed_env = p->GetType();
|
||||
|
||||
if (mathed_env == LM_EN_INTEXT) {
|
||||
if (fragile) outf += "\\protect";
|
||||
outf += "\\( "; // changed from " \\( " (Albrecht Dress)
|
||||
}
|
||||
else {
|
||||
if (!suffixIs(outf, '\n')) {
|
||||
// in batchmode we need to make sure
|
||||
// a space before an equation doesn't
|
||||
// make the LaTeX output different
|
||||
// compared to "Exported LaTeX" ARRae
|
||||
// Modified to work in a cleaner and hopefully more general way
|
||||
// (JMarc)
|
||||
outf += "\n";
|
||||
++number_of_newlines;
|
||||
}
|
||||
if (mathed_env == LM_EN_DISPLAY){
|
||||
outf += "\\[\n";
|
||||
}
|
||||
else {
|
||||
outf += "\\begin{";
|
||||
outf += latex_mathenv[mathed_env];
|
||||
outf += "}\n";
|
||||
}
|
||||
++number_of_newlines;
|
||||
}
|
||||
|
||||
if (label && label[0]>' ' && mathed_env == LM_EN_EQUATION){
|
||||
outf += "\\label{";
|
||||
outf += label;
|
||||
outf += "}\n";
|
||||
++number_of_newlines;
|
||||
}
|
||||
|
||||
p->Write(outf);
|
||||
|
||||
if (mathed_env == LM_EN_INTEXT){
|
||||
if (fragile) outf += "\\protect";
|
||||
outf += " \\)";
|
||||
}
|
||||
else if (mathed_env == LM_EN_DISPLAY){
|
||||
outf += "\\]\n";
|
||||
++number_of_newlines;
|
||||
}
|
||||
else {
|
||||
outf += "\n\\end{";
|
||||
outf += latex_mathenv[mathed_env];
|
||||
outf += "}\n";
|
||||
number_of_newlines += 2;
|
||||
}
|
||||
*newlines = number_of_newlines;
|
||||
}
|
||||
#endif
|
||||
|
1889
src/paragraph.C
1889
src/paragraph.C
File diff suppressed because it is too large
Load Diff
@ -3,10 +3,6 @@
|
||||
#ifndef LYX_ALGO_H
|
||||
#define LYX_ALGO_H
|
||||
|
||||
#include <algorithm>
|
||||
|
||||
// using std::less;
|
||||
|
||||
// Both these functions should ideally be placed into namespace lyx.
|
||||
// Also the using std::less should not be used.
|
||||
|
||||
@ -19,7 +15,7 @@ bool sorted(For first, For last)
|
||||
if (first == last) return true;
|
||||
For tmp = first;
|
||||
while (++tmp != last) {
|
||||
if (less(*tmp, *first++)) return false;
|
||||
if (*tmp < *first++) return false;
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
479
src/table.C
479
src/table.C
@ -11,26 +11,24 @@
|
||||
|
||||
#include <config.h>
|
||||
|
||||
#include <cstdlib>
|
||||
#include "table.h"
|
||||
#include "vspace.h"
|
||||
#include "layout.h"
|
||||
#include "support/lstrings.h"
|
||||
#include <algorithm>
|
||||
using std::max;
|
||||
#include <cstdlib>
|
||||
|
||||
#ifdef __GNUG__
|
||||
#pragma implementation
|
||||
#endif
|
||||
|
||||
#ifdef USE_OSTREAM_ONLY
|
||||
#include "table.h"
|
||||
#include "vspace.h"
|
||||
#include "layout.h"
|
||||
#include "support/lstrings.h"
|
||||
#include "support/lyxmanip.h"
|
||||
#else
|
||||
extern void addNewlineAndDepth(string & file, int depth); // Jug 990923
|
||||
#endif
|
||||
|
||||
using std::max;
|
||||
|
||||
static int const WIDTH_OF_LINE = 5;
|
||||
|
||||
|
||||
/* konstruktor */
|
||||
LyXTable::LyXTable(int rows_arg, int columns_arg)
|
||||
{
|
||||
@ -956,7 +954,6 @@ void LyXTable::Read(istream & is)
|
||||
}
|
||||
|
||||
|
||||
#ifdef USE_OSTREAM_ONLY
|
||||
// cell <0 will tex the preamble
|
||||
// returns the number of printed newlines
|
||||
int LyXTable::TexEndOfCell(ostream & os, int cell)
|
||||
@ -1293,342 +1290,6 @@ int LyXTable::TexEndOfCell(ostream & os, int cell)
|
||||
}
|
||||
return ret;
|
||||
}
|
||||
#else
|
||||
// cell <0 will tex the preamble
|
||||
// returns the number of printed newlines
|
||||
int LyXTable::TexEndOfCell(string & file, int cell)
|
||||
{
|
||||
int i;
|
||||
int ret = 0;
|
||||
int tmp; // tmp2;
|
||||
int fcell, nvcell;
|
||||
if (ShouldBeVeryLastCell(cell)) {
|
||||
// the very end at the very beginning
|
||||
if (Linebreaks(cell))
|
||||
file += "\\smallskip{}}";
|
||||
if (IsMultiColumn(cell))
|
||||
file += '}';
|
||||
if (RotateCell(cell)) {
|
||||
file += "\n\\end{sideways}";
|
||||
++ret;
|
||||
}
|
||||
file += "\\\\\n";
|
||||
++ret;
|
||||
|
||||
tmp = 0;
|
||||
fcell = cell;
|
||||
while (!IsFirstCell(fcell)) --fcell;
|
||||
for (i = 0; i < NumberOfCellsInRow(fcell); ++i) {
|
||||
if (BottomLine(fcell + i))
|
||||
++tmp;
|
||||
}
|
||||
if (tmp == NumberOfCellsInRow(fcell)) {
|
||||
file += "\\hline ";
|
||||
} else {
|
||||
tmp = 0;
|
||||
for (i = 0; i < NumberOfCellsInRow(fcell); ++i) {
|
||||
if (BottomLine(fcell + i)) {
|
||||
file += "\\cline{";
|
||||
file += tostr(column_of_cell(fcell + i) + 1);
|
||||
file += '-';
|
||||
file += tostr(right_column_of_cell(fcell + i) + 1);
|
||||
file += "} ";
|
||||
tmp = 1;
|
||||
}
|
||||
}
|
||||
}
|
||||
if (tmp){
|
||||
file += '\n';
|
||||
++ret;
|
||||
}
|
||||
if (is_long_table)
|
||||
file += "\\end{longtable}";
|
||||
else
|
||||
file += "\\end{tabular}";
|
||||
if (rotate) {
|
||||
file += "\n\\end{sideways}";
|
||||
++ret;
|
||||
}
|
||||
} else {
|
||||
nvcell = NextVirtualCell(cell + 1);
|
||||
if (cell < 0){
|
||||
// preamble
|
||||
if (rotate) {
|
||||
file += "\\begin{sideways}\n";
|
||||
++ret;
|
||||
}
|
||||
if (is_long_table)
|
||||
file += "\\begin{longtable}{";
|
||||
else
|
||||
file += "\\begin{tabular}{";
|
||||
for (i = 0; i < columns; ++i) {
|
||||
if (column_info[i].left_line)
|
||||
file += '|';
|
||||
if (!column_info[i].align_special.empty()) {
|
||||
file += column_info[i].align_special.c_str();
|
||||
} else if (!column_info[i].p_width.empty()) {
|
||||
file += "p{";
|
||||
file += column_info[i].p_width;
|
||||
file += '}';
|
||||
} else {
|
||||
switch (column_info[i].alignment) {
|
||||
case LYX_ALIGN_LEFT:
|
||||
file += 'l';
|
||||
break;
|
||||
case LYX_ALIGN_RIGHT:
|
||||
file += 'r';
|
||||
break;
|
||||
default:
|
||||
file += 'c';
|
||||
break;
|
||||
}
|
||||
}
|
||||
if (column_info[i].right_line)
|
||||
file += '|';
|
||||
}
|
||||
file += "}\n";
|
||||
++ret;
|
||||
tmp = 0;
|
||||
if (GetNumberOfCells()) {
|
||||
fcell = 0;
|
||||
for (i = 0; i < NumberOfCellsInRow(fcell); ++i) {
|
||||
if (TopLine(fcell + i))
|
||||
++tmp;
|
||||
}
|
||||
if (tmp == NumberOfCellsInRow(fcell)){
|
||||
file += "\\hline ";
|
||||
} else {
|
||||
tmp = 0;
|
||||
for (i = 0; i < NumberOfCellsInRow(fcell); ++i) {
|
||||
if (TopLine(fcell + i)) {
|
||||
file += "\\cline{";
|
||||
file += tostr(column_of_cell(fcell + i) + 1);
|
||||
file += '-';
|
||||
file += tostr(right_column_of_cell(fcell + i) + 1);
|
||||
file += "} ";
|
||||
tmp = 1;
|
||||
}
|
||||
}
|
||||
}
|
||||
if (tmp){
|
||||
file += '\n';
|
||||
++ret;
|
||||
}
|
||||
}
|
||||
if (RotateCell(0)) {
|
||||
file += "\\begin{sideways}\n";
|
||||
++ret;
|
||||
}
|
||||
} else {
|
||||
// usual cells
|
||||
if (Linebreaks(cell))
|
||||
file += "\\smallskip{}}";
|
||||
if (IsMultiColumn(cell)){
|
||||
file += '}';
|
||||
}
|
||||
if (RotateCell(cell)) {
|
||||
file += "\n\\end{sideways}";
|
||||
++ret;
|
||||
}
|
||||
if (IsLastCell(cell)) {
|
||||
int row = row_of_cell(cell);
|
||||
string hline1, hline2;
|
||||
bool print_hline = true;
|
||||
bool flag1 = IsLongTable() &&
|
||||
((row == endhead) || (row == endfirsthead) ||
|
||||
(row == endfoot) || (row == endlastfoot));
|
||||
++row;
|
||||
bool flag2 = IsLongTable() &&
|
||||
((row <= endhead) || (row <= endfirsthead) ||
|
||||
(row <= endfoot) || (row <= endlastfoot));
|
||||
--row;
|
||||
// print the bottom hline only if (otherwise it is doubled):
|
||||
// - is no LongTable
|
||||
// - there IS a first-header
|
||||
// - the next row is no special header/footer
|
||||
// & this row is no special header/footer
|
||||
// - the next row is a special header/footer
|
||||
// & this row is a special header/footer
|
||||
bool pr_top_hline = (flag1 && flag2) || (!flag1 && !flag2) ||
|
||||
(endfirsthead == endhead);
|
||||
file += "\\\\\n";
|
||||
++ret;
|
||||
tmp = 0;
|
||||
fcell = cell;
|
||||
while (!IsFirstCell(fcell))
|
||||
--fcell;
|
||||
for (i = 0; i < NumberOfCellsInRow(cell); ++i) {
|
||||
if (BottomLine(fcell + i))
|
||||
++tmp;
|
||||
}
|
||||
if (tmp == NumberOfCellsInRow(cell)){
|
||||
file += "\\hline ";
|
||||
hline1 = "\\hline ";
|
||||
} else {
|
||||
tmp = 0;
|
||||
for (i = 0; i < NumberOfCellsInRow(fcell); ++i) {
|
||||
if (BottomLine(fcell + i)){
|
||||
file += "\\cline{";
|
||||
file += tostr(column_of_cell(fcell + i) + 1);
|
||||
file += '-';
|
||||
file += tostr(right_column_of_cell(fcell + i) + 1);
|
||||
file += "} ";
|
||||
hline1 += "\\cline{";
|
||||
hline1 += tostr(column_of_cell(fcell + i) + 1);
|
||||
hline1 += '-';
|
||||
hline1 += tostr(right_column_of_cell(fcell + i) + 1);
|
||||
hline1 += "} ";
|
||||
tmp = 1;
|
||||
}
|
||||
}
|
||||
}
|
||||
if (tmp){
|
||||
file += '\n';
|
||||
++ret;
|
||||
}
|
||||
if (IsLongTable() && (row == endfoot)) {
|
||||
file += "\\endfoot\n";
|
||||
++ret;
|
||||
print_hline = false; // no double line below footer
|
||||
}
|
||||
if (IsLongTable() && (row == endlastfoot)) {
|
||||
file += "\\endlastfoot\n";
|
||||
++ret;
|
||||
print_hline = false; // no double line below footer
|
||||
}
|
||||
if (IsLongTable() && row_info[row].newpage) {
|
||||
file += "\\newpage\n";
|
||||
++ret;
|
||||
print_hline = false; // no line below a \\newpage-command
|
||||
}
|
||||
tmp = 0;
|
||||
if (nvcell < numberofcells && (cell < GetNumberOfCells() - 1) &&
|
||||
!ShouldBeVeryLastCell(cell)) {
|
||||
fcell = nvcell;
|
||||
for (i = 0; i < NumberOfCellsInRow(fcell); ++i) {
|
||||
if (TopLine(fcell + i))
|
||||
++tmp;
|
||||
}
|
||||
if (tmp == NumberOfCellsInRow(fcell)) {
|
||||
if (print_hline)
|
||||
file += "\\hline ";
|
||||
hline2 = "\\hline ";
|
||||
} else {
|
||||
tmp = 0;
|
||||
for (i = 0; i < NumberOfCellsInRow(fcell); ++i) {
|
||||
if (TopLine(fcell + i)) {
|
||||
if (print_hline) {
|
||||
file += "\\cline{";
|
||||
file += tostr(column_of_cell(fcell+i)+1);
|
||||
file += '-';
|
||||
file += tostr(right_column_of_cell(fcell+i)+1);
|
||||
file += "} ";
|
||||
}
|
||||
hline2 += "\\cline{";
|
||||
hline2 += tostr(column_of_cell(fcell+i)+1);
|
||||
hline2 += '-';
|
||||
hline2 += tostr(right_column_of_cell(fcell+i)+1);
|
||||
hline2 += "} ";
|
||||
tmp = 1;
|
||||
}
|
||||
}
|
||||
}
|
||||
if (tmp && print_hline){
|
||||
file += '\n';
|
||||
++ret;
|
||||
}
|
||||
}
|
||||
// the order here is important as if one defines two
|
||||
// or more things in one line only the first entry is
|
||||
// displayed the other are set to an empty-row. This
|
||||
// is important if I have a footer and want that the
|
||||
// lastfooter is NOT displayed!!!
|
||||
bool sflag2 = (row == endhead) || (row == endfirsthead) ||
|
||||
(row == endfoot) || (row == endlastfoot);
|
||||
--row;
|
||||
// sflag2 = IsLongTable() && (row >= 0) &&
|
||||
// (sflag2 || (row == endhead) || (row == endfirsthead));
|
||||
row += 2;
|
||||
bool sflag1 = IsLongTable() && (row != endhead) &&
|
||||
(row != endfirsthead) &&
|
||||
((row == endfoot) || (row == endlastfoot));
|
||||
--row;
|
||||
if (IsLongTable() && (row == endhead)) {
|
||||
file += "\\endhead\n";
|
||||
++ret;
|
||||
}
|
||||
if (IsLongTable() && (row == endfirsthead)) {
|
||||
file += "\\endfirsthead\n";
|
||||
++ret;
|
||||
}
|
||||
if (sflag1) { // add the \hline for next foot row
|
||||
if (!hline1.empty()) {
|
||||
file += hline1 + '\n';
|
||||
++ret;
|
||||
}
|
||||
}
|
||||
// add the \hline for the first row
|
||||
if (pr_top_hline && sflag2) {
|
||||
if (!hline2.empty()) {
|
||||
file += hline2 + '\n';
|
||||
++ret;
|
||||
}
|
||||
}
|
||||
if (nvcell < numberofcells && RotateCell(nvcell)) {
|
||||
file += "\\begin{sideways}\n";
|
||||
++ret;
|
||||
}
|
||||
} else {
|
||||
file += "&\n";
|
||||
++ret;
|
||||
if (nvcell < numberofcells && RotateCell(nvcell)) {
|
||||
file += "\\begin{sideways}\n";
|
||||
++ret;
|
||||
}
|
||||
}
|
||||
}
|
||||
if (nvcell < numberofcells && IsMultiColumn(nvcell)) {
|
||||
file += "\\multicolumn{";
|
||||
file += tostr(cells_in_multicolumn(nvcell));
|
||||
file += "}{";
|
||||
if (!cellinfo_of_cell(cell+1)->align_special.empty()) {
|
||||
file += cellinfo_of_cell(cell+1)->align_special;
|
||||
file += "}{";
|
||||
} else {
|
||||
if (LeftLine(nvcell))
|
||||
file += '|';
|
||||
if (!GetPWidth(nvcell).empty()) {
|
||||
file += "p{";
|
||||
file += GetPWidth(nvcell);
|
||||
file += '}';
|
||||
} else {
|
||||
switch (GetAlignment(nvcell)) {
|
||||
case LYX_ALIGN_LEFT: file += 'l'; break;
|
||||
case LYX_ALIGN_RIGHT: file += 'r'; break;
|
||||
default: file += 'c'; break;
|
||||
}
|
||||
}
|
||||
if (RightLine(nvcell))
|
||||
file += '|';
|
||||
//if (column_of_cell(cell+2)!= 0 && LeftLine(cell+2))
|
||||
if (((nvcell+1) < numberofcells) &&
|
||||
(NextVirtualCell(nvcell+1) < numberofcells) &&
|
||||
(column_of_cell(NextVirtualCell(nvcell+1))!= 0) &&
|
||||
LeftLine(NextVirtualCell(nvcell+1)))
|
||||
file += '|';
|
||||
file += "}{";
|
||||
}
|
||||
}
|
||||
if (nvcell < numberofcells && Linebreaks(nvcell)) {
|
||||
// !column_info[column_of_cell(nvcell)].p_width.empty()) {
|
||||
file += "\\parbox{";
|
||||
file += GetPWidth(nvcell);
|
||||
file += "}{\\smallskip{}";
|
||||
}
|
||||
}
|
||||
return ret;
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
#if 0
|
||||
@ -1772,7 +1433,6 @@ char const *LyXTable::getDocBookAlign(int cell, bool isColumn)
|
||||
}
|
||||
|
||||
|
||||
#ifdef USE_OSTREAM_ONLY
|
||||
// cell <0 will tex the preamble
|
||||
// returns the number of printed newlines
|
||||
int LyXTable::DocBookEndOfCell(ostream & os, int cell, int &depth)
|
||||
@ -1894,129 +1554,6 @@ int LyXTable::DocBookEndOfCell(ostream & os, int cell, int &depth)
|
||||
}
|
||||
return ret;
|
||||
}
|
||||
#else
|
||||
// cell <0 will tex the preamble
|
||||
// returns the number of printed newlines
|
||||
int LyXTable::DocBookEndOfCell(string & file, int cell, int &depth)
|
||||
{
|
||||
int i;
|
||||
int ret = 0;
|
||||
//int tmp; // tmp2; // unused
|
||||
int nvcell; // fcell; // unused
|
||||
if (ShouldBeVeryLastCell(cell)) {
|
||||
addNewlineAndDepth(file,--depth);
|
||||
file += "</ENTRY>";
|
||||
addNewlineAndDepth(file,--depth);
|
||||
file += "</ROW>";
|
||||
addNewlineAndDepth(file,--depth);
|
||||
file += "</TBODY>";
|
||||
addNewlineAndDepth(file,--depth);
|
||||
if (is_long_table)
|
||||
file += "</TGROUP>";
|
||||
else
|
||||
file += "</TGROUP>";
|
||||
addNewlineAndDepth(file,--depth);
|
||||
ret += 4;
|
||||
} else {
|
||||
nvcell = NextVirtualCell(cell+1);
|
||||
if (cell < 0) {
|
||||
// preamble
|
||||
if (is_long_table)
|
||||
file += "<TGROUP ";
|
||||
else
|
||||
file += "<TGROUP ";
|
||||
file += "COLS='";
|
||||
file += tostr(columns);
|
||||
file += "' COLSEP='1' ROWSEP='1'>";
|
||||
addNewlineAndDepth(file,++depth);
|
||||
++ret;
|
||||
for (i = 0; i < columns; ++i) {
|
||||
file += "<COLSPEC ALIGN='";
|
||||
file += getDocBookAlign(i, true);
|
||||
file += "' COLNAME='col";
|
||||
file += tostr(i+1);
|
||||
file += "' COLNUM='";
|
||||
file += tostr(i+1);
|
||||
file += "' COLSEP='";
|
||||
if (i == (columns-1)) {
|
||||
file += '1';
|
||||
} else {
|
||||
if (column_info[i].right_line ||
|
||||
column_info[i+1].left_line)
|
||||
file += '1';
|
||||
else
|
||||
file += '0';
|
||||
}
|
||||
file += "'>";
|
||||
addNewlineAndDepth(file, depth);
|
||||
++ret;
|
||||
#ifdef NOT_HANDLED_YET_AS_I_DONT_KNOW_HOW
|
||||
if (column_info[i].left_line)
|
||||
file += '|';
|
||||
#endif
|
||||
}
|
||||
file += "<TBODY>";
|
||||
addNewlineAndDepth(file,++depth);
|
||||
file += "<ROW>";
|
||||
addNewlineAndDepth(file,++depth);
|
||||
file += "<ENTRY ALIGN='";
|
||||
file += getDocBookAlign(0);
|
||||
file += "'";
|
||||
if (IsMultiColumn(0)) {
|
||||
file += " NAMEST='col1' NAMEEND='col";
|
||||
file += tostr(cells_in_multicolumn(0));
|
||||
file += "'";
|
||||
}
|
||||
file += ">";
|
||||
addNewlineAndDepth(file,++depth);
|
||||
ret += 3;
|
||||
} else {
|
||||
if (IsLastCell(cell)) {
|
||||
addNewlineAndDepth(file,--depth);
|
||||
file += "</ENTRY>";
|
||||
addNewlineAndDepth(file,--depth);
|
||||
file += "</ROW>";
|
||||
addNewlineAndDepth(file, depth);
|
||||
file += "<ROW>";
|
||||
addNewlineAndDepth(file,++depth);
|
||||
file += "<ENTRY ALIGN='";
|
||||
file += getDocBookAlign(cell+1);
|
||||
file += "' VALIGN='middle'";
|
||||
if (IsMultiColumn(cell+1)) {
|
||||
file += " NAMEST='col";
|
||||
file += tostr(column_of_cell(cell+1) + 1);
|
||||
file += "' NAMEEND='col";
|
||||
file += tostr(column_of_cell(cell+1) +
|
||||
cells_in_multicolumn(cell+1));
|
||||
file += "'";
|
||||
}
|
||||
file += ">";
|
||||
addNewlineAndDepth(file,++depth);
|
||||
ret += 4;
|
||||
} else {
|
||||
addNewlineAndDepth(file,--depth);
|
||||
file += "</ENTRY>";
|
||||
addNewlineAndDepth(file, depth);
|
||||
file += "<ENTRY ALIGN='";
|
||||
file += getDocBookAlign(cell+1);
|
||||
file += "' VALIGN='middle'";
|
||||
if (IsMultiColumn(cell+1)) {
|
||||
file += " NAMEST='col";
|
||||
file += tostr(column_of_cell(cell+1) + 1);
|
||||
file += "' NAMEEND='col";
|
||||
file += tostr(column_of_cell(cell+1) +
|
||||
cells_in_multicolumn(cell+1));
|
||||
file += "'";
|
||||
}
|
||||
file += ">";
|
||||
addNewlineAndDepth(file,++depth);
|
||||
ret += 3;
|
||||
}
|
||||
}
|
||||
}
|
||||
return ret;
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
bool LyXTable::IsMultiColumn(int cell)
|
||||
|
@ -19,7 +19,6 @@
|
||||
#include "LString.h"
|
||||
#include "support/LOstream.h"
|
||||
|
||||
#define USE_OSTREAM_ONLY 1
|
||||
|
||||
/* The features the text class offers for tables */
|
||||
|
||||
@ -167,17 +166,10 @@ public:
|
||||
|
||||
// cell <0 will tex the preamble
|
||||
// returns the number of printed newlines
|
||||
#ifdef USE_OSTREAM_ONLY
|
||||
///
|
||||
int TexEndOfCell(ostream &, int cell);
|
||||
///
|
||||
int DocBookEndOfCell(ostream &, int cell, int & depth);
|
||||
#else
|
||||
///
|
||||
int TexEndOfCell(string & file, int cell);
|
||||
///
|
||||
int DocBookEndOfCell(string & file, int cell, int & depth);
|
||||
#endif
|
||||
#if 0
|
||||
///
|
||||
int RoffEndOfCell(ostream &, int cell);
|
||||
|
67
src/text.C
67
src/text.C
@ -2966,14 +2966,10 @@ char * LyXText::SelectNextWord(float & value)
|
||||
/* Start the selection from here */
|
||||
sel_cursor = cursor;
|
||||
|
||||
#ifdef USE_OSTREAM_ONLY
|
||||
#ifdef HAVE_SSTREAM
|
||||
ostringstream latex;
|
||||
#else
|
||||
ostrstream latex;
|
||||
#endif
|
||||
#else
|
||||
string latex;
|
||||
#endif
|
||||
/* and find the end of the word
|
||||
(optional hyphens are part of a word) */
|
||||
@ -2982,22 +2978,16 @@ char * LyXText::SelectNextWord(float & value)
|
||||
|| (cursor.par->GetChar(cursor.pos) == LyXParagraph::META_INSET
|
||||
&& cursor.par->GetInset(cursor.pos) != 0
|
||||
&& cursor.par->GetInset(cursor.pos)->Latex(latex, 0, false) == 0
|
||||
#ifdef USE_OSTREAM_ONLY
|
||||
#ifdef HAVE_SSTREAM
|
||||
&& latex.str() == "\\-"
|
||||
#else
|
||||
&& string(latex.str(), 3) == "\\-" // this is not nice at all
|
||||
#endif
|
||||
#else
|
||||
&& latex == "\\-"
|
||||
#endif
|
||||
))
|
||||
cursor.pos++;
|
||||
|
||||
#ifdef USE_OSTREAM_ONLY
|
||||
#ifndef HAVE_SSTREAM
|
||||
delete [] latex.str();
|
||||
#endif
|
||||
#endif
|
||||
// Finally, we copy the word to a string and return it
|
||||
char * str = 0;
|
||||
@ -3024,15 +3014,11 @@ void LyXText::SelectSelectedWord()
|
||||
/* set the sel cursor */
|
||||
sel_cursor = cursor;
|
||||
|
||||
#ifdef USE_OSTREAM_ONLY
|
||||
#ifdef HAVE_SSTREAM
|
||||
ostringstream latex;
|
||||
#else
|
||||
ostrstream latex;
|
||||
#endif
|
||||
#else
|
||||
string latex;
|
||||
#endif
|
||||
|
||||
/* now find the end of the word */
|
||||
while (cursor.pos < cursor.par->Last()
|
||||
@ -3040,22 +3026,16 @@ void LyXText::SelectSelectedWord()
|
||||
|| (cursor.par->GetChar(cursor.pos) == LyXParagraph::META_INSET
|
||||
&& cursor.par->GetInset(cursor.pos) != 0
|
||||
&& cursor.par->GetInset(cursor.pos)->Latex(latex, 0, false) == 0
|
||||
#ifdef USE_OSTREAM_ONLY
|
||||
#ifdef HAVE_SSTREAM
|
||||
&& latex.str() == "\\-"
|
||||
#else
|
||||
&& string(latex.str(), 3) == "\\-"
|
||||
#endif
|
||||
#else
|
||||
&& latex == "\\-"
|
||||
#endif
|
||||
)))
|
||||
cursor.pos++;
|
||||
|
||||
#ifdef USE_OSTREAM_ONLY
|
||||
#ifndef HAVE_SSTREAM
|
||||
delete [] latex.str();
|
||||
#endif
|
||||
#endif
|
||||
SetCursor(cursor.par, cursor.pos);
|
||||
|
||||
@ -3732,10 +3712,33 @@ void LyXText::GetVisibleRow(int offset,
|
||||
y_top += LYX_PAPER_MARGIN;
|
||||
|
||||
if (row_ptr->par->pagebreak_top){ /* draw a top pagebreak */
|
||||
#if 0
|
||||
pain.line(0, offset + y_top + 2 * DefaultHeight(),
|
||||
paperwidth,
|
||||
offset + y_top + 2 * DefaultHeight(),
|
||||
LColor::pagebreak, Painter::line_onoffdash);
|
||||
#else
|
||||
LyXFont pb_font;
|
||||
pb_font.setColor(LColor::pagebreak).decSize();
|
||||
int w = 0, a = 0, d = 0;
|
||||
pain.line(0, offset + y_top + 2*DefaultHeight(),
|
||||
paperwidth,
|
||||
offset + y_top + 2*DefaultHeight(),
|
||||
LColor::pagebreak,
|
||||
Painter::line_onoffdash)
|
||||
.rectText(0,
|
||||
0,
|
||||
_("Page Break (top)"),
|
||||
pb_font,
|
||||
LColor::background,
|
||||
LColor::background, false, w, a, d);
|
||||
pain.rectText((paperwidth - w)/2,
|
||||
offset +y_top + 2*DefaultHeight() +d,
|
||||
_("Page Break (top)"),
|
||||
pb_font,
|
||||
LColor::background,
|
||||
LColor::background);
|
||||
#endif
|
||||
y_top += 3 * DefaultHeight();
|
||||
}
|
||||
|
||||
@ -3885,10 +3888,34 @@ void LyXText::GetVisibleRow(int offset,
|
||||
|
||||
/* draw a bottom pagebreak */
|
||||
if (firstpar->pagebreak_bottom) {
|
||||
#if 0
|
||||
pain.line(0, offset + y_bottom - 2 * DefaultHeight(),
|
||||
paperwidth,
|
||||
offset + y_bottom - 2 * DefaultHeight(),
|
||||
LColor::pagebreak, Painter::line_onoffdash);
|
||||
#else
|
||||
LyXFont pb_font;
|
||||
pb_font.setColor(LColor::pagebreak).decSize();
|
||||
int w = 0, a = 0, d = 0;
|
||||
pain.line(0,
|
||||
offset + y_bottom - 2 * DefaultHeight(),
|
||||
paperwidth,
|
||||
offset + y_bottom - 2 * DefaultHeight(),
|
||||
LColor::pagebreak,
|
||||
Painter::line_onoffdash)
|
||||
.rectText(0,
|
||||
0,
|
||||
_("Page Break (bottom)"),
|
||||
pb_font,
|
||||
LColor::background,
|
||||
LColor::background, false, w, a, d);
|
||||
pain.rectText((paperwidth - w)/2,
|
||||
offset +y_top + 2*DefaultHeight() +d,
|
||||
_("Page Break (bottom)"),
|
||||
pb_font,
|
||||
LColor::background,
|
||||
LColor::background);
|
||||
#endif
|
||||
y_bottom -= 3 * DefaultHeight();
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user