/* This file is part of
* ======================================================
- *
+ *
* LyX, The Document Processor
- *
+ *
* Copyright 1995 Matthias Ettrich
- * Copyright 1995-2000 The LyX Team.
+ * Copyright 1995-2001 The LyX Team.
*
* ====================================================== */
#include "insetlabel.h"
#include "support/LOstream.h"
-#include "lyx_gui_misc.h" //askForText
+#include "frontends/Alert.h"
#include "support/lstrings.h" //frontStrip, strip
#include "lyxtext.h"
#include "buffer.h"
+#include "gettext.h"
+#include "BufferView.h"
+#include "support/lstrings.h"
using std::ostream;
using std::vector;
/* Label. Used to insert a label automatically */
-InsetLabel::InsetLabel(string const & cmd)
-{
- scanCommand(cmd);
-}
+InsetLabel::InsetLabel(InsetCommandParams const & p, bool)
+ : InsetCommand(p)
+{}
-Inset * InsetLabel::Clone() const
+vector<string> const InsetLabel::getLabelList() const
{
- return new InsetLabel(getCommand());
+ return vector<string>(1, getContents());
}
-vector<string> InsetLabel::getLabelList() const
+void InsetLabel::edit(BufferView * bv, int, int, unsigned int)
{
- return vector<string>(1,contents);
-}
-
-
-void InsetLabel::Edit(BufferView * bv, int, int, unsigned int)
-{
- if (bv->buffer()->isReadonly()) {
- WarnReadonly(bv->buffer()->fileName());
- return;
- }
-
- pair<bool, string> result = askForText(_("Enter label:"),
- contents);
+ pair<bool, string> result = Alert::askForText(_("Enter label:"), getContents());
if (result.first) {
string new_contents = frontStrip(strip(result.second));
if (!new_contents.empty() &&
- contents != new_contents) {
+ getContents() != new_contents) {
bv->buffer()->markDirty();
- bool flag = bv->ChangeRefs(contents,new_contents);
- contents = new_contents;
- bv->text->RedoParagraph();
+ bool flag = bv->ChangeRefsIfUnique(getContents(),
+ new_contents);
+ setContents(new_contents);
+#if 0
+ bv->text->redoParagraph(bv);
if (flag) {
bv->redraw();
bv->fitCursor();
- //bv->updateScrollbar();
} else
- bv->update(1);
+ bv->update(bv->text, BufferView::SELECT|BufferView::FITCUR|BufferView::CHANGE);
+#else
+ bv->updateInset(this, !flag);
+#endif
}
}
}
-int InsetLabel::Latex(ostream & os,
+
+void InsetLabel::edit(BufferView * bv, bool)
+{
+ edit(bv, 0, 0, 0);
+}
+
+
+int InsetLabel::latex(Buffer const *, ostream & os,
bool /*fragile*/, bool /*fs*/) const
{
os << escape(getCommand());
return 0;
}
-int InsetLabel::Ascii(ostream & os) const
+int InsetLabel::ascii(Buffer const *, ostream & os, int) const
{
os << "<" << getContents() << ">";
return 0;
}
-int InsetLabel::Linuxdoc(ostream & os) const
+int InsetLabel::linuxdoc(Buffer const *, ostream & os) const
{
os << "<label id=\"" << getContents() << "\" >";
return 0;
}
-int InsetLabel::DocBook(ostream & os) const
+int InsetLabel::docbook(Buffer const *, ostream & os) const
{
- os << "<anchor id=\"" << getContents() << "\" >";
+ os << "<anchor id=\"" << getContents() << "\">";
return 0;
}
-
-
-// This function escapes 8-bit characters and other problematic characters
-// It's exactly the same code as in insetref.C.
-string InsetLabel::escape(string const & lab) const {
- char hexdigit[16] = { '0', '1', '2', '3', '4', '5', '6', '7',
- '8', '9', 'A', 'B', 'C', 'D', 'E', 'F' };
- string enc;
- for (string::size_type i= 0; i < lab.length(); ++i) {
- unsigned char c = lab[i];
- if (c >= 128 || c == '=' || c == '%') {
- enc += '=';
- enc += hexdigit[c >> 4];
- enc += hexdigit[c & 15];
- } else {
- enc += c;
- }
- }
- return enc;
-}