2000-06-12 11:27:15 +00:00
|
|
|
/* This file is part of
|
|
|
|
* ======================================================
|
|
|
|
*
|
|
|
|
* LyX, The Document Processor
|
|
|
|
*
|
|
|
|
* Copyright 1995 Matthias Ettrich
|
|
|
|
* Copyright 1995-2000 The LyX Team.
|
|
|
|
*
|
|
|
|
* ====================================================== */
|
|
|
|
|
|
|
|
#include <config.h>
|
|
|
|
|
|
|
|
#ifdef __GNUG__
|
|
|
|
#pragma implementation
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#include <algorithm>
|
|
|
|
|
|
|
|
#include "ExternalTemplate.h"
|
|
|
|
|
|
|
|
#include "lyxlex.h"
|
|
|
|
#include "support/path.h"
|
2000-06-12 12:52:51 +00:00
|
|
|
#include "support/LAssert.h"
|
2000-06-12 11:27:15 +00:00
|
|
|
|
|
|
|
using std::endl;
|
|
|
|
using std::ostream;
|
|
|
|
|
|
|
|
extern string user_lyxdir;
|
|
|
|
|
|
|
|
|
|
|
|
// We have to have dummy default commands for security reasons!
|
|
|
|
|
|
|
|
ExternalTemplate::ExternalTemplate()
|
|
|
|
: viewCommand("true"), editCommand("true")
|
|
|
|
{}
|
|
|
|
|
|
|
|
ExternalTemplate::FormatTemplate::FormatTemplate()
|
|
|
|
: updateCommand("true") {}
|
|
|
|
|
|
|
|
|
|
|
|
ExternalTemplateManager::ExternalTemplateManager()
|
|
|
|
{
|
|
|
|
// gimp gnuchess gnuplot ical netscape tetris xpaint
|
|
|
|
readTemplates(user_lyxdir);
|
|
|
|
dumpTemplates();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
class dumpTemplate {
|
|
|
|
public:
|
|
|
|
dumpTemplate(std::ostream & o)
|
|
|
|
: ost(o) {}
|
|
|
|
void operator()(ExternalTemplateManager::Templates::value_type const & vt) {
|
|
|
|
ExternalTemplate const & et = vt.second;
|
|
|
|
|
|
|
|
ost << "Template " << et.lyxName << "\n"
|
|
|
|
<< "\tGuiName " << et.guiName << "\n"
|
|
|
|
<< "\tHelpText\n"
|
|
|
|
<< et.helpText
|
|
|
|
<< "\tHelpTextEnd\n"
|
|
|
|
<< "\tFileFilter " << et.fileRegExp << "\n"
|
|
|
|
<< "\tViewCommand " << et.viewCommand << "\n"
|
|
|
|
<< "\tEditCommand " << et.editCommand << "\n"
|
|
|
|
<< "\tAutomaticProduction " << et.automaticProduction << "\n";
|
|
|
|
et.dumpFormats(ost);
|
|
|
|
ost << "TemplateEnd" << endl;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
|
|
|
ostream & ost;
|
|
|
|
};
|
|
|
|
|
|
|
|
class dumpFormat {
|
|
|
|
public:
|
|
|
|
dumpFormat(ostream & o)
|
|
|
|
: ost(o) {}
|
|
|
|
void operator()(ExternalTemplate::Formats::value_type const & vt) const{
|
|
|
|
ExternalTemplate::FormatTemplate const & ft = vt.second;
|
|
|
|
ost << "\tFormat " << vt.first << "\n"
|
|
|
|
<< "\t\tProduct " << ft.product << "\n"
|
|
|
|
<< "\t\tUpdateCommand " << ft.updateCommand << "\n"
|
|
|
|
<< "\t\tRequirement " << ft.requirement << "\n"
|
|
|
|
<< "\t\tPreamble\n"
|
|
|
|
<< ft.preamble
|
|
|
|
<< "\t\tPreambleEnd\n"
|
|
|
|
<< "\tFormatEnd\n";
|
|
|
|
}
|
|
|
|
private:
|
|
|
|
ostream & ost;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
void ExternalTemplate::dumpFormats(ostream & os) const
|
|
|
|
{
|
|
|
|
for_each(formats.begin(), formats.end(), dumpFormat(os));
|
|
|
|
}
|
|
|
|
|
|
|
|
void ExternalTemplateManager::dumpTemplates() const
|
|
|
|
{
|
|
|
|
for_each(templates.begin(), templates.end(), dumpTemplate(lyxerr));
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
ExternalTemplateManager & ExternalTemplateManager::get()
|
|
|
|
{
|
|
|
|
static ExternalTemplateManager externalTemplateManager;
|
|
|
|
return externalTemplateManager;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
ExternalTemplateManager::Templates &
|
|
|
|
ExternalTemplateManager::getTemplates()
|
|
|
|
{
|
|
|
|
return templates;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
ExternalTemplateManager::Templates const &
|
|
|
|
ExternalTemplateManager::getTemplates() const
|
|
|
|
{
|
|
|
|
return templates;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void ExternalTemplateManager::readTemplates(string const & path)
|
|
|
|
{
|
|
|
|
Path p(path);
|
|
|
|
|
|
|
|
enum TemplateTags {
|
|
|
|
TM_TEMPLATE = 1,
|
|
|
|
TM_END
|
|
|
|
};
|
|
|
|
|
|
|
|
keyword_item templatetags[] = {
|
|
|
|
{ "template", TM_TEMPLATE },
|
|
|
|
{ "templateend", TM_END }
|
|
|
|
};
|
|
|
|
|
|
|
|
LyXLex lex(templatetags, TM_END);
|
|
|
|
if (!lex.setFile("external_templates")) {
|
|
|
|
lyxerr << "No template file" << endl;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
while (lex.IsOK()) {
|
|
|
|
switch(lex.lex()) {
|
|
|
|
case TM_TEMPLATE: {
|
|
|
|
lex.next();
|
|
|
|
string temp = lex.GetString();
|
|
|
|
ExternalTemplate & tmp = templates[temp];
|
|
|
|
tmp.lyxName = temp;
|
|
|
|
tmp.readTemplate(lex);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
case TM_END:
|
|
|
|
lyxerr << "TemplateEnd: " << lex.GetString() << endl;
|
|
|
|
lyxerr << "Warning: End outside Template." << endl;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void ExternalTemplate::readTemplate(LyXLex & lex)
|
|
|
|
{
|
|
|
|
enum TemplateOptionTags {
|
|
|
|
TO_GUINAME = 1,
|
|
|
|
TO_HELPTEXT,
|
|
|
|
TO_FILTER,
|
|
|
|
TO_VIEWCMD,
|
|
|
|
TO_EDITCMD,
|
|
|
|
TO_AUTOMATIC,
|
|
|
|
TO_FORMAT,
|
|
|
|
TO_END
|
|
|
|
};
|
|
|
|
|
|
|
|
keyword_item templateoptiontags[] = {
|
|
|
|
{ "automaticproduction", TO_AUTOMATIC },
|
|
|
|
{ "editcommand", TO_EDITCMD },
|
|
|
|
{ "filefilter", TO_FILTER },
|
|
|
|
{ "format", TO_FORMAT },
|
|
|
|
{ "guiname", TO_GUINAME },
|
|
|
|
{ "helptext", TO_HELPTEXT },
|
|
|
|
{ "templateend", TO_END },
|
|
|
|
{ "viewcommand", TO_VIEWCMD }
|
|
|
|
};
|
|
|
|
|
|
|
|
pushpophelper pph(lex, templateoptiontags, TO_END);
|
|
|
|
|
|
|
|
while (lex.IsOK()) {
|
|
|
|
switch (lex.lex()) {
|
|
|
|
case TO_GUINAME:
|
|
|
|
lex.next(true);
|
|
|
|
guiName = lex.GetString();
|
|
|
|
break;
|
|
|
|
|
|
|
|
case TO_HELPTEXT:
|
|
|
|
helpText = lex.getLongString("HelpTextEnd");
|
|
|
|
break;
|
|
|
|
|
|
|
|
case TO_FILTER:
|
|
|
|
lex.next(true);
|
|
|
|
fileRegExp = lex.GetString();
|
|
|
|
break;
|
|
|
|
|
|
|
|
case TO_VIEWCMD:
|
|
|
|
lex.next(true);
|
|
|
|
viewCommand = lex.GetString();
|
|
|
|
// For security reasons, a command may not be empty!
|
|
|
|
if (viewCommand.empty())
|
|
|
|
viewCommand = "true";
|
|
|
|
break;
|
|
|
|
|
|
|
|
case TO_EDITCMD:
|
|
|
|
lex.next(true);
|
|
|
|
editCommand = lex.GetString();
|
|
|
|
// For security reasons, a command may not be empty!
|
|
|
|
if (editCommand.empty())
|
|
|
|
editCommand = "true";
|
|
|
|
break;
|
|
|
|
|
|
|
|
case TO_AUTOMATIC:
|
|
|
|
lex.next();
|
|
|
|
automaticProduction = lex.GetBool();
|
|
|
|
break;
|
|
|
|
|
|
|
|
case TO_FORMAT:
|
|
|
|
lex.next(true);
|
|
|
|
formats[lex.GetString()].readFormat(lex);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case TO_END:
|
|
|
|
return;
|
|
|
|
|
|
|
|
default:
|
|
|
|
lyxerr << "Default: " << lex.GetString() << endl;
|
|
|
|
Assert(false);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void ExternalTemplate::FormatTemplate::readFormat(LyXLex & lex)
|
|
|
|
{
|
|
|
|
enum FormatTags {
|
|
|
|
FO_PRODUCT = 1,
|
|
|
|
FO_UPDATECMD,
|
|
|
|
FO_REQUIREMENT,
|
|
|
|
FO_PREAMBLE,
|
|
|
|
FO_END
|
|
|
|
};
|
|
|
|
|
|
|
|
keyword_item formattags[] = {
|
|
|
|
{ "formatend", FO_END },
|
|
|
|
{ "preamble", FO_PREAMBLE },
|
|
|
|
{ "product", FO_PRODUCT },
|
|
|
|
{ "requirement", FO_REQUIREMENT },
|
|
|
|
{ "updatecommand", FO_UPDATECMD }
|
|
|
|
};
|
|
|
|
|
|
|
|
pushpophelper pph(lex, formattags, FO_END);
|
|
|
|
|
|
|
|
while (lex.IsOK()) {
|
|
|
|
switch(lex.lex()) {
|
|
|
|
case FO_PRODUCT:
|
|
|
|
lex.next(true);
|
|
|
|
product = lex.GetString();
|
|
|
|
break;
|
|
|
|
|
|
|
|
case FO_UPDATECMD:
|
|
|
|
lex.next(true);
|
|
|
|
updateCommand = lex.GetString();
|
|
|
|
// For security reasons, a command may not be empty!
|
|
|
|
if (updateCommand.empty())
|
|
|
|
updateCommand = "true";
|
|
|
|
break;
|
|
|
|
|
|
|
|
case FO_REQUIREMENT:
|
|
|
|
lex.next(true);
|
|
|
|
requirement = lex.GetString();
|
|
|
|
break;
|
|
|
|
|
|
|
|
case FO_PREAMBLE:
|
|
|
|
preamble = lex.getLongString("preambleend");
|
|
|
|
break;
|
|
|
|
|
|
|
|
case FO_END:
|
|
|
|
lyxerr << "FormatEnd: " << lex.GetString() << endl;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|