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.
579 lines
14 KiB
579 lines
14 KiB
/*******************************************************************************
|
|
*
|
|
* (C) COPYRIGHT MICROSOFT CORP., 1993-1995
|
|
* TITLE: BNDWIDTH.CPP
|
|
* VERSION: 1.0
|
|
* AUTHOR: jsenior
|
|
* DATE: 10/28/1998
|
|
*
|
|
********************************************************************************
|
|
*
|
|
* CHANGE LOG:
|
|
*
|
|
* DATE REV DESCRIPTION
|
|
* ---------- ------- ----------------------------------------------------------
|
|
* 10/28/1998 jsenior Original implementation.
|
|
*
|
|
*******************************************************************************/
|
|
#include "resource.h"
|
|
#include "itemfind.h"
|
|
#include "debug.h"
|
|
#include "powrpage.h"
|
|
#include "bandpage.h"
|
|
#include "usbapp.h"
|
|
#include <cpl.h>
|
|
#include <dbt.h>
|
|
|
|
#define WINDOWSCALEFACTOR 15
|
|
|
|
UINT CALLBACK
|
|
UsbApplet::StaticDialogCallback(HWND Hwnd,
|
|
UINT Msg,
|
|
LPPROPSHEETPAGE Page)
|
|
{
|
|
/* UsbApplet *that;
|
|
|
|
switch (Msg) {
|
|
case PSPCB_CREATE:
|
|
return TRUE; // return TRUE to continue with creation of page
|
|
|
|
case PSPCB_RELEASE:
|
|
that = (UsbPopup*) Page->lParam;
|
|
DeleteChunk(that);
|
|
delete that;
|
|
|
|
return 0; // return value ignored
|
|
|
|
default:
|
|
break;
|
|
}
|
|
*/
|
|
return TRUE;
|
|
}
|
|
|
|
BOOL
|
|
UsbApplet::CustomDialog()
|
|
{
|
|
InitCommonControls();
|
|
if (NULL == (hSplitCursor = LoadCursor(gHInst, MAKEINTRESOURCE(IDC_SPLIT)))) {
|
|
return FALSE;
|
|
}
|
|
|
|
if (-1 == DialogBoxParam(gHInst,
|
|
MAKEINTRESOURCE(IDD_CPL_USB),
|
|
NULL,
|
|
StaticDialogProc,
|
|
(LPARAM) this)) {
|
|
return FALSE;
|
|
}
|
|
return TRUE;
|
|
}
|
|
|
|
USBINT_PTR APIENTRY UsbApplet::StaticDialogProc(IN HWND hDlg,
|
|
IN UINT uMessage,
|
|
IN WPARAM wParam,
|
|
IN LPARAM lParam)
|
|
{
|
|
UsbApplet *that;
|
|
|
|
that = (UsbApplet *) UsbGetWindowLongPtr(hDlg, USBDWLP_USER);
|
|
|
|
if (!that && uMessage != WM_INITDIALOG)
|
|
return FALSE; //DefDlgProc(hDlg, uMessage, wParam, lParam);
|
|
|
|
switch (uMessage) {
|
|
|
|
HANDLE_MSG(hDlg, WM_SIZE, that->OnSize);
|
|
HANDLE_MSG(hDlg, WM_LBUTTONDOWN, that->OnLButtonDown);
|
|
HANDLE_MSG(hDlg, WM_LBUTTONUP, that->OnLButtonUp);
|
|
HANDLE_MSG(hDlg, WM_MOUSEMOVE, that->OnMouseMove);
|
|
HANDLE_MSG(hDlg, WM_CLOSE, that->OnClose);
|
|
HANDLE_MSG(hDlg, WM_NOTIFY, that->OnNotify);
|
|
|
|
case WM_DEVICECHANGE:
|
|
return that->OnDeviceChange(hDlg, (UINT)wParam, (DWORD)wParam);
|
|
|
|
case WM_COMMAND:
|
|
return that->OnCommand(HIWORD(wParam),
|
|
LOWORD(wParam),
|
|
(HWND) lParam);
|
|
|
|
case USBWM_NOTIFYREFRESH:
|
|
return that->Refresh();
|
|
case WM_INITDIALOG:
|
|
that = (UsbApplet *) lParam;
|
|
UsbSetWindowLongPtr(hDlg, USBDWLP_USER, (USBLONG_PTR) that);
|
|
that->hMainWnd = hDlg;
|
|
|
|
return that->OnInitDialog(hDlg);
|
|
|
|
default:
|
|
break;
|
|
}
|
|
|
|
return that->ActualDialogProc(hDlg, uMessage, wParam, lParam);
|
|
}
|
|
|
|
LRESULT
|
|
UsbApplet::OnDeviceChange(HWND hWnd, UINT wParam, DWORD lParam)
|
|
{
|
|
if ((wParam == DBT_DEVICEARRIVAL) ||
|
|
(wParam == DBT_DEVICEREMOVECOMPLETE)) {
|
|
Refresh();
|
|
}
|
|
return TRUE;
|
|
}
|
|
|
|
BOOL
|
|
UsbApplet::OnCommand(INT wNotifyCode,
|
|
INT wID,
|
|
HWND hCtl)
|
|
{
|
|
/* switch (wID) {
|
|
case IDOK:
|
|
EndDialog(hWnd, wID);
|
|
return TRUE;
|
|
}*/
|
|
return FALSE;
|
|
}
|
|
|
|
BOOL
|
|
UsbApplet::OnInitDialog(HWND HWnd)
|
|
{
|
|
hMainWnd = HWnd;
|
|
RECT rc;
|
|
HICON hIcon = LoadIcon(gHInst, MAKEINTRESOURCE(IDI_USB));
|
|
if (hIcon) {
|
|
SendMessage(HWnd, WM_SETICON, ICON_BIG, (LPARAM)hIcon);
|
|
SendMessage(HWnd, WM_SETICON, ICON_SMALL, (LPARAM)hIcon);
|
|
}
|
|
|
|
//
|
|
// Get a persistent handle to the tree view control
|
|
//
|
|
if (NULL == (hTreeDevices = GetDlgItem(HWnd, IDC_TREE_USB)) ||
|
|
NULL == (hEditControl = GetDlgItem(HWnd, IDC_EDIT1))) {
|
|
return FALSE;
|
|
}
|
|
|
|
TreeView_SetImageList(hTreeDevices, ImageList.ImageList(), TVSIL_NORMAL);
|
|
|
|
GetWindowRect(HWnd, &rc);
|
|
barLocation = (rc.right - rc.left) / 3;
|
|
ResizeWindows(HWnd, FALSE, 0);
|
|
|
|
if (!Refresh()) {
|
|
return FALSE;
|
|
}
|
|
|
|
//
|
|
// Everything seems to be working fine; let's register for device change
|
|
// notification
|
|
//
|
|
return RegisterForDeviceNotification(HWnd);
|
|
}
|
|
|
|
BOOL
|
|
UsbApplet::RegisterForDeviceNotification(HWND hWnd)
|
|
{
|
|
DEV_BROADCAST_DEVICEINTERFACE dbc;
|
|
|
|
memset(&dbc, 0, sizeof(DEV_BROADCAST_DEVICEINTERFACE));
|
|
dbc.dbcc_size = sizeof(DEV_BROADCAST_DEVICEINTERFACE);
|
|
dbc.dbcc_devicetype = DBT_DEVTYP_DEVICEINTERFACE;
|
|
dbc.dbcc_classguid = GUID_CLASS_USBHUB;
|
|
hDevNotify = RegisterDeviceNotification(hWnd,
|
|
&dbc,
|
|
DEVICE_NOTIFY_WINDOW_HANDLE);
|
|
if (!hDevNotify) {
|
|
return FALSE;
|
|
}
|
|
return TRUE;
|
|
}
|
|
|
|
HTREEITEM
|
|
UsbApplet::InsertRoot(LPTV_INSERTSTRUCT item,
|
|
UsbItem *firstController)
|
|
{
|
|
HTREEITEM hItem;
|
|
|
|
ZeroMemory(item, sizeof(TV_INSERTSTRUCT));
|
|
|
|
// Get the image index
|
|
|
|
item->hParent = NULL;
|
|
item->hInsertAfter = TVI_LAST;
|
|
item->item.mask = TVIF_TEXT | TVIF_PARAM | TVIF_IMAGE | TVIF_SELECTEDIMAGE | TVIF_STATE; // TVIF_CHILDREN
|
|
|
|
// item->itemex.state = TVIS_BOLD;
|
|
item->itemex.state |= TVIS_EXPANDED;
|
|
item->itemex.stateMask = (UINT)~(TVIS_STATEIMAGEMASK | TVIS_OVERLAYMASK);
|
|
item->itemex.pszText = TEXT("My Computer");
|
|
item->itemex.cchTextMax = _tcsclen(TEXT("My Computer"));
|
|
item->itemex.iImage = 0;
|
|
item->itemex.iSelectedImage = 0;
|
|
if (firstController) {
|
|
item->itemex.cChildren = 1;
|
|
}
|
|
//
|
|
// We will be able to recognize this from usbitems because we assign it the
|
|
// lParam value INVALID_HANDLE_VALUE instead of the address of a valid
|
|
// usbItem. Cunning, no? Ok, not really...
|
|
//
|
|
item->itemex.lParam = (LPARAM) INVALID_HANDLE_VALUE;
|
|
|
|
if (NULL == (hItem = (HTREEITEM)
|
|
SendMessage(hTreeDevices,
|
|
TVM_INSERTITEM,
|
|
0,
|
|
(LPARAM)(LPTV_INSERTSTRUCT)item))) {
|
|
int i = GetLastError();
|
|
}
|
|
return hItem;
|
|
}
|
|
|
|
BOOL
|
|
UsbApplet::Refresh()
|
|
{
|
|
TV_INSERTSTRUCT item;
|
|
UsbItem deviceItem;
|
|
HTREEITEM hTreeRoot = NULL;
|
|
|
|
// CWaitCursor wait;
|
|
|
|
//
|
|
// Clear all UI components, and then recreate the rootItem
|
|
//
|
|
TreeView_DeleteAllItems(hTreeDevices);
|
|
if (rootItem) {
|
|
DeleteChunk(rootItem);
|
|
delete rootItem;
|
|
}
|
|
rootItem = new UsbItem;
|
|
if (!rootItem) {
|
|
goto UsbAppletRefreshError;
|
|
}
|
|
|
|
AddChunk(rootItem);
|
|
|
|
if (!rootItem->EnumerateAll(&ImageList)) {
|
|
goto UsbAppletRefreshError;
|
|
}
|
|
|
|
hTreeRoot = InsertRoot(&item, rootItem->child);
|
|
|
|
if (rootItem->child) {
|
|
return UsbItem::InsertTreeItem (hTreeDevices,
|
|
rootItem->child,
|
|
hTreeRoot,
|
|
&item,
|
|
IsValid,
|
|
IsBold,
|
|
IsExpanded);
|
|
}
|
|
return TRUE;
|
|
UsbAppletRefreshError:
|
|
return FALSE;
|
|
}
|
|
|
|
VOID
|
|
UsbApplet::OnSize (HWND hWnd,
|
|
UINT state,
|
|
int cx,
|
|
int cy)
|
|
{
|
|
ResizeWindows(hWnd, FALSE, 0);
|
|
}
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// ResizeWindows()
|
|
//
|
|
// Handles resizing the two child windows of the main window. If
|
|
// bSizeBar is true, then the sizing is happening because the user is
|
|
// moving the bar. If bSizeBar is false, the sizing is happening
|
|
// because of the WM_SIZE or something like that.
|
|
//
|
|
//*****************************************************************************
|
|
|
|
VOID
|
|
UsbApplet::ResizeWindows (HWND hWnd,
|
|
BOOL bSizeBar,
|
|
int BarLocation)
|
|
{
|
|
RECT MainClientRect;
|
|
RECT MainWindowRect;
|
|
RECT TreeWindowRect;
|
|
// RECT StatusWindowRect;
|
|
int right;
|
|
|
|
// Is the user moving the bar?
|
|
//
|
|
if (!bSizeBar)
|
|
{
|
|
BarLocation = barLocation;
|
|
}
|
|
|
|
GetClientRect(hWnd, &MainClientRect);
|
|
|
|
// GetWindowRect(ghStatusWnd, &StatusWindowRect);
|
|
|
|
// Make sure the bar is in a OK location
|
|
//
|
|
if (bSizeBar)
|
|
{
|
|
if (BarLocation <
|
|
GetSystemMetrics(SM_CXSCREEN)/WINDOWSCALEFACTOR)
|
|
{
|
|
return;
|
|
}
|
|
|
|
if ((MainClientRect.right - BarLocation) <
|
|
GetSystemMetrics(SM_CXSCREEN)/WINDOWSCALEFACTOR)
|
|
{
|
|
return;
|
|
}
|
|
}
|
|
|
|
// Save the bar location
|
|
//
|
|
barLocation = BarLocation;
|
|
|
|
// Move the tree window
|
|
//
|
|
MoveWindow(hTreeDevices,
|
|
0,
|
|
0,
|
|
BarLocation,
|
|
MainClientRect.bottom,// - StatusWindowRect.bottom + StatusWindowRect.top,
|
|
TRUE);
|
|
|
|
// Get the size of the window (in case move window failed
|
|
//
|
|
GetWindowRect(hTreeDevices, &TreeWindowRect);
|
|
GetWindowRect(hWnd, &MainWindowRect);
|
|
|
|
right = TreeWindowRect.right - MainWindowRect.left;
|
|
|
|
// Move the edit window with respect to the tree window
|
|
//
|
|
MoveWindow(hEditControl,
|
|
right,
|
|
0,
|
|
MainClientRect.right-(right),
|
|
MainClientRect.bottom, // - StatusWindowRect.bottom + StatusWindowRect.top,
|
|
TRUE);
|
|
if (propPage) {
|
|
propPage->SizeWindow(right,
|
|
0,
|
|
MainClientRect.right-(right),
|
|
MainClientRect.bottom);
|
|
}
|
|
|
|
// Move the Status window with respect to the tree window
|
|
//
|
|
/* MoveWindow(ghStatusWnd,
|
|
0,
|
|
MainClientRect.bottom - StatusWindowRect.bottom + StatusWindowRect.top,
|
|
MainClientRect.right,
|
|
StatusWindowRect.bottom - StatusWindowRect.top,
|
|
TRUE);*/
|
|
}
|
|
|
|
VOID
|
|
UsbApplet::OnMouseMove (HWND hWnd,
|
|
int x,
|
|
int y,
|
|
UINT keyFlags)
|
|
{
|
|
SetCursor(hSplitCursor);
|
|
|
|
if (bButtonDown)
|
|
{
|
|
ResizeWindows(hMainWnd, TRUE, x);
|
|
}
|
|
}
|
|
|
|
VOID
|
|
UsbApplet::OnLButtonDown (
|
|
HWND hWnd,
|
|
BOOL fDoubleClick,
|
|
int x,
|
|
int y,
|
|
UINT keyFlags
|
|
)
|
|
{
|
|
bButtonDown = TRUE;
|
|
SetCapture(hMainWnd);
|
|
}
|
|
|
|
VOID
|
|
UsbApplet::OnLButtonUp (
|
|
HWND hWnd,
|
|
int x,
|
|
int y,
|
|
UINT keyFlags
|
|
)
|
|
{
|
|
bButtonDown = FALSE;
|
|
ReleaseCapture();
|
|
}
|
|
|
|
VOID
|
|
UsbApplet::OnClose (HWND hWnd)
|
|
{
|
|
// DestroyTree();
|
|
|
|
if (hDevNotify) {
|
|
UnregisterDeviceNotification(hDevNotify);
|
|
hDevNotify = NULL;
|
|
}
|
|
|
|
PostQuitMessage(0);
|
|
|
|
EndDialog(hMainWnd, 0);
|
|
}
|
|
|
|
LRESULT
|
|
UsbApplet::OnNotify (
|
|
HWND hWnd,
|
|
int DlgItem,
|
|
LPNMHDR lpNMHdr
|
|
)
|
|
{
|
|
switch(lpNMHdr->code){
|
|
case TVN_SELCHANGED: {
|
|
UsbItem *usbItem;
|
|
// HTREEITEM hTreeItem;
|
|
|
|
// hTreeItem = ((NM_TREEVIEW *)lpNMHdr)->itemNew.hItem;
|
|
usbItem = (UsbItem*) ((NM_TREEVIEW *)lpNMHdr)->itemNew.lParam;
|
|
|
|
if (usbItem)
|
|
{
|
|
UpdateEditControl((UsbItem *) usbItem);
|
|
}
|
|
SetActiveWindow(hTreeDevices);
|
|
}
|
|
case LVN_KEYDOWN: {
|
|
LPNMLVKEYDOWN pKey = (LPNMLVKEYDOWN) lpNMHdr;
|
|
if (VK_F5 == pKey->wVKey) {
|
|
return Refresh();
|
|
}
|
|
}
|
|
case TVN_KEYDOWN: {
|
|
LPNMTVKEYDOWN pKey = (LPNMTVKEYDOWN) lpNMHdr;
|
|
if (VK_F5 == pKey->wVKey) {
|
|
return Refresh();
|
|
}
|
|
}
|
|
/* case NM_KEYDOWN: {
|
|
LPNMKEY pKey = (LPNMKEY) lpNMHdr;
|
|
if (VK_F5 == pKey->nVKey) {
|
|
return Refresh();
|
|
}
|
|
}*/
|
|
/* if (DlgItem == IDC_TREE_USB &&
|
|
lpNMHdr->code == NM_RCLICK)
|
|
{
|
|
HMENU hMenu
|
|
CreateMenu();
|
|
|
|
return TRUE;
|
|
}
|
|
*/
|
|
|
|
}
|
|
return 0;
|
|
}
|
|
|
|
VOID
|
|
UsbApplet::UpdateEditControl(UsbItem *usbItem)
|
|
{
|
|
if (propPage) {
|
|
if (propPage->DestroyChild()) {
|
|
delete propPage;
|
|
propPage = NULL;
|
|
}
|
|
}
|
|
|
|
if (usbItem == INVALID_HANDLE_VALUE) {
|
|
propPage = new RootPage(usbItem);
|
|
} else if (usbItem->IsHub()) {
|
|
propPage = new PowerPage(usbItem);
|
|
} else if (usbItem->IsController()) {
|
|
propPage = new BandwidthPage(usbItem);
|
|
} else {
|
|
propPage = new GenericPage(usbItem);
|
|
}
|
|
if (propPage) {
|
|
propPage->CreateAsChild(hMainWnd, hEditControl, usbItem);
|
|
}
|
|
}
|
|
|
|
BOOL
|
|
UsbApplet::IsBold(UsbItem *Item)
|
|
{
|
|
return FALSE;
|
|
}
|
|
|
|
BOOL
|
|
UsbApplet::IsValid(UsbItem *Item)
|
|
{
|
|
return !Item->IsUnusedPort();
|
|
}
|
|
|
|
BOOL
|
|
UsbApplet::IsExpanded(UsbItem *Item)
|
|
{
|
|
if (Item->IsHub() || Item->IsController()) {
|
|
return TRUE;
|
|
}
|
|
return FALSE;
|
|
}
|
|
|
|
extern "C" {
|
|
|
|
LONG APIENTRY
|
|
CPlApplet(HWND hwndCPl,
|
|
UINT uMsg,
|
|
LPARAM lParam1,
|
|
LPARAM lParam2)
|
|
{
|
|
UsbApplet *applet;
|
|
applet = (UsbApplet*) lParam2;
|
|
|
|
switch (uMsg) {
|
|
case CPL_EXIT:
|
|
return 0;
|
|
case CPL_INQUIRE:
|
|
{
|
|
CPLINFO *info = (CPLINFO *) lParam2;
|
|
assert(lParam1 == 0);
|
|
applet = new UsbApplet();
|
|
info->idIcon = IDI_USB;
|
|
info->idName = IDS_USB;
|
|
info->idInfo = IDS_USB;
|
|
info->lData = (USBLONG_PTR) applet;
|
|
return 0;
|
|
}
|
|
case CPL_GETCOUNT:
|
|
return 1;
|
|
case CPL_INIT:
|
|
return TRUE;
|
|
case CPL_DBLCLK:
|
|
assert(lParam1 == 0);
|
|
if (applet->CustomDialog()) {
|
|
return 0;
|
|
}
|
|
return 1;
|
|
case CPL_STOP:
|
|
assert(lParam1 == 0);
|
|
applet->OnClose(hwndCPl);
|
|
delete applet;
|
|
return 0;
|
|
}
|
|
return 0;
|
|
}
|
|
|
|
}
|