Added VBScript stub implementation.

Robert Wilhelm robert.wilhelm at gmx.net
Sat Mar 7 13:09:13 CST 2009


---
 dlls/vbscript/Makefile.in     |    1 +
 dlls/vbscript/vbscript.c      |  231 +++++++++++++++++++++++++++++++++++++++++
 dlls/vbscript/vbscript.h      |   22 ++++
 dlls/vbscript/vbscript_main.c |    7 --
 4 files changed, 254 insertions(+), 7 deletions(-)
 create mode 100644 dlls/vbscript/vbscript.c

diff --git a/dlls/vbscript/Makefile.in b/dlls/vbscript/Makefile.in
index 1f62406..5c30e68 100644
--- a/dlls/vbscript/Makefile.in
+++ b/dlls/vbscript/Makefile.in
@@ -8,6 +8,7 @@ IMPORTS   = kernel32
 RC_SRCS = rsrc.rc
 
 C_SRCS = \
+	vbscript.c \
 	vbscript_main.c
 
 @MAKE_DLL_RULES@
diff --git a/dlls/vbscript/vbscript.c b/dlls/vbscript/vbscript.c
new file mode 100644
index 0000000..1f6557a
--- /dev/null
+++ b/dlls/vbscript/vbscript.c
@@ -0,0 +1,231 @@
+/*
+ * Copyright 2008 Jacek Caban for CodeWeavers
+ * Copyright 2009 Robert Wilhelm
+ *
+ * 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
+ */
+
+#include "vbscript.h"
+#include "activscp.h"
+
+#include "wine/debug.h"
+
+WINE_DEFAULT_DEBUG_CHANNEL(vbscript);
+
+
+typedef struct {
+    const IActiveScriptVtbl                 *lpIActiveScriptVtbl;
+ 
+    LONG ref;
+
+ 
+} VBScript;
+
+#define ACTSCRIPT(x)    ((IActiveScript*) &(x)->lpIActiveScriptVtbl)
+
+#define ACTSCRIPT_THIS(iface) DEFINE_THIS(VBScript, IActiveScript, iface)
+
+
+static HRESULT WINAPI VBScript_QueryInterface(IActiveScript *iface, REFIID riid, void **ppv)
+{
+    VBScript *This = ACTSCRIPT_THIS(iface);
+
+    *ppv = NULL;
+
+    if(IsEqualGUID(riid, &IID_IUnknown)) {
+        TRACE("(%p)->(IID_IUnknown %p)\n", This, ppv);
+        *ppv = ACTSCRIPT(This);
+    }else if(IsEqualGUID(riid, &IID_IActiveScript)) {
+        TRACE("(%p)->(IID_IActiveScript %p)\n", This, ppv);
+        *ppv = ACTSCRIPT(This);
+    }
+
+    if(*ppv) {
+        IUnknown_AddRef((IUnknown*)*ppv);
+        return S_OK;
+    }
+
+    FIXME("(%p)->(%s %p)\n", This, debugstr_guid(riid), ppv);
+    return E_NOINTERFACE;
+}
+
+static ULONG WINAPI VBScript_AddRef(IActiveScript *iface)
+{
+    VBScript *This = ACTSCRIPT_THIS(iface);
+    LONG ref = InterlockedIncrement(&This->ref);
+
+    TRACE("(%p) ref=%d\n", This, ref);
+
+    return ref;
+}
+
+static ULONG WINAPI VBScript_Release(IActiveScript *iface)
+{
+    VBScript *This = ACTSCRIPT_THIS(iface);
+    LONG ref = InterlockedDecrement(&This->ref);
+
+    TRACE("(%p) ref=%d\n", iface, ref);
+
+    if(!ref) {
+        heap_free(This);
+        unlock_module();
+    }
+
+    return ref;
+}
+
+static HRESULT WINAPI VBScript_SetScriptSite(IActiveScript *iface,
+                                            IActiveScriptSite *pass)
+{
+    VBScript *This = ACTSCRIPT_THIS(iface);
+    FIXME("(%p)->(%p)\n", This, pass);
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI VBScript_GetScriptSite(IActiveScript *iface, REFIID riid,
+                                            void **ppvObject)
+{
+    VBScript *This = ACTSCRIPT_THIS(iface);
+    FIXME("(%p)->()\n", This);
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI VBScript_SetScriptState(IActiveScript *iface, SCRIPTSTATE ss)
+{
+    VBScript *This = ACTSCRIPT_THIS(iface);
+    FIXME("(%p)->(%d)\n", This, ss);
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI VBScript_GetScriptState(IActiveScript *iface, SCRIPTSTATE *pssState)
+{
+    VBScript *This = ACTSCRIPT_THIS(iface);
+    FIXME("(%p)->(%p)\n", This, pssState);
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI VBScript_Close(IActiveScript *iface)
+{
+    VBScript *This = ACTSCRIPT_THIS(iface);
+    FIXME("(%p)->()\n", This);
+    return E_NOTIMPL;
+}
+
+
+static HRESULT WINAPI VBScript_AddNamedItem(IActiveScript *iface,
+                                           LPCOLESTR pstrName, DWORD dwFlags)
+{
+    VBScript *This = ACTSCRIPT_THIS(iface);
+    FIXME("(%p)->(%s %x)\n", This, debugstr_w(pstrName), dwFlags);
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI VBScript_AddTypeLib(IActiveScript *iface, REFGUID rguidTypeLib,
+                                         DWORD dwMajor, DWORD dwMinor, DWORD dwFlags)
+{
+    VBScript *This = ACTSCRIPT_THIS(iface);
+    FIXME("(%p)->()\n", This);
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI VBScript_GetScriptDispatch(IActiveScript *iface, LPCOLESTR pstrItemName,
+                                                IDispatch **ppdisp)
+{
+    VBScript *This = ACTSCRIPT_THIS(iface);
+    FIXME("(%p)->(%p)\n", This, ppdisp);
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI VBScript_GetCurrentScriptThreadID(IActiveScript *iface,
+                                                       SCRIPTTHREADID *pstridThread)
+{
+    VBScript *This = ACTSCRIPT_THIS(iface);
+    FIXME("(%p)->()\n", This);
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI VBScript_GetScriptThreadID(IActiveScript *iface,
+                                                DWORD dwWin32ThreadId, SCRIPTTHREADID *pstidThread)
+{
+    VBScript *This = ACTSCRIPT_THIS(iface);
+    FIXME("(%p)->()\n", This);
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI VBScript_GetScriptThreadState(IActiveScript *iface,
+        SCRIPTTHREADID stidThread, SCRIPTTHREADSTATE *pstsState)
+{
+    VBScript *This = ACTSCRIPT_THIS(iface);
+    FIXME("(%p)->()\n", This);
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI VBScript_InterruptScriptThread(IActiveScript *iface,
+        SCRIPTTHREADID stidThread, const EXCEPINFO *pexcepinfo, DWORD dwFlags)
+{
+    VBScript *This = ACTSCRIPT_THIS(iface);
+    FIXME("(%p)->()\n", This);
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI VBScript_Clone(IActiveScript *iface, IActiveScript **ppscript)
+{
+    VBScript *This = ACTSCRIPT_THIS(iface);
+    FIXME("(%p)->()\n", This);
+    return E_NOTIMPL;
+}
+
+#undef ACTSCRIPT_THIS
+
+static const IActiveScriptVtbl VBScriptVtbl = {
+    VBScript_QueryInterface,
+    VBScript_AddRef,
+    VBScript_Release,
+    VBScript_SetScriptSite,
+    VBScript_GetScriptSite,
+    VBScript_SetScriptState,
+    VBScript_GetScriptState,
+    VBScript_Close,
+    VBScript_AddNamedItem,
+    VBScript_AddTypeLib,
+    VBScript_GetScriptDispatch,
+    VBScript_GetCurrentScriptThreadID,
+    VBScript_GetScriptThreadID,
+    VBScript_GetScriptThreadState,
+    VBScript_InterruptScriptThread,
+    VBScript_Clone
+};
+
+HRESULT WINAPI VBScriptFactory_CreateInstance(IClassFactory *iface, IUnknown *pUnkOuter,
+                                              REFIID riid, void **ppv)
+{
+    VBScript *ret;
+    HRESULT hres;
+
+    TRACE("(%p %s %p)\n", pUnkOuter, debugstr_guid(riid), ppv);
+
+    lock_module();
+
+    ret = heap_alloc_zero(sizeof(*ret));
+    if(!ret)
+        return E_OUTOFMEMORY;
+
+    ret->lpIActiveScriptVtbl = &VBScriptVtbl;
+    ret->ref = 1;
+ 
+    hres = IActiveScript_QueryInterface(ACTSCRIPT(ret), riid, ppv);
+    IActiveScript_Release(ACTSCRIPT(ret));
+    return hres;
+}
diff --git a/dlls/vbscript/vbscript.h b/dlls/vbscript/vbscript.h
index dd1d4da..e3b0c6f 100644
--- a/dlls/vbscript/vbscript.h
+++ b/dlls/vbscript/vbscript.h
@@ -44,3 +44,25 @@ static inline void unlock_module(void)
     InterlockedDecrement(&module_ref);
 }
 
+static inline void *heap_alloc(size_t len)
+{
+    return HeapAlloc(GetProcessHeap(), 0, len);
+}
+
+static inline void *heap_alloc_zero(size_t len)
+{
+    return HeapAlloc(GetProcessHeap(), HEAP_ZERO_MEMORY, len);
+}
+
+static inline void *heap_realloc(void *mem, size_t len)
+{
+    return HeapReAlloc(GetProcessHeap(), 0, mem, len);
+}
+
+static inline BOOL heap_free(void *mem)
+{
+    return HeapFree(GetProcessHeap(), 0, mem);
+}
+
+#define DEFINE_THIS(cls,ifc,iface) ((cls*)((BYTE*)(iface)-offsetof(cls,lp ## ifc ## Vtbl)))
+
diff --git a/dlls/vbscript/vbscript_main.c b/dlls/vbscript/vbscript_main.c
index b22530a..626f12c 100644
--- a/dlls/vbscript/vbscript_main.c
+++ b/dlls/vbscript/vbscript_main.c
@@ -41,13 +41,6 @@ static const CLSID CLSID_VBScriptEncode =
 
 static HINSTANCE vbscript_hinstance;
 
-HRESULT WINAPI VBScriptFactory_CreateInstance(IClassFactory *iface, IUnknown *pUnkOuter,
-                                             REFIID riid, void **ppv)
-{
-    FIXME("(%p %s %p)\n", pUnkOuter, debugstr_guid(riid), ppv);
-    return E_NOTIMPL;
-}
-
 static HRESULT WINAPI ClassFactory_QueryInterface(IClassFactory *iface, REFIID riid, void **ppv)
 {
     *ppv = NULL;
-- 
1.6.0.6


--=-A9vYyjy5sS5sgisB0a7Q--




More information about the wine-patches mailing list