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.
 
 
 
 
 
 

175 lines
4.4 KiB

//+---------------------------------------------------------------------------
//
// Microsoft Windows
// Copyright (C) Microsoft Corporation, 1997.
//
// File: O P E N F O L D . C P P
//
// Contents: Folder launching code for the connections folder
//
// Notes:
//
// Author: jeffspr 12 Jan 1998
//
//----------------------------------------------------------------------------
#include "pch.h"
#pragma hdrstop
// Undocument shell32 stuff. Sigh.
#define DONT_WANT_SHELLDEBUG 1
#define NO_SHIDLIST 1
#define USE_SHLWAPI_IDLIST
#include "pidlutil.h"
#include <ncdebug.h>
#define AVOID_NET_CONFIG_DUPLICATES
#include "nsbase.h"
#include "nsres.h"
#include <ncdebug.h>
#include <ncreg.h>
#include <netshell.h>
#include <netconp.h>
#include <ncui.h>
#include "cfpidl.h"
#include "openfold.h"
// Note -- Don't convert this to a constant. We need copies of it within the
// functions because ParseDisplayName actually mangles the string.
//
// CLSID_MyComputer
// CLSID_ControlPanel
// CLSID_NetworkConnections
#define NETCON_FOLDER_PATH L"::{20D04FE0-3AEA-1069-A2D8-08002B30309D}\\" \
L"::{21EC2020-3AEA-1069-A2DD-08002B30309D}\\" \
L"::{7007ACC7-3202-11D1-AAD2-00805FC1270E}";
//+---------------------------------------------------------------------------
//
// Function: HrGetConnectionsFolderPidl
//
// Purpose: Get the connections folder pidl. Used in places where we're
// not folder specific, but we still need to update folder
// entries.
//
// Arguments:
// ppidlFolder [out] Return parameter for the folder pidl
//
// Returns:
//
// Author: jeffspr 13 Jun 1998
//
// Notes:
//
HRESULT HrGetConnectionsFolderPidl(OUT PCONFOLDPIDLFOLDER& ppidlFolder)
{
HRESULT hr = S_OK;
LPSHELLFOLDER pshf = NULL;
LPITEMIDLIST pidlFolder = NULL;
// "::CLSID_MyComputer\\::CLSID_ControlPanel\\::CLSID_ConnectionsFolder"
WCHAR szNetConFoldPath[] = NETCON_FOLDER_PATH;
// Get the desktop folder, so we can parse the display name and get
// the UI object of the connections folder
//
hr = SHGetDesktopFolder(&pshf);
if (SUCCEEDED(hr))
{
ULONG chEaten;
pidlFolder = NULL;
hr = pshf->ParseDisplayName(NULL, 0, (WCHAR *) szNetConFoldPath,
&chEaten, &pidlFolder, NULL);
ReleaseObj(pshf);
}
// If succeeded, fill in the return param.
//
if (SUCCEEDED(hr))
{
hr = ppidlFolder.InitializeFromItemIDList(pidlFolder);
SHFree(pidlFolder); // ISSUE: Why can't we free regardless?
}
TraceHr(ttidShellFolder, FAL, hr, FALSE, "HrGetConnectionsFolderPidl");
return hr;
}
//+---------------------------------------------------------------------------
//
// Function: HrOpenConnectionsFolder
//
// Purpose: Open the connections folder in explorer.
//
// Arguments:
// (none)
//
// Returns:
//
// Author: jeffspr 16 Apr 1998
//
// Notes:
//
HRESULT HrOpenConnectionsFolder()
{
HRESULT hr = S_OK;
HCURSOR hcWait = SetCursor(LoadCursor(NULL, IDC_WAIT));
PCONFOLDPIDLFOLDER pidlFolder;
hr = HrGetConnectionsFolderPidl(pidlFolder);
if (SUCCEEDED(hr))
{
Assert(!pidlFolder.empty());
SHELLEXECUTEINFO shei = { 0 };
shei.cbSize = sizeof(shei);
shei.fMask = SEE_MASK_IDLIST | SEE_MASK_INVOKEIDLIST | SEE_MASK_FLAG_DDEWAIT;
shei.nShow = SW_SHOW; // used to be SW_SHOWNORMAL
shei.lpIDList = const_cast<LPITEMIDLIST>(pidlFolder.GetItemIdList());
ShellExecuteEx(&shei);
}
if (hcWait)
{
SetCursor(hcWait);
}
TraceHr(ttidError, FAL, hr, FALSE, "HrOpenConnectionsFolder");
return hr;
}
HRESULT HrGetConnectionsIShellFolder(
const PCONFOLDPIDLFOLDER& pidlFolder,
LPSHELLFOLDER * ppsf)
{
HRESULT hr = S_OK;
LPSHELLFOLDER psfDesktop = NULL;
Assert(ppsf);
*ppsf = NULL;
// Get the desktop folder so we can use it to retrieve the
// connections folder
//
hr = SHGetDesktopFolder(&psfDesktop);
if (SUCCEEDED(hr))
{
Assert(psfDesktop);
hr = psfDesktop->BindToObject(pidlFolder.GetItemIdList(), NULL, IID_IShellFolder,
(LPVOID*) ppsf);
}
TraceHr(ttidShellFolder, FAL, hr, FALSE, "HrGetConnectionsIShellFolder");
return hr;
}