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
e265c493
Commit
e265c493
authored
6 years ago
by
Nikolay Sivov
Committed by
Alexandre Julliard
6 years ago
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
comctl32/edit: Use the global memory allocation helpers.
Signed-off-by:
Nikolay Sivov
<
nsivov@codeweavers.com
>
Signed-off-by:
Alexandre Julliard
<
julliard@winehq.org
>
parent
94faa161
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
34 additions
and
33 deletions
+34
-33
edit.c
dlls/comctl32/edit.c
+34
-33
No files found.
dlls/comctl32/edit.c
View file @
e265c493
...
@@ -50,6 +50,7 @@
...
@@ -50,6 +50,7 @@
#include "vsstyle.h"
#include "vsstyle.h"
#include "wine/unicode.h"
#include "wine/unicode.h"
#include "wine/debug.h"
#include "wine/debug.h"
#include "wine/heap.h"
WINE_DEFAULT_DEBUG_CHANNEL
(
edit
);
WINE_DEFAULT_DEBUG_CHANNEL
(
edit
);
...
@@ -242,7 +243,7 @@ static INT EDIT_WordBreakProc(EDITSTATE *es, LPWSTR s, INT index, INT count, INT
...
@@ -242,7 +243,7 @@ static INT EDIT_WordBreakProc(EDITSTATE *es, LPWSTR s, INT index, INT count, INT
memset
(
&
psa
,
0
,
sizeof
(
SCRIPT_ANALYSIS
));
memset
(
&
psa
,
0
,
sizeof
(
SCRIPT_ANALYSIS
));
psa
.
eScript
=
SCRIPT_UNDEFINED
;
psa
.
eScript
=
SCRIPT_UNDEFINED
;
es
->
logAttr
=
HeapAlloc
(
GetProcessHeap
(),
0
,
sizeof
(
SCRIPT_LOGATTR
)
*
get_text_length
(
es
));
es
->
logAttr
=
heap_alloc
(
sizeof
(
SCRIPT_LOGATTR
)
*
get_text_length
(
es
));
ScriptBreak
(
es
->
text
,
get_text_length
(
es
),
&
psa
,
es
->
logAttr
);
ScriptBreak
(
es
->
text
,
get_text_length
(
es
),
&
psa
,
es
->
logAttr
);
}
}
...
@@ -480,7 +481,7 @@ static void EDIT_BuildLineDefs_ML(EDITSTATE *es, INT istart, INT iend, INT delta
...
@@ -480,7 +481,7 @@ static void EDIT_BuildLineDefs_ML(EDITSTATE *es, INT istart, INT iend, INT delta
{
{
/* The buffer has been expanded, create a new line and
/* The buffer has been expanded, create a new line and
insert it into the link list */
insert it into the link list */
LINEDEF
*
new_line
=
HeapAlloc
(
GetProcessHeap
(),
HEAP_ZERO_MEMORY
,
sizeof
(
LINEDEF
));
LINEDEF
*
new_line
=
heap_alloc_zero
(
sizeof
(
*
new_line
));
new_line
->
next
=
previous_line
->
next
;
new_line
->
next
=
previous_line
->
next
;
previous_line
->
next
=
new_line
;
previous_line
->
next
=
new_line
;
current_line
=
new_line
;
current_line
=
new_line
;
...
@@ -490,7 +491,7 @@ static void EDIT_BuildLineDefs_ML(EDITSTATE *es, INT istart, INT iend, INT delta
...
@@ -490,7 +491,7 @@ static void EDIT_BuildLineDefs_ML(EDITSTATE *es, INT istart, INT iend, INT delta
{
{
/* The previous line merged with this line so we delete this extra entry */
/* The previous line merged with this line so we delete this extra entry */
previous_line
->
next
=
current_line
->
next
;
previous_line
->
next
=
current_line
->
next
;
HeapFree
(
GetProcessHeap
(),
0
,
current_line
);
heap_free
(
current_line
);
current_line
=
previous_line
->
next
;
current_line
=
previous_line
->
next
;
es
->
line_count
--
;
es
->
line_count
--
;
continue
;
continue
;
...
@@ -590,7 +591,7 @@ static void EDIT_BuildLineDefs_ML(EDITSTATE *es, INT istart, INT iend, INT delta
...
@@ -590,7 +591,7 @@ static void EDIT_BuildLineDefs_ML(EDITSTATE *es, INT istart, INT iend, INT delta
if
(
current_line
->
ssa
)
if
(
current_line
->
ssa
)
{
{
count
=
ScriptString_pcOutChars
(
current_line
->
ssa
);
count
=
ScriptString_pcOutChars
(
current_line
->
ssa
);
piDx
=
HeapAlloc
(
GetProcessHeap
(),
0
,
sizeof
(
INT
)
*
(
*
count
));
piDx
=
heap_alloc
(
sizeof
(
INT
)
*
(
*
count
));
ScriptStringGetLogicalWidths
(
current_line
->
ssa
,
piDx
);
ScriptStringGetLogicalWidths
(
current_line
->
ssa
,
piDx
);
prev
=
current_line
->
net_length
-
1
;
prev
=
current_line
->
net_length
-
1
;
...
@@ -600,7 +601,7 @@ static void EDIT_BuildLineDefs_ML(EDITSTATE *es, INT istart, INT iend, INT delta
...
@@ -600,7 +601,7 @@ static void EDIT_BuildLineDefs_ML(EDITSTATE *es, INT istart, INT iend, INT delta
}
while
(
prev
>
0
&&
current_line
->
width
>
fw
);
}
while
(
prev
>
0
&&
current_line
->
width
>
fw
);
if
(
prev
<=
0
)
if
(
prev
<=
0
)
prev
=
1
;
prev
=
1
;
HeapFree
(
GetProcessHeap
(),
0
,
piDx
);
heap_free
(
piDx
);
}
}
else
else
prev
=
(
fw
/
es
->
char_width
);
prev
=
(
fw
/
es
->
char_width
);
...
@@ -689,7 +690,7 @@ static void EDIT_BuildLineDefs_ML(EDITSTATE *es, INT istart, INT iend, INT delta
...
@@ -689,7 +690,7 @@ static void EDIT_BuildLineDefs_ML(EDITSTATE *es, INT istart, INT iend, INT delta
{
{
pnext
=
current_line
->
next
;
pnext
=
current_line
->
next
;
EDIT_InvalidateUniscribeData_linedef
(
current_line
);
EDIT_InvalidateUniscribeData_linedef
(
current_line
);
HeapFree
(
GetProcessHeap
(),
0
,
current_line
);
heap_free
(
current_line
);
current_line
=
pnext
;
current_line
=
pnext
;
es
->
line_count
--
;
es
->
line_count
--
;
}
}
...
@@ -1181,7 +1182,7 @@ static inline void text_buffer_changed(EDITSTATE *es)
...
@@ -1181,7 +1182,7 @@ static inline void text_buffer_changed(EDITSTATE *es)
{
{
es
->
text_length
=
(
UINT
)
-
1
;
es
->
text_length
=
(
UINT
)
-
1
;
HeapFree
(
GetProcessHeap
(),
0
,
es
->
logAttr
);
heap_free
(
es
->
logAttr
);
es
->
logAttr
=
NULL
;
es
->
logAttr
=
NULL
;
EDIT_InvalidateUniscribeData
(
es
);
EDIT_InvalidateUniscribeData
(
es
);
}
}
...
@@ -2463,7 +2464,7 @@ static void EDIT_EM_ReplaceSel(EDITSTATE *es, BOOL can_undo, const WCHAR *lpsz_r
...
@@ -2463,7 +2464,7 @@ static void EDIT_EM_ReplaceSel(EDITSTATE *es, BOOL can_undo, const WCHAR *lpsz_r
/* there is something to be deleted */
/* there is something to be deleted */
TRACE
(
"deleting stuff.
\n
"
);
TRACE
(
"deleting stuff.
\n
"
);
bufl
=
e
-
s
;
bufl
=
e
-
s
;
buf
=
HeapAlloc
(
GetProcessHeap
(),
0
,
(
bufl
+
1
)
*
sizeof
(
WCHAR
));
buf
=
heap_alloc
(
(
bufl
+
1
)
*
sizeof
(
WCHAR
));
if
(
!
buf
)
return
;
if
(
!
buf
)
return
;
memcpy
(
buf
,
es
->
text
+
s
,
bufl
*
sizeof
(
WCHAR
));
memcpy
(
buf
,
es
->
text
+
s
,
bufl
*
sizeof
(
WCHAR
));
buf
[
bufl
]
=
0
;
/* ensure 0 termination */
buf
[
bufl
]
=
0
;
/* ensure 0 termination */
...
@@ -2576,7 +2577,7 @@ static void EDIT_EM_ReplaceSel(EDITSTATE *es, BOOL can_undo, const WCHAR *lpsz_r
...
@@ -2576,7 +2577,7 @@ static void EDIT_EM_ReplaceSel(EDITSTATE *es, BOOL can_undo, const WCHAR *lpsz_r
EDIT_EM_EmptyUndoBuffer
(
es
);
EDIT_EM_EmptyUndoBuffer
(
es
);
}
}
HeapFree
(
GetProcessHeap
(),
0
,
buf
);
heap_free
(
buf
);
s
+=
strl
;
s
+=
strl
;
...
@@ -2803,12 +2804,12 @@ static BOOL EDIT_EM_SetTabStops(EDITSTATE *es, INT count, const INT *tabs)
...
@@ -2803,12 +2804,12 @@ static BOOL EDIT_EM_SetTabStops(EDITSTATE *es, INT count, const INT *tabs)
{
{
if
(
!
(
es
->
style
&
ES_MULTILINE
))
if
(
!
(
es
->
style
&
ES_MULTILINE
))
return
FALSE
;
return
FALSE
;
HeapFree
(
GetProcessHeap
(),
0
,
es
->
tabs
);
heap_free
(
es
->
tabs
);
es
->
tabs_count
=
count
;
es
->
tabs_count
=
count
;
if
(
!
count
)
if
(
!
count
)
es
->
tabs
=
NULL
;
es
->
tabs
=
NULL
;
else
{
else
{
es
->
tabs
=
HeapAlloc
(
GetProcessHeap
(),
0
,
count
*
sizeof
(
INT
));
es
->
tabs
=
heap_alloc
(
count
*
sizeof
(
INT
));
memcpy
(
es
->
tabs
,
tabs
,
count
*
sizeof
(
INT
));
memcpy
(
es
->
tabs
,
tabs
,
count
*
sizeof
(
INT
));
}
}
EDIT_InvalidateUniscribeData
(
es
);
EDIT_InvalidateUniscribeData
(
es
);
...
@@ -2852,7 +2853,7 @@ static BOOL EDIT_EM_Undo(EDITSTATE *es)
...
@@ -2852,7 +2853,7 @@ static BOOL EDIT_EM_Undo(EDITSTATE *es)
ulength
=
strlenW
(
es
->
undo_text
);
ulength
=
strlenW
(
es
->
undo_text
);
utext
=
HeapAlloc
(
GetProcessHeap
(),
0
,
(
ulength
+
1
)
*
sizeof
(
WCHAR
));
utext
=
heap_alloc
(
(
ulength
+
1
)
*
sizeof
(
WCHAR
));
strcpyW
(
utext
,
es
->
undo_text
);
strcpyW
(
utext
,
es
->
undo_text
);
...
@@ -2866,7 +2867,7 @@ static BOOL EDIT_EM_Undo(EDITSTATE *es)
...
@@ -2866,7 +2867,7 @@ static BOOL EDIT_EM_Undo(EDITSTATE *es)
/* send the notification after the selection start and end are set */
/* send the notification after the selection start and end are set */
EDIT_NOTIFY_PARENT
(
es
,
EN_CHANGE
);
EDIT_NOTIFY_PARENT
(
es
,
EN_CHANGE
);
EDIT_EM_ScrollCaret
(
es
);
EDIT_EM_ScrollCaret
(
es
);
HeapFree
(
GetProcessHeap
(),
0
,
utext
);
heap_free
(
utext
);
TRACE
(
"after UNDO:insertion length = %d, deletion buffer = %s
\n
"
,
TRACE
(
"after UNDO:insertion length = %d, deletion buffer = %s
\n
"
,
es
->
undo_insert_count
,
debugstr_w
(
es
->
undo_text
));
es
->
undo_insert_count
,
debugstr_w
(
es
->
undo_text
));
...
@@ -4171,7 +4172,7 @@ static void EDIT_GetCompositionStr(HIMC hIMC, LPARAM CompFlag, EDITSTATE *es)
...
@@ -4171,7 +4172,7 @@ static void EDIT_GetCompositionStr(HIMC hIMC, LPARAM CompFlag, EDITSTATE *es)
return
;
return
;
}
}
lpCompStr
=
HeapAlloc
(
GetProcessHeap
(),
0
,
buflen
);
lpCompStr
=
heap_alloc
(
buflen
);
if
(
!
lpCompStr
)
if
(
!
lpCompStr
)
{
{
ERR
(
"Unable to allocate IME CompositionString
\n
"
);
ERR
(
"Unable to allocate IME CompositionString
\n
"
);
...
@@ -4191,11 +4192,11 @@ static void EDIT_GetCompositionStr(HIMC hIMC, LPARAM CompFlag, EDITSTATE *es)
...
@@ -4191,11 +4192,11 @@ static void EDIT_GetCompositionStr(HIMC hIMC, LPARAM CompFlag, EDITSTATE *es)
if
(
dwBufLenAttr
)
if
(
dwBufLenAttr
)
{
{
dwBufLenAttr
++
;
dwBufLenAttr
++
;
lpCompStrAttr
=
HeapAlloc
(
GetProcessHeap
(),
0
,
dwBufLenAttr
+
1
);
lpCompStrAttr
=
heap_alloc
(
dwBufLenAttr
+
1
);
if
(
!
lpCompStrAttr
)
if
(
!
lpCompStrAttr
)
{
{
ERR
(
"Unable to allocate IME Attribute String
\n
"
);
ERR
(
"Unable to allocate IME Attribute String
\n
"
);
HeapFree
(
GetProcessHeap
(),
0
,
lpCompStr
);
heap_free
(
lpCompStr
);
return
;
return
;
}
}
ImmGetCompositionStringW
(
hIMC
,
GCS_COMPATTR
,
lpCompStrAttr
,
ImmGetCompositionStringW
(
hIMC
,
GCS_COMPATTR
,
lpCompStrAttr
,
...
@@ -4222,8 +4223,8 @@ static void EDIT_GetCompositionStr(HIMC hIMC, LPARAM CompFlag, EDITSTATE *es)
...
@@ -4222,8 +4223,8 @@ static void EDIT_GetCompositionStr(HIMC hIMC, LPARAM CompFlag, EDITSTATE *es)
es
->
selection_start
=
es
->
composition_start
;
es
->
selection_start
=
es
->
composition_start
;
es
->
selection_end
=
es
->
selection_start
+
es
->
composition_len
;
es
->
selection_end
=
es
->
selection_start
+
es
->
composition_len
;
HeapFree
(
GetProcessHeap
(),
0
,
lpCompStrAttr
);
heap_free
(
lpCompStrAttr
);
HeapFree
(
GetProcessHeap
(),
0
,
lpCompStr
);
heap_free
(
lpCompStr
);
}
}
static
void
EDIT_GetResultStr
(
HIMC
hIMC
,
EDITSTATE
*
es
)
static
void
EDIT_GetResultStr
(
HIMC
hIMC
,
EDITSTATE
*
es
)
...
@@ -4237,7 +4238,7 @@ static void EDIT_GetResultStr(HIMC hIMC, EDITSTATE *es)
...
@@ -4237,7 +4238,7 @@ static void EDIT_GetResultStr(HIMC hIMC, EDITSTATE *es)
return
;
return
;
}
}
lpResultStr
=
HeapAlloc
(
GetProcessHeap
(),
0
,
buflen
);
lpResultStr
=
heap_alloc
(
buflen
);
if
(
!
lpResultStr
)
if
(
!
lpResultStr
)
{
{
ERR
(
"Unable to alloc buffer for IME string
\n
"
);
ERR
(
"Unable to alloc buffer for IME string
\n
"
);
...
@@ -4256,7 +4257,7 @@ static void EDIT_GetResultStr(HIMC hIMC, EDITSTATE *es)
...
@@ -4256,7 +4257,7 @@ static void EDIT_GetResultStr(HIMC hIMC, EDITSTATE *es)
es
->
composition_start
=
es
->
selection_end
;
es
->
composition_start
=
es
->
selection_end
;
es
->
composition_len
=
0
;
es
->
composition_len
=
0
;
HeapFree
(
GetProcessHeap
(),
0
,
lpResultStr
);
heap_free
(
lpResultStr
);
}
}
static
void
EDIT_ImeComposition
(
HWND
hwnd
,
LPARAM
CompFlag
,
EDITSTATE
*
es
)
static
void
EDIT_ImeComposition
(
HWND
hwnd
,
LPARAM
CompFlag
,
EDITSTATE
*
es
)
...
@@ -4303,9 +4304,9 @@ static LRESULT EDIT_WM_NCCreate(HWND hwnd, LPCREATESTRUCTW lpcs)
...
@@ -4303,9 +4304,9 @@ static LRESULT EDIT_WM_NCCreate(HWND hwnd, LPCREATESTRUCTW lpcs)
TRACE
(
"Creating edit control, style = %08x
\n
"
,
lpcs
->
style
);
TRACE
(
"Creating edit control, style = %08x
\n
"
,
lpcs
->
style
);
if
(
!
(
es
=
HeapAlloc
(
GetProcessHeap
(),
HEAP_ZERO_MEMORY
,
sizeof
(
*
es
))))
if
(
!
(
es
=
heap_alloc_zero
(
sizeof
(
*
es
))))
return
FALSE
;
return
FALSE
;
SetWindowLongPtrW
(
hwnd
,
0
,
(
LONG_PTR
)
es
);
SetWindowLongPtrW
(
hwnd
,
0
,
(
LONG_PTR
)
es
);
/*
/*
* Note: since the EDITSTATE has not been fully initialized yet,
* Note: since the EDITSTATE has not been fully initialized yet,
...
@@ -4365,13 +4366,13 @@ static LRESULT EDIT_WM_NCCreate(HWND hwnd, LPCREATESTRUCTW lpcs)
...
@@ -4365,13 +4366,13 @@ static LRESULT EDIT_WM_NCCreate(HWND hwnd, LPCREATESTRUCTW lpcs)
goto
cleanup
;
goto
cleanup
;
es
->
buffer_size
=
LocalSize
(
es
->
hloc32W
)
/
sizeof
(
WCHAR
)
-
1
;
es
->
buffer_size
=
LocalSize
(
es
->
hloc32W
)
/
sizeof
(
WCHAR
)
-
1
;
if
(
!
(
es
->
undo_text
=
HeapAlloc
(
GetProcessHeap
(),
HEAP_ZERO_MEMORY
,
(
es
->
buffer_size
+
1
)
*
sizeof
(
WCHAR
))))
if
(
!
(
es
->
undo_text
=
heap_alloc_zero
(
(
es
->
buffer_size
+
1
)
*
sizeof
(
WCHAR
))))
goto
cleanup
;
goto
cleanup
;
es
->
undo_buffer_size
=
es
->
buffer_size
;
es
->
undo_buffer_size
=
es
->
buffer_size
;
if
(
es
->
style
&
ES_MULTILINE
)
if
(
es
->
style
&
ES_MULTILINE
)
if
(
!
(
es
->
first_line_def
=
HeapAlloc
(
GetProcessHeap
(),
HEAP_ZERO_MEMORY
,
sizeof
(
LINEDEF
))))
if
(
!
(
es
->
first_line_def
=
heap_alloc_zero
(
sizeof
(
LINEDEF
))))
goto
cleanup
;
goto
cleanup
;
es
->
line_count
=
1
;
es
->
line_count
=
1
;
/*
/*
...
@@ -4395,11 +4396,11 @@ static LRESULT EDIT_WM_NCCreate(HWND hwnd, LPCREATESTRUCTW lpcs)
...
@@ -4395,11 +4396,11 @@ static LRESULT EDIT_WM_NCCreate(HWND hwnd, LPCREATESTRUCTW lpcs)
cleanup:
cleanup:
SetWindowLongPtrW
(
es
->
hwndSelf
,
0
,
0
);
SetWindowLongPtrW
(
es
->
hwndSelf
,
0
,
0
);
EDIT_InvalidateUniscribeData
(
es
);
EDIT_InvalidateUniscribeData
(
es
);
HeapFree
(
GetProcessHeap
(),
0
,
es
->
first_line_def
);
heap_free
(
es
->
first_line_def
);
HeapFree
(
GetProcessHeap
(),
0
,
es
->
undo_text
);
heap_free
(
es
->
undo_text
);
if
(
es
->
hloc32W
)
LocalFree
(
es
->
hloc32W
);
if
(
es
->
hloc32W
)
LocalFree
(
es
->
hloc32W
);
HeapFree
(
GetProcessHeap
(),
0
,
es
->
logAttr
);
heap_free
(
es
->
logAttr
);
HeapFree
(
GetProcessHeap
(),
0
,
es
);
heap_free
(
es
);
return
FALSE
;
return
FALSE
;
}
}
...
@@ -4482,13 +4483,13 @@ static LRESULT EDIT_WM_NCDestroy(EDITSTATE *es)
...
@@ -4482,13 +4483,13 @@ static LRESULT EDIT_WM_NCDestroy(EDITSTATE *es)
while
(
pc
)
while
(
pc
)
{
{
pp
=
pc
->
next
;
pp
=
pc
->
next
;
HeapFree
(
GetProcessHeap
(),
0
,
pc
);
heap_free
(
pc
);
pc
=
pp
;
pc
=
pp
;
}
}
SetWindowLongPtrW
(
es
->
hwndSelf
,
0
,
0
);
SetWindowLongPtrW
(
es
->
hwndSelf
,
0
,
0
);
HeapFree
(
GetProcessHeap
(),
0
,
es
->
undo_text
);
heap_free
(
es
->
undo_text
);
HeapFree
(
GetProcessHeap
(),
0
,
es
);
heap_free
(
es
);
return
0
;
return
0
;
}
}
...
...
This diff is collapsed.
Click to expand it.
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