[3/6] jsproxy: Implement InternetInitializeAutoProxyDll and InternetDeinitializeAutoProxyDll.
Hans Leidekker
hans at codeweavers.com
Thu May 15 07:05:17 CDT 2014
---
dlls/jsproxy/jsproxy.spec | 4 +-
dlls/jsproxy/main.c | 109 ++++++++++++++++++++++++++++++++++++++++++++++
2 files changed, 111 insertions(+), 2 deletions(-)
diff --git a/dlls/jsproxy/jsproxy.spec b/dlls/jsproxy/jsproxy.spec
index 21943df..f557fe6 100644
--- a/dlls/jsproxy/jsproxy.spec
+++ b/dlls/jsproxy/jsproxy.spec
@@ -1,5 +1,5 @@
-@ stub InternetInitializeAutoProxyDll
+@ stdcall InternetInitializeAutoProxyDll(long str str ptr ptr) JSPROXY_InternetInitializeAutoProxyDll
@ stub InternetInitializeExAutoProxyDll
-@ stub InternetDeInitializeAutoProxyDll
+@ stdcall InternetDeInitializeAutoProxyDll(str long)
@ stub InternetDeInitializeExAutoProxyDll
@ stub InternetGetProxyInfo
diff --git a/dlls/jsproxy/main.c b/dlls/jsproxy/main.c
index fa9703d..9305ff8 100644
--- a/dlls/jsproxy/main.c
+++ b/dlls/jsproxy/main.c
@@ -23,12 +23,23 @@
#include "windef.h"
#include "winbase.h"
+#include "winnls.h"
+#include "wininet.h"
#include "wine/debug.h"
static HINSTANCE instance;
WINE_DEFAULT_DEBUG_CHANNEL(jsproxy);
+static CRITICAL_SECTION cs_jsproxy;
+static CRITICAL_SECTION_DEBUG critsect_debug =
+{
+ 0, 0, &cs_jsproxy,
+ { &critsect_debug.ProcessLocksList, &critsect_debug.ProcessLocksList },
+ 0, 0, { (DWORD_PTR)(__FILE__ ": cs_jsproxy") }
+};
+static CRITICAL_SECTION cs_jsproxy = { &critsect_debug, -1, 0, 0, 0, 0 };
+
/******************************************************************
* DllMain (jsproxy.@)
*/
@@ -46,3 +57,101 @@ BOOL WINAPI DllMain( HINSTANCE hinst, DWORD reason, LPVOID reserved )
}
return TRUE;
}
+
+static inline void *heap_alloc( SIZE_T size )
+{
+ return HeapAlloc( GetProcessHeap(), 0, size );
+}
+
+static inline BOOL heap_free( LPVOID mem )
+{
+ return HeapFree( GetProcessHeap(), 0, mem );
+}
+
+static inline WCHAR *strdupAW( const char *src, DWORD len )
+{
+ WCHAR *dst = NULL;
+ if (src)
+ {
+ int dst_len = MultiByteToWideChar( CP_ACP, 0, src, len, NULL, 0 );
+ if ((dst = heap_alloc( (dst_len + 1) * sizeof(WCHAR) ))) len = MultiByteToWideChar( CP_ACP, 0, src, len, dst, dst_len );
+ dst[dst_len] = 0;
+ }
+ return dst;
+}
+
+static struct pac_script
+{
+ WCHAR *text;
+} pac_script;
+static struct pac_script *global_script = &pac_script;
+
+/******************************************************************
+ * InternetDeInitializeAutoProxyDll (jsproxy.@)
+ */
+BOOL WINAPI InternetDeInitializeAutoProxyDll( LPSTR mime, DWORD reserved )
+{
+ TRACE( "%s, %u\n", debugstr_a(mime), reserved );
+
+ EnterCriticalSection( &cs_jsproxy );
+
+ heap_free( global_script->text );
+ global_script->text = NULL;
+
+ LeaveCriticalSection( &cs_jsproxy );
+ return TRUE;
+}
+
+static WCHAR *load_script( const char *filename )
+{
+ HANDLE handle;
+ DWORD size, bytes_read;
+ char *buffer;
+ int len;
+ WCHAR *script = NULL;
+
+ handle = CreateFileA( filename, GENERIC_READ, FILE_SHARE_READ, NULL, OPEN_EXISTING, 0, 0 );
+ if (handle == INVALID_HANDLE_VALUE) return NULL;
+
+ size = GetFileSize( handle, NULL );
+ if (!(buffer = heap_alloc( size ))) goto done;
+ if (!ReadFile( handle, buffer, size, &bytes_read, NULL ) || bytes_read != size) goto done;
+
+ len = MultiByteToWideChar( CP_ACP, 0, buffer, size, NULL, 0 );
+ if (!(script = heap_alloc( (len + 1) * sizeof(WCHAR) ))) goto done;
+ MultiByteToWideChar( CP_ACP, 0, buffer, size, script, len );
+ script[len] = 0;
+
+done:
+ CloseHandle( handle );
+ heap_free( buffer );
+ return script;
+}
+
+/******************************************************************
+ * InternetInitializeAutoProxyDll (jsproxy.@)
+ */
+BOOL WINAPI JSPROXY_InternetInitializeAutoProxyDll( DWORD version, LPSTR tmpfile, LPSTR mime,
+ AutoProxyHelperFunctions *callbacks,
+ LPAUTO_PROXY_SCRIPT_BUFFER buffer )
+{
+ BOOL ret = FALSE;
+
+ TRACE( "%u, %s, %s, %p, %p\n", version, debugstr_a(tmpfile), debugstr_a(mime), callbacks, buffer );
+
+ if (callbacks) FIXME( "callbacks not supported\n" );
+
+ EnterCriticalSection( &cs_jsproxy );
+
+ if (global_script->text)
+ {
+ LeaveCriticalSection( &cs_jsproxy );
+ return FALSE;
+ }
+ if (buffer && buffer->dwStructSize == sizeof(*buffer) && buffer->lpszScriptBuffer &&
+ (global_script->text = strdupAW( buffer->lpszScriptBuffer, buffer->dwScriptBufferSize ))) ret = TRUE;
+ else if ((global_script->text = load_script( tmpfile ))) ret = TRUE;
+
+ LeaveCriticalSection( &cs_jsproxy );
+ return ret;
+}
--
1.8.5.2 (Apple Git-48)
More information about the wine-patches
mailing list