inetcomm: Add a stub MimeInternational object.
diff --git a/dlls/inetcomm/Makefile.in b/dlls/inetcomm/Makefile.in
index 462294c..ee03db0 100644
--- a/dlls/inetcomm/Makefile.in
+++ b/dlls/inetcomm/Makefile.in
@@ -9,6 +9,7 @@
C_SRCS = \
inetcomm_main.c \
internettransport.c \
+ mimeintl.c \
mimeole.c \
regsvr.c
diff --git a/dlls/inetcomm/inetcomm.spec b/dlls/inetcomm/inetcomm.spec
index 36a5d8b..4db2c7d 100644
--- a/dlls/inetcomm/inetcomm.spec
+++ b/dlls/inetcomm/inetcomm.spec
@@ -76,7 +76,7 @@
@ stub MimeOleGetFileExtension
@ stub MimeOleGetFileInfo
@ stub MimeOleGetFileInfoW
-@ stub MimeOleGetInternat
+@ stdcall MimeOleGetInternat(ptr)
@ stub MimeOleGetPropA
@ stub MimeOleGetPropW
@ stub MimeOleGetPropertySchema
diff --git a/dlls/inetcomm/inetcomm_main.c b/dlls/inetcomm/inetcomm_main.c
index 15350df..579b05f 100644
--- a/dlls/inetcomm/inetcomm_main.c
+++ b/dlls/inetcomm/inetcomm_main.c
@@ -37,6 +37,8 @@
BOOL WINAPI DllMain(HINSTANCE hinstDLL, DWORD fdwReason, LPVOID lpvReserved)
{
+ IMimeInternational *international;
+
TRACE("(%p, %d, %p)\n", hinstDLL, fdwReason, lpvReserved);
switch (fdwReason)
@@ -47,8 +49,10 @@
DisableThreadLibraryCalls(hinstDLL);
if (!InternetTransport_RegisterClass(hinstDLL))
return FALSE;
+ MimeInternational_Construct(&international);
break;
case DLL_PROCESS_DETACH:
+ IMimeInternational_Release(international);
InternetTransport_UnregisterClass(hinstDLL);
break;
default:
diff --git a/dlls/inetcomm/inetcomm_private.h b/dlls/inetcomm/inetcomm_private.h
index bf6e5ce..5587ae7 100644
--- a/dlls/inetcomm/inetcomm_private.h
+++ b/dlls/inetcomm/inetcomm_private.h
@@ -71,3 +71,5 @@
HRESULT MimeBody_create(IUnknown *outer, void **obj);
HRESULT MimeAllocator_create(IUnknown *outer, void **obj);
+
+HRESULT MimeInternational_Construct(IMimeInternational **internat);
diff --git a/dlls/inetcomm/internettransport.c b/dlls/inetcomm/internettransport.c
index bba6aab..0d3c679 100644
--- a/dlls/inetcomm/internettransport.c
+++ b/dlls/inetcomm/internettransport.c
@@ -26,8 +26,12 @@
#include "windef.h"
#include "winbase.h"
#include "winnt.h"
+#include "winuser.h"
#include "winsock2.h"
#include "ws2tcpip.h"
+#include "objbase.h"
+#include "ole2.h"
+#include "mimeole.h"
#include "wine/debug.h"
diff --git a/dlls/inetcomm/mimeintl.c b/dlls/inetcomm/mimeintl.c
new file mode 100644
index 0000000..6cc1d96
--- /dev/null
+++ b/dlls/inetcomm/mimeintl.c
@@ -0,0 +1,241 @@
+/*
+ * MIME OLE International interface
+ *
+ * Copyright 2008 Huw Davies for CodeWeavers
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2.1 of the License, or (at your option) any later version.
+ *
+ * This library is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this library; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
+ */
+
+#define COBJMACROS
+#define NONAMELESSUNION
+
+#include <stdarg.h>
+#include <stdio.h>
+
+#include "windef.h"
+#include "winbase.h"
+#include "winuser.h"
+#include "winnls.h"
+#include "objbase.h"
+#include "ole2.h"
+#include "mimeole.h"
+
+#include "wine/list.h"
+#include "wine/debug.h"
+
+#include "inetcomm_private.h"
+
+WINE_DEFAULT_DEBUG_CHANNEL(inetcomm);
+
+typedef struct
+{
+ const IMimeInternationalVtbl *lpVtbl;
+ LONG refs;
+} internat;
+
+static inline internat *impl_from_IMimeInternational( IMimeInternational *iface )
+{
+ return (internat *)((char*)iface - FIELD_OFFSET(internat, lpVtbl));
+}
+
+static HRESULT WINAPI MimeInternat_QueryInterface( IMimeInternational *iface, REFIID riid, LPVOID *ppobj )
+{
+ if (IsEqualGUID(riid, &IID_IUnknown) ||
+ IsEqualGUID(riid, &IID_IMimeInternational))
+ {
+ IMimeInternational_AddRef( iface );
+ *ppobj = iface;
+ return S_OK;
+ }
+
+ FIXME("interface %s not implemented\n", debugstr_guid(riid));
+ return E_NOINTERFACE;
+}
+
+static ULONG WINAPI MimeInternat_AddRef( IMimeInternational *iface )
+{
+ internat *This = impl_from_IMimeInternational( iface );
+ return InterlockedIncrement(&This->refs);
+}
+
+static ULONG WINAPI MimeInternat_Release( IMimeInternational *iface )
+{
+ internat *This = impl_from_IMimeInternational( iface );
+ ULONG refs;
+
+ refs = InterlockedDecrement(&This->refs);
+ if (!refs)
+ {
+ HeapFree(GetProcessHeap(), 0, This);
+ }
+
+ return refs;
+}
+
+static HRESULT WINAPI MimeInternat_SetDefaultCharset(IMimeInternational *iface, HCHARSET hCharset)
+{
+ FIXME("stub\n");
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI MimeInternat_GetDefaultCharset(IMimeInternational *iface, LPHCHARSET phCharset)
+{
+ FIXME("stub\n");
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI MimeInternat_GetCodePageCharset(IMimeInternational *iface, CODEPAGEID cpiCodePage,
+ CHARSETTYPE ctCsetType,
+ LPHCHARSET phCharset)
+{
+ FIXME("stub\n");
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI MimeInternat_FindCharset(IMimeInternational *iface, LPCSTR pszCharset,
+ LPHCHARSET phCharset)
+{
+ FIXME("stub\n");
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI MimeInternat_GetCharsetInfo(IMimeInternational *iface, HCHARSET hCharset,
+ LPINETCSETINFO pCsetInfo)
+{
+ FIXME("stub\n");
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI MimeInternat_GetCodePageInfo(IMimeInternational *iface, CODEPAGEID cpiCodePage,
+ LPCODEPAGEINFO pCodePageInfo)
+{
+ FIXME("stub\n");
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI MimeInternat_DecodeHeader(IMimeInternational *iface, HCHARSET hCharset,
+ LPCSTR pszData,
+ LPPROPVARIANT pDecoded,
+ LPRFC1522INFO pRfc1522Info)
+{
+ FIXME("stub\n");
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI MimeInternat_EncodeHeader(IMimeInternational *iface, HCHARSET hCharset,
+ LPPROPVARIANT pData,
+ LPSTR *ppszEncoded,
+ LPRFC1522INFO pRfc1522Info)
+{
+ FIXME("stub\n");
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI MimeInternat_ConvertBuffer(IMimeInternational *iface, CODEPAGEID cpiSource,
+ CODEPAGEID cpiDest,
+ LPBLOB pIn,
+ LPBLOB pOut,
+ ULONG *pcbRead)
+{
+ FIXME("stub\n");
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI MimeInternat_ConvertString(IMimeInternational *iface, CODEPAGEID cpiSource,
+ CODEPAGEID cpiDest,
+ LPPROPVARIANT pIn,
+ LPPROPVARIANT pOut)
+{
+ FIXME("stub\n");
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI MimeInternat_MLANG_ConvertInetReset(IMimeInternational *iface)
+{
+ FIXME("stub\n");
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI MimeInternat_MLANG_ConvertInetString(IMimeInternational *iface, CODEPAGEID cpiSource,
+ CODEPAGEID cpiDest,
+ LPCSTR pSource,
+ int *pnSizeOfSource,
+ LPSTR pDestination,
+ int *pnDstSize)
+{
+ FIXME("stub\n");
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI MimeInternat_Rfc1522Decode(IMimeInternational *iface, LPCSTR pszValue,
+ LPCSTR pszCharset,
+ ULONG cchmax,
+ LPSTR *ppszDecoded)
+{
+ FIXME("stub\n");
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI MimeInternat_Rfc1522Encode(IMimeInternational *iface, LPCSTR pszValue,
+ HCHARSET hCharset,
+ LPSTR *ppszEncoded)
+{
+ FIXME("stub\n");
+ return E_NOTIMPL;
+}
+
+static IMimeInternationalVtbl mime_internat_vtbl =
+{
+ MimeInternat_QueryInterface,
+ MimeInternat_AddRef,
+ MimeInternat_Release,
+ MimeInternat_SetDefaultCharset,
+ MimeInternat_GetDefaultCharset,
+ MimeInternat_GetCodePageCharset,
+ MimeInternat_FindCharset,
+ MimeInternat_GetCharsetInfo,
+ MimeInternat_GetCodePageInfo,
+ MimeInternat_DecodeHeader,
+ MimeInternat_EncodeHeader,
+ MimeInternat_ConvertBuffer,
+ MimeInternat_ConvertString,
+ MimeInternat_MLANG_ConvertInetReset,
+ MimeInternat_MLANG_ConvertInetString,
+ MimeInternat_Rfc1522Decode,
+ MimeInternat_Rfc1522Encode
+};
+
+static internat *global_internat;
+
+HRESULT MimeInternational_Construct(IMimeInternational **internat)
+{
+ global_internat = HeapAlloc(GetProcessHeap(), 0, sizeof(*global_internat));
+ global_internat->lpVtbl = &mime_internat_vtbl;
+ global_internat->refs = 0;
+
+ *internat = (IMimeInternational*)&global_internat->lpVtbl;
+
+ IMimeInternational_AddRef(*internat);
+ return S_OK;
+}
+
+HRESULT WINAPI MimeOleGetInternat(IMimeInternational **internat)
+{
+ TRACE("(%p)\n", internat);
+
+ *internat = (IMimeInternational *)&global_internat->lpVtbl;
+ IMimeInternational_AddRef(*internat);
+ return S_OK;
+}
diff --git a/dlls/inetcomm/regsvr.c b/dlls/inetcomm/regsvr.c
index 620cfa7..a21b85b 100644
--- a/dlls/inetcomm/regsvr.c
+++ b/dlls/inetcomm/regsvr.c
@@ -31,8 +31,8 @@
#include "ocidl.h"
#include "initguid.h"
-#include "inetcomm_private.h"
#include "mimeole.h"
+#include "inetcomm_private.h"
#include "wine/debug.h"