4 * Copyright 1999 Corel Corporation
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
25 #include "wine/debug.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.@)
41 HRESULT WINAPI CreateAsyncBindCtxEx(IBindCtx *ibind, DWORD options,
42 IBindStatusCallback *callback, IEnumFORMATETC *format, IBindCtx** pbind,
45 FIXME("stub, returns failure\n");
50 /***********************************************************************
51 * CreateURLMoniker (URLMON.@)
53 * Create a url moniker
57 * E_OUTOFMEMORY out of memory
58 * MK_E_SYNTAX not a valid url
61 HRESULT WINAPI CreateURLMoniker(IMoniker *pmkContext, LPCWSTR szURL, IMoniker **ppmk)
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
78 * E_INVALIDARG invalid argument(s)
79 * E_OUTOFMEMORY out of memory
82 HRESULT WINAPI RegisterBindStatusCallback(
84 IBindStatusCallback *pbsc,
85 IBindStatusCallback **ppbscPrevious,
88 IBindStatusCallback *prev;
90 TRACE("(%p,%p,%p,%lu)\n", pbc, pbsc, ppbscPrevious, dwReserved);
92 if (pbc == NULL || pbsc == NULL)
95 if (SUCCEEDED(IBindCtx_GetObjectParam(pbc, BSCBHolder, (IUnknown **)&prev)))
97 IBindCtx_RevokeObjectParam(pbc, BSCBHolder);
99 *ppbscPrevious = prev;
101 IBindStatusCallback_Release(prev);
104 return IBindCtx_RegisterObjectParam(pbc, BSCBHolder, (IUnknown *)pbsc);
107 /***********************************************************************
108 * RevokeBindStatusCallback (URLMON.@)
110 * Unregister a bind status callback
114 * E_INVALIDARG invalid argument(s)
115 * E_FAIL pbsc wasn't registered with pbc
118 HRESULT WINAPI RevokeBindStatusCallback(
120 IBindStatusCallback *pbsc)
122 IBindStatusCallback *callback;
125 TRACE("(%p,%p)\n", pbc, pbsc);
127 if (pbc == NULL || pbsc == NULL)
130 if (SUCCEEDED(IBindCtx_GetObjectParam(pbc, BSCBHolder, (IUnknown **)&callback)))
132 if (callback == pbsc)
134 IBindCtx_RevokeObjectParam(pbc, BSCBHolder);
137 IBindStatusCallback_Release(pbsc);
143 /***********************************************************************
147 HRESULT WINAPI Extract(DWORD Param1, DWORD Param2)
149 TRACE("%lx %lx\n", Param1, Param2);