cleanup handling of LFUN_REGEXP_MODE ; cleanup Text::getStatus

git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@33363 a592a061-630c-0410-9148-cb99ea01b6c8
This commit is contained in:
Jean-Marc Lasgouttes 2010-02-08 11:19:48 +00:00
parent 7b86617ef5
commit b4d588e78a
3 changed files with 64 additions and 98 deletions

View File

@ -1024,11 +1024,6 @@ bool BufferView::getStatus(FuncRequest const & cmd, FuncStatus & flag)
flag.setEnabled(true); flag.setEnabled(true);
break; break;
case LFUN_REGEXP_MODE:
flag.setEnabled(buffer().isInternal() && !cur.inRegexped()
&& cur.inset().lyxCode() != ERT_CODE);
break;
case LFUN_LABEL_COPY_AS_REF: { case LFUN_LABEL_COPY_AS_REF: {
// if there is an inset at cursor, see whether it // if there is an inset at cursor, see whether it
// handles the lfun // handles the lfun

View File

@ -2393,6 +2393,11 @@ bool Text::getStatus(Cursor & cur, FuncRequest const & cmd,
code = MATH_HULL_CODE; code = MATH_HULL_CODE;
break; break;
case LFUN_REGEXP_MODE:
code = MATH_HULL_CODE;
enable = cur.buffer()->isInternal() && !cur.inRegexped();
break;
case LFUN_INSET_MODIFY: case LFUN_INSET_MODIFY:
// We need to disable this, because we may get called for a // We need to disable this, because we may get called for a
// tabular cell via // tabular cell via
@ -2403,31 +2408,38 @@ bool Text::getStatus(Cursor & cur, FuncRequest const & cmd,
case LFUN_FONT_EMPH: case LFUN_FONT_EMPH:
flag.setOnOff(fontinfo.emph() == FONT_ON); flag.setOnOff(fontinfo.emph() == FONT_ON);
enable = !cur.inset().getLayout().isPassThru();
break; break;
case LFUN_FONT_ITAL: case LFUN_FONT_ITAL:
flag.setOnOff(fontinfo.shape() == ITALIC_SHAPE); flag.setOnOff(fontinfo.shape() == ITALIC_SHAPE);
enable = !cur.inset().getLayout().isPassThru();
break; break;
case LFUN_FONT_NOUN: case LFUN_FONT_NOUN:
flag.setOnOff(fontinfo.noun() == FONT_ON); flag.setOnOff(fontinfo.noun() == FONT_ON);
enable = !cur.inset().getLayout().isPassThru();
break; break;
case LFUN_FONT_BOLD: case LFUN_FONT_BOLD:
case LFUN_FONT_BOLDSYMBOL: case LFUN_FONT_BOLDSYMBOL:
flag.setOnOff(fontinfo.series() == BOLD_SERIES); flag.setOnOff(fontinfo.series() == BOLD_SERIES);
enable = !cur.inset().getLayout().isPassThru();
break; break;
case LFUN_FONT_SANS: case LFUN_FONT_SANS:
flag.setOnOff(fontinfo.family() == SANS_FAMILY); flag.setOnOff(fontinfo.family() == SANS_FAMILY);
enable = !cur.inset().getLayout().isPassThru();
break; break;
case LFUN_FONT_ROMAN: case LFUN_FONT_ROMAN:
flag.setOnOff(fontinfo.family() == ROMAN_FAMILY); flag.setOnOff(fontinfo.family() == ROMAN_FAMILY);
enable = !cur.inset().getLayout().isPassThru();
break; break;
case LFUN_FONT_TYPEWRITER: case LFUN_FONT_TYPEWRITER:
flag.setOnOff(fontinfo.family() == TYPEWRITER_FAMILY); flag.setOnOff(fontinfo.family() == TYPEWRITER_FAMILY);
enable = !cur.inset().getLayout().isPassThru();
break; break;
case LFUN_CUT: case LFUN_CUT:
@ -2559,6 +2571,47 @@ bool Text::getStatus(Cursor & cur, FuncRequest const & cmd,
enable = theSpellChecker(); enable = theSpellChecker();
break; break;
case LFUN_LAYOUT:
enable = !cur.inset().forcePlainLayout();
break;
case LFUN_LAYOUT_PARAGRAPH:
case LFUN_PARAGRAPH_PARAMS:
case LFUN_PARAGRAPH_PARAMS_APPLY:
case LFUN_PARAGRAPH_UPDATE:
enable = cur.inset().allowParagraphCustomization();
break;
// FIXME: why are accent lfuns forbidden with pass_thru layouts?
case LFUN_ACCENT_ACUTE:
case LFUN_ACCENT_BREVE:
case LFUN_ACCENT_CARON:
case LFUN_ACCENT_CEDILLA:
case LFUN_ACCENT_CIRCLE:
case LFUN_ACCENT_CIRCUMFLEX:
case LFUN_ACCENT_DOT:
case LFUN_ACCENT_GRAVE:
case LFUN_ACCENT_HUNGARIAN_UMLAUT:
case LFUN_ACCENT_MACRON:
case LFUN_ACCENT_OGONEK:
case LFUN_ACCENT_TIE:
case LFUN_ACCENT_TILDE:
case LFUN_ACCENT_UMLAUT:
case LFUN_ACCENT_UNDERBAR:
case LFUN_ACCENT_UNDERDOT:
case LFUN_FONT_DEFAULT:
case LFUN_FONT_FRAK:
case LFUN_FONT_SIZE:
case LFUN_FONT_STATE:
case LFUN_FONT_UNDERLINE:
case LFUN_FONT_STRIKEOUT:
case LFUN_FONT_UULINE:
case LFUN_FONT_UWAVE:
case LFUN_TEXTSTYLE_APPLY:
case LFUN_TEXTSTYLE_UPDATE:
enable = !cur.inset().getLayout().isPassThru();
break;
case LFUN_WORD_DELETE_FORWARD: case LFUN_WORD_DELETE_FORWARD:
case LFUN_WORD_DELETE_BACKWARD: case LFUN_WORD_DELETE_BACKWARD:
case LFUN_LINE_DELETE: case LFUN_LINE_DELETE:
@ -2588,6 +2641,15 @@ bool Text::getStatus(Cursor & cur, FuncRequest const & cmd,
case LFUN_WORD_LEFT_SELECT: case LFUN_WORD_LEFT_SELECT:
case LFUN_WORD_SELECT: case LFUN_WORD_SELECT:
case LFUN_SECTION_SELECT: case LFUN_SECTION_SELECT:
case LFUN_BUFFER_BEGIN:
case LFUN_BUFFER_END:
case LFUN_BUFFER_BEGIN_SELECT:
case LFUN_BUFFER_END_SELECT:
case LFUN_INSET_BEGIN:
case LFUN_INSET_END:
case LFUN_INSET_BEGIN_SELECT:
case LFUN_INSET_END_SELECT:
case LFUN_INSET_SELECT_ALL:
case LFUN_PARAGRAPH_UP: case LFUN_PARAGRAPH_UP:
case LFUN_PARAGRAPH_DOWN: case LFUN_PARAGRAPH_DOWN:
case LFUN_LINE_BEGIN: case LFUN_LINE_BEGIN:
@ -2602,48 +2664,10 @@ bool Text::getStatus(Cursor & cur, FuncRequest const & cmd,
case LFUN_SERVER_GET_XY: case LFUN_SERVER_GET_XY:
case LFUN_SERVER_SET_XY: case LFUN_SERVER_SET_XY:
case LFUN_SERVER_GET_LAYOUT: case LFUN_SERVER_GET_LAYOUT:
case LFUN_LAYOUT:
case LFUN_SELF_INSERT: case LFUN_SELF_INSERT:
case LFUN_FONT_DEFAULT:
case LFUN_FONT_UNDERLINE:
case LFUN_FONT_STRIKEOUT:
case LFUN_FONT_UULINE:
case LFUN_FONT_UWAVE:
case LFUN_FONT_SIZE:
case LFUN_TEXTSTYLE_APPLY:
case LFUN_TEXTSTYLE_UPDATE:
case LFUN_LAYOUT_PARAGRAPH:
case LFUN_PARAGRAPH_UPDATE:
case LFUN_ACCENT_UMLAUT:
case LFUN_ACCENT_CIRCUMFLEX:
case LFUN_ACCENT_GRAVE:
case LFUN_ACCENT_ACUTE:
case LFUN_ACCENT_TILDE:
case LFUN_ACCENT_CEDILLA:
case LFUN_ACCENT_MACRON:
case LFUN_ACCENT_DOT:
case LFUN_ACCENT_UNDERDOT:
case LFUN_ACCENT_UNDERBAR:
case LFUN_ACCENT_CARON:
case LFUN_ACCENT_BREVE:
case LFUN_ACCENT_TIE:
case LFUN_ACCENT_HUNGARIAN_UMLAUT:
case LFUN_ACCENT_CIRCLE:
case LFUN_ACCENT_OGONEK:
case LFUN_THESAURUS_ENTRY:
case LFUN_PARAGRAPH_PARAMS_APPLY:
case LFUN_PARAGRAPH_PARAMS:
case LFUN_ESCAPE:
case LFUN_BUFFER_BEGIN:
case LFUN_BUFFER_END:
case LFUN_BUFFER_BEGIN_SELECT:
case LFUN_BUFFER_END_SELECT:
case LFUN_INSET_BEGIN:
case LFUN_INSET_END:
case LFUN_INSET_BEGIN_SELECT:
case LFUN_INSET_END_SELECT:
case LFUN_INSET_SELECT_ALL:
case LFUN_UNICODE_INSERT: case LFUN_UNICODE_INSERT:
case LFUN_THESAURUS_ENTRY:
case LFUN_ESCAPE:
// these are handled in our dispatch() // these are handled in our dispatch()
enable = true; enable = true;
break; break;
@ -2658,48 +2682,6 @@ bool Text::getStatus(Cursor & cur, FuncRequest const & cmd,
|| cur.paragraph().layout().pass_thru)) || cur.paragraph().layout().pass_thru))
enable = false; enable = false;
switch (cmd.action) {
case LFUN_ACCENT_ACUTE:
case LFUN_ACCENT_BREVE:
case LFUN_ACCENT_CARON:
case LFUN_ACCENT_CEDILLA:
case LFUN_ACCENT_CIRCLE:
case LFUN_ACCENT_CIRCUMFLEX:
case LFUN_ACCENT_DOT:
case LFUN_ACCENT_GRAVE:
case LFUN_ACCENT_HUNGARIAN_UMLAUT:
case LFUN_ACCENT_MACRON:
case LFUN_ACCENT_OGONEK:
case LFUN_ACCENT_TIE:
case LFUN_ACCENT_TILDE:
case LFUN_ACCENT_UMLAUT:
case LFUN_ACCENT_UNDERBAR:
case LFUN_ACCENT_UNDERDOT:
case LFUN_FONT_BOLD:
case LFUN_FONT_BOLDSYMBOL:
case LFUN_FONT_TYPEWRITER:
case LFUN_FONT_DEFAULT:
case LFUN_FONT_EMPH:
case LFUN_FONT_NOUN:
case LFUN_FONT_ROMAN:
case LFUN_FONT_SANS:
case LFUN_FONT_FRAK:
case LFUN_FONT_ITAL:
case LFUN_FONT_SIZE:
case LFUN_FONT_STATE:
case LFUN_FONT_UNDERLINE:
case LFUN_FONT_STRIKEOUT:
case LFUN_FONT_UULINE:
case LFUN_FONT_UWAVE:
case LFUN_TEXTSTYLE_APPLY:
case LFUN_TEXTSTYLE_UPDATE:
if (cur.inset().getLayout().isPassThru())
enable = false;
break;
default:
break;
}
flag.setEnabled(enable); flag.setEnabled(enable);
return true; return true;
} }

View File

@ -298,17 +298,6 @@ bool InsetText::getStatus(Cursor & cur, FuncRequest const & cmd,
FuncStatus & status) const FuncStatus & status) const
{ {
switch (cmd.action) { switch (cmd.action) {
case LFUN_LAYOUT:
status.setEnabled(!forcePlainLayout());
return true;
case LFUN_LAYOUT_PARAGRAPH:
case LFUN_PARAGRAPH_PARAMS:
case LFUN_PARAGRAPH_PARAMS_APPLY:
case LFUN_PARAGRAPH_UPDATE:
status.setEnabled(allowParagraphCustomization());
return true;
case LFUN_INSET_DISSOLVE: { case LFUN_INSET_DISSOLVE: {
bool const main_inset = &buffer().inset() == this; bool const main_inset = &buffer().inset() == this;
bool const target_inset = cmd.argument().empty() bool const target_inset = cmd.argument().empty()