Windows NT 4.0 source code leak
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.
 
 
 
 
 
 

536 lines
11 KiB

/*
* File: open_msc.c - stuff for calling Common Open Dialog
*
* Copyright 1991 by Hilgraeve Inc. -- Monroe, MI
* All rights reserved
*
* $Revision: 1.31 $
* $Date: 1996/08/02 12:04:41 $
*/
#include <windows.h>
#pragma hdrstop
// #define DEBUGSTR 1
#include <commdlg.h>
#include <memory.h>
#include <tdll\stdtyp.h>
#include <term\res.h>
#include <tdll\mc.h>
#include <tdll\tdll.h>
#include <tdll\globals.h>
#include <tdll\file_msc.h>
#include <tdll\load_res.h>
#include <tdll\tchar.h>
#include <tdll\assert.h>
#include <tdll\misc.h>
#include "open_msc.h"
static OPENFILENAME ofn;
/*=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-
* FUNCTION:
*
* DESCRIPTION:
*
* ARGUEMENTS:
*
* RETURNS:
*/
BOOL FAR PASCAL gnrcFindDirHookProc(HWND hdlg,
UINT msg,
WPARAM wPar,
LPARAM lPar)
{
WORD windowID;
windowID = LOWORD(wPar);
switch (msg)
{
case WM_INITDIALOG:
break;
case WM_DESTROY:
break;
case WM_COMMAND:
switch (windowID)
{
case IDOK:
SetDlgItemText(hdlg, edt1, "foo.foo");
// EndDialog(hdlg, 1);
break;
case lst2:
if (HIWORD(lPar) == LBN_DBLCLK)
{
SetFocus(GetDlgItem(hdlg, IDOK));
PostMessage(hdlg,
WM_COMMAND,
IDOK,
MAKELONG((INT)GetDlgItem(hdlg, IDOK),0));
}
break;
default:
break;
}
break;
default:
break;
}
return FALSE;
}
/*=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-
* FUNCTION:
*
* DESCRIPTION:
*
* ARGUEMENTS:
*
* RETURNS:
*/
#if FALSE
BOOL FAR PASCAL gnrcFindFileHookProc(HWND hdlg,
UINT msg,
WPARAM wPar,
LPARAM lPar)
{
WORD windowID;
windowID = LOWORD(wPar);
switch (msg)
{
case WM_INITDIALOG:
ofn.lCustData = 0;
break;
case WM_DESTROY:
break;
default:
break;
}
return FALSE;
}
#endif
/*=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-
* FUNCTION:
* gnrcFindFileDialog
*
* DESCRIPTION:
* This function makes the FindFile common dialog a little bit easier to
* call.
*
* ARGUEMENTS:
* hwnd -- the window handle to use as the parent
* pszTitle -- text to display as the title
* pszDirectory -- path to use as default directory
* pszMasks -- file name masks
*
* RETURNS:
* A pointer to a string that contains the file name. This string is malloced
* and must be freed by the caller, or..
* NULL which indicates the user canceled the operation.
*/
LPTSTR gnrcFindFileDialogInternal(HWND hwnd,
LPCTSTR pszTitle,
LPCTSTR pszDirectory,
LPCTSTR pszMasks,
int nFindFlag,
LPCTSTR pszInitName)
{
int index;
LPTSTR pszRet = NULL;
LPTSTR pszStr;
LPCTSTR pszWrk;
TCHAR acMask[128];
TCHAR acTitle[64];
TCHAR szExt[4];
TCHAR szFile[FNAME_LEN];
TCHAR szDir[FNAME_LEN];
int iRet;
//DWORD dwMaxComponentLength;
//DWORD dwFileSystemFlags;
memset((LPTSTR)&ofn, 0, sizeof(ofn));
memset(szFile, 0, sizeof(szFile));
memset(szExt, 0, sizeof(szExt));
memset(acMask, 0, sizeof(acMask));
memset(acTitle, 0, sizeof(acTitle));
ofn.lStructSize = sizeof(OPENFILENAME);
ofn.hwndOwner = hwnd;
ofn.hInstance = (HANDLE)GetWindowLong(hwnd, GWL_HINSTANCE);
if ((pszMasks == NULL) || (StrCharGetStrLength(pszMasks) == 0))
{
resLoadFileMask(glblQueryDllHinst(),
IDS_CMM_ALL_FILES1,
1,
acMask,
sizeof(acMask) / sizeof(TCHAR));
ofn.lpstrFilter = acMask;
}
else
{
ofn.lpstrFilter = pszMasks;
pszWrk = pszMasks;
pszWrk = StrCharFindFirst(pszWrk, TEXT('.'));
if (*pszWrk == '.')
{
pszWrk = StrCharNext(pszWrk);
pszStr = (LPTSTR)pszWrk;
index = 0;
/* This works because we know how the mask are going to be formed */
while ((index < 3) && (*pszWrk != ')'))
{
index += 1;
pszWrk = StrCharNext(pszWrk);
}
if (pszWrk != pszStr)
memcpy(szDir, pszStr, pszWrk - pszStr);
}
pszWrk = NULL;
}
if(StrCharGetByteCount(pszInitName) <= FNAME_LEN)
{
memcpy(szFile, pszInitName, StrCharGetByteCount(pszInitName));
}
ofn.lpstrDefExt = (LPTSTR)szExt;
ofn.lpstrCustomFilter = NULL;
ofn.nMaxCustFilter = 0;
ofn.nFilterIndex = 0;
ofn.lpstrFile = szFile;
ofn.nMaxFile = FNAME_LEN;
if ((pszDirectory == NULL) || (StrCharGetStrLength(pszDirectory) == 0))
{
#if defined(NT_EDITION)
GetUserDirectory(szDir, sizeof(szDir) / sizeof(TCHAR));
#else
TCHAR acDirTmp[FNAME_LEN];
GetCurrentDirectory(FNAME_LEN, acDirTmp);
StrCharCopy(szDir, acDirTmp);
#endif
}
else
{
StrCharCopy(szDir, pszDirectory);
}
pszStr = StrCharLast(szDir);
if (*pszStr == TEXT('\\'))
*pszStr = TEXT('\0');
ofn.lpstrInitialDir = szDir;
ofn.lpstrFileTitle = NULL;
ofn.nMaxFileTitle = 0;
if ((pszTitle == NULL) || (StrCharGetByteCount(pszTitle) == 0))
{
// ofn.lpstrTitle = "Select File";
LoadString(glblQueryDllHinst(),
IDS_CPF_SELECT_FILE,
acTitle,
sizeof(acTitle) / sizeof(TCHAR));
ofn.lpstrTitle = acTitle;
}
else
{
ofn.lpstrTitle = pszTitle;
}
ofn.Flags = OFN_HIDEREADONLY | OFN_PATHMUSTEXIST | OFN_OVERWRITEPROMPT;
//ofn.Flags = OFN_HIDEREADONLY | OFN_PATHMUSTEXIST;
if (nFindFlag)
{
ofn.Flags |= OFN_FILEMUSTEXIST;
iRet = GetOpenFileName(&ofn);
}
else
{
#if 0
// This was added so the common dialog for "Save As" applies
// the same restrictions as the New Connect dialog when it
// comes to saving session file names.
//
GetVolumeInformation(NULL, NULL, 0, NULL, &dwMaxComponentLength,
&dwFileSystemFlags, NULL, 0);
if(dwMaxComponentLength == 255)
{
ofn.nMaxFile = dwMaxComponentLength - 1;
}
else
{
ofn.nMaxFile = 8;
}
#endif
iRet = GetSaveFileName(&ofn);
}
if (iRet == TRUE)
{
if (StrCharGetStrLength(szFile) > 0)
{
pszRet = malloc(StrCharGetByteCount(szFile) + 1);
if (pszRet != NULL)
StrCharCopy(pszRet, szFile);
}
return pszRet;
}
else
{
return(NULL);
}
}
/*=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-
* FUNCTION:
*
* DESCRIPTION:
*
* ARGUMENTS:
*
* RETURNS:
*
*/
LPTSTR gnrcFindFileDialog(HWND hwnd,
LPCTSTR pszTitle,
LPCTSTR pszDirectory,
LPCTSTR pszMasks)
{
return gnrcFindFileDialogInternal(hwnd,
pszTitle,
pszDirectory,
pszMasks,
TRUE,
NULL);
}
/*=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-
* FUNCTION:
*
* DESCRIPTION:
*
* ARGUMENTS:
*
* RETURNS:
*
*/
LPTSTR gnrcSaveFileDialog(HWND hwnd,
LPCTSTR pszTitle,
LPCTSTR pszDirectory,
LPCTSTR pszMasks,
LPCTSTR pszInitName)
{
return gnrcFindFileDialogInternal(hwnd,
pszTitle,
pszDirectory,
pszMasks,
FALSE,
pszInitName);
}
/*=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-
* FUNCTION:
* gnrcFindDirectoryDialog
*
* DESCRIPTION:
*
* ARGUEMENTS:
*
* RETURNS:
*/
LPTSTR gnrcFindDirectoryDialog(HWND hwnd, HSESSION hSession, LPTSTR pszDir)
{
BOOL bRet;
LPTSTR pszStr;
TCHAR acTitle[64];
TCHAR acList[64];
TCHAR szDir[FNAME_LEN];
TCHAR szFile[FNAME_LEN];
LoadString(glblQueryDllHinst(),
IDS_CMM_SEL_DIR,
acTitle,
sizeof(acTitle) / sizeof(TCHAR));
resLoadFileMask(glblQueryDllHinst(),
IDS_CMM_ALL_FILES1,
1,
acList,
sizeof(acList) / sizeof(TCHAR));
memset((LPTSTR)&ofn, 0, sizeof(ofn));
TCHAR_Fill(szFile, TEXT('\0'), sizeof(szFile) / sizeof(TCHAR));
ofn.lCustData = 0L;
ofn.lStructSize = sizeof(OPENFILENAME);
ofn.hwndOwner = hwnd;
ofn.hInstance = (HANDLE)GetWindowLong(hwnd, GWL_HINSTANCE);
ofn.lpstrTitle = acTitle;
ofn.lpstrFilter = acList;
ofn.lpstrCustomFilter = NULL;
ofn.nMaxCustFilter = 0;
ofn.nFilterIndex = 0;
ofn.lpstrFile = szFile;
ofn.nMaxFile = FNAME_LEN;
ofn.nMaxFileTitle = 0;
ofn.lpstrDefExt = NULL;
ofn.Flags = OFN_ENABLEHOOK | OFN_ENABLETEMPLATE |
OFN_HIDEREADONLY | OFN_PATHMUSTEXIST;
ofn.lpfnHook = gnrcFindDirHookProc;
ofn.lpTemplateName = MAKEINTRESOURCE(IDD_FINDDIRECTORY);
if ((pszDir == NULL) || (StrCharGetStrLength(pszDir) == 0))
{
GetCurrentDirectory(FNAME_LEN, szDir);
}
else
{
StrCharCopy(szDir, pszDir);
}
pszStr = StrCharLast(szDir);
if (*pszStr == TEXT('\\'))
*pszStr = TEXT('\0');
ofn.lpstrInitialDir = szDir;
ofn.lpstrFileTitle = NULL;
bRet = GetOpenFileName(&ofn);
if (StrCharGetStrLength(szFile) == 0)
return NULL;
pszStr = StrCharFindLast(szFile, TEXT('\\'));
if (*pszStr == TEXT('\\'))
{
pszStr = StrCharNext(pszStr);
*pszStr = TEXT('\0');
}
fileFinalizeDIR(hSession, szFile, szFile);
pszStr = malloc(StrCharGetByteCount(szFile) + 1);
StrCharCopy(pszStr, szFile);
return pszStr;
}
/*=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-
* FUNCTION:
* GetUserDirectory (NT_EDITION only)
*
* DESCRIPTION:
* Returns the default HyperTerminal directory for the current user.
*
* ARGUMENTS:
* pszUserDir -- where to write the default directory
* dwSize -- size, in characters, of the above buffer
*
* RETURNS:
* If the function succeeds, the return value is the number of characters
* stored into the buffer pointed to by pszDir, not including the
* terminating null character.
*
* If the specified environment variable name was not found in the
* environment block for the current process, the return value is zero.
*
* If the buffer pointed to by lpBuffer is not large enough, the return
* value is the buffer size, in characters, required to hold the value
* string and its terminating null character.
*
* Author: JMH, 6-12-96
*/
DWORD GetUserDirectory(LPTSTR pszUserDir, DWORD dwSize)
{
TCHAR szProfileRoot[_MAX_PATH];
DWORD dwRet;
TCHAR szProfileDir[_MAX_PATH];
// Per Microsoft, all Open/Save/Save As... dialogs should default to
// %USERPROFILE%\start menu\programs\accessories\hyperterminal
// jmh:06-12-96
//
// This is the \start menu\programs\accessories\hyperterminal part...
// jmh:08-02-96 Now loaded from resources, for interationalization
//
LoadString(glblQueryDllHinst(),
IDS_GNRL_PROFILE_DIR,
szProfileDir,
sizeof(szProfileDir) / sizeof(TCHAR));
dwRet = GetEnvironmentVariable(TEXT("USERPROFILE"), // address of environment variable name
szProfileRoot, // address of buffer for variable value
sizeof(szProfileRoot) / sizeof(TCHAR)); // size of buffer, in characters
assert(dwRet > 0);
assert(dwRet <= sizeof(szProfileRoot) / sizeof(TCHAR));
dwRet = lstrlen(szProfileRoot) + lstrlen(szProfileDir);
if (dwRet < dwSize)
{
wsprintf(pszUserDir, TEXT("%s%s"), szProfileRoot, szProfileDir);
assert((int) dwRet == lstrlen(pszUserDir));
}
return dwRet;
}
/*=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-
* FUNCTION:
* CreateUserDirectory (NT_EDITION only)
*
* DESCRIPTION:
* For NT, if HT is installed after the os update, no directory
* will exist for HT in the user profile. This function creates the
* directory if necessary, since the rest of the program assumes
* it exists.
*
* ARGUMENTS:
* None.
*
* RETURNS:
* Nothing.
*
* Author: JMH, 6-13-96
*/
void CreateUserDirectory(void)
{
TCHAR szUserDir[_MAX_PATH];
GetUserDirectory(szUserDir, sizeof(szUserDir) / sizeof(TCHAR));
mscCreatePath(szUserDir);
}