mirror of
https://github.com/reactos/reactos.git
synced 2025-04-22 05:00:27 +00:00
- Move scanf.c into strings, it belongs there.
- Move thread.c to process, and remove outdated/duplicated copy. - Sync threadx with Wine. - Update README.WINE accordingly. svn path=/trunk/; revision=33865
This commit is contained in:
parent
c129f7fcd3
commit
3f2bc58da5
8 changed files with 118 additions and 132 deletions
|
@ -421,6 +421,7 @@
|
||||||
<file>atof.c</file>
|
<file>atof.c</file>
|
||||||
<file>ctype.c</file>
|
<file>ctype.c</file>
|
||||||
<file>lasttok.c</file>
|
<file>lasttok.c</file>
|
||||||
|
<file>scanf.c</file>
|
||||||
<file>strcoll.c</file>
|
<file>strcoll.c</file>
|
||||||
<file>strdup.c</file>
|
<file>strdup.c</file>
|
||||||
<file>strerror.c</file>
|
<file>strerror.c</file>
|
||||||
|
@ -484,8 +485,6 @@
|
||||||
</directory>
|
</directory>
|
||||||
<directory name="wine">
|
<directory name="wine">
|
||||||
<file>heap.c</file>
|
<file>heap.c</file>
|
||||||
<file>scanf.c</file>
|
|
||||||
<file>thread.c</file>
|
|
||||||
<file>undname.c</file>
|
<file>undname.c</file>
|
||||||
</directory>
|
</directory>
|
||||||
</module>
|
</module>
|
||||||
|
|
|
@ -131,6 +131,7 @@
|
||||||
<file>wcsrchr.c</file>
|
<file>wcsrchr.c</file>
|
||||||
</ifnot>
|
</ifnot>
|
||||||
<file>ctype.c</file>
|
<file>ctype.c</file>
|
||||||
|
<file>scanf.c</file>
|
||||||
<file>strcspn.c</file>
|
<file>strcspn.c</file>
|
||||||
<file>stricmp.c</file>
|
<file>stricmp.c</file>
|
||||||
<file>strnicmp.c</file>
|
<file>strnicmp.c</file>
|
||||||
|
@ -159,10 +160,6 @@
|
||||||
<file>wtol.c</file>
|
<file>wtol.c</file>
|
||||||
</directory>
|
</directory>
|
||||||
|
|
||||||
<directory name="wine">
|
|
||||||
<file>scanf.c</file>
|
|
||||||
</directory>
|
|
||||||
|
|
||||||
<directory name="wstring">
|
<directory name="wstring">
|
||||||
<file>wcsicmp.c</file>
|
<file>wcsicmp.c</file>
|
||||||
<file>wcslwr.c</file>
|
<file>wcslwr.c</file>
|
||||||
|
|
|
@ -1,23 +1,117 @@
|
||||||
#include <precomp.h>
|
|
||||||
|
|
||||||
#if 0
|
|
||||||
/*
|
/*
|
||||||
* @unimplemented
|
* msvcrt.dll thread functions
|
||||||
|
*
|
||||||
|
* Copyright 2000 Jon Griffiths
|
||||||
|
*
|
||||||
|
* This library is free software; you can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU Lesser General Public
|
||||||
|
* License as published by the Free Software Foundation; either
|
||||||
|
* version 2.1 of the License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This library is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||||
|
* Lesser General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Lesser General Public
|
||||||
|
* License along with this library; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <precomp.h>
|
||||||
|
#include <internal/wine/msvcrt.h>
|
||||||
|
|
||||||
|
#include <malloc.h>
|
||||||
|
#include <process.h>
|
||||||
|
|
||||||
|
#include <debug.h>
|
||||||
|
|
||||||
|
void _amsg_exit (int errnum);
|
||||||
|
/* Index to TLS */
|
||||||
|
DWORD MSVCRT_tls_index;
|
||||||
|
|
||||||
|
typedef void (*_beginthread_start_routine_t)(void *);
|
||||||
|
typedef unsigned int (__stdcall *_beginthreadex_start_routine_t)(void *);
|
||||||
|
|
||||||
|
/********************************************************************/
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
_beginthread_start_routine_t start_address;
|
||||||
|
void *arglist;
|
||||||
|
} _beginthread_trampoline_t;
|
||||||
|
|
||||||
|
/*********************************************************************
|
||||||
|
* msvcrt_get_thread_data
|
||||||
|
*
|
||||||
|
* Return the thread local storage structure.
|
||||||
|
*/
|
||||||
|
MSVCRT_thread_data *msvcrt_get_thread_data(void)
|
||||||
|
{
|
||||||
|
MSVCRT_thread_data *ptr;
|
||||||
|
DWORD err = GetLastError(); /* need to preserve last error */
|
||||||
|
|
||||||
|
if (!(ptr = TlsGetValue( MSVCRT_tls_index )))
|
||||||
|
{
|
||||||
|
if (!(ptr = HeapAlloc( GetProcessHeap(), HEAP_ZERO_MEMORY, sizeof(*ptr) )))
|
||||||
|
_amsg_exit( _RT_THREAD );
|
||||||
|
if (!TlsSetValue( MSVCRT_tls_index, ptr )) _amsg_exit( _RT_THREAD );
|
||||||
|
ptr->random_seed = 1;
|
||||||
|
}
|
||||||
|
SetLastError( err );
|
||||||
|
return ptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*********************************************************************
|
||||||
|
* _beginthread_trampoline
|
||||||
|
*/
|
||||||
|
static DWORD CALLBACK _beginthread_trampoline(LPVOID arg)
|
||||||
|
{
|
||||||
|
_beginthread_trampoline_t local_trampoline;
|
||||||
|
|
||||||
|
/* Maybe it's just being paranoid, but freeing arg right
|
||||||
|
* away seems safer.
|
||||||
|
*/
|
||||||
|
memcpy(&local_trampoline,arg,sizeof(local_trampoline));
|
||||||
|
free(arg);
|
||||||
|
|
||||||
|
local_trampoline.start_address(local_trampoline.arglist);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*********************************************************************
|
||||||
|
* _beginthread (MSVCRT.@)
|
||||||
*/
|
*/
|
||||||
unsigned long _beginthread(
|
unsigned long _beginthread(
|
||||||
void (__cdecl *start_address)(void*),
|
_beginthread_start_routine_t start_address, /* [in] Start address of routine that begins execution of new thread */
|
||||||
unsigned stack_size,
|
unsigned int stack_size, /* [in] Stack size for new thread or 0 */
|
||||||
void* arglist)
|
void *arglist) /* [in] Argument list to be passed to new thread or NULL */
|
||||||
{
|
|
||||||
__set_errno ( ENOSYS );
|
|
||||||
return (unsigned long)-1;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
/*
|
|
||||||
* @unimplemented
|
|
||||||
*/
|
|
||||||
void _endthread(void)
|
|
||||||
{
|
{
|
||||||
|
_beginthread_trampoline_t* trampoline;
|
||||||
|
|
||||||
|
DPRINT("(%p, %d, %p)\n", start_address, stack_size, arglist);
|
||||||
|
|
||||||
|
/* Allocate the trampoline here so that it is still valid when the thread
|
||||||
|
* starts... typically after this function has returned.
|
||||||
|
* _beginthread_trampoline is responsible for freeing the trampoline
|
||||||
|
*/
|
||||||
|
trampoline=malloc(sizeof(*trampoline));
|
||||||
|
trampoline->start_address = start_address;
|
||||||
|
trampoline->arglist = arglist;
|
||||||
|
|
||||||
|
/* FIXME */
|
||||||
|
return (unsigned long)CreateThread(NULL, stack_size, _beginthread_trampoline,
|
||||||
|
trampoline, 0, NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*********************************************************************
|
||||||
|
* _endthread (MSVCRT.@)
|
||||||
|
*/
|
||||||
|
void CDECL _endthread(void)
|
||||||
|
{
|
||||||
|
DPRINT("(void)\n");
|
||||||
|
|
||||||
|
/* FIXME */
|
||||||
|
ExitThread(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* EOF */
|
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
/*
|
/*
|
||||||
* @unimplemented
|
* @unimplemented
|
||||||
*/
|
*/
|
||||||
unsigned long _beginthreadex(
|
unsigned long CDECL _beginthreadex(
|
||||||
void* security,
|
void* security,
|
||||||
unsigned stack_size,
|
unsigned stack_size,
|
||||||
unsigned (__stdcall *start_address)(void*),
|
unsigned (__stdcall *start_address)(void*),
|
||||||
|
@ -32,7 +32,7 @@ unsigned long _beginthreadex(
|
||||||
/*
|
/*
|
||||||
* @implemented
|
* @implemented
|
||||||
*/
|
*/
|
||||||
void _endthreadex(unsigned retval)
|
void CDECL _endthreadex(unsigned retval)
|
||||||
{
|
{
|
||||||
/*
|
/*
|
||||||
* Just call the API function. Any CRT specific processing is done in
|
* Just call the API function. Any CRT specific processing is done in
|
||||||
|
|
|
@ -1,106 +0,0 @@
|
||||||
/*
|
|
||||||
* msvcrt.dll thread functions
|
|
||||||
*
|
|
||||||
* Copyright 2000 Jon Griffiths
|
|
||||||
*
|
|
||||||
* This library is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU Lesser General Public
|
|
||||||
* License as published by the Free Software Foundation; either
|
|
||||||
* version 2.1 of the License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This library is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
||||||
* Lesser General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU Lesser General Public
|
|
||||||
* License along with this library; if not, write to the Free Software
|
|
||||||
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include <precomp.h>
|
|
||||||
#include <internal/wine/msvcrt.h>
|
|
||||||
|
|
||||||
#include <malloc.h>
|
|
||||||
#include <process.h>
|
|
||||||
|
|
||||||
#include <debug.h>
|
|
||||||
|
|
||||||
void _amsg_exit (int errnum);
|
|
||||||
/* Index to TLS */
|
|
||||||
DWORD MSVCRT_tls_index;
|
|
||||||
|
|
||||||
typedef void (*_beginthread_start_routine_t)(void *);
|
|
||||||
typedef unsigned int (__stdcall *_beginthreadex_start_routine_t)(void *);
|
|
||||||
|
|
||||||
/********************************************************************/
|
|
||||||
|
|
||||||
typedef struct {
|
|
||||||
_beginthread_start_routine_t start_address;
|
|
||||||
void *arglist;
|
|
||||||
} _beginthread_trampoline_t;
|
|
||||||
|
|
||||||
/*********************************************************************
|
|
||||||
* msvcrt_get_thread_data
|
|
||||||
*
|
|
||||||
* Return the thread local storage structure.
|
|
||||||
*/
|
|
||||||
MSVCRT_thread_data *msvcrt_get_thread_data(void)
|
|
||||||
{
|
|
||||||
MSVCRT_thread_data *ptr;
|
|
||||||
DWORD err = GetLastError(); /* need to preserve last error */
|
|
||||||
|
|
||||||
if (!(ptr = TlsGetValue( MSVCRT_tls_index )))
|
|
||||||
{
|
|
||||||
if (!(ptr = HeapAlloc( GetProcessHeap(), HEAP_ZERO_MEMORY, sizeof(*ptr) )))
|
|
||||||
_amsg_exit( _RT_THREAD );
|
|
||||||
if (!TlsSetValue( MSVCRT_tls_index, ptr ))
|
|
||||||
_amsg_exit( _RT_THREAD );
|
|
||||||
if (!TlsSetValue( MSVCRT_tls_index, ptr ))
|
|
||||||
_amsg_exit( _RT_THREAD );
|
|
||||||
}
|
|
||||||
SetLastError( err );
|
|
||||||
return ptr;
|
|
||||||
}
|
|
||||||
|
|
||||||
/*********************************************************************
|
|
||||||
* _beginthread_trampoline
|
|
||||||
*/
|
|
||||||
static DWORD CALLBACK _beginthread_trampoline(LPVOID arg)
|
|
||||||
{
|
|
||||||
_beginthread_trampoline_t local_trampoline;
|
|
||||||
|
|
||||||
/* Maybe it's just being paranoid, but freeing arg right
|
|
||||||
* away seems safer.
|
|
||||||
*/
|
|
||||||
memcpy(&local_trampoline,arg,sizeof(local_trampoline));
|
|
||||||
free(arg);
|
|
||||||
|
|
||||||
local_trampoline.start_address(local_trampoline.arglist);
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/*********************************************************************
|
|
||||||
* _beginthread (MSVCRT.@)
|
|
||||||
*/
|
|
||||||
unsigned long _beginthread(
|
|
||||||
_beginthread_start_routine_t start_address, /* [in] Start address of routine that begins execution of new thread */
|
|
||||||
unsigned int stack_size, /* [in] Stack size for new thread or 0 */
|
|
||||||
void *arglist) /* [in] Argument list to be passed to new thread or NULL */
|
|
||||||
{
|
|
||||||
_beginthread_trampoline_t* trampoline;
|
|
||||||
|
|
||||||
DPRINT("(%p, %d, %p)\n", start_address, stack_size, arglist);
|
|
||||||
|
|
||||||
/* Allocate the trampoline here so that it is still valid when the thread
|
|
||||||
* starts... typically after this function has returned.
|
|
||||||
* _beginthread_trampoline is responsible for freeing the trampoline
|
|
||||||
*/
|
|
||||||
trampoline=malloc(sizeof(*trampoline));
|
|
||||||
trampoline->start_address = start_address;
|
|
||||||
trampoline->arglist = arglist;
|
|
||||||
|
|
||||||
/* FIXME */
|
|
||||||
return (unsigned long)CreateThread(NULL, stack_size, _beginthread_trampoline,
|
|
||||||
trampoline, 0, NULL);
|
|
||||||
}
|
|
|
@ -143,10 +143,12 @@ kernel32 -
|
||||||
reactos/dll/win32/kernel32/misc/lcformat.c # Out of sync
|
reactos/dll/win32/kernel32/misc/lcformat.c # Out of sync
|
||||||
|
|
||||||
msvcrt -
|
msvcrt -
|
||||||
reactos/dll/win32/msvcrt/wine/*.c # Out of sync
|
|
||||||
reactos/lib/sdk/crt/cpp.c # Synced at 20071111
|
reactos/lib/sdk/crt/cpp.c # Synced at 20071111
|
||||||
reactos/lib/sdk/crt/cppexcept.c # Synced at 20071111
|
reactos/lib/sdk/crt/cppexcept.c # Synced at 20071111
|
||||||
|
reactos/lib/sdk/crt/strings/scanf.c/h # Synced at 20080604
|
||||||
|
reactos/lib/sdk/crt/wine/heap.c # Synced at 20080529
|
||||||
reactos/lib/sdk/crt/wine # Synced at XXXXXXXX
|
reactos/lib/sdk/crt/wine # Synced at XXXXXXXX
|
||||||
|
reactos/lib/sdk/crt/thread/thread.c # Synced at 20080604
|
||||||
|
|
||||||
User32 -
|
User32 -
|
||||||
reactos/dll/win32/user32/controls/button.c # Synced at 20071022
|
reactos/dll/win32/user32/controls/button.c # Synced at 20071022
|
||||||
|
|
Loading…
Reference in a new issue