Commit ec722448 authored by Mike McCormack's avatar Mike McCormack Committed by Alexandre Julliard

Use Interlocked* functions in AddRef and Release.

parent 8ea4fffb
...@@ -624,13 +624,13 @@ MLANGCF_QueryInterface(LPCLASSFACTORY iface,REFIID riid,LPVOID *ppobj) ...@@ -624,13 +624,13 @@ MLANGCF_QueryInterface(LPCLASSFACTORY iface,REFIID riid,LPVOID *ppobj)
static ULONG WINAPI MLANGCF_AddRef(LPCLASSFACTORY iface) { static ULONG WINAPI MLANGCF_AddRef(LPCLASSFACTORY iface) {
IClassFactoryImpl *This = (IClassFactoryImpl *)iface; IClassFactoryImpl *This = (IClassFactoryImpl *)iface;
return ++(This->ref); return InterlockedIncrement(&This->ref);
} }
static ULONG WINAPI MLANGCF_Release(LPCLASSFACTORY iface) { static ULONG WINAPI MLANGCF_Release(LPCLASSFACTORY iface) {
IClassFactoryImpl *This = (IClassFactoryImpl *)iface; IClassFactoryImpl *This = (IClassFactoryImpl *)iface;
ULONG ref = --This->ref; ULONG ref = InterlockedDecrement(&This->ref);
if (ref == 0) if (ref == 0)
{ {
...@@ -733,12 +733,12 @@ typedef struct tagMLang_impl ...@@ -733,12 +733,12 @@ typedef struct tagMLang_impl
static ULONG WINAPI MLang_AddRef( MLang_impl* This) static ULONG WINAPI MLang_AddRef( MLang_impl* This)
{ {
return ++(This->ref); return InterlockedIncrement(&This->ref);
} }
static ULONG WINAPI MLang_Release( MLang_impl* This ) static ULONG WINAPI MLang_Release( MLang_impl* This )
{ {
ULONG ref = --This->ref; ULONG ref = InterlockedDecrement(&This->ref);
TRACE("%p ref = %ld\n", This, ref); TRACE("%p ref = %ld\n", This, ref);
if (ref == 0) if (ref == 0)
...@@ -823,14 +823,14 @@ static ULONG WINAPI fnIEnumCodePage_AddRef( ...@@ -823,14 +823,14 @@ static ULONG WINAPI fnIEnumCodePage_AddRef(
IEnumCodePage* iface) IEnumCodePage* iface)
{ {
ICOM_THIS_MULTI(EnumCodePage_impl, vtbl_IEnumCodePage, iface); ICOM_THIS_MULTI(EnumCodePage_impl, vtbl_IEnumCodePage, iface);
return ++(This->ref); return InterlockedIncrement(&This->ref);
} }
static ULONG WINAPI fnIEnumCodePage_Release( static ULONG WINAPI fnIEnumCodePage_Release(
IEnumCodePage* iface) IEnumCodePage* iface)
{ {
ICOM_THIS_MULTI(EnumCodePage_impl, vtbl_IEnumCodePage, iface); ICOM_THIS_MULTI(EnumCodePage_impl, vtbl_IEnumCodePage, iface);
ULONG ref = --This->ref; ULONG ref = InterlockedDecrement(&This->ref);
TRACE("%p ref = %ld\n", This, ref); TRACE("%p ref = %ld\n", This, ref);
if (ref == 0) if (ref == 0)
...@@ -1009,14 +1009,14 @@ static ULONG WINAPI fnIEnumScript_AddRef( ...@@ -1009,14 +1009,14 @@ static ULONG WINAPI fnIEnumScript_AddRef(
IEnumScript* iface) IEnumScript* iface)
{ {
ICOM_THIS_MULTI(EnumScript_impl, vtbl_IEnumScript, iface); ICOM_THIS_MULTI(EnumScript_impl, vtbl_IEnumScript, iface);
return ++(This->ref); return InterlockedIncrement(&This->ref);
} }
static ULONG WINAPI fnIEnumScript_Release( static ULONG WINAPI fnIEnumScript_Release(
IEnumScript* iface) IEnumScript* iface)
{ {
ICOM_THIS_MULTI(EnumScript_impl, vtbl_IEnumScript, iface); ICOM_THIS_MULTI(EnumScript_impl, vtbl_IEnumScript, iface);
ULONG ref = --This->ref; ULONG ref = InterlockedDecrement(&This->ref);
TRACE("%p ref = %ld\n", This, ref); TRACE("%p ref = %ld\n", This, ref);
if (ref == 0) if (ref == 0)
......
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