Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-cw
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-cw
Commits
a0dbcb25
Commit
a0dbcb25
authored
Apr 19, 2007
by
Huw Davies
Committed by
Alexandre Julliard
Apr 20, 2007
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
user32: Add a function to return the length of the text buffer.
parent
c79ce3cd
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
26 additions
and
23 deletions
+26
-23
edit.c
dlls/user32/edit.c
+26
-23
No files found.
dlls/user32/edit.c
View file @
a0dbcb25
...
@@ -394,6 +394,10 @@ static DWORD get_app_version(void)
...
@@ -394,6 +394,10 @@ static DWORD get_app_version(void)
return
version
;
return
version
;
}
}
static
inline
UINT
get_text_length
(
EDITSTATE
*
es
)
{
return
strlenW
(
es
->
text
);
}
static
HBRUSH
EDIT_NotifyCtlColor
(
EDITSTATE
*
es
,
HDC
hdc
)
static
HBRUSH
EDIT_NotifyCtlColor
(
EDITSTATE
*
es
,
HDC
hdc
)
{
{
...
@@ -760,8 +764,7 @@ static LRESULT WINAPI EditWndProc_common( HWND hwnd, UINT msg,
...
@@ -760,8 +764,7 @@ static LRESULT WINAPI EditWndProc_common( HWND hwnd, UINT msg,
break
;
break
;
case
EM_POSFROMCHAR
:
case
EM_POSFROMCHAR
:
result
=
strlenW
(
es
->
text
);
if
((
INT
)
wParam
>=
get_text_length
(
es
))
result
=
-
1
;
if
((
INT
)
wParam
>=
result
)
result
=
-
1
;
else
result
=
EDIT_EM_PosFromChar
(
es
,
(
INT
)
wParam
,
FALSE
);
else
result
=
EDIT_EM_PosFromChar
(
es
,
(
INT
)
wParam
,
FALSE
);
break
;
break
;
...
@@ -895,8 +898,8 @@ static LRESULT WINAPI EditWndProc_common( HWND hwnd, UINT msg,
...
@@ -895,8 +898,8 @@ static LRESULT WINAPI EditWndProc_common( HWND hwnd, UINT msg,
break
;
break
;
case
WM_GETTEXTLENGTH
:
case
WM_GETTEXTLENGTH
:
if
(
unicode
)
result
=
strlenW
(
es
->
text
);
if
(
unicode
)
result
=
get_text_length
(
es
);
else
result
=
WideCharToMultiByte
(
CP_ACP
,
0
,
es
->
text
,
strlenW
(
es
->
text
),
else
result
=
WideCharToMultiByte
(
CP_ACP
,
0
,
es
->
text
,
get_text_length
(
es
),
NULL
,
0
,
NULL
,
NULL
);
NULL
,
0
,
NULL
,
NULL
);
break
;
break
;
...
@@ -1571,7 +1574,7 @@ static INT EDIT_CharFromPos(EDITSTATE *es, INT x, INT y, LPBOOL after_wrap)
...
@@ -1571,7 +1574,7 @@ static INT EDIT_CharFromPos(EDITSTATE *es, INT x, INT y, LPBOOL after_wrap)
else
else
{
{
INT
low
=
es
->
x_offset
;
INT
low
=
es
->
x_offset
;
INT
high
=
strlenW
(
es
->
text
)
+
1
;
INT
high
=
get_text_length
(
es
)
+
1
;
while
(
low
<
high
-
1
)
while
(
low
<
high
-
1
)
{
{
INT
mid
=
(
low
+
high
)
/
2
;
INT
mid
=
(
low
+
high
)
/
2
;
...
@@ -1647,7 +1650,7 @@ static void EDIT_GetLineRect(EDITSTATE *es, INT line, INT scol, INT ecol, LPRECT
...
@@ -1647,7 +1650,7 @@ static void EDIT_GetLineRect(EDITSTATE *es, INT line, INT scol, INT ecol, LPRECT
static
LPWSTR
EDIT_GetPasswordPointer_SL
(
EDITSTATE
*
es
)
static
LPWSTR
EDIT_GetPasswordPointer_SL
(
EDITSTATE
*
es
)
{
{
if
(
es
->
style
&
ES_PASSWORD
)
{
if
(
es
->
style
&
ES_PASSWORD
)
{
INT
len
=
strlenW
(
es
->
text
);
INT
len
=
get_text_length
(
es
);
LPWSTR
text
=
HeapAlloc
(
GetProcessHeap
(),
0
,
(
len
+
1
)
*
sizeof
(
WCHAR
));
LPWSTR
text
=
HeapAlloc
(
GetProcessHeap
(),
0
,
(
len
+
1
)
*
sizeof
(
WCHAR
));
text
[
len
]
=
'\0'
;
text
[
len
]
=
'\0'
;
while
(
len
)
text
[
--
len
]
=
es
->
password_char
;
while
(
len
)
text
[
--
len
]
=
es
->
password_char
;
...
@@ -1847,7 +1850,7 @@ static void EDIT_InvalidateText(EDITSTATE *es, INT start, INT end)
...
@@ -1847,7 +1850,7 @@ static void EDIT_InvalidateText(EDITSTATE *es, INT start, INT end)
return
;
return
;
if
(
end
==
-
1
)
if
(
end
==
-
1
)
end
=
strlenW
(
es
->
text
);
end
=
get_text_length
(
es
);
if
(
end
<
start
)
{
if
(
end
<
start
)
{
INT
tmp
=
start
;
INT
tmp
=
start
;
...
@@ -1995,7 +1998,7 @@ static void EDIT_MoveEnd(EDITSTATE *es, BOOL extend)
...
@@ -1995,7 +1998,7 @@ static void EDIT_MoveEnd(EDITSTATE *es, BOOL extend)
e
=
EDIT_CharFromPos
(
es
,
0x3fffffff
,
e
=
EDIT_CharFromPos
(
es
,
0x3fffffff
,
HIWORD
(
EDIT_EM_PosFromChar
(
es
,
es
->
selection_end
,
es
->
flags
&
EF_AFTER_WRAP
)),
&
after_wrap
);
HIWORD
(
EDIT_EM_PosFromChar
(
es
,
es
->
selection_end
,
es
->
flags
&
EF_AFTER_WRAP
)),
&
after_wrap
);
else
else
e
=
strlenW
(
es
->
text
);
e
=
get_text_length
(
es
);
EDIT_EM_SetSel
(
es
,
extend
?
es
->
selection_start
:
e
,
e
,
after_wrap
);
EDIT_EM_SetSel
(
es
,
extend
?
es
->
selection_start
:
e
,
e
,
after_wrap
);
EDIT_EM_ScrollCaret
(
es
);
EDIT_EM_ScrollCaret
(
es
);
}
}
...
@@ -2361,7 +2364,7 @@ static void EDIT_AdjustFormatRect(EDITSTATE *es)
...
@@ -2361,7 +2364,7 @@ static void EDIT_AdjustFormatRect(EDITSTATE *es)
es
->
format_rect
.
bottom
=
min
(
es
->
format_rect
.
bottom
,
ClientRect
.
bottom
);
es
->
format_rect
.
bottom
=
min
(
es
->
format_rect
.
bottom
,
ClientRect
.
bottom
);
if
((
es
->
style
&
ES_MULTILINE
)
&&
!
(
es
->
style
&
ES_AUTOHSCROLL
))
if
((
es
->
style
&
ES_MULTILINE
)
&&
!
(
es
->
style
&
ES_AUTOHSCROLL
))
EDIT_BuildLineDefs_ML
(
es
,
0
,
strlenW
(
es
->
text
),
0
,
NULL
);
EDIT_BuildLineDefs_ML
(
es
,
0
,
get_text_length
(
es
),
0
,
NULL
);
EDIT_SetCaretPos
(
es
,
es
->
selection_end
,
es
->
flags
&
EF_AFTER_WRAP
);
EDIT_SetCaretPos
(
es
,
es
->
selection_end
,
es
->
flags
&
EF_AFTER_WRAP
);
}
}
...
@@ -2441,7 +2444,7 @@ static void EDIT_UnlockBuffer(EDITSTATE *es, BOOL force)
...
@@ -2441,7 +2444,7 @@ static void EDIT_UnlockBuffer(EDITSTATE *es, BOOL force)
if
(
es
->
hloc32W
)
{
if
(
es
->
hloc32W
)
{
CHAR
*
textA
=
NULL
;
CHAR
*
textA
=
NULL
;
UINT
countA
=
0
;
UINT
countA
=
0
;
UINT
countW
=
strlenW
(
es
->
text
)
+
1
;
UINT
countW
=
get_text_length
(
es
)
+
1
;
STACK16FRAME
*
stack16
=
NULL
;
STACK16FRAME
*
stack16
=
NULL
;
HANDLE16
oldDS
=
0
;
HANDLE16
oldDS
=
0
;
...
@@ -2883,7 +2886,7 @@ static INT EDIT_EM_LineFromChar(EDITSTATE *es, INT index)
...
@@ -2883,7 +2886,7 @@ static INT EDIT_EM_LineFromChar(EDITSTATE *es, INT index)
if
(
!
(
es
->
style
&
ES_MULTILINE
))
if
(
!
(
es
->
style
&
ES_MULTILINE
))
return
0
;
return
0
;
if
(
index
>
(
INT
)
strlenW
(
es
->
text
))
if
(
index
>
(
INT
)
get_text_length
(
es
))
return
es
->
line_count
-
1
;
return
es
->
line_count
-
1
;
if
(
index
==
-
1
)
if
(
index
==
-
1
)
index
=
min
(
es
->
selection_start
,
es
->
selection_end
);
index
=
min
(
es
->
selection_start
,
es
->
selection_end
);
...
@@ -2945,7 +2948,7 @@ static INT EDIT_EM_LineLength(EDITSTATE *es, INT index)
...
@@ -2945,7 +2948,7 @@ static INT EDIT_EM_LineLength(EDITSTATE *es, INT index)
LINEDEF
*
line_def
;
LINEDEF
*
line_def
;
if
(
!
(
es
->
style
&
ES_MULTILINE
))
if
(
!
(
es
->
style
&
ES_MULTILINE
))
return
strlenW
(
es
->
text
);
return
get_text_length
(
es
);
if
(
index
==
-
1
)
{
if
(
index
==
-
1
)
{
/* get the number of remaining non-selected chars of selected lines */
/* get the number of remaining non-selected chars of selected lines */
...
@@ -3053,7 +3056,7 @@ static BOOL EDIT_EM_LineScroll_internal(EDITSTATE *es, INT dx, INT dy)
...
@@ -3053,7 +3056,7 @@ static BOOL EDIT_EM_LineScroll_internal(EDITSTATE *es, INT dx, INT dy)
*/
*/
static
LRESULT
EDIT_EM_PosFromChar
(
EDITSTATE
*
es
,
INT
index
,
BOOL
after_wrap
)
static
LRESULT
EDIT_EM_PosFromChar
(
EDITSTATE
*
es
,
INT
index
,
BOOL
after_wrap
)
{
{
INT
len
=
strlenW
(
es
->
text
);
INT
len
=
get_text_length
(
es
);
INT
l
;
INT
l
;
INT
li
;
INT
li
;
INT
x
;
INT
x
;
...
@@ -3159,7 +3162,7 @@ static LRESULT EDIT_EM_PosFromChar(EDITSTATE *es, INT index, BOOL after_wrap)
...
@@ -3159,7 +3162,7 @@ static LRESULT EDIT_EM_PosFromChar(EDITSTATE *es, INT index, BOOL after_wrap)
static
void
EDIT_EM_ReplaceSel
(
EDITSTATE
*
es
,
BOOL
can_undo
,
LPCWSTR
lpsz_replace
,
BOOL
send_update
,
BOOL
honor_limit
)
static
void
EDIT_EM_ReplaceSel
(
EDITSTATE
*
es
,
BOOL
can_undo
,
LPCWSTR
lpsz_replace
,
BOOL
send_update
,
BOOL
honor_limit
)
{
{
UINT
strl
=
strlenW
(
lpsz_replace
);
UINT
strl
=
strlenW
(
lpsz_replace
);
UINT
tl
=
strlenW
(
es
->
text
);
UINT
tl
=
get_text_length
(
es
);
UINT
utl
;
UINT
utl
;
UINT
s
;
UINT
s
;
UINT
e
;
UINT
e
;
...
@@ -3208,7 +3211,7 @@ static void EDIT_EM_ReplaceSel(EDITSTATE *es, BOOL can_undo, LPCWSTR lpsz_replac
...
@@ -3208,7 +3211,7 @@ static void EDIT_EM_ReplaceSel(EDITSTATE *es, BOOL can_undo, LPCWSTR lpsz_replac
}
}
if
(
strl
)
{
if
(
strl
)
{
/* there is an insertion */
/* there is an insertion */
tl
=
strlenW
(
es
->
text
);
tl
=
get_text_length
(
es
);
TRACE
(
"inserting stuff (tl %d, strl %d, selstart %d (%s), text %s)
\n
"
,
tl
,
strl
,
s
,
debugstr_w
(
es
->
text
+
s
),
debugstr_w
(
es
->
text
));
TRACE
(
"inserting stuff (tl %d, strl %d, selstart %d (%s), text %s)
\n
"
,
tl
,
strl
,
s
,
debugstr_w
(
es
->
text
+
s
),
debugstr_w
(
es
->
text
));
for
(
p
=
es
->
text
+
tl
;
p
>=
es
->
text
+
s
;
p
--
)
for
(
p
=
es
->
text
+
tl
;
p
>=
es
->
text
+
s
;
p
--
)
p
[
strl
]
=
p
[
0
];
p
[
strl
]
=
p
[
0
];
...
@@ -3452,7 +3455,7 @@ static void EDIT_EM_ScrollCaret(EDITSTATE *es)
...
@@ -3452,7 +3455,7 @@ static void EDIT_EM_ScrollCaret(EDITSTATE *es)
EDIT_UpdateText
(
es
,
NULL
,
TRUE
);
EDIT_UpdateText
(
es
,
NULL
,
TRUE
);
}
else
if
(
x
>
es
->
format_rect
.
right
)
{
}
else
if
(
x
>
es
->
format_rect
.
right
)
{
INT
x_last
;
INT
x_last
;
INT
len
=
strlenW
(
es
->
text
);
INT
len
=
get_text_length
(
es
);
goal
=
es
->
format_rect
.
right
-
format_width
/
HSCROLL_FRACTION
;
goal
=
es
->
format_rect
.
right
-
format_width
/
HSCROLL_FRACTION
;
do
{
do
{
es
->
x_offset
++
;
es
->
x_offset
++
;
...
@@ -3545,7 +3548,7 @@ static void EDIT_EM_SetHandle(EDITSTATE *es, HLOCAL hloc)
...
@@ -3545,7 +3548,7 @@ static void EDIT_EM_SetHandle(EDITSTATE *es, HLOCAL hloc)
EDIT_EM_EmptyUndoBuffer
(
es
);
EDIT_EM_EmptyUndoBuffer
(
es
);
es
->
flags
&=
~
EF_MODIFIED
;
es
->
flags
&=
~
EF_MODIFIED
;
es
->
flags
&=
~
EF_UPDATE
;
es
->
flags
&=
~
EF_UPDATE
;
EDIT_BuildLineDefs_ML
(
es
,
0
,
strlenW
(
es
->
text
),
0
,
NULL
);
EDIT_BuildLineDefs_ML
(
es
,
0
,
get_text_length
(
es
),
0
,
NULL
);
EDIT_UpdateText
(
es
,
NULL
,
TRUE
);
EDIT_UpdateText
(
es
,
NULL
,
TRUE
);
EDIT_EM_ScrollCaret
(
es
);
EDIT_EM_ScrollCaret
(
es
);
/* force scroll info update */
/* force scroll info update */
...
@@ -3617,7 +3620,7 @@ static void EDIT_EM_SetHandle16(EDITSTATE *es, HLOCAL16 hloc)
...
@@ -3617,7 +3620,7 @@ static void EDIT_EM_SetHandle16(EDITSTATE *es, HLOCAL16 hloc)
EDIT_EM_EmptyUndoBuffer
(
es
);
EDIT_EM_EmptyUndoBuffer
(
es
);
es
->
flags
&=
~
EF_MODIFIED
;
es
->
flags
&=
~
EF_MODIFIED
;
es
->
flags
&=
~
EF_UPDATE
;
es
->
flags
&=
~
EF_UPDATE
;
EDIT_BuildLineDefs_ML
(
es
,
0
,
strlenW
(
es
->
text
),
0
,
NULL
);
EDIT_BuildLineDefs_ML
(
es
,
0
,
get_text_length
(
es
),
0
,
NULL
);
EDIT_UpdateText
(
es
,
NULL
,
TRUE
);
EDIT_UpdateText
(
es
,
NULL
,
TRUE
);
EDIT_EM_ScrollCaret
(
es
);
EDIT_EM_ScrollCaret
(
es
);
/* force scroll info update */
/* force scroll info update */
...
@@ -3779,7 +3782,7 @@ static void EDIT_EM_SetSel(EDITSTATE *es, UINT start, UINT end, BOOL after_wrap)
...
@@ -3779,7 +3782,7 @@ static void EDIT_EM_SetSel(EDITSTATE *es, UINT start, UINT end, BOOL after_wrap)
{
{
UINT
old_start
=
es
->
selection_start
;
UINT
old_start
=
es
->
selection_start
;
UINT
old_end
=
es
->
selection_end
;
UINT
old_end
=
es
->
selection_end
;
UINT
len
=
strlenW
(
es
->
text
);
UINT
len
=
get_text_length
(
es
);
if
(
start
==
(
UINT
)
-
1
)
{
if
(
start
==
(
UINT
)
-
1
)
{
start
=
es
->
selection_end
;
start
=
es
->
selection_end
;
...
@@ -3894,7 +3897,7 @@ static void EDIT_EM_SetWordBreakProc(EDITSTATE *es, void *wbp)
...
@@ -3894,7 +3897,7 @@ static void EDIT_EM_SetWordBreakProc(EDITSTATE *es, void *wbp)
es
->
word_break_proc16
=
NULL
;
es
->
word_break_proc16
=
NULL
;
if
((
es
->
style
&
ES_MULTILINE
)
&&
!
(
es
->
style
&
ES_AUTOHSCROLL
))
{
if
((
es
->
style
&
ES_MULTILINE
)
&&
!
(
es
->
style
&
ES_AUTOHSCROLL
))
{
EDIT_BuildLineDefs_ML
(
es
,
0
,
strlenW
(
es
->
text
),
0
,
NULL
);
EDIT_BuildLineDefs_ML
(
es
,
0
,
get_text_length
(
es
),
0
,
NULL
);
EDIT_UpdateText
(
es
,
NULL
,
TRUE
);
EDIT_UpdateText
(
es
,
NULL
,
TRUE
);
}
}
}
}
...
@@ -3913,7 +3916,7 @@ static void EDIT_EM_SetWordBreakProc16(EDITSTATE *es, EDITWORDBREAKPROC16 wbp)
...
@@ -3913,7 +3916,7 @@ static void EDIT_EM_SetWordBreakProc16(EDITSTATE *es, EDITWORDBREAKPROC16 wbp)
es
->
word_break_proc
=
NULL
;
es
->
word_break_proc
=
NULL
;
es
->
word_break_proc16
=
wbp
;
es
->
word_break_proc16
=
wbp
;
if
((
es
->
style
&
ES_MULTILINE
)
&&
!
(
es
->
style
&
ES_AUTOHSCROLL
))
{
if
((
es
->
style
&
ES_MULTILINE
)
&&
!
(
es
->
style
&
ES_AUTOHSCROLL
))
{
EDIT_BuildLineDefs_ML
(
es
,
0
,
strlenW
(
es
->
text
),
0
,
NULL
);
EDIT_BuildLineDefs_ML
(
es
,
0
,
get_text_length
(
es
),
0
,
NULL
);
EDIT_UpdateText
(
es
,
NULL
,
TRUE
);
EDIT_UpdateText
(
es
,
NULL
,
TRUE
);
}
}
}
}
...
@@ -4105,7 +4108,7 @@ static void EDIT_WM_ContextMenu(EDITSTATE *es, INT x, INT y)
...
@@ -4105,7 +4108,7 @@ static void EDIT_WM_ContextMenu(EDITSTATE *es, INT x, INT y)
/* delete */
/* delete */
EnableMenuItem
(
popup
,
5
,
MF_BYPOSITION
|
((
end
-
start
)
&&
!
(
es
->
style
&
ES_READONLY
)
?
MF_ENABLED
:
MF_GRAYED
));
EnableMenuItem
(
popup
,
5
,
MF_BYPOSITION
|
((
end
-
start
)
&&
!
(
es
->
style
&
ES_READONLY
)
?
MF_ENABLED
:
MF_GRAYED
));
/* select all */
/* select all */
EnableMenuItem
(
popup
,
7
,
MF_BYPOSITION
|
(
start
||
(
end
!=
strlenW
(
es
->
text
))
?
MF_ENABLED
:
MF_GRAYED
));
EnableMenuItem
(
popup
,
7
,
MF_BYPOSITION
|
(
start
||
(
end
!=
get_text_length
(
es
))
?
MF_ENABLED
:
MF_GRAYED
));
if
(
x
==
-
1
&&
y
==
-
1
)
/* passed via VK_APPS press/release */
if
(
x
==
-
1
&&
y
==
-
1
)
/* passed via VK_APPS press/release */
{
{
...
@@ -4999,7 +5002,7 @@ static void EDIT_WM_SetFont(EDITSTATE *es, HFONT font, BOOL redraw)
...
@@ -4999,7 +5002,7 @@ static void EDIT_WM_SetFont(EDITSTATE *es, HFONT font, BOOL redraw)
EC_USEFONTINFO
,
EC_USEFONTINFO
,
FALSE
);
EC_USEFONTINFO
,
EC_USEFONTINFO
,
FALSE
);
if
(
es
->
style
&
ES_MULTILINE
)
if
(
es
->
style
&
ES_MULTILINE
)
EDIT_BuildLineDefs_ML
(
es
,
0
,
strlenW
(
es
->
text
),
0
,
NULL
);
EDIT_BuildLineDefs_ML
(
es
,
0
,
get_text_length
(
es
),
0
,
NULL
);
else
else
EDIT_CalcLineWidth_SL
(
es
);
EDIT_CalcLineWidth_SL
(
es
);
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment