/* 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(InsetCommandParams const & p)
+InsetLabel::InsetLabel(InsetCommandParams const & p, bool)
: InsetCommand(p)
{}
vector<string> const InsetLabel::getLabelList() const
{
- return vector<string>(1,getContents());
+ return vector<string>(1, getContents());
}
-void InsetLabel::Edit(BufferView * bv, int, int, unsigned int)
+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:"), getContents());
+ pair<bool, string> result = Alert::askForText(_("Enter label:"), getContents());
if (result.first) {
string new_contents = frontStrip(strip(result.second));
if (!new_contents.empty() &&
getContents() != new_contents) {
bv->buffer()->markDirty();
- bool flag = bv->ChangeRefs(getContents(),new_contents);
- setContents( new_contents );
- bv->text->RedoParagraph(bv);
+ bool flag = bv->ChangeRefsIfUnique(getContents(),
+ new_contents);
+ setContents(new_contents);
+#if 0
+ bv->text->redoParagraph(bv);
if (flag) {
bv->redraw();
- bv->fitCursor(getLyXText(bv));
+ bv->fitCursor();
} else
- bv->update(BufferView::SELECT|BufferView::FITCUR|BufferView::CHANGE);
+ bv->update(bv->text, BufferView::SELECT|BufferView::FITCUR|BufferView::CHANGE);
+#else
+ bv->updateInset(this, !flag);
+#endif
}
}
}
-int InsetLabel::Latex(Buffer const *, 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(Buffer const *, ostream & os, int) const
+int InsetLabel::ascii(Buffer const *, ostream & os, int) const
{
os << "<" << getContents() << ">";
return 0;
}
-int InsetLabel::Linuxdoc(Buffer const *, ostream & os) const
+int InsetLabel::linuxdoc(Buffer const *, ostream & os) const
{
os << "<label id=\"" << getContents() << "\" >";
return 0;
}
-int InsetLabel::DocBook(Buffer const *, ostream & os) const
+int InsetLabel::docbook(Buffer const *, ostream & os) const
{
- os << "<anchor id=\"" << getContents() << "\" ></anchor>";
+ 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 const 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;
-}