Source code of Windows XP (NT5)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

1424 lines
42 KiB

#include "precomp.h"
#include "resource.h"
#include "PropWnd2.h"
#include "WndProcs.h"
#include "nmakwiz.h"
#include "nmakreg.h"
#include <algorithm>
const int CPropertyDataWindow2::mcs_iTop = 0;
const int CPropertyDataWindow2::mcs_iLeft = 150;
const int CPropertyDataWindow2::mcs_iBorder = 15;
/* static */ map< UINT, CPolicyData::eKeyType > CPropertyDataWindow2::ms_ClassMap;
/* static */ map< UINT, TCHAR* > CPropertyDataWindow2::ms_KeyMap;
/* static */ map< UINT, TCHAR* > CPropertyDataWindow2::ms_ValueMap;
LRESULT CALLBACK DefaultProc( HWND hwnd, UINT iMsg, WPARAM wParam, LPARAM lParam )
{
switch( iMsg )
{
case WM_VSCROLL:
{
OnMsg_VScroll( hwnd, wParam );
return 0;
break;
}
case WM_COMMAND:
{
return 0;
}
}
return( DefWindowProc( hwnd, iMsg, wParam, lParam ) );
}
CPropertyDataWindow2::CPropertyDataWindow2( HWND hwndParent, UINT uIDD, LPTSTR szClassName, UINT PopUpHelpMenuTextId, int iX, int iY, int iWidth, int iHeight, BOOL bScroll ) :
m_hwnd( NULL ),
m_IDD( uIDD ),
m_wndProc( (WNDPROC) DefaultProc),
m_bInit( FALSE ),
m_hwndParent( hwndParent )
{
m_szClassName = new TCHAR[ lstrlen( szClassName ) + 1 ];
lstrcpy( m_szClassName, szClassName );
_InitWindow();
_SizeWindow( iX, iY, iWidth, iHeight );
if( bScroll )
{
_PrepScrollBars();
}
ShowWindow( FALSE );
}
CPropertyDataWindow2::CPropertyDataWindow2( HWND hwndParent, UINT uIDD, LPTSTR szClassName, WNDPROC wndProc, UINT PopUpHelpMenuTextId, int iX, int iY, int iWidth, int iHeight, BOOL bScroll ) :
m_IDD( uIDD ),
m_hwnd( NULL ),
m_wndProc( wndProc ),
m_bInit( FALSE ),
m_hwndParent( hwndParent )
{
m_szClassName = new TCHAR[ lstrlen( szClassName ) + 1 ];
lstrcpy( m_szClassName, szClassName );
_InitWindow();
_SizeWindow( iX, iY, iWidth, iHeight );
if( bScroll )
{
_PrepScrollBars();
}
ShowWindow( FALSE );
}
CPropertyDataWindow2::~CPropertyDataWindow2( void )
{
delete [] m_szClassName;
list< CControlID * >::iterator it;
for( it = m_condList.begin(); it != m_condList.end(); it++ )
{
delete *it;
}
for( it = m_specialControlList.begin(); it != m_specialControlList.end(); it++ )
{
delete *it;
}
}
void CPropertyDataWindow2::Reset()
{
list< HWND >::iterator i;
for( i = m_enableList.begin(); i != m_enableList.end(); i++ )
{
switch (GetWindowLong(*i, GWL_STYLE) & 0x0F)
{
case BS_AUTORADIOBUTTON:
case BS_RADIOBUTTON:
// Do nothing -- we always want default item checked
break;
default:
Button_SetCheck(*i, FALSE);
break;
}
}
list< CControlID * >::iterator it;
for( it = m_condList.begin(); it != m_condList.end(); it++ )
{
(*it)->Reset( m_hwnd );
}
for( it = m_specialControlList.begin(); it != m_specialControlList.end(); it++ )
{
(*it)->Reset( m_hwnd );
}
}
void CPropertyDataWindow2::SetEnableListID( UINT uCount, ... )
{
UINT uID;
HWND hwnd;
va_list ap;
va_start( ap, uCount );
while( uCount )
{
uID = va_arg( ap, UINT );
uCount--;
if( NULL == ( hwnd = GetDlgItem( m_hwnd, uID ) ) )
{
OutputDebugString( TEXT("Enabling Invalid ID\n") );
}
else
{
m_checkIDList.push_front( uID );
m_enableList.push_front( hwnd );
}
}
va_end( ap );
}
BOOL CPropertyDataWindow2::SetFocus( UINT id )
{
return ::SetFocus( GetDlgItem( m_hwnd, id ) ) ? TRUE : FALSE;
}
void CPropertyDataWindow2::SetEditData( UINT id, TCHAR* sz )
{
Edit_SetText( GetDlgItem( m_hwnd, id ), sz );
}
void CPropertyDataWindow2::GetEditData( UINT id, LPTSTR sz, ULONG cb ) const
{
Edit_GetText( GetDlgItem( m_hwnd, id ), sz, cb );
}
ULONG CPropertyDataWindow2::GetEditDataLen( UINT id ) const
{
return Edit_GetTextLength( GetDlgItem( m_hwnd, id ) );
}
BOOL CPropertyDataWindow2::GetCheck( UINT id ) const
{
return(Button_GetCheck( GetDlgItem( m_hwnd, id ) ) ? TRUE : FALSE);
}
void CPropertyDataWindow2::SetCheck( UINT id, BOOL bCheck )
{
Button_SetCheck( GetDlgItem( m_hwnd, id ), bCheck );
}
void CPropertyDataWindow2::ShowWindow( BOOL bShowWindow /* = TRUE */ )
{
::ShowWindow( m_hwnd, bShowWindow ? SW_SHOW : SW_HIDE );
}
void CPropertyDataWindow2::EnableWindow( BOOL bEnable /* = TRUE */ )
{
list< HWND >::const_iterator it;
for (it = m_enableList.begin(); it != m_enableList.end(); ++it)
{
::EnableWindow( (HWND)(*it), bEnable );
}
if( m_specialControlList.size() )
{
list< CControlID * >::const_iterator iter;
for( iter = m_specialControlList.begin();
iter != m_specialControlList.end();
iter++ )
{
switch( (*iter)->GetType() )
{
case CControlID::CHECK:
case CControlID::SLIDER:
case CControlID::EDIT:
case CControlID::EDIT_NUM:
case CControlID::STATIC:
case CControlID::COMBO:
{
HWND hwnd = GetDlgItem( m_hwnd, (*iter)->GetID() );
::EnableWindow( hwnd, bEnable );
break;
}
default:
OutputDebugString( TEXT("CPropertyDataWindow2::EnableWindow: unknown CControlID::type\n") );
assert( 0 );
break;
}
}
}
if( m_condList.size() )
{
list< CControlID * >::const_iterator iter;
for( iter = m_condList.begin();
iter != m_condList.end();
iter++ )
{
::EnableWindow( (*iter)->GetCondHwnd(), bEnable );
}
}
}
BOOL CPropertyDataWindow2::_InitWindow( void )
{
if( FALSE == m_bInit )
{
WNDCLASSEX wc;
ZeroMemory( &wc, sizeof( WNDCLASSEX ) );
wc . cbSize = sizeof( WNDCLASSEX );
wc . style = 0;
wc . cbWndExtra = DLGWINDOWEXTRA;
wc . hInstance = g_hInstance;
wc . lpfnWndProc = m_wndProc;
wc . lpszClassName = m_szClassName;
if( 0 == RegisterClassEx( &wc ) )
{
return FALSE;
}
if( NULL == (m_hwnd = CreateDialogParam( g_hInstance, MAKEINTRESOURCE( m_IDD ), m_hwndParent, NULL/*(DLGPROC)m_wndProc*/, 0 ) ) )
{
ErrorMessage( TEXT("CPropertyDataWindow2::_InitWindow"), GetLastError() );
}
m_bInit = TRUE;
}
return TRUE;
}
BOOL CPropertyDataWindow2::_SizeWindow( int X, int Y, int Width, int Height )
{
GetClientRect( m_hwnd, &m_rect );
return SetWindowPos( m_hwnd, // handle to window
HWND_TOP, // placement-order handle
X, // horizontal position
Y, // vertical position
Width, // width
Height, // height
0 // window-positioning flags
);
}
void CPropertyDataWindow2::_PrepScrollBars()
{
RECT clientRect;
GetClientRect( m_hwnd, &clientRect );
int iTotalHeight = (m_rect.bottom - m_rect.top);
int iVisible = clientRect.bottom - clientRect.top;
if( iTotalHeight <= iVisible )
{
return;
}
SCROLLINFO ScrollInfo;
ScrollInfo . cbSize = sizeof( SCROLLINFO );
ScrollInfo . fMask = SIF_ALL;
ScrollInfo . nMin = 0;
ScrollInfo . nMax = iTotalHeight;
// Make the scroll bar scroll 4/5th of a screen per page
ScrollInfo . nPage = MulDiv( iVisible, 4, 5 );
ScrollInfo . nPos = 0;
SetScrollInfo( m_hwnd, SB_VERT, &ScrollInfo, 0 );
}
void CPropertyDataWindow2::AddControl( CControlID *pControlID )
{
m_specialControlList.push_front( pControlID );
}
void CPropertyDataWindow2::ConnectControlsToCheck( UINT idCheck, UINT uCount, ... )
{
HWND hwndCheck = GetDlgItem( m_hwnd, idCheck );
PSUBDATA pSubData = new SUBDATA;
pSubData -> proc = SubclassWindow( hwndCheck, wndProcForCheckTiedToEdit );
va_list ap;
va_start( ap, uCount );
while( uCount )
{
uCount--;
CControlID *pControlID = va_arg( ap, CControlID * );
m_condList.push_front( pControlID );
switch( pControlID->GetType() )
{
case CControlID::STATIC:
case CControlID::CHECK:
case CControlID::SLIDER:
case CControlID::EDIT:
case CControlID::EDIT_NUM:
case CControlID::COMBO:
{
HWND hwnd = GetDlgItem( m_hwnd, pControlID->GetID() );
pSubData->list.push_front( hwnd );
break;
}
default:
OutputDebugString( TEXT("CPropertyDataWindow2::ConnectControlsToCheck: unknown CControlID::type\n") );
break;
}
}
SetWindowLong( hwndCheck, GWL_USERDATA, (long)pSubData );
}
BOOL CPropertyDataWindow2::WriteStringValue
(
LPCTSTR szKeyName,
LPCTSTR szValue
)
{
TCHAR szFile[MAX_PATH];
//
// We SAVE settings to the file on the finish page.
//
g_pWiz->m_FinishSheet.GetFilePane()->GetPathAndFile(szFile);
return(WritePrivateProfileString(SECTION_SETTINGS, szKeyName,
szValue, szFile));
}
BOOL CPropertyDataWindow2::WriteNumberValue
(
LPCTSTR szKeyName,
int nValue
)
{
TCHAR szValue[MAX_DIGITS];
TCHAR szFile[MAX_PATH];
//
// We SAVE settings to the file on the finish page.
//
g_pWiz->m_FinishSheet.GetFilePane()->GetPathAndFile(szFile);
wsprintf(szValue, "%d", nValue);
return(WritePrivateProfileString(SECTION_SETTINGS, szKeyName,
szValue, szFile));
}
void CPropertyDataWindow2::ReadStringValue
(
LPCTSTR szKeyName,
LPTSTR szValue,
UINT cchMax
)
{
TCHAR szFile[MAX_PATH];
//
// We READ settings from the file on the intro page.
//
g_pWiz->m_IntroSheet.GetFilePane()->GetPathAndFile(szFile);
GetPrivateProfileString(SECTION_SETTINGS, szKeyName,
TEXT(""), szValue, cchMax, szFile);
}
void CPropertyDataWindow2::ReadNumberValue
(
LPCTSTR szKeyName,
int * pnValue
)
{
TCHAR szFile[MAX_PATH];
//
// We READ settings from the file on the intro page.
//
g_pWiz->m_IntroSheet.GetFilePane()->GetPathAndFile(szFile);
*pnValue = GetPrivateProfileInt(SECTION_SETTINGS, szKeyName,
0, szFile);
}
void CPropertyDataWindow2::ReadSettings()
{
list< CControlID *>::const_iterator it;
_ReadCheckSettings();
for( it = m_condList.begin(); it != m_condList.end(); it++ )
{
_ReadCheckSetting( (*it)->GetCondID() );
switch( (*it)->GetType() )
{
case CControlID::STATIC:
break;
case CControlID::EDIT:
case CControlID::EDIT_NUM:
_ReadEditSetting( (*it)->GetID() );
break;
case CControlID::CHECK:
_ReadCheckSetting( (*it)->GetID() );
break;
case CControlID::COMBO:
_ReadComboSetting( (*it)->GetID() );
break;
case CControlID::SLIDER:
_ReadSliderSetting( (*it) );
break;
default:
OutputDebugString( TEXT("CPropertyDataWindow2::ReadSettings: unknown CControlID::type\n") );
assert( 0 );
break;
}
}
for( it = m_specialControlList.begin(); it != m_specialControlList.end(); it++ )
{
switch( (*it)->GetType() )
{
case CControlID::STATIC:
break;
case CControlID::EDIT:
case CControlID::EDIT_NUM:
_ReadEditSetting( (*it)->GetID() );
break;
case CControlID::CHECK:
_ReadCheckSetting( (*it)->GetID() );
break;
case CControlID::COMBO:
_ReadComboSetting( (*it)->GetID() );
break;
case CControlID::SLIDER:
_ReadSliderSetting( (*it) );
break;
default:
OutputDebugString( TEXT("CPropertyDataWindow2::ReadSettings: unknown CControlID::type\n") );
assert( 0 );
break;
}
}
}
BOOL CPropertyDataWindow2::WriteSettings()
{
list< CControlID *>::const_iterator it;
_WriteCheckSettings();
for( it = m_condList.begin(); it != m_condList.end(); it++ )
{
_WriteCheckSetting( (*it)->GetCondID() );
switch( (*it)->GetType() )
{
case CControlID::EDIT:
case CControlID::EDIT_NUM:
_WriteEditSetting( (*it)->GetID() );
break;
case CControlID::CHECK:
_WriteCheckSetting( (*it)->GetID() );
break;
case CControlID::COMBO:
_WriteComboSetting( (*it)->GetID() );
break;
case CControlID::SLIDER:
_WriteSliderSetting( (*it)->GetID() );
break;
case CControlID::STATIC:
break;
default:
OutputDebugString( TEXT("CPropertyDataWindow2::WriteSettings: unknown CControlID::type\n") );
assert( 0 );
break;
}
}
for( it = m_specialControlList.begin(); it != m_specialControlList.end(); it++ )
{
switch( (*it)->GetType() )
{
case CControlID::EDIT:
case CControlID::EDIT_NUM:
_WriteEditSetting( (*it)->GetID() );
break;
case CControlID::CHECK:
_WriteCheckSetting( (*it)->GetID() );
break;
case CControlID::COMBO:
_WriteComboSetting( (*it)->GetID() );
break;
case CControlID::SLIDER:
_WriteSliderSetting( (*it)->GetID() );
break;
case CControlID::STATIC:
break;
default:
OutputDebugString( TEXT("CPropertyDataWindow2::WriteSettings: unknown CControlID::type\n") );
assert( 0 );
break;
}
}
return TRUE;
}
void CPropertyDataWindow2::_ReadEditSetting( UINT EditID )
{
TCHAR szKeyName[8];
TCHAR szSetting[512];
wsprintf( szKeyName, TEXT("%d"), EditID );
ReadStringValue(szKeyName, szSetting, CCHMAX(szSetting));
SetEditData(EditID, szSetting);
}
BOOL CPropertyDataWindow2::_WriteEditSetting( UINT EditID )
{
BOOL fSuccess;
int iLen = GetEditDataLen( EditID ) + 1;
LPTSTR szData = new TCHAR[ iLen ];
GetEditData( EditID, szData, iLen );
TCHAR szKeyName[ 8 ];
wsprintf(szKeyName, TEXT("%d"), EditID);
fSuccess = WriteStringValue(szKeyName, szData);
delete [] szData;
return(fSuccess);
}
void CPropertyDataWindow2::_ReadIntSetting( UINT ID, int *pData )
{
TCHAR szKeyName[ 8 ];
wsprintf( szKeyName, TEXT("%d"), ID );
ReadNumberValue(szKeyName, pData);
}
BOOL CPropertyDataWindow2::_WriteIntSetting( UINT ID, int data )
{
TCHAR szKeyName[ 8 ];
wsprintf( szKeyName, TEXT("%d"), ID );
return(WriteNumberValue(szKeyName, data));
}
void CPropertyDataWindow2::_ReadSliderSetting( CControlID *pControlID )
{
int iPos;
UINT ID = pControlID->GetID();
_ReadIntSetting( ID, &iPos);
//
// HACK FOR AV BANDWIDTH -- TrackBars are limited to WORD-sized values
// for range. So the registry has the real value (bits/sec) but we
// represent it in NMRK UI as (kbits/sec).
//
iPos /= 1000;
TrackBar_SetPos( GetDlgItem( m_hwnd, ID ), TRUE, iPos);
TCHAR szPos[ MAX_DIGITS ];
wsprintf( szPos, TEXT("%u"), iPos );
Static_SetText( GetDlgItem( m_hwnd, pControlID->GetStaticID()), szPos );
}
BOOL CPropertyDataWindow2::_WriteSliderSetting( UINT ID )
{
int iPos;
//
// HACK FOR AV BANDWIDTH -- TrackBars are limited to WORD-sized values
// for range. So the registry has the real value (bits/sec) but we
// represent it in NMRK UI as (kbits/sec).
//
iPos = TrackBar_GetPos(GetDlgItem(m_hwnd, ID));
iPos *= 1000;
return _WriteIntSetting( ID, iPos);
}
void CPropertyDataWindow2::_ReadComboSetting( UINT ID )
{
int iSelected;
_ReadIntSetting( ID, &iSelected );
HWND hwndCombo = GetDlgItem( m_hwnd, ID );
ComboBox_SetCurSel( hwndCombo, iSelected );
}
BOOL CPropertyDataWindow2::_WriteComboSetting( UINT ID )
{
return _WriteIntSetting( ID, ComboBox_GetCurSel( GetDlgItem( m_hwnd, ID ) ) );
}
void CPropertyDataWindow2::_ReadCheckSetting( UINT ID )
{
TCHAR szKeyName[ 8 ];
int nValue;
wsprintf( szKeyName, TEXT("%d"), ID );
ReadNumberValue(szKeyName, &nValue);
CheckDlgButton(m_hwnd, ID, nValue);
}
BOOL CPropertyDataWindow2::_WriteCheckSetting( UINT ID )
{
TCHAR szKeyName[ MAX_DIGITS ];
wsprintf( szKeyName, TEXT("%d"), ID );
return(WriteNumberValue(szKeyName, IsDlgButtonChecked(m_hwnd, ID)));
}
void CPropertyDataWindow2::_ReadCheckSettings()
{
for( list< UINT >::const_iterator it = m_checkIDList.begin(); it != m_checkIDList.end(); it++ )
{
_ReadCheckSetting(*it);
}
}
BOOL CPropertyDataWindow2::_WriteCheckSettings()
{
for( list< UINT >::const_iterator it = m_checkIDList.begin(); it != m_checkIDList.end(); it++ )
{
if (!_WriteCheckSetting(*it))
{
return FALSE;
}
}
return TRUE;
}
void CPropertyDataWindow2::MapControlsToRegKeys( void )
{
if( 0 != ms_ValueMap.size() )
{
return;
}
UINT CurrentID;
// File Transfer
CurrentID = IDC_PREVENT_THE_USER_FROM_SENDING_FILES;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[ CurrentID ] = POLICIES_KEY;;
ms_ValueMap[ CurrentID ] = REGVAL_POL_NO_FILETRANSFER_SEND;
CurrentID = IDC_PREVENT_THE_USER_FROM_RECEIVING_FILES;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[ CurrentID ] = POLICIES_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_POL_NO_FILETRANSFER_RECEIVE;
CurrentID = IDC_EDIT_MAXIMUM_SIZE_OF_SENT_FILES;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[ CurrentID ] = POLICIES_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_POL_MAX_SENDFILESIZE;
// App Sharing
CurrentID = IDC_DISABLE_ALL_SHARING_FEATURES;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[ CurrentID ] = POLICIES_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_POL_NO_APP_SHARING;
CurrentID = IDC_DISABLE_WEBDIR;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[ CurrentID ] = POLICIES_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_POL_NO_WEBDIR;
CurrentID = IDC_DISABLE_WEBDIR_GK;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[ CurrentID ] = POLICIES_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_POL_NO_WEBDIR;
CurrentID = IDC_PREVENT_SHARING;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[ CurrentID ] = POLICIES_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_POL_NO_SHARING;
CurrentID = IDC_PREVENT_SHARING_DESKTOP;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[ CurrentID ] = POLICIES_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_POL_NO_DESKTOP_SHARING;
CurrentID = IDC_PREVENT_SHARING_TRUECOLOR;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[ CurrentID ] = POLICIES_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_POL_NO_TRUECOLOR_SHARING;
CurrentID = IDC_PREVENT_SHARING_EXPLORER;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[ CurrentID ] = POLICIES_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_POL_NO_EXPLORER_SHARING;
CurrentID = IDC_PREVENT_SHARING_DOS;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[ CurrentID ] = POLICIES_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_POL_NO_MSDOS_SHARING;
CurrentID = IDC_PREVENT_SHARING_CONTROL;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[ CurrentID ] = POLICIES_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_POL_NO_ALLOW_CONTROL;
CurrentID = IDC_DISABLE_RDS_ON_ALL;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_LOCAL_MACHINE;
ms_KeyMap[ CurrentID ] = POLICIES_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_POL_NO_RDS;
CurrentID = IDC_DISABLE_RDS_ON_WIN9X;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_LOCAL_MACHINE;
ms_KeyMap[ CurrentID ] = POLICIES_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_POL_NO_RDS_WIN9X;
// Audio
CurrentID = IDC_CREATE_AN_AUDIO_LOG_FILE; // HKLM
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_LOCAL_MACHINE;
ms_KeyMap[ CurrentID ] = DEBUG_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_RETAIL_LOG;
CurrentID = IDC_CHECK_MUTE_SPEAKER_BY_DEFAULT;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[ CurrentID ] = AUDIO_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_SPKMUTE;
CurrentID = IDC_CHECK_MUTE_MICROPHONE_BY_DEFAULT;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[ CurrentID ] = AUDIO_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_RECMUTE;
CurrentID = IDC_ENABLE_DIRECT_SOUND;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[ CurrentID ] = AUDIO_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_DIRECTSOUND;
CurrentID = IDC_NOCHANGE_DIRECT_SOUND;
ms_ClassMap[CurrentID] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[CurrentID] = POLICIES_KEY;
ms_ValueMap[CurrentID] = REGVAL_POL_NOCHANGE_DIRECTSOUND;
CurrentID = IDC_PREVENT_THE_USER_FROM_USING_AUDIO;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[ CurrentID ] = POLICIES_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_POL_NO_AUDIO;
CurrentID = IDC_DISABLE_FULL_DUPLEX_AUDIO;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[ CurrentID ] = POLICIES_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_POL_NO_FULLDUPLEX;
// Video
CurrentID = IDC_DISABLE_SENDING_VIDEO;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[ CurrentID ] = POLICIES_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_POL_NO_VIDEO_SEND;
CurrentID = IDC_DISABLE_RECIEVING_VIDEO;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[ CurrentID ] = POLICIES_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_POL_NO_VIDEO_RECEIVE;
// Notifications
//
// REMOTE OLDER WARNING is GONE
//
CurrentID = IDC_REQUIRE_COMPLETE_AUTHENTICATION;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_LOCAL_MACHINE;
ms_KeyMap[ CurrentID ] = POLICIES_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_POL_NO_INCOMPLETE_CERTS;
CurrentID = IDC_EDIT_SET_RDN_FOR_REQUIRED_CA;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_LOCAL_MACHINE;
ms_KeyMap[ CurrentID ] = POLICIES_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_POL_ISSUER;
// Directory Services
CurrentID = IDC_ALLOW_USER_TO_USE_DIRECTORY_SERVICES;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[ CurrentID ] = CONFERENCING_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_DONT_LOGON_ULS;
CurrentID = IDC_PREVENT_THE_USER_FROM_ADDING_NEW_SERVERS;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[ CurrentID ] = POLICIES_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_POL_NO_ADDING_NEW_ULS;
// Chat
CurrentID = IDC_DISABLE_CHAT;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[ CurrentID ] = POLICIES_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_POL_NO_CHAT;
// Whiteboard
//
// BOGUS BUGBUG LAURABU
// We have OLD and NEW whiteboard
//
CurrentID = IDC_DISABLE_2XWHITEBOARD;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[ CurrentID ] = POLICIES_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_POL_NO_OLDWHITEBOARD;
CurrentID = IDC_DISABLE_WHITEBOARD;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[ CurrentID ] = POLICIES_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_POL_NO_NEWWHITEBOARD;
// Online Support
CurrentID = IDC_EDIT_SET_URL_FOR_INTERNAL_SUPPORT_PAGE;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[ CurrentID ] = POLICIES_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_POL_INTRANET_SUPPORT_URL;
CurrentID = IDC_SHOW_THE_ONLINE_SUPPORT_PAGE_THE_FIRST_TIME_NETMEETING_STARTS;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[ CurrentID ] = POLICIES_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_POL_SHOW_FIRST_TIME_URL;
// Options Dialog
CurrentID = IDC_DISABLE_THE_GENERAL_OPTIONS_PAGE;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[ CurrentID ] = POLICIES_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_POL_NO_GENERALPAGE;
CurrentID = IDC_DISABLE_THE_ADVANCED_CALLING_BUTTON;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[ CurrentID ] = POLICIES_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_POL_NO_ADVANCEDCALLING;
CurrentID = IDC_DISABLE_THE_SECURITY_OPTIONS_PAGE;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[ CurrentID ] = POLICIES_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_POL_NO_SECURITYPAGE;
CurrentID = IDC_DISABLE_THE_AUDIO_OPTIONS_PAGE;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[ CurrentID ] = POLICIES_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_POL_NO_AUDIOPAGE;
CurrentID = IDC_DISABLE_THE_VIDEO_OPTIONS_PAGE;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[ CurrentID ] = POLICIES_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_POL_NO_VIDEOPAGE;
CurrentID = IDC_DISABLE_AUTOACCEPT;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[ CurrentID ] = POLICIES_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_POL_NO_AUTOACCEPTCALLS;
CurrentID = IDC_PERSIST_AUTOACCEPT;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[ CurrentID ] = POLICIES_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_POL_PERSIST_AUTOACCEPTCALLS;
// Security RADIO Options
CurrentID = IDC_RADIO_SECURITY_DEFAULT;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[ CurrentID ] = POLICIES_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_POL_SECURITY;
CurrentID = IDC_RADIO_SECURITY_REQUIRED;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[ CurrentID ] = POLICIES_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_POL_SECURITY;
CurrentID = IDC_RADIO_SECURITY_DISABLED;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[ CurrentID ] = POLICIES_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_POL_SECURITY;
// Call mode RADIO options
CurrentID = IDC_RADIO_CALLMODE_DIRECT;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[ CurrentID ] = CONFERENCING_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_CALLING_MODE;
CurrentID = IDC_RADIO_CALLMODE_GATEKEEPER;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[ CurrentID ] = CONFERENCING_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_CALLING_MODE;
// Gateway
CurrentID = IDC_CHECK_GATEWAY;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[ CurrentID ] = CONFERENCING_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_USE_H323_GATEWAY;
CurrentID = IDC_EDIT_GATEWAY;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[ CurrentID ] = CONFERENCING_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_H323_GATEWAY;
// Gatekeeper addressing RADIO options
CurrentID = IDC_RADIO_GKMODE_ACCOUNT;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[ CurrentID ] = CONFERENCING_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_GK_METHOD;
CurrentID = IDC_RADIO_GKMODE_PHONE;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[ CurrentID ] = CONFERENCING_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_GK_METHOD;
CurrentID = IDC_RADIO_GKMODE_BOTH;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[ CurrentID ] = CONFERENCING_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_GK_METHOD;
CurrentID = IDC_EDIT_GATEKEEPER;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[ CurrentID ] = CONFERENCING_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_GK_SERVER;
CurrentID = IDC_CHECK_NOCHANGECALLMODE;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[ CurrentID ] = POLICIES_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_POL_NOCHANGECALLMODE;
// AV Throughput
CurrentID = IDC_SLIDE_AV_THROUGHPUT;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[ CurrentID ] = POLICIES_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_POL_MAX_BANDWIDTH;
// AutoConf
CurrentID = IDC_CHECK_AUTOCONFIG_CLIENTS;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[ CurrentID ] = POLICIES_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_AUTOCONF_USE;
CurrentID = IDC_AUTOCONF_URL;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[ CurrentID ] = POLICIES_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_AUTOCONF_CONFIGFILE;
// Network Speed RADIO options
CurrentID = IDC_RADIO_NETSPEED_144;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[ CurrentID ] = AUDIO_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_TYPICALBANDWIDTH;
CurrentID = IDC_RADIO_NETSPEED_288;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[ CurrentID ] = AUDIO_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_TYPICALBANDWIDTH;
CurrentID = IDC_RADIO_NETSPEED_ISDN;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[ CurrentID ] = AUDIO_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_TYPICALBANDWIDTH;
CurrentID = IDC_RADIO_NETSPEED_LAN;
ms_ClassMap[ CurrentID ] = CPolicyData::eKeyType_HKEY_CURRENT_USER;
ms_KeyMap[ CurrentID ] = AUDIO_KEY;
ms_ValueMap[ CurrentID ] = REGVAL_TYPICALBANDWIDTH;
}
BOOL CPropertyDataWindow2::WriteToINF( HANDLE hFile, BOOL bCheckValues )
{
list< UINT > condList;
list< CControlID *>::const_iterator it;
_WriteChecksToINF( hFile, bCheckValues );
for( it = m_condList.begin(); it != m_condList.end(); it++ )
{
if( ms_ValueMap.find( (*it)->GetCondID() ) != ms_ValueMap.end() )
{
list< UINT >::const_iterator i;
if( (i = find( condList.begin(), condList.end(), (*it)->GetCondID() ) ) == condList.end() )
{
condList.push_front( (*it)->GetCondID() );
_WriteCheckToINF( hFile, (*it)->GetCondID(), bCheckValues );
}
}
if( bCheckValues)
{
bCheckValues = Button_GetCheck( (*it)->GetCondHwnd() );
}
switch( (*it)->GetType() )
{
case CControlID::STATIC:
break;
case CControlID::EDIT_NUM:
if( ms_ValueMap.find( (*it)->GetID() ) != ms_ValueMap.end() )
{
_WriteEditNumToINF( hFile, (*it)->GetID(), bCheckValues );
}
break;
case CControlID::EDIT:
if( ms_ValueMap.find( (*it)->GetID() ) != ms_ValueMap.end() )
{
_WriteEditToINF( hFile, (*it)->GetID(), bCheckValues );
}
break;
case CControlID::CHECK:
if( ms_ValueMap.find( (*it)->GetID() ) != ms_ValueMap.end() )
{
_WriteCheckToINF( hFile, (*it)->GetID(), bCheckValues );
}
break;
case CControlID::COMBO:
if( ms_ValueMap.find( (*it)->GetID() ) != ms_ValueMap.end() )
{
_WriteComboToINF( hFile, (*it)->GetID(), bCheckValues );
}
break;
case CControlID::SLIDER:
if( ms_ValueMap.find( (*it)->GetID() ) != ms_ValueMap.end() )
{
_WriteSliderToINF( hFile, (*it)->GetID(), bCheckValues );
}
break;
default:
OutputDebugString( TEXT("CPropertyDataWindow2::WriteToINF: unknown CControlID::type\n") );
assert( 0 );
break;
}
}
for( it = m_specialControlList.begin(); it != m_specialControlList.end(); it++ )
{
switch( (*it)->GetType() )
{
case CControlID::STATIC:
break;
case CControlID::EDIT_NUM:
if( ms_ValueMap.find( (*it)->GetID() ) != ms_ValueMap.end() )
{
_WriteEditNumToINF( hFile, (*it)->GetID(), bCheckValues );
}
break;
case CControlID::EDIT:
if( ms_ValueMap.find( (*it)->GetID() ) != ms_ValueMap.end() )
{
_WriteEditToINF( hFile, (*it)->GetID(), bCheckValues );
}
break;
case CControlID::CHECK:
if( ms_ValueMap.find( (*it)->GetID() ) != ms_ValueMap.end() )
{
_WriteCheckToINF( hFile, (*it)->GetID(), bCheckValues );
}
break;
case CControlID::COMBO:
if( ms_ValueMap.find( (*it)->GetID() ) != ms_ValueMap.end() )
{
_WriteComboToINF( hFile, (*it)->GetID(), bCheckValues );
}
break;
case CControlID::SLIDER:
if( ms_ValueMap.find( (*it)->GetID() ) != ms_ValueMap.end() )
{
_WriteSliderToINF( hFile, (*it)->GetID(), bCheckValues );
}
break;
default:
OutputDebugString( TEXT("CPropertyDataWindow2::WriteToINF: unknown CControlID::type\n") );
assert( 0 );
break;
}
}
return TRUE;
}
void CPropertyDataWindow2::_WriteCheckToINF( HANDLE hFile, UINT ID, BOOL bCheckValues )
{
HWND hwndButton;
BOOL fIsRadioButton;
DWORD dwWrite;
hwndButton = GetDlgItem(m_hwnd, ID);
switch (GetWindowLong(hwndButton, GWL_STYLE) & 0x0F)
{
case BS_RADIOBUTTON:
case BS_AUTORADIOBUTTON:
fIsRadioButton = TRUE;
break;
default:
fIsRadioButton = FALSE;
break;
}
if (bCheckValues && Button_GetCheck(hwndButton))
{
if (fIsRadioButton)
{
//
// For radio buttons, real value is in user data
//
dwWrite = GetWindowLong(hwndButton, GWL_USERDATA);
}
else
{
dwWrite = TRUE;
}
CPolicyData(ms_ClassMap[ID], ms_KeyMap[ID], ms_ValueMap[ID], dwWrite).
SaveToINFFile(hFile);
}
else
{
//
// If this is a radio button, do not write the unchecked ones out.
//
if (!fIsRadioButton)
{
dwWrite = FALSE;
CPolicyData(ms_ClassMap[ ID ],
ms_KeyMap[ ID ],
ms_ValueMap[ ID ],
dwWrite).SaveToINFFile( hFile );
}
}
}
void CPropertyDataWindow2::_WriteChecksToINF( HANDLE hFile, BOOL bCheckValues )
{
list< UINT >::const_iterator it;
for (it = m_checkIDList.begin(); it != m_checkIDList.end(); it++)
{
if (ms_ValueMap.find(*it) != ms_ValueMap.end())
{
_WriteCheckToINF(hFile, *it, bCheckValues);
}
}
}
void CPropertyDataWindow2::_WriteEditNumToINF( HANDLE hFile, UINT EditID, BOOL bCheckValues )
{
if( bCheckValues )
{
CPolicyData( ms_ClassMap[ EditID ],
ms_KeyMap[ EditID ],
ms_ValueMap[ EditID ],
(DWORD) GetDlgItemInt( m_hwnd, EditID, NULL, FALSE ) ).SaveToINFFile( hFile );
}
else
{
_DeleteKey( hFile, EditID );
}
}
void CPropertyDataWindow2::_WriteEditToINF( HANDLE hFile, UINT EditID, BOOL bCheckValues )
{
if( bCheckValues )
{
int iLen = GetEditDataLen( EditID ) + 1;
LPTSTR szData = new TCHAR[ iLen ];
GetEditData( EditID, szData, iLen );
CPolicyData( ms_ClassMap[ EditID ],
ms_KeyMap[ EditID ],
ms_ValueMap[ EditID ],
szData ).SaveToINFFile( hFile );
delete [] szData;
}
else
{
_DeleteKey( hFile, EditID );
}
}
void CPropertyDataWindow2::_WriteSliderToINF( HANDLE hFile, UINT SliderID, BOOL bCheckValues )
{
if( bCheckValues )
{
int iPos;
iPos = TrackBar_GetPos(GetDlgItem(m_hwnd, SliderID));
iPos *= 1000;
CPolicyData( ms_ClassMap[ SliderID ],
ms_KeyMap[ SliderID ],
ms_ValueMap[ SliderID ],
(DWORD)iPos
).SaveToINFFile( hFile );
}
else
{
_DeleteKey( hFile, SliderID );
}
}
void CPropertyDataWindow2::_WriteComboToINF( HANDLE hFile, UINT ComboID, BOOL bCheckValues )
{
if( bCheckValues )
{
HWND hwndCombo = GetDlgItem( m_hwnd, ComboID );
CPolicyData( ms_ClassMap[ ComboID ],
ms_KeyMap[ ComboID ],
ms_ValueMap[ ComboID ],
(DWORD) ComboBox_GetItemData( hwndCombo, ComboBox_GetCurSel( hwndCombo ) )
).SaveToINFFile( hFile );
}
else
{
_DeleteKey( hFile, ComboID );
}
}
void CPropertyDataWindow2::_DeleteKey( HANDLE hFile, UINT ID )
{
CPolicyData( ms_ClassMap[ ID ],
ms_KeyMap[ ID ],
ms_ValueMap[ ID ],
CPolicyData::OpDelete()
).SaveToINFFile( hFile );
}
int CPropertyDataWindow2::Spew( HWND hwndList, int iStartLine )
{
list< UINT >::const_iterator it;
for( it = m_checkIDList.begin(); it != m_checkIDList.end(); it++ )
{
if( Button_GetCheck( GetDlgItem( m_hwnd, *it ) ) )
{
HWND hwndButton = GetDlgItem( m_hwnd, *it );
// 2 is 1 for '\0' and 1 for '\t'
int iButtonTextLen = Button_GetTextLength( hwndButton ) + 2;
LPTSTR szButtonText = new TCHAR[ iButtonTextLen ];
szButtonText[0] = '\t';
Button_GetText( hwndButton, &(szButtonText[1]), iButtonTextLen - 1 );
ListBox_InsertString( hwndList, iStartLine, szButtonText );
iStartLine++;
}
}
list< CControlID *>::const_iterator i;
if( m_condList.size() )
{
for( i = m_condList.begin(); i != m_condList.end(); i++ )
{
if( Button_GetCheck( (*i)->GetCondHwnd() ) )
{
iStartLine = _Spew( hwndList, iStartLine, *i );
}
}
}
if( m_specialControlList.size() )
{
for( i = m_specialControlList.begin(); i != m_specialControlList.end(); i++ )
{
iStartLine = _Spew( hwndList, iStartLine, *i );
}
}
return iStartLine;
}
int CPropertyDataWindow2::_Spew( HWND hwndList, int iStartLine, CControlID *pControlID )
{
switch( pControlID->GetType() )
{
case CControlID::EDIT_NUM:
case CControlID::EDIT:
{
int iEditLen = GetEditDataLen( pControlID->GetID() ) + 1;
if( iEditLen )
{
int iLen = Button_GetTextLength( pControlID->GetCondHwnd() ) + 1;
LPTSTR sz = new TCHAR[ iLen];
Button_GetText( pControlID->GetCondHwnd(), sz, iLen );
LPTSTR szData = new TCHAR[ iEditLen];
GetEditData( pControlID->GetID(), szData, iEditLen );
// 2 is: 1 for ' ' and 1 for '\t'
LPTSTR szBuff = new TCHAR[ iLen + iEditLen + 2];
wsprintf( szBuff, TEXT("\t%s %s"), sz, szData );
ListBox_InsertString( hwndList, iStartLine, szBuff );
iStartLine++;
delete [] szData;
delete [] szBuff;
delete [] sz;
}
break;
}
case CControlID::CHECK:
{
HWND hwnd = GetDlgItem( m_hwnd, pControlID->GetID() );
if( Button_GetCheck( hwnd ) )
{
int iLen = Button_GetTextLength( hwnd ) + 2;
LPTSTR sz = new TCHAR[ iLen];
sz[0] = '\t';
Button_GetText( hwnd, &sz[1], iLen );
ListBox_InsertString( hwndList, iStartLine, sz );
iStartLine++;
delete [] sz;
}
break;
}
case CControlID::COMBO:
{
HWND hwnd = GetDlgItem( m_hwnd, pControlID->GetID() );
int iCurSel = ComboBox_GetCurSel( hwnd );
int iLen = ComboBox_GetLBTextLen( hwnd, iCurSel ) + 2;
LPTSTR sz = new TCHAR[ iLen ];
sz[0] = '\t';
ComboBox_GetLBText( hwnd, iCurSel, &(sz[1]) );
ListBox_InsertString( hwndList, iStartLine, sz );
iStartLine++;
delete [] sz;
break;
}
case CControlID::SLIDER:
{
HWND hwnd = GetDlgItem( m_hwnd, pControlID->GetID() );
TCHAR sz[ MAX_DIGITS ];
wsprintf( sz, TEXT("\t%d kbits/s"), TrackBar_GetPos( hwnd ) );
ListBox_InsertString( hwndList, iStartLine, sz );
iStartLine++;
break;
}
case CControlID::STATIC:
break;
default:
OutputDebugString( TEXT("CPropertyDataWindow2::_Spew: unknown CControlID::type\n") );
assert( 0 );
break;
}
return iStartLine;
}