ntdll: Set the TARGET_UNWIND flag when calling the unwind handler for the target...
[wine/multimedia.git] / dlls / url / url_main.c
blobb65aa02972ae61c97f344770a9a88060056efd9d
1 /*
2 * Copyright 2006 Alexandre Julliard
4 * This library is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU Lesser General Public
6 * License as published by the Free Software Foundation; either
7 * version 2.1 of the License, or (at your option) any later version.
9 * This library is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 * Lesser General Public License for more details.
14 * You should have received a copy of the GNU Lesser General Public
15 * License along with this library; if not, write to the Free Software
16 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
19 #include <stdarg.h>
20 #include "windef.h"
21 #include "winbase.h"
22 #include "winreg.h"
23 #include "winerror.h"
24 #include "shellapi.h"
25 #include "shlwapi.h"
26 #include "intshcut.h"
27 #include "winuser.h"
28 #include "commctrl.h"
29 #include "prsht.h"
30 #include "wine/debug.h"
32 WINE_DEFAULT_DEBUG_CHANNEL(url);
34 /***********************************************************************
35 * DllMain (URL.@)
37 BOOL WINAPI DllMain( HINSTANCE inst, DWORD reason, LPVOID reserved )
39 switch(reason)
41 case DLL_WINE_PREATTACH:
42 return FALSE; /* prefer native version */
43 case DLL_PROCESS_ATTACH:
44 DisableThreadLibraryCalls( inst );
45 break;
47 return TRUE;
50 /***********************************************************************
51 * AddMIMEFileTypesPS (URL.@)
53 * Build and Manage a Filetype-Association Property Sheet
55 * PARAMS
56 * unknown1 [I] Pointer to an Read-Only Area
57 * lppsh [I] PTR to the target PropertySheetHeader (ANSI)
59 * RETURNS
60 * Success: 0
63 DWORD WINAPI AddMIMEFileTypesPS(VOID * unknown1, LPPROPSHEETHEADERA lppsh)
65 FIXME("(%p, %p): stub!\n", unknown1, lppsh);
66 return 0;
69 /***********************************************************************
70 * InetIsOffline (URL.@)
73 BOOL WINAPI InetIsOffline(DWORD flags)
75 FIXME("(%08x): stub!\n", flags);
77 return FALSE;
80 /***********************************************************************
81 * FileProtocolHandlerA (URL.@)
83 * Handles a URL given to it and executes it.
85 * HWND hWnd - Parent Window
86 * HINSTANCE hInst - ignored
87 * LPCSTR pszUrl - The URL that needs to be handled
88 * int nShowCmd - How to display the operation.
91 HRESULT WINAPI FileProtocolHandlerA(HWND hWnd, HINSTANCE hInst, LPCSTR pszUrl,
92 int nShowCmd)
94 CHAR pszPath[MAX_PATH];
95 DWORD size = MAX_PATH;
96 HRESULT createpath = PathCreateFromUrlA(pszUrl,pszPath,&size,0);
98 TRACE("(%p, %s, %d)\n",hWnd,debugstr_a(pszUrl),nShowCmd);
100 if(createpath != S_OK)
101 return E_FAIL;
103 ShellExecuteA(hWnd,NULL,pszPath,NULL,NULL,nShowCmd);
105 return S_OK;
108 /***********************************************************************
109 * OpenURLA (URL.@)
112 void WINAPI OpenURLA(HWND hwnd, HINSTANCE inst, LPCSTR cmdline, INT show)
114 FIXME("(%p, %p, %s, %d): stub!\n", hwnd, inst, debugstr_a(cmdline), show);
117 /***********************************************************************
118 * TelnetProtocolHandlerA (URL.@)
122 HRESULT WINAPI TelnetProtocolHandlerA(HWND hWnd, LPSTR lpStr)
124 FIXME("(%p, %p): stub!\n",hWnd,lpStr);
126 return E_NOTIMPL;