- Reimplementation of EM_LINELENGTH.

- Some attempt at documentation of double-linked list of
  ME_DisplayItem's.
This commit is contained in:
Krzysztof Foltman 2005-09-29 10:30:50 +00:00 committed by Alexandre Julliard
parent 7f8614bbd4
commit ed8379d1ad
4 changed files with 22 additions and 13 deletions

View File

@ -1623,7 +1623,7 @@ LRESULT WINAPI RichEditANSIWndProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lP
case EM_LINELENGTH: case EM_LINELENGTH:
{ {
ME_DisplayItem *item, *item_end; ME_DisplayItem *item, *item_end;
int nChars = 0; int nChars = 0, nThisLineOfs = 0, nNextLineOfs = 0;
if (wParam > ME_GetTextLength(editor)) if (wParam > ME_GetTextLength(editor))
return 0; return 0;
@ -1634,17 +1634,13 @@ LRESULT WINAPI RichEditANSIWndProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lP
} }
item = ME_FindItemAtOffset(editor, diRun, wParam, NULL); item = ME_FindItemAtOffset(editor, diRun, wParam, NULL);
item = ME_RowStart(item); item = ME_RowStart(item);
item_end = ME_RowEnd(item); nThisLineOfs = ME_CharOfsFromRunOfs(editor, ME_FindItemFwd(item, diRun), 0);
if (!item_end) item_end = ME_FindItemFwd(item, diStartRow);
{ if (item_end)
/* Empty buffer, no runs */ nNextLineOfs = ME_CharOfsFromRunOfs(editor, ME_FindItemFwd(item_end, diRun), 0);
nChars = 0;
}
else else
{ nNextLineOfs = ME_FindItemFwd(item, diParagraphOrEnd)->member.para.nCharOfs-1;
nChars = ME_CharOfsFromRunOfs(editor, item_end, ME_StrLen(item_end->member.run.strText)); nChars = nNextLineOfs - nThisLineOfs;
nChars -= ME_CharOfsFromRunOfs(editor, item, 0);
}
TRACE("EM_LINELENGTH(%d)==%d\n",wParam, nChars); TRACE("EM_LINELENGTH(%d)==%d\n",wParam, nChars);
return nChars; return nChars;
} }

View File

@ -98,7 +98,7 @@ int ME_ReverseFindWhitespaceV(ME_String *s, int nVChar);
/* row.c */ /* row.c */
ME_DisplayItem *ME_FindRowStart(ME_Context *c, ME_DisplayItem *run, int nRelPos); ME_DisplayItem *ME_FindRowStart(ME_Context *c, ME_DisplayItem *run, int nRelPos);
ME_DisplayItem *ME_RowStart(ME_DisplayItem *item); ME_DisplayItem *ME_RowStart(ME_DisplayItem *item);
ME_DisplayItem *ME_RowEnd(ME_DisplayItem *item); /* ME_DisplayItem *ME_RowEnd(ME_DisplayItem *item); */
void ME_RenumberParagraphs(ME_DisplayItem *item); /* TODO */ void ME_RenumberParagraphs(ME_DisplayItem *item); /* TODO */
ME_DisplayItem *ME_FindRowWithNumber(ME_TextEditor *editor, int nRow); ME_DisplayItem *ME_FindRowWithNumber(ME_TextEditor *editor, int nRow);
int ME_RowNumberFromCharOfs(ME_TextEditor *editor, int nOfs); int ME_RowNumberFromCharOfs(ME_TextEditor *editor, int nOfs);

View File

@ -161,6 +161,18 @@ typedef struct tagME_Row
int nYPos; int nYPos;
} ME_Row; } ME_Row;
/* the display item list layout is like this:
* - the document consists of paragraphs
* - each paragraph contains at least one run, the last run in the paragraph
* is an end-of-paragraph run
* - each formatted paragraph contains at least one row, which corresponds
* to a screen line (that's why there are no rows in an unformatted
* paragraph
* - the paragraphs contain "shortcut" pointers to the previous and the next
* paragraph, that makes iteration over paragraphs faster
* - the list starts with diTextStart and ends with diTextEnd
*/
typedef struct tagME_DisplayItem typedef struct tagME_DisplayItem
{ {
ME_DIType type; ME_DIType type;

View File

@ -77,12 +77,13 @@ ME_DisplayItem *ME_RowStart(ME_DisplayItem *item) {
return ME_FindItemBackOrHere(item, diStartRow); return ME_FindItemBackOrHere(item, diStartRow);
} }
/*
ME_DisplayItem *ME_RowEnd(ME_DisplayItem *item) { ME_DisplayItem *ME_RowEnd(ME_DisplayItem *item) {
ME_DisplayItem *item2 = ME_FindItemFwd(item, diStartRowOrParagraphOrEnd); ME_DisplayItem *item2 = ME_FindItemFwd(item, diStartRowOrParagraphOrEnd);
if (!item2) return NULL; if (!item2) return NULL;
return ME_FindItemBack(item, diRun); return ME_FindItemBack(item, diRun);
} }
*/
ME_DisplayItem * ME_DisplayItem *
ME_FindRowWithNumber(ME_TextEditor *editor, int nRow) ME_FindRowWithNumber(ME_TextEditor *editor, int nRow)