Authors: David Hammerton <david@transgaming.com>, Peter Hunnisett <peter@transgaming...
[wine.git] / dlls / urlmon / umon.c
blobb31a76f589b59e6d9c36f408728687bf1d04f6a5
1 /*
2 * UrlMon
4 * Copyright 1999 Corel Corporation
6 * Ulrich Czekalla
8 * This library is free software; you can redistribute it and/or
9 * modify it under the terms of the GNU Lesser General Public
10 * License as published by the Free Software Foundation; either
11 * version 2.1 of the License, or (at your option) any later version.
13 * This library is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16 * Lesser General Public License for more details.
18 * You should have received a copy of the GNU Lesser General Public
19 * License along with this library; if not, write to the Free Software
20 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
23 #include "windef.h"
24 #include "objbase.h"
25 #include "wine/debug.h"
27 #include "urlmon.h"
29 WINE_DEFAULT_DEBUG_CHANNEL(urlmon);
31 /* native urlmon.dll uses this key, too */
32 static WCHAR BSCBHolder[] = { '_','B','S','C','B','_','H','o','l','d','e','r','_',0 };
35 /***********************************************************************
36 * CreateAsyncBindCtxEx (URLMON.@)
38 * not implemented
41 HRESULT WINAPI CreateAsyncBindCtxEx(IBindCtx *ibind, DWORD options,
42 IBindStatusCallback *callback, IEnumFORMATETC *format, IBindCtx** pbind,
43 DWORD reserved)
45 FIXME("stub, returns failure\n");
46 return E_INVALIDARG;
50 /***********************************************************************
51 * CreateURLMoniker (URLMON.@)
53 * Create a url moniker
55 * RETURNS
56 * S_OK success
57 * E_OUTOFMEMORY out of memory
58 * MK_E_SYNTAX not a valid url
61 HRESULT WINAPI CreateURLMoniker(IMoniker *pmkContext, LPCWSTR szURL, IMoniker **ppmk)
63 TRACE("\n");
65 if (NULL != pmkContext)
66 FIXME("Non-null pmkContext not implemented\n");
68 return CreateFileMoniker(szURL, ppmk);
71 /***********************************************************************
72 * RegisterBindStatusCallback (URLMON.@)
74 * Register a bind status callback
76 * RETURNS
77 * S_OK success
78 * E_INVALIDARG invalid argument(s)
79 * E_OUTOFMEMORY out of memory
82 HRESULT WINAPI RegisterBindStatusCallback(
83 IBindCtx *pbc,
84 IBindStatusCallback *pbsc,
85 IBindStatusCallback **ppbscPrevious,
86 DWORD dwReserved)
88 IBindStatusCallback *prev;
90 TRACE("(%p,%p,%p,%lu)\n", pbc, pbsc, ppbscPrevious, dwReserved);
92 if (pbc == NULL || pbsc == NULL)
93 return E_INVALIDARG;
95 if (SUCCEEDED(IBindCtx_GetObjectParam(pbc, BSCBHolder, (IUnknown **)&prev)))
97 IBindCtx_RevokeObjectParam(pbc, BSCBHolder);
98 if (ppbscPrevious)
99 *ppbscPrevious = prev;
100 else
101 IBindStatusCallback_Release(prev);
104 return IBindCtx_RegisterObjectParam(pbc, BSCBHolder, (IUnknown *)pbsc);
107 /***********************************************************************
108 * RevokeBindStatusCallback (URLMON.@)
110 * Unregister a bind status callback
112 * RETURNS
113 * S_OK success
114 * E_INVALIDARG invalid argument(s)
115 * E_FAIL pbsc wasn't registered with pbc
118 HRESULT WINAPI RevokeBindStatusCallback(
119 IBindCtx *pbc,
120 IBindStatusCallback *pbsc)
122 IBindStatusCallback *callback;
123 HRESULT hr = E_FAIL;
125 TRACE("(%p,%p)\n", pbc, pbsc);
127 if (pbc == NULL || pbsc == NULL)
128 return E_INVALIDARG;
130 if (SUCCEEDED(IBindCtx_GetObjectParam(pbc, BSCBHolder, (IUnknown **)&callback)))
132 if (callback == pbsc)
134 IBindCtx_RevokeObjectParam(pbc, BSCBHolder);
135 hr = S_OK;
137 IBindStatusCallback_Release(pbsc);
140 return hr;
143 /***********************************************************************
144 * Extract (URLMON.@)
147 HRESULT WINAPI Extract(DWORD Param1, DWORD Param2)
149 TRACE("%lx %lx\n", Param1, Param2);
151 return S_OK;