return !memcmp( dos + 1, fakedll_signature, sizeof(fakedll_signature) );
}
+/* create directories leading to a given file */
+static void create_directories( const WCHAR *name )
+{
+ WCHAR *path, *p;
+
+ /* create the directory/directories */
+ path = HeapAlloc(GetProcessHeap(), 0, (strlenW(name) + 1)*sizeof(WCHAR));
+ strcpyW(path, name);
+
+ p = strchrW(path, '\\');
+ while (p != NULL)
+ {
+ *p = 0;
+ if (!CreateDirectoryW(path, NULL))
+ TRACE("Couldn't create directory %s - error: %d\n", wine_dbgstr_w(path), GetLastError());
+ *p = '\\';
+ p = strchrW(p+1, '\\');
+ }
+ HeapFree(GetProcessHeap(), 0, path);
+}
+
/***********************************************************************
* create_fake_dll
*/
HMODULE module;
BOOL ret;
+ /* check for empty name which means to only create the directory */
+ if (name[strlenW(name) - 1] == '\\')
+ {
+ create_directories( name );
+ return TRUE;
+ }
+
/* first check for an existing file */
h = CreateFileW( name, GENERIC_READ|GENERIC_WRITE, 0, NULL, OPEN_EXISTING, 0, NULL );
if (h != INVALID_HANDLE_VALUE)
}
else
{
- if (GetLastError() == ERROR_PATH_NOT_FOUND)
- {
- WCHAR *path;
- WCHAR *pathel;
-
- /* create the directory/directories */
- path = HeapAlloc(GetProcessHeap(), 0, (strlenW(name) + 1)*sizeof(WCHAR));
- strcpyW(path, name);
-
- pathel = strchrW(path, '\\');
- while (pathel != NULL)
- {
- *pathel = 0;
- if (!CreateDirectoryW(path, NULL))
- TRACE("Couldn't create directory %s - error: %d\n", wine_dbgstr_w(path), GetLastError());
- *pathel = '\\';
- pathel = strchrW(pathel+1, '\\');
- }
-
- HeapFree(GetProcessHeap(), 0, path);
- }
+ if (GetLastError() == ERROR_PATH_NOT_FOUND) create_directories( name );
h = CreateFileW( name, GENERIC_WRITE, 0, NULL, CREATE_NEW, 0, NULL );
if (h == INVALID_HANDLE_VALUE)