ENH: add ability to run from different directories
This commit is contained in:
parent
0798a177ea
commit
f76a992ff9
|
@ -65,13 +65,35 @@ BEGIN_MESSAGE_MAP(CAboutDlg, CDialog)
|
|||
CMakeSetupDialog::CMakeSetupDialog(CWnd* pParent /*=NULL*/)
|
||||
: CDialog(CMakeSetupDialog::IDD, pParent)
|
||||
{
|
||||
CString startPath = _pgmptr;
|
||||
startPath.Replace('\\', '_');
|
||||
startPath.Replace(':', '_');
|
||||
startPath.Replace(".EXE", "");
|
||||
startPath.Replace(".exe", "");
|
||||
m_RegistryKey = "Software\\Kitware\\CMakeSetup\\Settings\\";
|
||||
// _pgmptr should be the directory from which cmake was run from
|
||||
// use it as the unique key for the dialog
|
||||
m_RegistryKey += startPath;
|
||||
|
||||
//{{AFX_DATA_INIT(CMakeSetupDialog)
|
||||
m_WhereSource = _T("");
|
||||
m_WhereBuild = _T("");
|
||||
//}}AFX_DATA_INIT
|
||||
// Note that LoadIcon does not require a subsequent DestroyIcon in Win32
|
||||
m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
|
||||
m_WhereSource = _T("");
|
||||
// Guess the initial source directory based on the location
|
||||
// of this program, it should be in CMake/Source/
|
||||
startPath = _pgmptr;
|
||||
int removePos = startPath.Find("\\CMake\\Source");
|
||||
if(removePos == -1)
|
||||
{
|
||||
removePos = startPath.Find("/CMake/Source");
|
||||
}
|
||||
if(removePos != -1)
|
||||
{
|
||||
startPath = startPath.Left(removePos);
|
||||
}
|
||||
m_WhereSource = startPath;
|
||||
this->LoadFromRegistry();
|
||||
}
|
||||
|
||||
|
@ -273,7 +295,7 @@ void CMakeSetupDialog::SaveToRegistry()
|
|||
DWORD dwDummy;
|
||||
|
||||
if(RegCreateKeyEx(HKEY_CURRENT_USER,
|
||||
_T("Software\\Kitware\\CMakeSetup\\Settings"),
|
||||
m_RegistryKey,
|
||||
0, "", REG_OPTION_NON_VOLATILE, KEY_READ|KEY_WRITE,
|
||||
NULL, &hKey, &dwDummy) != ERROR_SUCCESS)
|
||||
{
|
||||
|
@ -295,8 +317,8 @@ void CMakeSetupDialog::SaveToRegistry()
|
|||
|
||||
void CMakeSetupDialog::ReadRegistryValue(HKEY hKey,
|
||||
CString *val,
|
||||
char *key,
|
||||
char *adefault)
|
||||
const char *key,
|
||||
const char *adefault)
|
||||
{
|
||||
DWORD dwType, dwSize;
|
||||
char *pb;
|
||||
|
@ -321,7 +343,7 @@ void CMakeSetupDialog::LoadFromRegistry()
|
|||
{
|
||||
HKEY hKey;
|
||||
if(RegOpenKeyEx(HKEY_CURRENT_USER,
|
||||
_T("Software\\Kitware\\CMakeSetup\\Settings"),
|
||||
m_RegistryKey,
|
||||
0, KEY_READ, &hKey) != ERROR_SUCCESS)
|
||||
{
|
||||
return;
|
||||
|
|
|
@ -22,8 +22,8 @@ protected:
|
|||
void LoadFromRegistry();
|
||||
void ReadRegistryValue(HKEY hKey,
|
||||
CString *val,
|
||||
char *key,
|
||||
char *adefault);
|
||||
const char *key,
|
||||
const char *aadefault);
|
||||
// Dialog Data
|
||||
//{{AFX_DATA(CMakeSetupDialog)
|
||||
enum { IDD = IDD_CMakeSetupDialog_DIALOG };
|
||||
|
@ -40,7 +40,7 @@ protected:
|
|||
// Implementation
|
||||
protected:
|
||||
HICON m_hIcon;
|
||||
|
||||
CString m_RegistryKey;
|
||||
// Generated message map functions
|
||||
//{{AFX_MSG(CMakeSetupDialog)
|
||||
virtual BOOL OnInitDialog();
|
||||
|
|
Loading…
Reference in New Issue