#include "Buffer.h"
#include "BufferParams.h"
#include "BufferView.h"
+#include "CutAndPaste.h"
#include "FuncRequest.h"
#include "FuncStatus.h"
#include "InsetGraphics.h"
#include "LayoutFile.h"
#include "LyXAction.h"
#include "LyXRC.h"
+#include "LyXVC.h"
#include "Lexer.h"
-#include "MetricsInfo.h"
#include "ParagraphParameters.h"
+#include "version.h"
#include "frontends/Application.h"
#include "support/filetools.h"
#include "support/gettext.h"
#include "support/lstrings.h"
+#include "support/Translator.h"
#include <sstream>
translator.addPair(InsetInfo::MENU_INFO, "menu");
translator.addPair(InsetInfo::ICON_INFO, "icon");
translator.addPair(InsetInfo::BUFFER_INFO, "buffer");
+ translator.addPair(InsetInfo::LYX_INFO, "lyxinfo");
return translator;
}
-InsetInfo::InsetInfo(Buffer const & buf, string const & name)
+InsetInfo::InsetInfo(Buffer * buf, string const & name)
: InsetCollapsable(buf), type_(UNKNOWN_INFO), name_()
{
setAutoBreakRows(true);
Inset * InsetInfo::editXY(Cursor & cur, int x, int y)
{
- cur.push(*this);
- return InsetCollapsable::editXY(cur, x, y);
+ // do not allow the cursor to be set in this Inset
+ return Inset::editXY(cur, x, y);
}
}
-docstring InsetInfo::name() const
+docstring InsetInfo::layoutName() const
{
return from_ascii("Info:" + infoType());
}
_("Missing \\end_inset at this point."),
from_utf8(token));
}
- setLayout(buffer().params());
updateInfo();
}
}
-bool InsetInfo::validate(docstring const & arg) const
+bool InsetInfo::validateModifyArgument(docstring const & arg) const
{
string type;
string const name = trim(split(to_utf8(arg), type, ' '));
+
switch (nameTranslator().find(type)) {
case UNKNOWN_INFO:
return false;
+
case SHORTCUT_INFO:
case SHORTCUTS_INFO:
case MENU_INFO:
case ICON_INFO: {
FuncRequest func = lyxaction.lookupFunc(name);
- return func.action != LFUN_UNKNOWN_ACTION;
+ return func.action() != LFUN_UNKNOWN_ACTION;
}
+
case LYXRC_INFO: {
ostringstream oss;
lyxrc.write(oss, true, name);
return !oss.str().empty();
}
+
case PACKAGE_INFO:
case TEXTCLASS_INFO:
return true;
+
case BUFFER_INFO:
- return name == "name" || name == "path" || name == "class";
+ if (name == "name" || name == "path" || name == "class")
+ return true;
+ if (name == "vcs-revision" || name == "vcs-tree-revision" ||
+ name == "vcs-author" || name == "vcs-date" || name == "vcs-time")
+ return buffer().lyxvc().inUse();
+ return false;
+
+ case LYX_INFO:
+ return name == "version";
}
+
return false;
}
bool InsetInfo::getStatus(Cursor & cur, FuncRequest const & cmd,
FuncStatus & flag) const
{
- switch (cmd.action) {
- case LFUN_MOUSE_PRESS:
- case LFUN_MOUSE_RELEASE:
- case LFUN_MOUSE_MOTION:
- case LFUN_MOUSE_DOUBLE:
- case LFUN_MOUSE_TRIPLE:
- case LFUN_COPY:
+ switch (cmd.action()) {
case LFUN_INSET_SETTINGS:
return InsetCollapsable::getStatus(cur, cmd, flag);
- case LFUN_INSET_MODIFY:
+ case LFUN_INSET_DIALOG_UPDATE:
+ case LFUN_INSET_COPY_AS:
flag.setEnabled(true);
- break;
+ return true;
+
+ case LFUN_INSET_MODIFY:
+ if (validateModifyArgument(cmd.argument())) {
+ flag.setEnabled(true);
+ return true;
+ }
+ //fall through
default:
return false;
}
- return true;
}
void InsetInfo::doDispatch(Cursor & cur, FuncRequest & cmd)
{
- // allow selection, copy but not cut, delete etc
- switch (cmd.action) {
- case LFUN_MOUSE_PRESS:
- case LFUN_MOUSE_RELEASE:
- case LFUN_MOUSE_MOTION:
- case LFUN_MOUSE_DOUBLE:
- case LFUN_MOUSE_TRIPLE:
- case LFUN_COPY:
- case LFUN_INSET_SETTINGS:
- InsetCollapsable::doDispatch(cur, cmd);
- break;
-
+ switch (cmd.action()) {
case LFUN_INSET_MODIFY:
+ cur.recordUndo();
setInfo(to_utf8(cmd.argument()));
- cur.pos() = 0;
break;
+ case LFUN_INSET_COPY_AS: {
+ cap::clearSelection();
+ Cursor copy(cur);
+ copy.pushBackward(*this);
+ copy.pit() = 0;
+ copy.pos() = 0;
+ copy.resetAnchor();
+ copy.pit() = copy.lastpit();
+ copy.pos() = copy.lastpos();
+ copy.setSelection();
+ cap::copySelection(copy);
+ break;
+ }
+
default:
+ InsetCollapsable::doDispatch(cur, cmd);
break;
}
}
string type;
name_ = trim(split(name, type, ' '));
type_ = nameTranslator().find(type);
- setLayout(buffer().params());
updateInfo();
}
break;
case SHORTCUT_INFO:
case SHORTCUTS_INFO: {
- FuncRequest func = lyxaction.lookupFunc(name_);
- if (func.action == LFUN_UNKNOWN_ACTION) {
+ FuncRequest const func = lyxaction.lookupFunc(name_);
+ if (func.action() == LFUN_UNKNOWN_ACTION) {
error("Unknown action %1$s");
break;
}
}
case LYXRC_INFO: {
ostringstream oss;
+ if (name_.empty()) {
+ setText(_("undefined"));
+ break;
+ }
lyxrc.write(oss, true, name_);
string result = oss.str();
- // remove leading \\name
- result = result.substr(name_.size() + 2);
+ if (result.size() < 2) {
+ setText(_("undefined"));
+ break;
+ }
+ string::size_type loc = result.rfind("\n", result.size() - 2);
+ loc = loc == string::npos ? 0 : loc + 1;
+ if (result.size() < loc + name_.size() + 1
+ || result.substr(loc + 1, name_.size()) != name_) {
+ setText(_("undefined"));
+ break;
+ }
+ // remove leading comments and \\name and space
+ result = result.substr(loc + name_.size() + 2);
+
// remove \n and ""
result = rtrim(result, "\n");
result = trim(result, "\"");
// check in packages.lst
setText(LaTeXFeatures::isAvailable(name_) ? _("yes") : _("no"));
break;
+
case TEXTCLASS_INFO: {
// name_ is the class name
- setText(LayoutFileList::get().haveClass(name_) ? _("yes") : _("no"));
+ LayoutFileList const & list = LayoutFileList::get();
+ bool available = false;
+ if (list.haveClass(name_))
+ available = list[name_].isTeXClassAvailable();
+ setText(available ? _("yes") : _("no"));
break;
}
case MENU_INFO: {
docstring_list names;
- FuncRequest func = lyxaction.lookupFunc(name_);
- if (func.action == LFUN_UNKNOWN_ACTION) {
+ FuncRequest const func = lyxaction.lookupFunc(name_);
+ if (func.action() == LFUN_UNKNOWN_ACTION) {
error("Unknown action %1$s");
break;
}
// iterate through the menubackend to find it
+ if (!theApp()) {
+ error("Can't determine menu entry for action %1$s in batch mode");
+ break;
+ }
if (!theApp()->searchMenu(func, names)) {
error("No menu entry for action %1$s");
break;
// do not insert > for the top level menu item
if (it != beg)
par.insertInset(par.size(), new InsetSpecialChar(InsetSpecialChar::MENU_SEPARATOR),
- Change(Change::UNCHANGED));
+ f, Change(Change::UNCHANGED));
//FIXME: add proper underlines here. This
// involves rewriting searchMenu used above to
// return a vector of menus. If we do not do
}
case ICON_INFO: {
FuncRequest func = lyxaction.lookupFunc(name_);
- docstring icon_name = theApp()->iconName(func, true);
+ docstring icon_name = frontend::Application::iconName(func, true);
//FIXME: We should use the icon directly instead of
// going through FileName. The code below won't work
// if the icon is embedded in the executable through
// the Qt resource system.
+ // This is only a negligible performance problem:
+ // If the installed icon differs from the resource icon the
+ // installed one is preferred anyway, and all icons that are
+ // embedded in the resources are installed as well.
FileName file(to_utf8(icon_name));
if (!file.exists())
break;
- InsetGraphics * inset = new InsetGraphics(buffer());
+ InsetGraphics * inset = new InsetGraphics(buffer_);
InsetGraphicsParams igp;
igp.filename = file;
inset->setParams(igp);
clear();
- paragraphs().front().insertInset(0, inset,
+ Font const f(inherit_font, buffer().params().language);
+ paragraphs().front().insertInset(0, inset, f,
Change(Change::UNCHANGED));
break;
}
case BUFFER_INFO: {
- if (name_ == "name")
+ if (name_ == "name") {
setText(from_utf8(buffer().fileName().onlyFileName()));
- else if (name_ == "path")
- setText(from_utf8(buffer().filePath()));
- else if (name_ == "class")
+ break;
+ }
+ if (name_ == "path") {
+ setText(from_utf8(os::latex_path(buffer().filePath())));
+ break;
+ }
+ if (name_ == "class") {
setText(from_utf8(bp.documentClass().name()));
+ break;
+ }
+
+ // everything that follows is for version control.
+ // nothing that isn't version control should go below this line.
+ if (!buffer().lyxvc().inUse()) {
+ setText(_("No version control"));
+ break;
+ }
+ LyXVC::RevisionInfo itype = LyXVC::Unknown;
+ if (name_ == "vcs-revision")
+ itype = LyXVC::File;
+ else if (name_ == "vcs-tree-revision")
+ itype = LyXVC::Tree;
+ else if (name_ == "vcs-author")
+ itype = LyXVC::Author;
+ else if (name_ == "vcs-time")
+ itype = LyXVC::Time;
+ else if (name_ == "vcs-date")
+ itype = LyXVC::Date;
+ string binfo = buffer().lyxvc().revisionInfo(itype);
+ if (binfo.empty())
+ setText(from_ascii(name_) + " unknown");
else
- setText(_("Unknown buffer info"));
+ setText(from_utf8(binfo));
break;
}
+ case LYX_INFO:
+ if (name_ == "version")
+ setText(from_ascii(lyx_version));
+ break;
}
}
-docstring InsetInfo::contextMenu(BufferView const &, int, int) const
+string InsetInfo::contextMenu(BufferView const &, int, int) const
+{
+ //FIXME: We override the implementation of InsetCollapsable,
+ //because this inset is not a collapsable inset.
+ return contextMenuName();
+}
+
+
+string InsetInfo::contextMenuName() const
{
- return from_ascii("context-info");
+ return "context-info";
}