Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-winehq
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-winehq
Commits
fc99ddd9
Commit
fc99ddd9
authored
May 24, 2001
by
Dmitry Timoshkov
Committed by
Alexandre Julliard
May 24, 2001
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Remove kernel32 dependency on user32 by implementing family of k32
functions as callouts to user32.
parent
a2eb86bb
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
194 additions
and
74 deletions
+194
-74
Makefile.in
dlls/kernel/Makefile.in
+1
-0
kernel32.spec
dlls/kernel/kernel32.spec
+7
-7
kernel_main.c
dlls/kernel/kernel_main.c
+2
-67
string.c
dlls/kernel/string.c
+184
-0
No files found.
dlls/kernel/Makefile.in
View file @
fc99ddd9
...
@@ -13,6 +13,7 @@ C_SRCS = \
...
@@ -13,6 +13,7 @@ C_SRCS = \
format_msg.c
\
format_msg.c
\
kernel_main.c
\
kernel_main.c
\
stress.c
\
stress.c
\
string.c
\
sync.c
\
sync.c
\
thunk.c
\
thunk.c
\
time.c
\
time.c
\
...
...
dlls/kernel/kernel32.spec
View file @
fc99ddd9
...
@@ -26,13 +26,13 @@ debug_channels (comm debugstr dll int resource stress thunk toolhelp win32)
...
@@ -26,13 +26,13 @@ debug_channels (comm debugstr dll int resource stress thunk toolhelp win32)
7 register -i386 VxDCall6(long) VxDCall
7 register -i386 VxDCall6(long) VxDCall
8 register -i386 VxDCall7(long) VxDCall
8 register -i386 VxDCall7(long) VxDCall
9 register -i386 VxDCall8(long) VxDCall
9 register -i386 VxDCall8(long) VxDCall
10
forward k32CharToOemA user32.
CharToOemA
10
stdcall k32CharToOemA(str ptr) k32
CharToOemA
11
forward k32CharToOemBuffA user32.
CharToOemBuffA
11
stdcall k32CharToOemBuffA(str ptr long) k32
CharToOemBuffA
12
forward k32OemToCharA user32.
OemToCharA
12
stdcall k32OemToCharA(ptr ptr) k32
OemToCharA
13
forward k32OemToCharBuffA user32.
OemToCharBuffA
13
stdcall k32OemToCharBuffA(ptr ptr long) k32
OemToCharBuffA
14
forward k32LoadStringA user32.
LoadStringA
14
stdcall k32LoadStringA(long long ptr long) k32
LoadStringA
15
forward k32wsprintfA user32.
wsprintfA
15
varargs k32wsprintfA(str str) k32
wsprintfA
16
forward k32wvsprintfA user32.
wvsprintfA
16
stdcall k32wvsprintfA(ptr str ptr) k32
wvsprintfA
17 register -i386 CommonUnimpStub() CommonUnimpStub
17 register -i386 CommonUnimpStub() CommonUnimpStub
18 stdcall GetProcessDword(long long) GetProcessDword
18 stdcall GetProcessDword(long long) GetProcessDword
19 stub ThunkTheTemplateHandle
19 stub ThunkTheTemplateHandle
...
...
dlls/kernel/kernel_main.c
View file @
fc99ddd9
...
@@ -110,72 +110,7 @@ BOOL WINAPI MAIN_KernelInit( HINSTANCE hinst, DWORD reason, LPVOID reserved )
...
@@ -110,72 +110,7 @@ BOOL WINAPI MAIN_KernelInit( HINSTANCE hinst, DWORD reason, LPVOID reserved )
*
*
* Entry point for kernel functions that do nothing.
* Entry point for kernel functions that do nothing.
*/
*/
LONG
WINAPI
KERNEL_nop
(
void
)
{
return
0
;
}
LONG
WINAPI
KERNEL_nop
(
void
)
/***************************************************************************
*
* Win 2.x string functions now moved to USER
*
* We rather want to implement them here instead of doing Callouts
*/
/***********************************************************************
* KERNEL_AnsiNext16 (KERNEL.77)
*/
SEGPTR
WINAPI
KERNEL_AnsiNext16
(
SEGPTR
current
)
{
return
(
*
(
char
*
)
MapSL
(
current
))
?
current
+
1
:
current
;
}
/***********************************************************************
* KERNEL_AnsiPrev16(KERNEL.78)
*/
SEGPTR
WINAPI
KERNEL_AnsiPrev16
(
SEGPTR
start
,
SEGPTR
current
)
{
return
(
current
==
start
)
?
start
:
current
-
1
;
}
/***********************************************************************
* KERNEL_AnsiUpper16 (KERNEL.79)
*/
SEGPTR
WINAPI
KERNEL_AnsiUpper16
(
SEGPTR
strOrChar
)
{
/* uppercase only one char if strOrChar < 0x10000 */
if
(
HIWORD
(
strOrChar
))
{
char
*
s
=
MapSL
(
strOrChar
);
while
(
*
s
)
{
*
s
=
toupper
(
*
s
);
s
++
;
}
return
strOrChar
;
}
else
return
toupper
((
char
)
strOrChar
);
}
/***********************************************************************
* KERNEL_AnsiLower16 (KERNEL.80)
*/
SEGPTR
WINAPI
KERNEL_AnsiLower16
(
SEGPTR
strOrChar
)
{
/* lowercase only one char if strOrChar < 0x10000 */
if
(
HIWORD
(
strOrChar
))
{
char
*
s
=
MapSL
(
strOrChar
);
while
(
*
s
)
{
*
s
=
tolower
(
*
s
);
s
++
;
}
return
strOrChar
;
}
else
return
tolower
((
char
)
strOrChar
);
}
/***********************************************************************
* KERNEL_lstrcmp16 (KERNEL.87)
*/
INT16
WINAPI
KERNEL_lstrcmp16
(
LPCSTR
str1
,
LPCSTR
str2
)
{
{
return
(
INT16
)
strcmp
(
str1
,
str2
)
;
return
0
;
}
}
dlls/kernel/string.c
0 → 100644
View file @
fc99ddd9
/*
* Kernel string functions
*/
#include <ctype.h>
#include <string.h>
#include "winbase.h"
#include "wine/winbase16.h"
static
INT
WINAPI
(
*
pLoadStringA
)(
HINSTANCE
,
UINT
,
LPSTR
,
INT
);
static
INT
WINAPI
(
*
pwvsprintfA
)(
LPSTR
,
LPCSTR
,
va_list
);
/***********************************************************************
* Helper for k32 family functions
*/
static
void
*
user32_proc_address
(
const
char
*
proc_name
)
{
static
HMODULE
hUser32
;
if
(
!
hUser32
)
hUser32
=
LoadLibraryA
(
"user32.dll"
);
return
GetProcAddress
(
hUser32
,
proc_name
);
}
/***********************************************************************
* KERNEL_lstrcmp16 (KERNEL.87)
*/
INT16
WINAPI
KERNEL_lstrcmp16
(
LPCSTR
str1
,
LPCSTR
str2
)
{
return
(
INT16
)
strcmp
(
str1
,
str2
);
}
/***********************************************************************
* k32CharToOemBuffA (KERNEL32.@)
*/
BOOL
WINAPI
k32CharToOemBuffA
(
LPCSTR
s
,
LPSTR
d
,
DWORD
len
)
{
WCHAR
*
bufW
;
if
((
bufW
=
HeapAlloc
(
GetProcessHeap
(),
0
,
len
*
sizeof
(
WCHAR
)
)))
{
MultiByteToWideChar
(
CP_ACP
,
0
,
s
,
len
,
bufW
,
len
);
WideCharToMultiByte
(
CP_OEMCP
,
0
,
bufW
,
len
,
d
,
len
,
NULL
,
NULL
);
HeapFree
(
GetProcessHeap
(),
0
,
bufW
);
}
return
TRUE
;
}
/***********************************************************************
* k32CharToOemA (KERNEL32.@)
*/
BOOL
WINAPI
k32CharToOemA
(
LPCSTR
s
,
LPSTR
d
)
{
if
(
!
s
||
!
d
)
return
TRUE
;
return
k32CharToOemBuffA
(
s
,
d
,
strlen
(
s
)
+
1
);
}
/***********************************************************************
* k32OemToCharBuffA (KERNEL32.@)
*/
BOOL
WINAPI
k32OemToCharBuffA
(
LPCSTR
s
,
LPSTR
d
,
DWORD
len
)
{
WCHAR
*
bufW
;
if
((
bufW
=
HeapAlloc
(
GetProcessHeap
(),
0
,
len
*
sizeof
(
WCHAR
)
)))
{
MultiByteToWideChar
(
CP_OEMCP
,
0
,
s
,
len
,
bufW
,
len
);
WideCharToMultiByte
(
CP_ACP
,
0
,
bufW
,
len
,
d
,
len
,
NULL
,
NULL
);
HeapFree
(
GetProcessHeap
(),
0
,
bufW
);
}
return
TRUE
;
}
/***********************************************************************
* k32OemToCharA (KERNEL32.@)
*/
BOOL
WINAPI
k32OemToCharA
(
LPCSTR
s
,
LPSTR
d
)
{
return
k32OemToCharBuffA
(
s
,
d
,
strlen
(
s
)
+
1
);
}
/**********************************************************************
* k32LoadStringA (KERNEL32.@)
*/
INT
WINAPI
k32LoadStringA
(
HINSTANCE
instance
,
UINT
resource_id
,
LPSTR
buffer
,
INT
buflen
)
{
if
(
!
pLoadStringA
)
pLoadStringA
=
user32_proc_address
(
"LoadStringA"
);
return
pLoadStringA
(
instance
,
resource_id
,
buffer
,
buflen
);
}
/***********************************************************************
* k32wvsprintfA (KERNEL32.@)
*/
INT
WINAPI
k32wvsprintfA
(
LPSTR
buffer
,
LPCSTR
spec
,
va_list
args
)
{
if
(
!
pwvsprintfA
)
pwvsprintfA
=
user32_proc_address
(
"wvsprintfA"
);
return
(
*
pwvsprintfA
)(
buffer
,
spec
,
args
);
}
/***********************************************************************
* k32wsprintfA (KERNEL32.@)
*/
INT
WINAPIV
k32wsprintfA
(
LPSTR
buffer
,
LPCSTR
spec
,
...)
{
va_list
args
;
INT
res
;
va_start
(
args
,
spec
);
res
=
k32wvsprintfA
(
buffer
,
spec
,
args
);
va_end
(
args
);
return
res
;
}
/***************************************************************************
*
* Win 2.x string functions now moved to USER
*
* We rather want to implement them here instead of doing Callouts
*/
/***********************************************************************
* KERNEL_AnsiNext16 (KERNEL.77)
*/
SEGPTR
WINAPI
KERNEL_AnsiNext16
(
SEGPTR
current
)
{
return
(
*
(
char
*
)
MapSL
(
current
))
?
current
+
1
:
current
;
}
/***********************************************************************
* KERNEL_AnsiPrev16(KERNEL.78)
*/
SEGPTR
WINAPI
KERNEL_AnsiPrev16
(
SEGPTR
start
,
SEGPTR
current
)
{
return
(
current
==
start
)
?
start
:
current
-
1
;
}
/***********************************************************************
* KERNEL_AnsiUpper16 (KERNEL.79)
*/
SEGPTR
WINAPI
KERNEL_AnsiUpper16
(
SEGPTR
strOrChar
)
{
/* uppercase only one char if strOrChar < 0x10000 */
if
(
HIWORD
(
strOrChar
))
{
char
*
s
=
MapSL
(
strOrChar
);
while
(
*
s
)
{
*
s
=
toupper
(
*
s
);
s
++
;
}
return
strOrChar
;
}
else
return
toupper
((
char
)
strOrChar
);
}
/***********************************************************************
* KERNEL_AnsiLower16 (KERNEL.80)
*/
SEGPTR
WINAPI
KERNEL_AnsiLower16
(
SEGPTR
strOrChar
)
{
/* lowercase only one char if strOrChar < 0x10000 */
if
(
HIWORD
(
strOrChar
))
{
char
*
s
=
MapSL
(
strOrChar
);
while
(
*
s
)
{
*
s
=
tolower
(
*
s
);
s
++
;
}
return
strOrChar
;
}
else
return
tolower
((
char
)
strOrChar
);
}
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