fdui->input_tiny = obj = fl_add_input(FL_FLOAT_INPUT, 370, 20, 70, 30, _("tiny"));
fl_set_object_lsize(obj, FL_NORMAL_SIZE);
fl_set_object_callback(obj, C_FormBaseDeprecatedInputCB, 0);
- fdui->input_script = obj = fl_add_input(FL_FLOAT_INPUT, 370, 50, 70, 30, _("script"));
+ fdui->input_script = obj = fl_add_input(FL_FLOAT_INPUT, 370, 50, 70, 30, _("smallest"));
fl_set_object_lsize(obj, FL_NORMAL_SIZE);
fl_set_object_callback(obj, C_FormBaseDeprecatedInputCB, 0);
- fdui->input_footnote = obj = fl_add_input(FL_FLOAT_INPUT, 370, 80, 70, 30, _("footnote"));
+ fdui->input_footnote = obj = fl_add_input(FL_FLOAT_INPUT, 370, 80, 70, 30, _("smaller"));
fl_set_object_lsize(obj, FL_NORMAL_SIZE);
fl_set_object_callback(obj, C_FormBaseDeprecatedInputCB, 0);
fdui->input_small = obj = fl_add_input(FL_FLOAT_INPUT, 370, 110, 70, 30, _("small"));
#include "support/lstrings.h"
#include "BufferView.h"
#include "buffer.h"
+#include "debug.h"
#include "gettext.h"
using lyx::pos_type;
{
Paragraph * par = text->cursor.par();
pos_type pos = text->cursor.pos();
+ Paragraph * prev_par = par;
+ pos_type prev_pos;
UpdatableInset * inset;
while (par && !IsStringInText(par, pos, str, cs, mw)) {
return SR_FOUND_NOUPDATE;
text = bv->getLyXText();
}
- if (pos < par->size() - 1)
- ++pos;
- else {
- pos = 0;
+
+ ++pos;
+
+ if (pos >= par->size()) {
+ prev_par = par;
+ // consider 0-sized empty pars
+ prev_pos = std::min(pos, par->size());
par = par->next();
+ pos = 0;
}
}
+
if (par) {
text->setCursor(bv, par, pos);
return SR_FOUND;
-#if 0
- } else if (text->inset_owner) {
- // test if we're inside an inset if yes unlock the inset
- // and recall us with the outside LyXText!
- bv->unlockInset((UpdatableInset *)text->inset_owner);
- if (!bv->theLockingInset()) {
- text = bv->getLyXText();
- par = text->cursor.par();
- pos = text->cursor.pos();
- if (pos < par->size() - 1)
- ++pos;
- else {
- pos = 0;
- par = par->next();
- }
- if (!par)
- return SR_NOT_FOUND;
- text->setCursor(bv, par, pos);
- return SearchForward(bv, text, str, cs, mw);
- } else {
- return SR_NOT_FOUND;
- }
-#endif
- } else
+ } else {
+ // make sure we end up at the end of the text,
+ // not the start point of the last search
+ text->setCursor(bv, prev_par, prev_pos);
return SR_NOT_FOUND;
+ }
}
{
Paragraph * par = text->cursor.par();
pos_type pos = text->cursor.pos();
+ Paragraph * prev_par = par;
+ pos_type prev_pos = pos;
do {
if (pos > 0)
--pos;
else {
+ prev_pos = pos;
+ prev_par = par;
// We skip empty paragraphs (Asger)
do {
par = par->previous();
if (par) {
text->setCursor(bv, par, pos);
return SR_FOUND;
+ } else {
+ // go to the last part of the unsuccessful search
+ text->setCursor(bv, prev_par, prev_pos);
+ return SR_NOT_FOUND;
}
-#if 0
- else if (text->inset_owner) {
- // test if we're inside an inset if yes unlock the inset
- // and recall us with the outside LyXText!
- bv->unlockInset((UpdatableInset *)text->inset_owner);
- if (!bv->theLockingInset()) {
- return SearchBackward(bv, bv->getLyXText(), str, cs, mw);
- }
- }
-#endif
- return SR_NOT_FOUND;
}