int i, j, ch = 0, rc = -1, hideQuoted = 0, q_level = 0, force_redraw = 0;
int lines = 0, curline = 0, topline = 0, oldtopline = 0, err, first = 1;
int r = -1, wrapped = 0, searchctx = 0;
- int redraw = REDRAW_FULL;
FILE *fp = NULL;
LOFF_T last_pos = 0, last_offset = 0;
int old_smart_wrap, old_markers;
mutt_window_t *pager_status_window = NULL;
mutt_window_t *pager_window = NULL;
+ MUTTMENU *pager_menu = NULL;
MUTTMENU *index = NULL; /* the Pager Index (PI) */
int indexlen = PagerIndexLines; /* indexlen not always == PIL */
int indicator = indexlen / 3; /* the indicator line of the PI */
pager_status_window = safe_calloc (1, sizeof (mutt_window_t));
pager_window = safe_calloc (1, sizeof (mutt_window_t));
+ pager_menu = mutt_new_menu (MENU_PAGER);
+ mutt_push_current_menu (pager_menu);
+
while (ch != -1)
{
mutt_curs_set (0);
- if (redraw & REDRAW_FULL)
+ if (pager_menu->redraw & REDRAW_FULL)
{
#if ! (defined (USE_SLANG_CURSES) || defined (HAVE_RESIZETERM))
mutt_reflow_windows ();
SearchBack = Resize->SearchBack;
}
lines = Resize->line;
- redraw |= REDRAW_SIGWINCH;
+ pager_menu->redraw |= REDRAW_SIGWINCH;
FREE (&Resize);
}
menu_redraw_index(index);
}
- redraw |= REDRAW_BODY | REDRAW_INDEX | REDRAW_STATUS;
+ pager_menu->redraw |= REDRAW_BODY | REDRAW_INDEX | REDRAW_STATUS;
#ifdef USE_SIDEBAR
- redraw |= REDRAW_SIDEBAR;
+ pager_menu->redraw |= REDRAW_SIDEBAR;
#endif
mutt_show_error ();
}
- if (redraw & REDRAW_SIGWINCH)
+ if (pager_menu->redraw & REDRAW_SIGWINCH)
{
i = -1;
j = -1;
}
#ifdef USE_SIDEBAR
- if ((redraw & REDRAW_SIDEBAR) || SidebarNeedsRedraw)
+ if ((pager_menu->redraw & REDRAW_SIDEBAR) || SidebarNeedsRedraw)
{
SidebarNeedsRedraw = 0;
mutt_sb_draw ();
}
#endif
- if ((redraw & REDRAW_BODY) || topline != oldtopline)
+ if ((pager_menu->redraw & REDRAW_BODY) || topline != oldtopline)
{
do {
mutt_window_move (pager_window, 0, 0);
/* We are going to update the pager status bar, so it isn't
* necessary to reset to normal color now. */
- redraw |= REDRAW_STATUS; /* need to update the % seen */
+ pager_menu->redraw |= REDRAW_STATUS; /* need to update the % seen */
}
- if (redraw & REDRAW_STATUS)
+ if (pager_menu->redraw & REDRAW_STATUS)
{
struct hdr_format_info hfi;
char pager_progress_str[4];
/* redraw the pager_index indicator, because the
* flags for this message might have changed. */
- if ((redraw & REDRAW_INDEX) && index && (index_window->rows > 0))
+ if ((pager_menu->redraw & REDRAW_INDEX) && index && (index_window->rows > 0))
{
menu_redraw_current (index);
NORMAL_COLOR;
}
- redraw = 0;
+ pager_menu->redraw = 0;
if (option(OPTBRAILLEFRIENDLY)) {
if (brailleLine!=-1) {
{
/* fatal error occurred */
FREE (&Context);
- redraw = REDRAW_FULL;
+ pager_menu->redraw = REDRAW_FULL;
ch = -1;
break;
}
}
}
- redraw = REDRAW_FULL;
+ pager_menu->redraw = REDRAW_FULL;
set_option (OPTSEARCHINVALID);
}
}
lastLine = 0;
topline = 0;
- redraw = REDRAW_FULL | REDRAW_SIGWINCH;
+ pager_menu->redraw = REDRAW_FULL | REDRAW_SIGWINCH;
ch = 0;
}
}
}
- redraw = REDRAW_BODY;
+ pager_menu->redraw = REDRAW_BODY;
break;
case OP_SEARCH_TOGGLE:
if (SearchCompiled)
{
SearchFlag ^= MUTT_SEARCH;
- redraw = REDRAW_BODY;
+ pager_menu->redraw = REDRAW_BODY;
}
break;
{
InHelp = 1;
mutt_help (MENU_PAGER);
- redraw = REDRAW_FULL;
+ pager_menu->redraw = REDRAW_FULL;
InHelp = 0;
}
else
if (hideQuoted && lineInfo[topline].type == MT_COLOR_QUOTED)
topline = up_n_lines (1, lineInfo, topline, hideQuoted);
else
- redraw = REDRAW_BODY;
+ pager_menu->redraw = REDRAW_BODY;
}
break;
case OP_REDRAW:
clearok (stdscr, true);
- redraw = REDRAW_FULL;
+ pager_menu->redraw = REDRAW_FULL;
break;
case OP_NULL:
extra->idx, extra->idxlen,
extra->bdy);
else
- ci_bounce_message (extra->hdr, &redraw);
+ ci_bounce_message (extra->hdr, &pager_menu->redraw);
break;
case OP_RESEND:
extra->bdy);
else
mutt_resend_message (NULL, extra->ctx, extra->hdr);
- redraw = REDRAW_FULL;
+ pager_menu->redraw = REDRAW_FULL;
break;
case OP_COMPOSE_TO_SENDER:
mutt_compose_to_sender (extra->hdr);
- redraw = REDRAW_FULL;
+ pager_menu->redraw = REDRAW_FULL;
break;
case OP_CHECK_TRADITIONAL:
mutt_create_alias (extra->bdy->hdr->env, NULL);
else
mutt_create_alias (extra->hdr->env, NULL);
- MAYBE_REDRAW (redraw);
+ MAYBE_REDRAW (pager_menu->redraw);
break;
case OP_PURGE_MESSAGE:
mutt_set_flag (Context, extra->hdr, MUTT_PURGE, (ch == OP_PURGE_MESSAGE));
if (option (OPTDELETEUNTAG))
mutt_set_flag (Context, extra->hdr, MUTT_TAG, 0);
- redraw = REDRAW_STATUS | REDRAW_INDEX;
+ pager_menu->redraw = REDRAW_STATUS | REDRAW_INDEX;
if (option (OPTRESOLVE))
{
ch = -1;
CHECK_READONLY;
if (mutt_change_flag (extra->hdr, (ch == OP_MAIN_SET_FLAG)) == 0)
- redraw |= REDRAW_STATUS | REDRAW_INDEX;
+ pager_menu->redraw |= REDRAW_STATUS | REDRAW_INDEX;
if (extra->hdr->deleted && option (OPTRESOLVE))
{
ch = -1;
}
if (!option (OPTRESOLVE) && PagerIndexLines)
- redraw = REDRAW_FULL;
+ pager_menu->redraw = REDRAW_FULL;
else
- redraw = REDRAW_STATUS | REDRAW_INDEX;
+ pager_menu->redraw = REDRAW_STATUS | REDRAW_INDEX;
}
break;
}
if (option (OPTFORCEREDRAWPAGER))
- redraw = REDRAW_FULL;
+ pager_menu->redraw = REDRAW_FULL;
unset_option (OPTFORCEREDRAWINDEX);
unset_option (OPTFORCEREDRAWPAGER);
break;
CHECK_ACL(MUTT_ACL_WRITE, "Cannot flag message");
mutt_set_flag (Context, extra->hdr, MUTT_FLAG, !extra->hdr->flagged);
- redraw = REDRAW_STATUS | REDRAW_INDEX;
+ pager_menu->redraw = REDRAW_STATUS | REDRAW_INDEX;
if (option (OPTRESOLVE))
{
ch = -1;
mutt_pipe_attachment_list (extra->fp, 0, extra->bdy, 0);
else
mutt_pipe_message (extra->hdr);
- MAYBE_REDRAW (redraw);
+ MAYBE_REDRAW (pager_menu->redraw);
break;
case OP_PRINT:
CHECK_MODE(IsHeader (extra) && !IsAttach (extra));
CHECK_ATTACH;
ci_send_message (0, NULL, NULL, extra->ctx, NULL);
- redraw = REDRAW_FULL;
+ pager_menu->redraw = REDRAW_FULL;
break;
#ifdef USE_NNTP
query_quadoption (OPT_TOMODERATED,_("Posting to this group not allowed, may be moderated. Continue?")) != MUTT_YES)
break;
ci_send_message (SENDNEWS, NULL, NULL, extra->ctx, NULL);
- redraw = REDRAW_FULL;
+ pager_menu->redraw = REDRAW_FULL;
break;
case OP_FORWARD_TO_GROUP:
extra->idxlen, extra->bdy, SENDNEWS);
else
ci_send_message (SENDNEWS|SENDFORWARD, NULL, NULL, extra->ctx, extra->hdr);
- redraw = REDRAW_FULL;
+ pager_menu->redraw = REDRAW_FULL;
break;
case OP_FOLLOWUP:
else
ci_send_message (SENDNEWS|SENDREPLY, NULL, NULL,
extra->ctx, extra->hdr);
- redraw = REDRAW_FULL;
+ pager_menu->redraw = REDRAW_FULL;
break;
}
#endif
SENDREPLY);
else
ci_send_message (SENDREPLY, NULL, NULL, extra->ctx, extra->hdr);
- redraw = REDRAW_FULL;
+ pager_menu->redraw = REDRAW_FULL;
break;
case OP_RECALL_MESSAGE:
CHECK_MODE(IsHeader (extra) && !IsAttach(extra));
CHECK_ATTACH;
ci_send_message (SENDPOSTPONED, NULL, NULL, extra->ctx, extra->hdr);
- redraw = REDRAW_FULL;
+ pager_menu->redraw = REDRAW_FULL;
break;
case OP_GROUP_REPLY:
extra->idxlen, extra->bdy, SENDREPLY|SENDGROUPREPLY);
else
ci_send_message (SENDREPLY | SENDGROUPREPLY, NULL, NULL, extra->ctx, extra->hdr);
- redraw = REDRAW_FULL;
+ pager_menu->redraw = REDRAW_FULL;
break;
case OP_LIST_REPLY:
extra->idxlen, extra->bdy, SENDREPLY|SENDLISTREPLY);
else
ci_send_message (SENDREPLY | SENDLISTREPLY, NULL, NULL, extra->ctx, extra->hdr);
- redraw = REDRAW_FULL;
+ pager_menu->redraw = REDRAW_FULL;
break;
case OP_FORWARD_MESSAGE:
extra->idxlen, extra->bdy, 0);
else
ci_send_message (SENDFORWARD, NULL, NULL, extra->ctx, extra->hdr);
- redraw = REDRAW_FULL;
+ pager_menu->redraw = REDRAW_FULL;
break;
case OP_DECRYPT_SAVE:
(ch == OP_DECODE_SAVE) || (ch == OP_DECODE_COPY),
(ch == OP_DECRYPT_SAVE) || (ch == OP_DECRYPT_COPY) ||
0,
- &redraw) == 0 && (ch == OP_SAVE || ch == OP_DECODE_SAVE
+ &pager_menu->redraw) == 0 && (ch == OP_SAVE || ch == OP_DECODE_SAVE
|| ch == OP_DECRYPT_SAVE
))
{
rc = OP_MAIN_NEXT_UNDELETED;
}
else
- redraw |= REDRAW_STATUS | REDRAW_INDEX;
+ pager_menu->redraw |= REDRAW_STATUS | REDRAW_INDEX;
}
- MAYBE_REDRAW (redraw);
+ MAYBE_REDRAW (pager_menu->redraw);
break;
case OP_SHELL_ESCAPE:
mutt_shell_escape ();
- MAYBE_REDRAW (redraw);
+ MAYBE_REDRAW (pager_menu->redraw);
break;
case OP_TAG:
? NULL : Context->last_tag);
}
- redraw = REDRAW_STATUS | REDRAW_INDEX;
+ pager_menu->redraw = REDRAW_STATUS | REDRAW_INDEX;
if (option (OPTRESOLVE))
{
ch = -1;
mutt_set_flag (Context, extra->hdr, MUTT_READ, 1);
first = 0;
Context->msgnotreadyet = -1;
- redraw = REDRAW_STATUS | REDRAW_INDEX;
+ pager_menu->redraw = REDRAW_STATUS | REDRAW_INDEX;
if (option (OPTRESOLVE))
{
ch = -1;
mutt_set_flag (Context, extra->hdr, MUTT_DELETE, 0);
mutt_set_flag (Context, extra->hdr, MUTT_PURGE, 0);
- redraw = REDRAW_STATUS | REDRAW_INDEX;
+ pager_menu->redraw = REDRAW_STATUS | REDRAW_INDEX;
if (option (OPTRESOLVE))
{
ch = -1;
}
if (!option (OPTRESOLVE) && PagerIndexLines)
- redraw = REDRAW_FULL;
+ pager_menu->redraw = REDRAW_FULL;
else
- redraw = REDRAW_STATUS | REDRAW_INDEX;
+ pager_menu->redraw = REDRAW_STATUS | REDRAW_INDEX;
}
break;
mutt_view_attachments (extra->hdr);
if (Context && extra->hdr->attach_del)
Context->changed = 1;
- redraw = REDRAW_FULL;
+ pager_menu->redraw = REDRAW_FULL;
break;
case OP_MAIL_KEY:
CHECK_MODE(IsHeader(extra));
CHECK_ATTACH;
ci_send_message (SENDKEY, NULL, NULL, extra->ctx, extra->hdr);
- redraw = REDRAW_FULL;
+ pager_menu->redraw = REDRAW_FULL;
break;
case OP_EDIT_LABEL:
rc = mutt_label_message(extra->hdr);
if (rc > 0) {
Context->changed = 1;
- redraw = REDRAW_FULL;
+ pager_menu->redraw = REDRAW_FULL;
mutt_message (_("%d labels changed."), rc);
}
else {
}
CHECK_MODE(IsHeader(extra));
crypt_extract_keys_from_messages(extra->hdr);
- redraw = REDRAW_FULL;
+ pager_menu->redraw = REDRAW_FULL;
break;
case OP_WHAT_KEY:
case OP_SIDEBAR_TOGGLE_VISIBLE:
toggle_option (OPTSIDEBAR);
mutt_reflow_windows();
- redraw = REDRAW_FULL;
+ pager_menu->redraw = REDRAW_FULL;
break;
#endif
SearchCompiled = 0;
}
FREE (&lineInfo);
+ mutt_pop_current_menu (pager_menu);
+ mutt_menu_destroy (&pager_menu);
if (index)
mutt_menu_destroy(&index);