mirror of
https://github.com/reactos/reactos.git
synced 2025-01-05 13:59:25 +00:00
- Register the standard control classes in GetClassInfo[Ex][AW] if needed.
svn path=/trunk/; revision=9044
This commit is contained in:
parent
d7d8c7ba0f
commit
37bfcac65a
2 changed files with 12 additions and 71 deletions
|
@ -1,4 +1,4 @@
|
||||||
/* $Id: class.c,v 1.44 2004/01/23 23:38:26 ekohl Exp $
|
/* $Id: class.c,v 1.45 2004/04/08 21:14:21 navaraf Exp $
|
||||||
*
|
*
|
||||||
* COPYRIGHT: See COPYING in the top level directory
|
* COPYRIGHT: See COPYING in the top level directory
|
||||||
* PROJECT: ReactOS user32.dll
|
* PROJECT: ReactOS user32.dll
|
||||||
|
@ -15,6 +15,7 @@
|
||||||
#include <debug.h>
|
#include <debug.h>
|
||||||
#include <window.h>
|
#include <window.h>
|
||||||
#include <strpool.h>
|
#include <strpool.h>
|
||||||
|
#include <user32/regcontrol.h>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -40,6 +41,8 @@ static BOOL GetClassInfoExCommon(
|
||||||
str = (LPWSTR)lpszClass;
|
str = (LPWSTR)lpszClass;
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
extern BOOL ControlsInitialized;
|
||||||
|
|
||||||
if (unicode)
|
if (unicode)
|
||||||
{
|
{
|
||||||
str = HEAP_strdupW ( lpszClass, wcslen(lpszClass) );
|
str = HEAP_strdupW ( lpszClass, wcslen(lpszClass) );
|
||||||
|
@ -61,6 +64,12 @@ static BOOL GetClassInfoExCommon(
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Register built-in controls if not already done */
|
||||||
|
if ( !ControlsInitialized )
|
||||||
|
{
|
||||||
|
ControlsInitialized = ControlsInit(str);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
str2.Length = str3.Length = 0;
|
str2.Length = str3.Length = 0;
|
||||||
|
@ -139,74 +148,6 @@ GetClassInfoExW(
|
||||||
LPWNDCLASSEXW lpwcx)
|
LPWNDCLASSEXW lpwcx)
|
||||||
{
|
{
|
||||||
return GetClassInfoExCommon(hinst, lpszClass, lpwcx, TRUE);
|
return GetClassInfoExCommon(hinst, lpszClass, lpwcx, TRUE);
|
||||||
|
|
||||||
// AG: I've kept this here (commented out) in case of bugs with my
|
|
||||||
// own "common" routine (see above):
|
|
||||||
|
|
||||||
/*LPWSTR str;
|
|
||||||
UNICODE_STRING str2;
|
|
||||||
WNDCLASSEXW w;
|
|
||||||
BOOL retval;
|
|
||||||
|
|
||||||
if ( !lpszClass || !lpwcx )
|
|
||||||
{
|
|
||||||
SetLastError(ERROR_INVALID_PARAMETER);
|
|
||||||
return FALSE;
|
|
||||||
}
|
|
||||||
|
|
||||||
if(IS_ATOM(lpszClass))
|
|
||||||
str = (LPWSTR)lpszClass;
|
|
||||||
else
|
|
||||||
{
|
|
||||||
str = HEAP_strdupW ( lpszClass, wcslen(lpszClass) );
|
|
||||||
if ( !str )
|
|
||||||
{
|
|
||||||
SetLastError (RtlNtStatusToDosError(STATUS_NO_MEMORY));
|
|
||||||
return FALSE;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
str2.Length = str3.Length = 0;
|
|
||||||
str2.MaximumLength = str3.MaximumLength = 255;
|
|
||||||
str2.Buffer = (PWSTR)HEAP_alloc ( str2.MaximumLength * sizeof(WCHAR) );
|
|
||||||
if ( !str2.Buffer )
|
|
||||||
{
|
|
||||||
SetLastError (RtlNtStatusToDosError(STATUS_NO_MEMORY));
|
|
||||||
if ( !IS_ATOM(str) )
|
|
||||||
HEAP_free ( str );
|
|
||||||
return FALSE;
|
|
||||||
}
|
|
||||||
|
|
||||||
str3.Buffer = (PWSTR)HEAP_alloc ( str3.MaximumLength * sizeof(WCHAR) );
|
|
||||||
if ( !str3.Buffer )
|
|
||||||
{
|
|
||||||
SetLastError (RtlNtStatusToDosError(STATUS_NO_MEMORY));
|
|
||||||
if ( !IS_ATOM(str) )
|
|
||||||
HEAP_free ( str );
|
|
||||||
HEAP_free ( str2.Buffer );
|
|
||||||
return FALSE;
|
|
||||||
}
|
|
||||||
|
|
||||||
w.lpszMenuName = (LPCWSTR)&str2;
|
|
||||||
w.lpszClassName = (LPCWSTR)&str3;
|
|
||||||
retval = (BOOL)NtUserGetClassInfo(hinst, str, &w, TRUE, 0);
|
|
||||||
if ( !IS_ATOM(str) )
|
|
||||||
HEAP_free(str);
|
|
||||||
RtlCopyMemory ( lpwcx, &w, sizeof(WNDCLASSEXW) );
|
|
||||||
|
|
||||||
if ( !IS_INTRESOURCE(w.lpszMenuName) && w.lpszMenuName )
|
|
||||||
{
|
|
||||||
lpwcx->lpszMenuName = heap_string_poolW ( str2.Buffer, str2.Length );
|
|
||||||
}
|
|
||||||
if ( !IS_ATOM(w.lpszClassName) && w.lpszClassName )
|
|
||||||
{
|
|
||||||
lpwcx->lpszClassName = heap_string_poolW ( str3.Buffer, str3.Length );
|
|
||||||
}
|
|
||||||
|
|
||||||
HEAP_free ( str2.Buffer );
|
|
||||||
HEAP_free ( str3.Buffer );
|
|
||||||
|
|
||||||
return retval;*/
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
/* $Id: window.c,v 1.106 2004/04/07 08:25:40 gvg Exp $
|
/* $Id: window.c,v 1.107 2004/04/08 21:14:21 navaraf Exp $
|
||||||
*
|
*
|
||||||
* COPYRIGHT: See COPYING in the top level directory
|
* COPYRIGHT: See COPYING in the top level directory
|
||||||
* PROJECT: ReactOS user32.dll
|
* PROJECT: ReactOS user32.dll
|
||||||
|
@ -22,7 +22,7 @@
|
||||||
#define NDEBUG
|
#define NDEBUG
|
||||||
#include <debug.h>
|
#include <debug.h>
|
||||||
|
|
||||||
static BOOL ControlsInitialized = FALSE;
|
BOOL ControlsInitialized = FALSE;
|
||||||
|
|
||||||
/* FUNCTIONS *****************************************************************/
|
/* FUNCTIONS *****************************************************************/
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue