Index: boot/bootdata/hivedef.inf =================================================================== --- boot/bootdata/hivedef.inf (revision 66624) +++ boot/bootdata/hivedef.inf (working copy) @@ -1842,6 +1842,7 @@ HKCU,"SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced","ListviewShadow",0x00010001,0x00000001 HKCU,"SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced","HideFileExt",0x00010001,0x00000000 HKCU,"SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced","StartMenuLogoff",0x00010001,0x00000001 +HKCU,"SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced","Hidden",0x00010003,1 ; default shell HKCU,"SOFTWARE\Microsoft\Windows NT\CurrentVersion\Winlogon",,0x00000012 Index: dll/win32/shell32/CDefView.cpp =================================================================== --- dll/win32/shell32/CDefView.cpp (revision 66342) +++ dll/win32/shell32/CDefView.cpp (working copy) @@ -860,16 +860,34 @@ HRESULT CDefView::FillList() { CComPtr pEnumIDList; - PITEMID_CHILD pidl; - DWORD dwFetched; - HRESULT hRes; - HDPA hdpa; + PITEMID_CHILD pidl; + DWORD dwFetched; + HRESULT hRes; + HDPA hdpa; + HKEY hKey; + DWORD dFlags = SHCONTF_NONFOLDERS | SHCONTF_FOLDERS; TRACE("%p\n", this); - /* get the itemlist from the shfolder*/ - /* FIXME: make showing hidden files a setting. */ - hRes = m_pSFParent->EnumObjects(m_hWnd, SHCONTF_NONFOLDERS | SHCONTF_FOLDERS | SHCONTF_INCLUDEHIDDEN, &pEnumIDList); + /* determine if there is a setting to show all the hidden files/folders */ + if (RegOpenKeyExW(HKEY_CURRENT_USER, L"Software\\Microsoft\\Windows\\CurrentVersion\\Explorer\\Advanced", 0, KEY_QUERY_VALUE, &hKey) == ERROR_SUCCESS) + { + DWORD dataLength, flagVal; + + dataLength = sizeof(flagVal); + if (RegQueryValueExW(hKey, L"Hidden", NULL, NULL, (LPBYTE)&flagVal, &dataLength) == ERROR_SUCCESS) + { + /* if the value is 1, then show all hidden files/folders */ + if (flagVal == 1) + dFlags |= SHCONTF_INCLUDEHIDDEN; + } + + /* close the key */ + RegCloseKey(hKey); + } + + /* get the itemlist from the shfolder */ + hRes = m_pSFParent->EnumObjects(m_hWnd, dFlags, &pEnumIDList); if (hRes != S_OK) { if (hRes == S_FALSE)