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.
 
 
 
 
 
 

358 lines
8.1 KiB

//+-------------------------------------------------------------------------
//
// Microsoft Windows
//
// Copyright (C) Microsoft Corporation, 1997 - 1999
//
// File: SnpUtils.cpp
//
//--------------------------------------------------------------------------
#include "stdafx.h"
#include "windowsx.h"
DWORD FormatError(HRESULT hr, TCHAR *pszBuffer, UINT cchBuffer)
{
DWORD dwErr;
// Copy over default message into szBuffer
_tcscpy(pszBuffer, _T("Error"));
// Ok, we can't get the error info, so try to format it
// using the FormatMessage
// Ignore the return message, if this call fails then I don't
// know what to do.
dwErr = FormatMessage(
FORMAT_MESSAGE_FROM_SYSTEM,
NULL,
hr,
0,
pszBuffer,
cchBuffer,
NULL);
pszBuffer[cchBuffer-1] = 0;
return dwErr;
}
///////////////////////////////////////////////////////////////////////////////
// GetErrorMessage
// Format the error message based on the HRESULT
//
// Note: The caller should NOT try to modify the string returned by this function
//
LPCTSTR GetErrorMessage(HRESULT hr)
{
AFX_MANAGE_STATE(AfxGetStaticModuleState());
static CString st;
st = _T("");
if (FAILED(hr))
{
TCHAR szBuffer[2048];
CString stErrCode;
FormatError(hr, szBuffer, DimensionOf(szBuffer));
stErrCode.Format(_T("%08lx"), hr);
AfxFormatString2(st, IDS_ERROR_SYSTEM_ERROR_FORMAT,
szBuffer, (LPCTSTR) stErrCode);
}
return (LPCTSTR)st;
}
void ReportError(UINT uMsgId, HRESULT hr)
{
CString strMessage;
CThemeContextActivator activator;
strMessage.FormatMessage (uMsgId, GetErrorMessage(hr));
AfxMessageBox (strMessage);
}
//Allocate the data buffer for a new Wireless Policy. Fills in
//default values and the GUID identifier.
//The caller needs to call FreeWirelessPolicyData if the return is
//S_OK
HRESULT CreateWirelessPolicyDataBuffer(
PWIRELESS_POLICY_DATA * ppPolicy
)
{
ASSERT(ppPolicy);
HRESULT hr = S_OK;
*ppPolicy = NULL;
PWIRELESS_POLICY_DATA pPolicy = NULL;
pPolicy = (PWIRELESS_POLICY_DATA)AllocPolMem(sizeof(*pPolicy));
if (NULL == pPolicy)
{
return E_OUTOFMEMORY;
}
CoCreateGuid(&pPolicy->PolicyIdentifier);
pPolicy->dwPollingInterval = 10800;
pPolicy->dwDisableZeroConf = 0;
pPolicy->dwNumPreferredSettings = 0;
pPolicy->dwNetworkToAccess = WIRELESS_ACCESS_NETWORK_ANY;
pPolicy->dwConnectToNonPreferredNtwks = 0;
if (FAILED(hr))
{
if (pPolicy)
{
FreePolMem(pPolicy);
}
}
else
{
*ppPolicy = pPolicy;
}
return hr;
}
void FreeAndThenDupString(LPWSTR * ppwszDest, LPCWSTR pwszSource)
{
ASSERT(ppwszDest);
if (*ppwszDest)
FreePolStr(*ppwszDest);
*ppwszDest = AllocPolStr(pwszSource);
}
void SSIDDupString(WCHAR *ppwszDest, LPCWSTR pwszSource)
{
wcsncpy(ppwszDest,pwszSource, 32);
}
BOOL
IsDuplicateSSID(
CString &NewSSID,
DWORD dwNetworkType,
PWIRELESS_POLICY_DATA pWirelessPolicyData,
DWORD dwId
)
{
DWORD dwError = 0;
DWORD dwNumPreferredSettings = 0;
PWIRELESS_PS_DATA pWirelessPSData = NULL;
PWIRELESS_PS_DATA *ppWirelessPSData = NULL;
DWORD i = 0;
BOOL bDuplicate = FALSE;
DWORD dwSSIDLen = 0;
DWORD dwStart = 0;
DWORD dwEnd = 0;
WCHAR pszTempSSID[33];
ppWirelessPSData = pWirelessPolicyData->ppWirelessPSData;
dwNumPreferredSettings = pWirelessPolicyData->dwNumPreferredSettings;
if (dwNetworkType == WIRELESS_NETWORK_TYPE_AP) {
dwStart = 0;
dwEnd = pWirelessPolicyData->dwNumAPNetworks;
} else
{
dwStart = pWirelessPolicyData->dwNumAPNetworks;
dwEnd = pWirelessPolicyData->dwNumPreferredSettings;
}
for (i = dwStart; i < dwEnd ; i++) {
if (i != dwId) {
pWirelessPSData = *(ppWirelessPSData + i);
dwSSIDLen = pWirelessPSData->dwWirelessSSIDLen;
// terminate the pszWirelessSSID to correct length or comparision may fail
// ideally WirelessSSID should be a 33 char unicode string with room for a null
// char in the end. Since, we didnt start with that to begin with,
// As a hack, copy the ssid to a new location with null termination.
wcsncpy(pszTempSSID, pWirelessPSData->pszWirelessSSID, 32);
pszTempSSID[dwSSIDLen] = L'\0';
if (0 == NewSSID.Compare(pszTempSSID)) {
bDuplicate = TRUE;
}
}
}
return (bDuplicate);
}
HRESULT DeleteWirelessPolicy(HANDLE hPolicyStore,
PWIRELESS_POLICY_DATA pPolicy)
{
ASSERT(pPolicy);
HRESULT hr = S_OK;
CWRg(WirelessDeletePolicyData(
hPolicyStore,
pPolicy
));
Error:
return hr;
}
#ifndef PROPSHEETPAGE_LATEST
#ifdef UNICODE
#define PROPSHEETPAGE_LATEST PROPSHEETPAGEW_LATEST
#else
#define PROPSHEETPAGE_LATEST PROPSHEETPAGEA_LATEST
#endif
#endif
HPROPSHEETPAGE MyCreatePropertySheetPage(PROPSHEETPAGE* ppsp)
{
PROPSHEETPAGE_LATEST pspLatest = {0};
CopyMemory (&pspLatest, ppsp, ppsp->dwSize);
pspLatest.dwSize = sizeof(pspLatest);
HPROPSHEETPAGE pProp= ::CreatePropertySheetPage (&pspLatest);
DWORD dwErr = GetLastError();
{
LPVOID lpMsgBuf;
FormatMessage(
FORMAT_MESSAGE_ALLOCATE_BUFFER |
FORMAT_MESSAGE_FROM_SYSTEM |
FORMAT_MESSAGE_IGNORE_INSERTS,
NULL,
dwErr,
MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT), // Default language
(LPTSTR) &lpMsgBuf,
0,
NULL
);
// Free the buffer.
LocalFree( lpMsgBuf );
}
return pProp;
}
void
InitFonts(
HWND hDialog,
HFONT& bigBoldFont)
{
ASSERT(::IsWindow(hDialog));
do
{
NONCLIENTMETRICS ncm;
memset(&ncm, 0, sizeof(ncm));
ncm.cbSize = sizeof(ncm);
if ( FALSE == ::SystemParametersInfo(SPI_GETNONCLIENTMETRICS, 0, &ncm, 0))
{
break;
}
LOGFONT bigBoldLogFont = ncm.lfMessageFont;
bigBoldLogFont.lfWeight = FW_BOLD;
//localize
CString fontName;
fontName.LoadString(IDS_BOLD_FONT_NAME);
// ensure null termination 260237
memset(bigBoldLogFont.lfFaceName, 0, LF_FACESIZE * sizeof(TCHAR));
size_t fnLen = fontName.GetLength();
lstrcpyn(
bigBoldLogFont.lfFaceName, // destination buffer
(LPCTSTR) fontName, // string // don't copy over the last null
min(LF_FACESIZE - 1, fnLen) // number of characters to copy
);
//define font size
CString strTemp;
strTemp.LoadString(IDS_BOLD_FONT_SIZE);
unsigned fontSize = _ttoi( (LPCTSTR) strTemp );
HDC hdc = 0;
hdc = ::GetDC(hDialog);
if ( NULL == hdc )
{
break;
}
bigBoldLogFont.lfHeight =
- ::MulDiv(
static_cast<int>(fontSize),
GetDeviceCaps(hdc, LOGPIXELSY),
72);
bigBoldFont = ::CreateFontIndirect( ( CONST LOGFONT* ) &bigBoldLogFont);
if ( NULL == bigBoldFont )
{
break;
}
ReleaseDC(hDialog, hdc);
}
while (0);
}
void
SetControlFont(HWND parentDialog, int controlID, HFONT font)
{
ASSERT(::IsWindow(parentDialog));
ASSERT(controlID);
ASSERT(font);
HWND control = ::GetDlgItem(parentDialog, controlID);
if (control)
{
SetWindowFont(control, font, TRUE);
}
}
void
SetLargeFont(HWND dialog, int bigBoldResID)
{
ASSERT(::IsWindow(dialog));
ASSERT(bigBoldResID);
static HFONT bigBoldFont = 0;
if (!bigBoldFont)
{
InitFonts(dialog, bigBoldFont);
}
SetControlFont(dialog, bigBoldResID, bigBoldFont);
}