Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-winehq
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-winehq
Commits
c1043428
Commit
c1043428
authored
Apr 08, 2010
by
Alexandre Julliard
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
inetcomm: Store an index instead of a handle for mime bodies to avoid pointer conversion warnings.
parent
5c632145
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
9 additions
and
10 deletions
+9
-10
mimeintl.c
dlls/inetcomm/mimeintl.c
+1
-1
mimeole.c
dlls/inetcomm/mimeole.c
+8
-9
No files found.
dlls/inetcomm/mimeintl.c
View file @
c1043428
...
@@ -268,7 +268,7 @@ static HRESULT WINAPI MimeInternat_FindCharset(IMimeInternational *iface, LPCSTR
...
@@ -268,7 +268,7 @@ static HRESULT WINAPI MimeInternat_FindCharset(IMimeInternational *iface, LPCSTR
if
(
SUCCEEDED
(
hr
))
if
(
SUCCEEDED
(
hr
))
*
phCharset
=
add_charset
(
&
This
->
charsets
,
&
mlang_info
,
*
phCharset
=
add_charset
(
&
This
->
charsets
,
&
mlang_info
,
(
HCHARSET
)
InterlockedIncrement
(
&
This
->
next_charset_handle
));
UlongToHandle
(
InterlockedIncrement
(
&
This
->
next_charset_handle
)
));
}
}
LeaveCriticalSection
(
&
This
->
cs
);
LeaveCriticalSection
(
&
This
->
cs
);
...
...
dlls/inetcomm/mimeole.c
View file @
c1043428
...
@@ -1419,7 +1419,7 @@ static HRESULT create_sub_stream(IStream *stream, ULARGE_INTEGER start, ULARGE_I
...
@@ -1419,7 +1419,7 @@ static HRESULT create_sub_stream(IStream *stream, ULARGE_INTEGER start, ULARGE_I
typedef
struct
body_t
typedef
struct
body_t
{
{
struct
list
entry
;
struct
list
entry
;
HBODY
hbody
;
DWORD
index
;
IMimeBody
*
mime_body
;
IMimeBody
*
mime_body
;
struct
body_t
*
parent
;
struct
body_t
*
parent
;
...
@@ -1434,7 +1434,7 @@ typedef struct MimeMessage
...
@@ -1434,7 +1434,7 @@ typedef struct MimeMessage
IStream
*
stream
;
IStream
*
stream
;
struct
list
body_tree
;
struct
list
body_tree
;
HBODY
next_hbody
;
DWORD
next_index
;
}
MimeMessage
;
}
MimeMessage
;
static
HRESULT
WINAPI
MimeMessage_QueryInterface
(
IMimeMessage
*
iface
,
REFIID
riid
,
void
**
ppv
)
static
HRESULT
WINAPI
MimeMessage_QueryInterface
(
IMimeMessage
*
iface
,
REFIID
riid
,
void
**
ppv
)
...
@@ -1512,13 +1512,13 @@ static HRESULT WINAPI MimeMessage_IsDirty(
...
@@ -1512,13 +1512,13 @@ static HRESULT WINAPI MimeMessage_IsDirty(
return
E_NOTIMPL
;
return
E_NOTIMPL
;
}
}
static
body_t
*
new_body_entry
(
IMimeBody
*
mime_body
,
HBODY
hbody
,
body_t
*
parent
)
static
body_t
*
new_body_entry
(
IMimeBody
*
mime_body
,
DWORD
index
,
body_t
*
parent
)
{
{
body_t
*
body
=
HeapAlloc
(
GetProcessHeap
(),
0
,
sizeof
(
*
body
));
body_t
*
body
=
HeapAlloc
(
GetProcessHeap
(),
0
,
sizeof
(
*
body
));
if
(
body
)
if
(
body
)
{
{
body
->
mime_body
=
mime_body
;
body
->
mime_body
=
mime_body
;
body
->
hbody
=
hbody
;
body
->
index
=
index
;
list_init
(
&
body
->
children
);
list_init
(
&
body
->
children
);
body
->
parent
=
parent
;
body
->
parent
=
parent
;
}
}
...
@@ -1630,8 +1630,7 @@ static body_t *create_sub_body(MimeMessage *msg, IStream *pStm, BODYOFFSETS *off
...
@@ -1630,8 +1630,7 @@ static body_t *create_sub_body(MimeMessage *msg, IStream *pStm, BODYOFFSETS *off
offset
->
cbBodyStart
=
cur
.
u
.
LowPart
+
offset
->
cbHeaderStart
;
offset
->
cbBodyStart
=
cur
.
u
.
LowPart
+
offset
->
cbHeaderStart
;
if
(
parent
)
MimeBody_set_offsets
(
impl_from_IMimeBody
(
mime_body
),
offset
);
if
(
parent
)
MimeBody_set_offsets
(
impl_from_IMimeBody
(
mime_body
),
offset
);
IMimeBody_SetData
(
mime_body
,
IET_BINARY
,
NULL
,
NULL
,
&
IID_IStream
,
pStm
);
IMimeBody_SetData
(
mime_body
,
IET_BINARY
,
NULL
,
NULL
,
&
IID_IStream
,
pStm
);
body
=
new_body_entry
(
mime_body
,
msg
->
next_hbody
,
parent
);
body
=
new_body_entry
(
mime_body
,
msg
->
next_index
++
,
parent
);
msg
->
next_hbody
=
(
HBODY
)((
DWORD
)
msg
->
next_hbody
+
1
);
if
(
IMimeBody_IsContentType
(
mime_body
,
"multipart"
,
NULL
)
==
S_OK
)
if
(
IMimeBody_IsContentType
(
mime_body
,
"multipart"
,
NULL
)
==
S_OK
)
{
{
...
@@ -1812,7 +1811,7 @@ static HRESULT find_body(struct list *list, HBODY hbody, body_t **body)
...
@@ -1812,7 +1811,7 @@ static HRESULT find_body(struct list *list, HBODY hbody, body_t **body)
LIST_FOR_EACH_ENTRY
(
cur
,
list
,
body_t
,
entry
)
LIST_FOR_EACH_ENTRY
(
cur
,
list
,
body_t
,
entry
)
{
{
if
(
cur
->
hbody
==
hbody
)
if
(
cur
->
index
==
HandleToUlong
(
hbody
)
)
{
{
*
body
=
cur
;
*
body
=
cur
;
return
S_OK
;
return
S_OK
;
...
@@ -1948,7 +1947,7 @@ static HRESULT WINAPI MimeMessage_GetBody(
...
@@ -1948,7 +1947,7 @@ static HRESULT WINAPI MimeMessage_GetBody(
hr
=
get_body
(
This
,
location
,
hPivot
,
&
body
);
hr
=
get_body
(
This
,
location
,
hPivot
,
&
body
);
if
(
hr
==
S_OK
)
*
phBody
=
body
->
hbody
;
if
(
hr
==
S_OK
)
*
phBody
=
UlongToHandle
(
body
->
index
)
;
return
hr
;
return
hr
;
}
}
...
@@ -2562,7 +2561,7 @@ HRESULT MimeMessage_create(IUnknown *outer, void **obj)
...
@@ -2562,7 +2561,7 @@ HRESULT MimeMessage_create(IUnknown *outer, void **obj)
This
->
refs
=
1
;
This
->
refs
=
1
;
This
->
stream
=
NULL
;
This
->
stream
=
NULL
;
list_init
(
&
This
->
body_tree
);
list_init
(
&
This
->
body_tree
);
This
->
next_
hbody
=
(
HBODY
)
1
;
This
->
next_
index
=
1
;
*
obj
=
&
This
->
lpVtbl
;
*
obj
=
&
This
->
lpVtbl
;
return
S_OK
;
return
S_OK
;
...
...
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