Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-cw
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-cw
Commits
befbb0e4
Commit
befbb0e4
authored
Aug 14, 2002
by
Alexandre Julliard
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Make behavior of builtin executables closer to that of builtin dlls.
Fixed case sensitivity of builtin executables.
parent
78872596
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
127 additions
and
57 deletions
+127
-57
module.h
include/module.h
+1
-0
loadorder.c
loader/loadorder.c
+56
-0
module.c
loader/module.c
+2
-23
process.c
scheduler/process.c
+68
-34
No files found.
include/module.h
View file @
befbb0e4
...
@@ -259,6 +259,7 @@ extern BOOL PE_InitDLL( HMODULE module, DWORD type, LPVOID lpReserved );
...
@@ -259,6 +259,7 @@ extern BOOL PE_InitDLL( HMODULE module, DWORD type, LPVOID lpReserved );
extern
DWORD
PE_fixup_imports
(
WINE_MODREF
*
wm
);
extern
DWORD
PE_fixup_imports
(
WINE_MODREF
*
wm
);
/* loader/loadorder.c */
/* loader/loadorder.c */
extern
BOOL
MODULE_GetBuiltinPath
(
const
char
*
libname
,
const
char
*
ext
,
char
*
filename
,
UINT
size
);
extern
void
MODULE_GetLoadOrder
(
enum
loadorder_type
plo
[],
const
char
*
path
,
BOOL
win32
);
extern
void
MODULE_GetLoadOrder
(
enum
loadorder_type
plo
[],
const
char
*
path
,
BOOL
win32
);
extern
void
MODULE_AddLoadOrderOption
(
const
char
*
option
);
extern
void
MODULE_AddLoadOrderOption
(
const
char
*
option
);
...
...
loader/loadorder.c
View file @
befbb0e4
...
@@ -418,6 +418,62 @@ static BOOL get_registry_value( HKEY hkey, const char *module, enum loadorder_ty
...
@@ -418,6 +418,62 @@ static BOOL get_registry_value( HKEY hkey, const char *module, enum loadorder_ty
/***************************************************************************
/***************************************************************************
* MODULE_GetBuiltinPath
*
* Get the path of a builtin module when the native file does not exist.
*/
BOOL
MODULE_GetBuiltinPath
(
const
char
*
libname
,
const
char
*
ext
,
char
*
filename
,
UINT
size
)
{
char
*
p
;
BOOL
ret
=
FALSE
;
UINT
len
=
GetSystemDirectoryA
(
filename
,
size
);
if
(
FILE_contains_path
(
libname
))
{
char
*
tmp
;
/* if the library name contains a path and can not be found,
* return an error.
* exception: if the path is the system directory, proceed,
* so that modules which are not PE modules can be loaded.
* If the library name does not contain a path and can not
* be found, assume the system directory is meant */
if
(
strlen
(
libname
)
>=
size
)
return
FALSE
;
/* too long */
if
(
strchr
(
libname
,
'/'
))
/* need to convert slashes */
{
if
(
!
(
tmp
=
HeapAlloc
(
GetProcessHeap
(),
0
,
strlen
(
libname
)
+
1
)))
return
FALSE
;
strcpy
(
tmp
,
libname
);
for
(
p
=
tmp
;
*
p
;
p
++
)
if
(
*
p
==
'/'
)
*
p
=
'\\'
;
}
else
tmp
=
(
char
*
)
libname
;
if
(
!
FILE_strncasecmp
(
filename
,
tmp
,
len
)
&&
tmp
[
len
]
==
'\\'
)
{
strcpy
(
filename
,
tmp
);
ret
=
TRUE
;
}
if
(
tmp
!=
libname
)
HeapFree
(
GetProcessHeap
(),
0
,
tmp
);
if
(
!
ret
)
return
FALSE
;
}
else
{
if
(
strlen
(
libname
)
>=
size
-
len
-
1
)
return
FALSE
;
filename
[
len
]
=
'\\'
;
strcpy
(
filename
+
len
+
1
,
libname
);
}
/* if the filename doesn't have an extension, append the default */
if
(
!
(
p
=
strrchr
(
filename
,
'.'
))
||
strchr
(
p
,
'/'
)
||
strchr
(
p
,
'\\'
))
{
if
(
strlen
(
filename
)
+
strlen
(
ext
)
>=
size
)
return
FALSE
;
strcat
(
filename
,
ext
);
}
return
TRUE
;
}
/***************************************************************************
* MODULE_GetLoadOrder (internal)
* MODULE_GetLoadOrder (internal)
*
*
* Locate the loadorder of a module.
* Locate the loadorder of a module.
...
...
loader/module.c
View file @
befbb0e4
...
@@ -1194,7 +1194,7 @@ WINE_MODREF *MODULE_LoadLibraryExA( LPCSTR libname, HANDLE hfile, DWORD flags )
...
@@ -1194,7 +1194,7 @@ WINE_MODREF *MODULE_LoadLibraryExA( LPCSTR libname, HANDLE hfile, DWORD flags )
WINE_MODREF
*
pwm
;
WINE_MODREF
*
pwm
;
int
i
;
int
i
;
enum
loadorder_type
loadorder
[
LOADORDER_NTYPES
];
enum
loadorder_type
loadorder
[
LOADORDER_NTYPES
];
LPSTR
filename
,
p
;
LPSTR
filename
;
const
char
*
filetype
=
""
;
const
char
*
filetype
=
""
;
DWORD
found
;
DWORD
found
;
BOOL
allocated_libdir
=
FALSE
;
BOOL
allocated_libdir
=
FALSE
;
...
@@ -1222,28 +1222,7 @@ WINE_MODREF *MODULE_LoadLibraryExA( LPCSTR libname, HANDLE hfile, DWORD flags )
...
@@ -1222,28 +1222,7 @@ WINE_MODREF *MODULE_LoadLibraryExA( LPCSTR libname, HANDLE hfile, DWORD flags )
/* build the modules filename */
/* build the modules filename */
if
(
!
found
)
if
(
!
found
)
{
{
if
(
!
GetSystemDirectoryA
(
filename
,
MAX_PATH
)
)
if
(
!
MODULE_GetBuiltinPath
(
libname
,
".dll"
,
filename
,
MAX_PATH
))
goto
error
;
goto
error
;
/* if the library name contains a path and can not be found,
* return an error.
* exception: if the path is the system directory, proceed,
* so that modules which are not PE modules can be loaded.
* If the library name does not contain a path and can not
* be found, assume the system directory is meant */
if
(
!
FILE_strncasecmp
(
filename
,
libname
,
strlen
(
filename
)
))
strcpy
(
filename
,
libname
);
else
{
if
(
FILE_contains_path
(
libname
))
goto
error
;
strcat
(
filename
,
"
\\
"
);
strcat
(
filename
,
libname
);
}
/* if the filename doesn't have an extension, append .DLL */
if
(
!
(
p
=
strrchr
(
filename
,
'.'
))
||
strchr
(
p
,
'/'
)
||
strchr
(
p
,
'\\'
))
strcat
(
filename
,
".dll"
);
}
}
/* Check for already loaded module */
/* Check for already loaded module */
...
...
scheduler/process.c
View file @
befbb0e4
...
@@ -255,18 +255,46 @@ inline static const char *get_basename( const char *name )
...
@@ -255,18 +255,46 @@ inline static const char *get_basename( const char *name )
/***********************************************************************
/***********************************************************************
* open_builtin_exe_file
*
* Open an exe file for a builtin exe.
*/
static
void
*
open_builtin_exe_file
(
const
char
*
name
,
char
*
error
,
int
error_size
,
int
test_only
)
{
char
exename
[
MAX_PATH
],
*
p
;
const
char
*
basename
=
get_basename
(
name
);
if
(
strlen
(
basename
)
>=
sizeof
(
exename
))
return
NULL
;
strcpy
(
exename
,
basename
);
for
(
p
=
exename
;
*
p
;
p
++
)
*
p
=
FILE_tolower
(
*
p
);
return
wine_dll_load_main_exe
(
exename
,
error
,
error_size
,
test_only
);
}
/***********************************************************************
* open_exe_file
* open_exe_file
*
*
* Open a
n
exe file, taking load order into account.
* Open a
specific
exe file, taking load order into account.
* Returns the file handle or 0 for a builtin exe.
* Returns the file handle or 0 for a builtin exe.
*/
*/
static
HANDLE
open_exe_file
(
const
char
*
name
)
static
HANDLE
open_exe_file
(
const
char
*
name
)
{
{
enum
loadorder_type
loadorder
[
LOADORDER_NTYPES
];
enum
loadorder_type
loadorder
[
LOADORDER_NTYPES
];
char
buffer
[
MAX_PATH
];
HANDLE
handle
;
HANDLE
handle
;
int
i
;
int
i
;
SetLastError
(
ERROR_FILE_NOT_FOUND
);
TRACE
(
"looking for %s
\n
"
,
debugstr_a
(
name
)
);
if
((
handle
=
CreateFileA
(
name
,
GENERIC_READ
,
FILE_SHARE_READ
,
NULL
,
OPEN_EXISTING
,
0
,
0
))
==
INVALID_HANDLE_VALUE
)
{
/* file doesn't exist, check for builtin */
if
(
!
FILE_contains_path
(
name
))
goto
error
;
if
(
!
MODULE_GetBuiltinPath
(
name
,
""
,
buffer
,
sizeof
(
buffer
)
))
goto
error
;
name
=
buffer
;
}
MODULE_GetLoadOrder
(
loadorder
,
name
,
TRUE
);
MODULE_GetLoadOrder
(
loadorder
,
name
,
TRUE
);
for
(
i
=
0
;
i
<
LOADORDER_NTYPES
;
i
++
)
for
(
i
=
0
;
i
<
LOADORDER_NTYPES
;
i
++
)
...
@@ -276,19 +304,23 @@ static HANDLE open_exe_file( const char *name )
...
@@ -276,19 +304,23 @@ static HANDLE open_exe_file( const char *name )
{
{
case
LOADORDER_DLL
:
case
LOADORDER_DLL
:
TRACE
(
"Trying native exe %s
\n
"
,
debugstr_a
(
name
)
);
TRACE
(
"Trying native exe %s
\n
"
,
debugstr_a
(
name
)
);
if
((
handle
=
CreateFileA
(
name
,
GENERIC_READ
,
FILE_SHARE_READ
,
if
(
handle
!=
INVALID_HANDLE_VALUE
)
return
handle
;
NULL
,
OPEN_EXISTING
,
0
,
0
))
!=
INVALID_HANDLE_VALUE
)
return
handle
;
if
(
GetLastError
()
!=
ERROR_FILE_NOT_FOUND
)
return
INVALID_HANDLE_VALUE
;
break
;
break
;
case
LOADORDER_BI
:
case
LOADORDER_BI
:
TRACE
(
"Trying built-in exe %s
\n
"
,
debugstr_a
(
name
)
);
TRACE
(
"Trying built-in exe %s
\n
"
,
debugstr_a
(
name
)
);
if
(
wine_dll_load_main_exe
(
get_basename
(
name
),
NULL
,
0
,
1
))
return
0
;
if
(
open_builtin_exe_file
(
name
,
NULL
,
0
,
1
))
break
;
{
if
(
handle
!=
INVALID_HANDLE_VALUE
)
CloseHandle
(
handle
);
return
0
;
}
default:
default:
break
;
break
;
}
}
}
}
if
(
handle
!=
INVALID_HANDLE_VALUE
)
CloseHandle
(
handle
);
error:
SetLastError
(
ERROR_FILE_NOT_FOUND
);
return
INVALID_HANDLE_VALUE
;
return
INVALID_HANDLE_VALUE
;
}
}
...
@@ -308,46 +340,48 @@ static BOOL find_exe_file( const char *name, char *buffer, int buflen, HANDLE *h
...
@@ -308,46 +340,48 @@ static BOOL find_exe_file( const char *name, char *buffer, int buflen, HANDLE *h
TRACE
(
"looking for %s
\n
"
,
debugstr_a
(
name
)
);
TRACE
(
"looking for %s
\n
"
,
debugstr_a
(
name
)
);
if
(
SearchPathA
(
NULL
,
name
,
".exe"
,
buflen
,
buffer
,
NULL
))
if
(
!
SearchPathA
(
NULL
,
name
,
".exe"
,
buflen
,
buffer
,
NULL
)
&&
!
MODULE_GetBuiltinPath
(
name
,
".exe"
,
buffer
,
buflen
))
{
{
*
handle
=
open_exe_file
(
buffer
);
/* no builtin found, try native without extension in case it is a Unix app */
return
TRUE
;
}
/* no such file in path, try builtin with .exe extension */
if
(
SearchPathA
(
NULL
,
name
,
NULL
,
buflen
,
buffer
,
NULL
))
{
lstrcpynA
(
buffer
,
get_basename
(
name
),
buflen
);
TRACE
(
"Trying native/Unix binary %s
\n
"
,
debugstr_a
(
buffer
)
);
if
(
!
strchr
(
buffer
,
'.'
))
if
((
*
handle
=
CreateFileA
(
buffer
,
GENERIC_READ
,
FILE_SHARE_READ
,
{
NULL
,
OPEN_EXISTING
,
0
,
0
))
!=
INVALID_HANDLE_VALUE
)
char
*
p
=
buffer
+
strlen
(
buffer
);
return
TRUE
;
lstrcpynA
(
p
,
".exe"
,
buflen
-
(
p
-
buffer
)
);
}
return
FALSE
;
}
}
MODULE_GetLoadOrder
(
loadorder
,
buffer
,
TRUE
);
MODULE_GetLoadOrder
(
loadorder
,
buffer
,
TRUE
);
for
(
i
=
0
;
i
<
LOADORDER_NTYPES
;
i
++
)
for
(
i
=
0
;
i
<
LOADORDER_NTYPES
;
i
++
)
{
{
if
(
loadorder
[
i
]
==
LOADORDER_BI
)
if
(
loadorder
[
i
]
==
LOADORDER_INVALID
)
break
;
switch
(
loadorder
[
i
])
{
{
case
LOADORDER_DLL
:
TRACE
(
"Trying native exe %s
\n
"
,
debugstr_a
(
buffer
)
);
if
((
*
handle
=
CreateFileA
(
buffer
,
GENERIC_READ
,
FILE_SHARE_READ
,
NULL
,
OPEN_EXISTING
,
0
,
0
))
!=
INVALID_HANDLE_VALUE
)
return
TRUE
;
if
(
GetLastError
()
!=
ERROR_FILE_NOT_FOUND
)
return
TRUE
;
break
;
case
LOADORDER_BI
:
TRACE
(
"Trying built-in exe %s
\n
"
,
debugstr_a
(
buffer
)
);
TRACE
(
"Trying built-in exe %s
\n
"
,
debugstr_a
(
buffer
)
);
if
(
wine_dll_load_main_ex
e
(
buffer
,
NULL
,
0
,
1
))
if
(
open_builtin_exe_fil
e
(
buffer
,
NULL
,
0
,
1
))
{
{
*
handle
=
0
;
*
handle
=
0
;
return
TRUE
;
return
TRUE
;
}
}
break
;
break
;
default:
break
;
}
}
if
(
loadorder
[
i
]
==
LOADORDER_INVALID
)
break
;
}
/* no builtin found, try native without extension in case it is a Unix app */
if
(
SearchPathA
(
NULL
,
name
,
NULL
,
buflen
,
buffer
,
NULL
))
{
TRACE
(
"Trying native/Unix binary %s
\n
"
,
debugstr_a
(
buffer
)
);
if
((
*
handle
=
CreateFileA
(
buffer
,
GENERIC_READ
,
FILE_SHARE_READ
,
NULL
,
OPEN_EXISTING
,
0
,
0
))
!=
INVALID_HANDLE_VALUE
)
return
TRUE
;
}
}
SetLastError
(
ERROR_FILE_NOT_FOUND
);
return
FALSE
;
return
FALSE
;
}
}
...
@@ -569,7 +603,7 @@ void PROCESS_InitWine( int argc, char *argv[], LPSTR win16_exe_name, HANDLE *win
...
@@ -569,7 +603,7 @@ void PROCESS_InitWine( int argc, char *argv[], LPSTR win16_exe_name, HANDLE *win
if
(
!
main_exe_file
)
/* no file handle -> Winelib app */
if
(
!
main_exe_file
)
/* no file handle -> Winelib app */
{
{
TRACE
(
"starting Winelib app %s
\n
"
,
debugstr_a
(
main_exe_name
)
);
TRACE
(
"starting Winelib app %s
\n
"
,
debugstr_a
(
main_exe_name
)
);
if
(
wine_dll_load_main_exe
(
get_basename
(
main_exe_name
)
,
error
,
sizeof
(
error
),
0
))
if
(
open_builtin_exe_file
(
main_exe_name
,
error
,
sizeof
(
error
),
0
))
goto
found
;
goto
found
;
MESSAGE
(
"%s: cannot open builtin library for '%s': %s
\n
"
,
argv0
,
main_exe_name
,
error
);
MESSAGE
(
"%s: cannot open builtin library for '%s': %s
\n
"
,
argv0
,
main_exe_name
,
error
);
ExitProcess
(
1
);
ExitProcess
(
1
);
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment