Commit 96307570 authored by Huw Davies's avatar Huw Davies Committed by Alexandre Julliard

riched20: Use cell ptrs in the table tab handler.

parent 77895ecd
...@@ -2799,7 +2799,7 @@ static LRESULT ME_Char(ME_TextEditor *editor, WPARAM charCode, ...@@ -2799,7 +2799,7 @@ static LRESULT ME_Char(ME_TextEditor *editor, WPARAM charCode,
!(ctrl_is_down && !editor->bEmulateVersion10)) !(ctrl_is_down && !editor->bEmulateVersion10))
{ {
ME_DisplayItem *para; ME_DisplayItem *para;
BOOL bSelectedRow = FALSE; BOOL selected_row = FALSE;
para = cursor.pPara; para = cursor.pPara;
if (ME_IsSelection(editor) && if (ME_IsSelection(editor) &&
...@@ -2808,11 +2808,11 @@ static LRESULT ME_Char(ME_TextEditor *editor, WPARAM charCode, ...@@ -2808,11 +2808,11 @@ static LRESULT ME_Char(ME_TextEditor *editor, WPARAM charCode,
para->member.para.prev_para->type == diParagraph) para->member.para.prev_para->type == diParagraph)
{ {
para = para->member.para.prev_para; para = para->member.para.prev_para;
bSelectedRow = TRUE; selected_row = TRUE;
} }
if (ME_IsInTable(para)) if (ME_IsInTable(para))
{ {
ME_TabPressedInTable(editor, bSelectedRow); table_handle_tab( editor, selected_row );
ME_CommitUndo(editor); ME_CommitUndo(editor);
return 0; return 0;
} }
......
...@@ -297,6 +297,7 @@ ME_Paragraph *cell_first_para( ME_Cell *cell ) DECLSPEC_HIDDEN; ...@@ -297,6 +297,7 @@ ME_Paragraph *cell_first_para( ME_Cell *cell ) DECLSPEC_HIDDEN;
ME_Cell *cell_next( ME_Cell *cell ) DECLSPEC_HIDDEN; ME_Cell *cell_next( ME_Cell *cell ) DECLSPEC_HIDDEN;
ME_Cell *cell_prev( ME_Cell *cell ) DECLSPEC_HIDDEN; ME_Cell *cell_prev( ME_Cell *cell ) DECLSPEC_HIDDEN;
ME_Paragraph *table_append_row( ME_TextEditor *editor, ME_Paragraph *table_row ) DECLSPEC_HIDDEN; ME_Paragraph *table_append_row( ME_TextEditor *editor, ME_Paragraph *table_row ) DECLSPEC_HIDDEN;
void table_handle_tab( ME_TextEditor *editor, BOOL selected_row ) DECLSPEC_HIDDEN;
ME_Paragraph *table_insert_cell( ME_TextEditor *editor, ME_Cursor *cursor ) DECLSPEC_HIDDEN; ME_Paragraph *table_insert_cell( ME_TextEditor *editor, ME_Cursor *cursor ) DECLSPEC_HIDDEN;
ME_Paragraph *table_insert_row_end( ME_TextEditor *editor, ME_Cursor *cursor ) DECLSPEC_HIDDEN; ME_Paragraph *table_insert_row_end( ME_TextEditor *editor, ME_Cursor *cursor ) DECLSPEC_HIDDEN;
ME_Paragraph *table_insert_row_start( ME_TextEditor *editor, ME_Cursor *cursor ) DECLSPEC_HIDDEN; ME_Paragraph *table_insert_row_start( ME_TextEditor *editor, ME_Cursor *cursor ) DECLSPEC_HIDDEN;
...@@ -308,7 +309,6 @@ ME_Cell *table_row_end_cell( ME_Paragraph *para ) DECLSPEC_HIDDEN; ...@@ -308,7 +309,6 @@ ME_Cell *table_row_end_cell( ME_Paragraph *para ) DECLSPEC_HIDDEN;
ME_Cell *table_row_first_cell( ME_Paragraph *para ) DECLSPEC_HIDDEN; ME_Cell *table_row_first_cell( ME_Paragraph *para ) DECLSPEC_HIDDEN;
ME_Paragraph *table_row_start( ME_Paragraph *para ) DECLSPEC_HIDDEN; ME_Paragraph *table_row_start( ME_Paragraph *para ) DECLSPEC_HIDDEN;
void ME_CheckTablesForCorruption(ME_TextEditor *editor) DECLSPEC_HIDDEN; void ME_CheckTablesForCorruption(ME_TextEditor *editor) DECLSPEC_HIDDEN;
void ME_TabPressedInTable(ME_TextEditor *editor, BOOL bSelectedRow) DECLSPEC_HIDDEN;
void ME_MoveCursorFromTableRowStartParagraph(ME_TextEditor *editor) DECLSPEC_HIDDEN; void ME_MoveCursorFromTableRowStartParagraph(ME_TextEditor *editor) DECLSPEC_HIDDEN;
struct RTFTable *ME_MakeTableDef(ME_TextEditor *editor) DECLSPEC_HIDDEN; struct RTFTable *ME_MakeTableDef(ME_TextEditor *editor) DECLSPEC_HIDDEN;
void ME_InitTableDef(ME_TextEditor *editor, struct RTFTable *tableDef) DECLSPEC_HIDDEN; void ME_InitTableDef(ME_TextEditor *editor, struct RTFTable *tableDef) DECLSPEC_HIDDEN;
......
...@@ -481,30 +481,27 @@ ME_Paragraph* table_append_row( ME_TextEditor *editor, ME_Paragraph *table_row ) ...@@ -481,30 +481,27 @@ ME_Paragraph* table_append_row( ME_TextEditor *editor, ME_Paragraph *table_row )
} }
/* Selects the next table cell or appends a new table row if at end of table */ /* Selects the next table cell or appends a new table row if at end of table */
static void ME_SelectOrInsertNextCell( ME_TextEditor *editor, ME_DisplayItem *run ) static void table_select_next_cell_or_append( ME_TextEditor *editor, ME_Run *run )
{ {
ME_Paragraph *para = run->member.run.para; ME_Paragraph *para = run->para;
ME_Cell *cell;
int i; int i;
assert(run && run->type == diRun); assert( para_in_table( para ) );
assert(ME_IsInTable(run));
if (!editor->bEmulateVersion10) /* v4.1 */ if (!editor->bEmulateVersion10) /* v4.1 */
{ {
ME_DisplayItem *cell;
/* Get the initial cell */ /* Get the initial cell */
if (para->nFlags & MEPF_ROWSTART) cell = para_next( para )->pCell; if (para->nFlags & MEPF_ROWSTART) cell = para_cell( para_next( para ) );
else if (para->nFlags & MEPF_ROWEND) cell = para_prev( para )->pCell; else if (para->nFlags & MEPF_ROWEND) cell = para_cell( para_prev( para ) );
else cell = para->pCell; else cell = para_cell( para );
assert(cell);
/* Get the next cell. */ /* Get the next cell. */
if (cell->member.cell.next_cell && if (cell_next( cell ) && cell_next( cell_next( cell ) ))
cell->member.cell.next_cell->member.cell.next_cell) cell = cell_next( cell );
else
{ {
cell = cell->member.cell.next_cell; para = para_next( table_row_end( para ) );
} else { if (para->nFlags & MEPF_ROWSTART) cell = para_cell( para_next( para ) );
para = para_next( table_row_end( &ME_FindItemFwd( cell, diParagraph )->member.para ) );
if (para->nFlags & MEPF_ROWSTART) cell = para_next( para )->pCell;
else else
{ {
/* Insert row */ /* Insert row */
...@@ -521,38 +518,32 @@ static void ME_SelectOrInsertNextCell( ME_TextEditor *editor, ME_DisplayItem *ru ...@@ -521,38 +518,32 @@ static void ME_SelectOrInsertNextCell( ME_TextEditor *editor, ME_DisplayItem *ru
} }
} }
/* Select cell */ /* Select cell */
editor->pCursors[1].pRun = ME_FindItemFwd(cell, diRun); editor->pCursors[1].pPara = para_get_di( cell_first_para( cell ) );
editor->pCursors[1].pPara = ME_GetParagraph(editor->pCursors[1].pRun); editor->pCursors[1].pRun = run_get_di( para_first_run( &editor->pCursors[1].pPara->member.para ) );
editor->pCursors[1].nOffset = 0; editor->pCursors[1].nOffset = 0;
assert(editor->pCursors[0].pRun); editor->pCursors[0].pPara = para_get_di( cell_end_para( cell ) );
cell = cell->member.cell.next_cell; editor->pCursors[0].pRun = run_get_di( para_end_run( &editor->pCursors[0].pPara->member.para ) );
editor->pCursors[0].pRun = ME_FindItemBack(cell, diRun);
editor->pCursors[0].pPara = ME_GetParagraph(editor->pCursors[0].pRun);
editor->pCursors[0].nOffset = 0; editor->pCursors[0].nOffset = 0;
assert(editor->pCursors[1].pRun);
} }
else /* v1.0 - 3.0 */ else /* v1.0 - 3.0 */
{ {
if (run->member.run.nFlags & MERF_ENDPARA && if (run->nFlags & MERF_ENDPARA && para_in_table( para_next( para ) ))
ME_IsInTable(ME_FindItemFwd(run, diParagraphOrEnd)))
{ {
run = ME_FindItemFwd(run, diRun); run = run_next_all_paras( run );
assert(run); assert(run);
} }
for (i = 0; i < 2; i++) for (i = 0; i < 2; i++)
{ {
while (!(run->member.run.nFlags & MERF_TAB)) while (!(run->nFlags & MERF_TAB))
{ {
run = ME_FindItemFwd(run, diRunOrParagraphOrEnd); if (!run_next( run ))
if (run->type != diRun)
{ {
para = &run->member.para; para = para_next( run->para );
if (para_in_table( para )) if (para_in_table( para ))
{ {
run = run_get_di( para_first_run( para ) ); run = para_first_run( para );
assert(run);
editor->pCursors[0].pPara = para_get_di( para ); editor->pCursors[0].pPara = para_get_di( para );
editor->pCursors[0].pRun = run; editor->pCursors[0].pRun = run_get_di( run );
editor->pCursors[0].nOffset = 0; editor->pCursors[0].nOffset = 0;
i = 1; i = 1;
} }
...@@ -569,18 +560,18 @@ static void ME_SelectOrInsertNextCell( ME_TextEditor *editor, ME_DisplayItem *ru ...@@ -569,18 +560,18 @@ static void ME_SelectOrInsertNextCell( ME_TextEditor *editor, ME_DisplayItem *ru
return; return;
} }
} }
else run = run_next( run );
} }
if (i == 0) if (i == 0) run = run_next_all_paras( run );
run = ME_FindItemFwd(run, diRun); editor->pCursors[i].pRun = run_get_di( run );
editor->pCursors[i].pRun = run; editor->pCursors[i].pPara = para_get_di( run->para );
editor->pCursors[i].pPara = ME_GetParagraph(run);
editor->pCursors[i].nOffset = 0; editor->pCursors[i].nOffset = 0;
} }
} }
} }
void ME_TabPressedInTable(ME_TextEditor *editor, BOOL bSelectedRow) void table_handle_tab( ME_TextEditor *editor, BOOL selected_row )
{ {
/* FIXME: Shift tab should move to the previous cell. */ /* FIXME: Shift tab should move to the previous cell. */
ME_Cursor fromCursor, toCursor; ME_Cursor fromCursor, toCursor;
...@@ -593,7 +584,9 @@ void ME_TabPressedInTable(ME_TextEditor *editor, BOOL bSelectedRow) ...@@ -593,7 +584,9 @@ void ME_TabPressedInTable(ME_TextEditor *editor, BOOL bSelectedRow)
{ {
fromCursor = editor->pCursors[0]; fromCursor = editor->pCursors[0];
toCursor = editor->pCursors[1]; toCursor = editor->pCursors[1];
} else { }
else
{
fromCursor = editor->pCursors[1]; fromCursor = editor->pCursors[1];
toCursor = editor->pCursors[0]; toCursor = editor->pCursors[0];
} }
...@@ -604,29 +597,28 @@ void ME_TabPressedInTable(ME_TextEditor *editor, BOOL bSelectedRow) ...@@ -604,29 +597,28 @@ void ME_TabPressedInTable(ME_TextEditor *editor, BOOL bSelectedRow)
{ {
editor->pCursors[0] = toCursor; editor->pCursors[0] = toCursor;
editor->pCursors[1] = toCursor; editor->pCursors[1] = toCursor;
} else {
ME_SelectOrInsertNextCell(editor, toCursor.pRun);
} }
} else { /* v1.0 - 3.0 */ else table_select_next_cell_or_append( editor, &toCursor.pRun->member.run );
if (!ME_IsInTable(fromCursor.pRun)) { }
else /* v1.0 - 3.0 */
{
if (!ME_IsInTable(fromCursor.pRun))
{
editor->pCursors[0] = fromCursor; editor->pCursors[0] = fromCursor;
editor->pCursors[1] = fromCursor; editor->pCursors[1] = fromCursor;
/* FIXME: For some reason the caret is shown at the start of the /* FIXME: For some reason the caret is shown at the start of the
* previous paragraph in v1.0 to v3.0 */ * previous paragraph in v1.0 to v3.0 */
} else if ((bSelectedRow || !ME_IsInTable(toCursor.pRun))) { }
ME_SelectOrInsertNextCell(editor, fromCursor.pRun); else if ((selected_row || !para_in_table( &toCursor.pPara->member.para )))
} else { table_select_next_cell_or_append( editor, &fromCursor.pRun->member.run );
if (ME_IsSelection(editor) && !toCursor.nOffset) else
{ {
ME_DisplayItem *run; ME_Run *run = run_prev( &toCursor.pRun->member.run );
run = ME_FindItemBack(toCursor.pRun, diRunOrParagraphOrEnd);
if (run->type == diRun && run->member.run.nFlags & MERF_TAB) if (ME_IsSelection(editor) && !toCursor.nOffset && run && run->nFlags & MERF_TAB)
ME_SelectOrInsertNextCell(editor, run); table_select_next_cell_or_append( editor, run );
else else
ME_SelectOrInsertNextCell(editor, toCursor.pRun); table_select_next_cell_or_append( editor, &toCursor.pRun->member.run );
} else {
ME_SelectOrInsertNextCell(editor, toCursor.pRun);
}
} }
} }
ME_InvalidateSelection(editor); ME_InvalidateSelection(editor);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment