#include "support/debug.h"
#include "support/FileNameList.h"
#include "support/filetools.h"
-#include "support/FileZipListDir.h"
#include "support/gettext.h"
#include "support/lstrings.h"
-#include "support/lyxlib.h"
#include "support/os.h"
#include "support/Package.h"
#include "support/Path.h"
#include "support/Systemcall.h"
-using std::find_if;
-using std::string;
-using std::vector;
-using std::distance;
-
+using namespace std;
+using namespace lyx::support;
namespace lyx {
-using support::addName;
-using support::bformat;
-using support::changeExtension;
-using support::compare_ascii_no_case;
-using support::contains;
-using support::FileName;
-using support::FileNameList;
-using support::getExtension;
-using support::libFileSearch;
-using support::libScriptSearch;
-using support::makeAbsPath;
-using support::makeRelPath;
-using support::onlyFilename;
-using support::onlyPath;
-using support::package;
-using support::prefixIs;
-using support::quoteName;
-using support::removeExtension;
-using support::split;
-using support::subst;
-using support::Systemcall;
-
namespace Alert = lyx::frontend::Alert;
string const token_base("$$b");
string const token_to("$$o");
string const token_path("$$p");
+string const token_orig_path("$$r");
string result;
if (bp.papersize != PAPER_CUSTOM) {
- string const paper_size = bp.paperSizeName();
- if (paper_size != "b5" && paper_size != "foolscap")
+ string const paper_size = bp.paperSizeName(BufferParams::DVIPDFM);
+ if (!paper_size.empty())
result = "-p "+ paper_size;
if (bp.orientation == ORIENTATION_LANDSCAPE)
cit != path.end(); ++cit) {
Converter const & conv = converterlist_[*cit];
if (conv.latex)
+ if (contains(conv.from, "xetex"))
+ return OutputParams::XETEX;
if (contains(conv.to, "pdf"))
return OutputParams::PDFLATEX;
if (conv.xml)
// if no special converter defined, then we take the
// default one from ImageMagic.
string const from_ext = from_format.empty() ?
- getExtension(from_file.absFilename()) :
+ getExtension(from_file.absFileName()) :
formats.extension(from_format);
string const to_ext = formats.extension(to_format);
string const command =
- support::os::python() + ' ' +
+ os::python() + ' ' +
quoteName(libFileSearch("scripts", "convertDefault.py").toFilesystemEncoding()) +
' ' +
quoteName(from_ext + ':' + from_file.toFilesystemEncoding()) +
return true;
}
}
+
+ // only warn once per session and per file type
+ static std::map<string, string> warned;
+ if (warned.find(from_format) != warned.end() && warned.find(from_format)->second == to_format) {
+ return false;
+ }
+ warned.insert(make_pair(from_format, to_format));
+
Alert::error(_("Cannot convert file"),
bformat(_("No information for converting %1$s "
"format files to %2$s.\n"
// used anyway.
OutputParams runparams(buffer ? &buffer->params().encoding() : 0);
runparams.flavor = getFlavor(edgepath);
+
+ if (buffer) {
+ runparams.use_japanese = buffer->bufferFormat() == "platex";
+ runparams.use_indices = buffer->params().use_indices;
+ runparams.bibtex_command = (buffer->params().bibtex_command == "default") ?
+ string() : buffer->params().bibtex_command;
+ runparams.index_command = (buffer->params().index_command == "default") ?
+ string() : buffer->params().index_command;
+ }
// Some converters (e.g. lilypond) can only output files to the
// current directory, so we need to change the current directory.
// This has the added benefit that all other files that may be
// generated by the converter are deleted when LyX closes and do not
// clutter the real working directory.
- string const path(onlyPath(from_file.absFilename()));
+ string const path(onlyPath(from_file.absFileName()));
// Prevent the compiler from optimizing away p
FileName pp(path);
- support::PathChanger p(pp);
+ PathChanger p(pp);
// empty the error list before any new conversion takes place.
errorList.clear();
bool run_latex = false;
- string from_base = changeExtension(from_file.absFilename(), "");
- string to_base = changeExtension(to_file.absFilename(), "");
+ string from_base = changeExtension(from_file.absFileName(), "");
+ string to_base = changeExtension(to_file.absFileName(), "");
FileName infile;
FileName outfile = from_file;
for (Graph::EdgePath::const_iterator cit = edgepath.begin();
}
infile = outfile;
outfile = FileName(conv.result_dir.empty()
- ? changeExtension(from_file.absFilename(), conv.To->extension())
+ ? changeExtension(from_file.absFileName(), conv.To->extension())
: addName(subst(conv.result_dir,
token_base, from_base),
subst(conv.result_file,
- token_base, onlyFilename(from_base))));
+ token_base, onlyFileName(from_base))));
// if input and output files are equal, we use a
// temporary file as intermediary (JMarc)
if (buffer)
outfile = FileName(addName(buffer->temppath(), "tmpfile.out"));
else
- outfile = FileName(addName(package().temp_dir().absFilename(),
+ outfile = FileName(addName(package().temp_dir().absFileName(),
"tmpfile.out"));
}
// FIXME UNICODE
string const infile2 =
- to_utf8(makeRelPath(from_utf8(infile.absFilename()), from_utf8(path)));
+ to_utf8(makeRelPath(from_utf8(infile.absFileName()), from_utf8(path)));
string const outfile2 =
- to_utf8(makeRelPath(from_utf8(outfile.absFilename()), from_utf8(path)));
+ to_utf8(makeRelPath(from_utf8(outfile.absFileName()), from_utf8(path)));
string command = conv.command;
command = subst(command, token_from, quoteName(infile2));
command = subst(command, token_base, quoteName(from_base));
command = subst(command, token_to, quoteName(outfile2));
+ command = subst(command, token_path, quoteName(infile.onlyPath().absFileName()));
+ command = subst(command, token_orig_path, quoteName(orig_from.onlyPath().absFileName()));
command = libScriptSearch(command);
if (!conv.parselog.empty())
bool Converters::move(string const & fmt,
FileName const & from, FileName const & to, bool copy)
{
+ if (from == to)
+ return true;
bool no_errors = true;
- string const path = onlyPath(from.absFilename());
- string const base = onlyFilename(removeExtension(from.absFilename()));
- string const to_base = removeExtension(to.absFilename());
- string const to_extension = getExtension(to.absFilename());
+ string const path = onlyPath(from.absFileName());
+ string const base = onlyFileName(removeExtension(from.absFileName()));
+ string const to_base = removeExtension(to.absFileName());
+ string const to_extension = getExtension(to.absFileName());
- FileNameList const files = FileName(path).dirList(getExtension(from.absFilename()));
- if (from == to)
- return true;
- for (FileNameList::const_iterator it = files.begin();
+ support::FileNameList const files = FileName(path).dirList(getExtension(from.absFileName()));
+ for (support::FileNameList::const_iterator it = files.begin();
it != files.end(); ++it) {
- string const from2 = it->absFilename();
- string const file2 = onlyFilename(from2);
+ string const from2 = it->absFileName();
+ string const file2 = onlyFileName(from2);
if (prefixIs(file2, base)) {
string const to2 = changeExtension(
to_base + file2.substr(base.length()),
buffer.bufferErrors(terr, errorList);
// check return value from latex.run().
- if ((result & LaTeX::NO_LOGFILE)) {
+ if ((result & LaTeX::NO_LOGFILE) && !buffer.isClone()) {
docstring const str =
bformat(_("LaTeX did not run successfully. "
"Additionally, LyX could not locate "
"the LaTeX log %1$s."), from_utf8(name));
Alert::error(_("LaTeX failed"), str);
- } else if (result & LaTeX::NO_OUTPUT) {
+ } else if ((result & LaTeX::NO_OUTPUT) && !buffer.isClone()) {
Alert::warning(_("Output is empty"),
_("An empty output file was generated."));
}
void Converters::buildGraph()
{
+ // clear graph's data structures
G_.init(formats.size());
- ConverterList::iterator beg = converterlist_.begin();
+ // each of the converters knows how to convert one format to another
+ // so, for each of them, we create an arrow on the graph, going from
+ // the one to the other
+ ConverterList::iterator it = converterlist_.begin();
ConverterList::iterator const end = converterlist_.end();
- for (ConverterList::iterator it = beg; it != end ; ++it) {
- int const s = formats.getNumber(it->from);
- int const t = formats.getNumber(it->to);
- G_.addEdge(s,t);
+ for (; it != end ; ++it) {
+ int const from = formats.getNumber(it->from);
+ int const to = formats.getNumber(it->to);
+ G_.addEdge(from, to);
}
}
-std::vector<Format const *> const
-Converters::intToFormat(std::vector<int> const & input)
+vector<Format const *> const
+Converters::intToFormat(vector<int> const & input)
{
vector<Format const *> result(input.size());
}
+vector<Format const *> Converters::exportableFormats(bool only_viewable)
+{
+ vector<string> s = savers();
+ vector<Format const *> result = getReachable(s[0], only_viewable, true);
+ for (vector<string>::const_iterator it = s.begin() + 1;
+ it != s.end(); ++it) {
+ vector<Format const *> r =
+ getReachable(*it, only_viewable, false);
+ result.insert(result.end(), r.begin(), r.end());
+ }
+ return result;
+}
+
+
vector<string> Converters::loaders() const
{
vector<string> v;
}
+vector<string> Converters::savers() const
+{
+ vector<string> v;
+ v.push_back("docbook");
+ v.push_back("latex");
+ v.push_back("literate");
+ v.push_back("lyx");
+ v.push_back("xhtml");
+ v.push_back("pdflatex");
+ v.push_back("platex");
+ v.push_back("text");
+ v.push_back("xetex");
+ return v;
+}
+
+
} // namespace lyx