summaryrefslogtreecommitdiffstats
path: root/Source/MFCDialog
diff options
context:
space:
mode:
Diffstat (limited to 'Source/MFCDialog')
-rw-r--r--Source/MFCDialog/CMakeDialog.cpp327
-rw-r--r--Source/MFCDialog/CMakeSetup.dsp8
-rw-r--r--Source/MFCDialog/CMakeSetupDialog.cpp10
3 files changed, 9 insertions, 336 deletions
diff --git a/Source/MFCDialog/CMakeDialog.cpp b/Source/MFCDialog/CMakeDialog.cpp
deleted file mode 100644
index 373ad47..0000000
--- a/Source/MFCDialog/CMakeDialog.cpp
+++ /dev/null
@@ -1,327 +0,0 @@
-// CMakeSetupDialogDlg.cpp : implementation file
-//
-
-#include "stdafx.h"
-#include "pcbuilder.h"
-#include "CMakeSetupDialog.h"
-#include "../itkDSWBuilder.h"
-#include "../itkVC60Configure.h"
-
-#ifdef _DEBUG
-#define new DEBUG_NEW
-#undef THIS_FILE
-static char THIS_FILE[] = __FILE__;
-#endif
-
-/////////////////////////////////////////////////////////////////////////////
-// CAboutDlg dialog used for App About
-
-class CAboutDlg : public CDialog
-{
-public:
- CAboutDlg();
-
-// Dialog Data
- //{{AFX_DATA(CAboutDlg)
- enum { IDD = IDD_ABOUTBOX };
- //}}AFX_DATA
-
- // ClassWizard generated virtual function overrides
- //{{AFX_VIRTUAL(CAboutDlg)
-protected:
- virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV support
- //}}AFX_VIRTUAL
-
-// Implementation
-protected:
- //{{AFX_MSG(CAboutDlg)
- //}}AFX_MSG
- DECLARE_MESSAGE_MAP()
- };
-
-CAboutDlg::CAboutDlg() : CDialog(CAboutDlg::IDD)
-{
- //{{AFX_DATA_INIT(CAboutDlg)
- //}}AFX_DATA_INIT
-}
-
-void CAboutDlg::DoDataExchange(CDataExchange* pDX)
-{
- CDialog::DoDataExchange(pDX);
- //{{AFX_DATA_MAP(CAboutDlg)
- //}}AFX_DATA_MAP
-}
-
-BEGIN_MESSAGE_MAP(CAboutDlg, CDialog)
- //{{AFX_MSG_MAP(CAboutDlg)
- // No message handlers
- //}}AFX_MSG_MAP
- END_MESSAGE_MAP();
-
-
-/////////////////////////////////////////////////////////////////////////////
-// CMakeSetupDialog dialog
-
-CMakeSetupDialog::CMakeSetupDialog(CWnd* pParent /*=NULL*/)
- : CDialog(CMakeSetupDialog::IDD, pParent)
-{
- //{{AFX_DATA_INIT(CMakeSetupDialog)
- m_WhereITK = _T("");
- m_WhereBuildITK = _T("");
- //}}AFX_DATA_INIT
- // Note that LoadIcon does not require a subsequent DestroyIcon in Win32
- m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
- m_WhereITK = _T("");
- this->LoadFromRegistry();
-}
-
-void CMakeSetupDialog::DoDataExchange(CDataExchange* pDX)
-{
- CDialog::DoDataExchange(pDX);
- //{{AFX_DATA_MAP(CMakeSetupDialog)
- DDX_Text(pDX, IDC_WhereITK, m_WhereITK);
- DDX_Text(pDX, IDC_WhereITK2, m_WhereBuildITK);
- //}}AFX_DATA_MAP
-}
-
-BEGIN_MESSAGE_MAP(CMakeSetupDialog, CDialog)
- //{{AFX_MSG_MAP(CMakeSetupDialog)
- ON_WM_SYSCOMMAND()
- ON_WM_PAINT()
- ON_WM_QUERYDRAGICON()
- ON_EN_CHANGE(IDC_WhereITK, OnChangeEdit1)
- ON_BN_CLICKED(IDC_BUTTON2, OnBrowse)
- ON_BN_CLICKED(IDC_BUTTON3, OnButton3)
- //}}AFX_MSG_MAP
- END_MESSAGE_MAP();
-
-
-/////////////////////////////////////////////////////////////////////////////
-// CMakeSetupDialog message handlers
-
-BOOL CMakeSetupDialog::OnInitDialog()
-{
- CDialog::OnInitDialog();
-
- // Add "About..." menu item to system menu.
-
- // IDM_ABOUTBOX must be in the system command range.
- ASSERT((IDM_ABOUTBOX & 0xFFF0) == IDM_ABOUTBOX);
- ASSERT(IDM_ABOUTBOX < 0xF000);
-
- CMenu* pSysMenu = GetSystemMenu(FALSE);
- if (pSysMenu != NULL)
- {
- CString strAboutMenu;
- strAboutMenu.LoadString(IDS_ABOUTBOX);
- if (!strAboutMenu.IsEmpty())
- {
- pSysMenu->AppendMenu(MF_SEPARATOR);
- pSysMenu->AppendMenu(MF_STRING, IDM_ABOUTBOX, strAboutMenu);
- }
- }
-
- // Set the icon for this dialog. The framework does this automatically
- // when the application's main window is not a dialog
- SetIcon(m_hIcon, TRUE); // Set big icon
- SetIcon(m_hIcon, FALSE); // Set small icon
-
- // TODO: Add extra initialization here
-
- return TRUE; // return TRUE unless you set the focus to a control
-}
-
-void CMakeSetupDialog::OnSysCommand(UINT nID, LPARAM lParam)
-{
- if ((nID & 0xFFF0) == IDM_ABOUTBOX)
- {
- CAboutDlg dlgAbout;
- dlgAbout.DoModal();
- }
- else
- {
- CDialog::OnSysCommand(nID, lParam);
- }
-}
-
-// If you add a minimize button to your dialog, you will need the code below
-// to draw the icon. For MFC applications using the document/view model,
-// this is automatically done for you by the framework.
-
-void CMakeSetupDialog::OnPaint()
-{
- if (IsIconic())
- {
- CPaintDC dc(this); // device context for painting
-
- SendMessage(WM_ICONERASEBKGND, (WPARAM) dc.GetSafeHdc(), 0);
-
- // Center icon in client rectangle
- int cxIcon = GetSystemMetrics(SM_CXICON);
- int cyIcon = GetSystemMetrics(SM_CYICON);
- CRect rect;
- GetClientRect(&rect);
- int x = (rect.Width() - cxIcon + 1) / 2;
- int y = (rect.Height() - cyIcon + 1) / 2;
-
- // Draw the icon
- dc.DrawIcon(x, y, m_hIcon);
- }
- else
- {
- CDialog::OnPaint();
- }
-}
-
-// The system calls this to obtain the cursor to display while the user drags
-// the minimized window.
-HCURSOR CMakeSetupDialog::OnQueryDragIcon()
-{
- return (HCURSOR) m_hIcon;
-}
-
-void CMakeSetupDialog::OnChangeEdit1()
-{
- // TODO: If this is a RICHEDIT control, the control will not
- // send this notification unless you override the CDialog::OnInitDialog()
- // function and call CRichEditCtrl().SetEventMask()
- // with the ENM_CHANGE flag ORed into the mask.
-
- // TODO: Add your control notification handler code here
-
-}
-
-void CMakeSetupDialog::OnBrowse()
-{
- this->UpdateData();
- Browse(m_WhereITK, "Enter Path to Insight Source");
- this->UpdateData(false);
-}
-
-bool CMakeSetupDialog::Browse(CString &result, const char *title)
-{
-// don't know what to do with initial right now...
- char szPathName[4096];
- BROWSEINFO bi;
-
- bi.hwndOwner = m_hWnd;
- bi.pidlRoot = NULL;
- bi.pszDisplayName = (LPTSTR)szPathName;
- bi.lpszTitle = title;
- bi.ulFlags = BIF_BROWSEINCLUDEFILES ;
- bi.lpfn = NULL;
-
- LPITEMIDLIST pidl = SHBrowseForFolder(&bi);
-
- bool bSuccess = (bool)SHGetPathFromIDList(pidl, szPathName);
- if(bSuccess)
- {
- result = szPathName;
- }
-
- return bSuccess;
-}
-
-void CMakeSetupDialog::OnOK()
-{
- // get all the info from the screen
- this->UpdateData();
-
- // configure the system for VC60
- itkVC60Configure config;
- config.SetWhereITK(m_WhereITK);
- config.SetWhereBuildITK(m_WhereBuildITK);
- config.Configure();
-
- itkDSWBuilder builder;
- // Set the ITK home directory
- builder.SetHomeDirectory(m_WhereITK);
- // Set the Makefile.in file
- CString makefileIn = m_WhereITK;
- makefileIn += "/Makefile.in";
- builder.SetInputMakefilePath(makefileIn);
- // Set the output directory
- builder.SetOutputDirectory(m_WhereBuildITK);
- // set the directory which contains the Makefile.in
- builder.SetMakefileDirectory(m_WhereITK);
- // Create the master DSW file and all children dsp files for ITK
- builder.CreateDSWFile();
- CDialog::OnOK();
- this->SaveToRegistry();
-}
-
-void CMakeSetupDialog::OnButton3()
-{
- this->UpdateData();
- Browse(m_WhereBuildITK, "Enter Path to Insight Build");
- this->UpdateData(false);
-}
-
-void CMakeSetupDialog::SaveToRegistry()
-{
- HKEY hKey;
- DWORD dwDummy;
-
- if(RegCreateKeyEx(HKEY_CURRENT_USER,
- _T("Software\\Kitware\\ITK PCBuilder\\Settings"),
- 0, "", REG_OPTION_NON_VOLATILE, KEY_READ|KEY_WRITE,
- NULL, &hKey, &dwDummy) != ERROR_SUCCESS)
- {
- return;
- }
- else
- {
- RegSetValueEx(hKey, _T("WhereITK"), 0, REG_SZ,
- (CONST BYTE *)(const char *)m_WhereITK,
- m_WhereITK.GetLength());
- RegSetValueEx(hKey, _T("WhereBuildITK"), 0, REG_SZ,
- (CONST BYTE *)(const char *)m_WhereBuildITK,
- m_WhereBuildITK.GetLength());
-
- }
- RegCloseKey(hKey);
-}
-
-
-void CMakeSetupDialog::ReadRegistryValue(HKEY hKey,
- CString *val,
- char *key,
- char *adefault)
-{
- DWORD dwType, dwSize;
- char *pb;
-
- dwType = REG_SZ;
- pb = val->GetBuffer(MAX_PATH);
- dwSize = MAX_PATH;
- if(RegQueryValueEx(hKey,_T(key), NULL, &dwType,
- (BYTE *)pb, &dwSize) != ERROR_SUCCESS)
- {
- val->ReleaseBuffer();
- *val = _T(adefault);
- }
- else
- {
- val->ReleaseBuffer();
- }
-}
-
-
-void CMakeSetupDialog::LoadFromRegistry()
-{
- HKEY hKey;
- if(RegOpenKeyEx(HKEY_CURRENT_USER,
- _T("Software\\Kitware\\ITK PCBuilder\\Settings"),
- 0, KEY_READ, &hKey) != ERROR_SUCCESS)
- {
- return;
- }
- else
- {
- // save some values
- this->ReadRegistryValue(hKey, &(m_WhereITK),"WhereITK","C:\\Insight");
- this->ReadRegistryValue(hKey, &(m_WhereBuildITK),"WhereBuildITK",
- "C:\\vtkbin");
- }
- RegCloseKey(hKey);
-}
diff --git a/Source/MFCDialog/CMakeSetup.dsp b/Source/MFCDialog/CMakeSetup.dsp
index 9864a7c..3e59357 100644
--- a/Source/MFCDialog/CMakeSetup.dsp
+++ b/Source/MFCDialog/CMakeSetup.dsp
@@ -108,6 +108,10 @@ SOURCE=..\cmClassFile.cxx
# End Source File
# Begin Source File
+SOURCE=..\cmCollectFlags.cxx
+# End Source File
+# Begin Source File
+
SOURCE=..\cmDirectory.cxx
# End Source File
# Begin Source File
@@ -232,9 +236,5 @@ SOURCE=.\res\CMakeSetupDialog.ico
SOURCE=.\res\CMakeSetupDialog.rc2
# End Source File
# End Group
-# Begin Source File
-
-SOURCE=.\ReadMe.txt
-# End Source File
# End Target
# End Project
diff --git a/Source/MFCDialog/CMakeSetupDialog.cpp b/Source/MFCDialog/CMakeSetupDialog.cpp
index 32b8027..f3dc17b 100644
--- a/Source/MFCDialog/CMakeSetupDialog.cpp
+++ b/Source/MFCDialog/CMakeSetupDialog.cpp
@@ -4,7 +4,7 @@
#include "stdafx.h"
#include "CMakeSetup.h"
#include "CMakeSetupDialog.h"
-#include "../cmDSWBuilder.h"
+#include "../cmDSWMakefile.h"
#include "../itkVC60Configure.h"
#ifdef _DEBUG
@@ -232,19 +232,19 @@ void CMakeSetupDialog::OnOK()
config.SetWhereBuild(m_WhereBuild);
config.Configure();
- cmDSWBuilder builder;
+ cmDSWMakefile builder;
// Set the ITK home directory
builder.SetHomeDirectory(m_WhereSource);
// Set the CMakeLists.txt file
CString makefileIn = m_WhereSource;
makefileIn += "/CMakeLists.txt";
- builder.SetInputMakefilePath(makefileIn);
+ builder.ReadMakefile(makefileIn);
// Set the output directory
builder.SetOutputDirectory(m_WhereBuild);
// set the directory which contains the CMakeLists.txt
- builder.SetMakefileDirectory(m_WhereSource);
+ builder.SetCurrentDirectory(m_WhereSource);
// Create the master DSW file and all children dsp files for ITK
- builder.CreateDSWFile();
+ builder.OutputDSWFile();
CDialog::OnOK();
this->SaveToRegistry();
}