Commit ce2024ce authored by Chuck Crayne's avatar Chuck Crayne Committed by Alexandre Julliard

- Recognize "\n" as an alternative soft line break in function

EDIT_BuildLineDefs_ML of edit.c. - Major restructuring of richedit.c to provide bug fixes, enhanced function, and improved debug support.
parent 06c665d7
...@@ -69,7 +69,8 @@ typedef enum ...@@ -69,7 +69,8 @@ typedef enum
END_0 = 0, /* line ends with terminating '\0' character */ END_0 = 0, /* line ends with terminating '\0' character */
END_WRAP, /* line is wrapped */ END_WRAP, /* line is wrapped */
END_HARD, /* line ends with a hard return '\r\n' */ END_HARD, /* line ends with a hard return '\r\n' */
END_SOFT /* line ends with a soft return '\r\r\n' */ END_SOFT, /* line ends with a soft return '\r\r\n' */
END_RICH /* line ends with a single '\n' */
} LINE_END; } LINE_END;
typedef struct tagLINEDEF { typedef struct tagLINEDEF {
...@@ -1238,6 +1239,7 @@ static void EDIT_BuildLineDefs_ML(HWND hwnd, EDITSTATE *es, INT istart, INT iend ...@@ -1238,6 +1239,7 @@ static void EDIT_BuildLineDefs_ML(HWND hwnd, EDITSTATE *es, INT istart, INT iend
/* Find end of line */ /* Find end of line */
cp = current_position; cp = current_position;
while (*cp) { while (*cp) {
if (*cp == '\n') break;
if ((*cp == '\r') && (*(cp + 1) == '\n')) if ((*cp == '\r') && (*(cp + 1) == '\n'))
break; break;
cp++; cp++;
...@@ -1250,6 +1252,9 @@ static void EDIT_BuildLineDefs_ML(HWND hwnd, EDITSTATE *es, INT istart, INT iend ...@@ -1250,6 +1252,9 @@ static void EDIT_BuildLineDefs_ML(HWND hwnd, EDITSTATE *es, INT istart, INT iend
} else if ((cp > current_position) && (*(cp - 1) == '\r')) { } else if ((cp > current_position) && (*(cp - 1) == '\r')) {
current_line->ending = END_SOFT; current_line->ending = END_SOFT;
current_line->net_length = cp - current_position - 1; current_line->net_length = cp - current_position - 1;
} else if (*cp == '\n') {
current_line->ending = END_RICH;
current_line->net_length = cp - current_position;
} else { } else {
current_line->ending = END_HARD; current_line->ending = END_HARD;
current_line->net_length = cp - current_position; current_line->net_length = cp - current_position;
...@@ -1311,6 +1316,9 @@ static void EDIT_BuildLineDefs_ML(HWND hwnd, EDITSTATE *es, INT istart, INT iend ...@@ -1311,6 +1316,9 @@ static void EDIT_BuildLineDefs_ML(HWND hwnd, EDITSTATE *es, INT istart, INT iend
case END_SOFT: case END_SOFT:
current_line->length = current_line->net_length + 3; current_line->length = current_line->net_length + 3;
break; break;
case END_RICH:
current_line->length = current_line->net_length + 1;
break;
case END_HARD: case END_HARD:
current_line->length = current_line->net_length + 2; current_line->length = current_line->net_length + 2;
break; break;
......
...@@ -251,6 +251,20 @@ typedef struct _charrange ...@@ -251,6 +251,20 @@ typedef struct _charrange
LONG cpMax; LONG cpMax;
} CHARRANGE; } CHARRANGE;
typedef struct _textrange
{
CHARRANGE chrg;
LPSTR lpstrText;
} TEXTRANGEA;
typedef struct _textrangew
{
CHARRANGE chrg;
LPWSTR lpstrText;
} TEXTRANGEW;
DECL_WINELIB_TYPE_AW(TEXTRANGE)
typedef struct typedef struct
{ {
DWORD dwCookie; DWORD dwCookie;
......
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