From 3948112d35088c6ac49ea13afbc272bf905edc6c Mon Sep 17 00:00:00 2001 From: stephena Date: Mon, 28 Jun 2004 23:01:54 +0000 Subject: [PATCH] Removed old StellaX project and files in preparation for the new VC7 solution which includes the Stella and StellaX projects. git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@289 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba --- stella/src/win32/AboutPage.cxx | 45 - stella/src/win32/AboutPage.hxx | 45 - stella/src/win32/BrowseForFolder.cxx | 226 ----- stella/src/win32/BrowseForFolder.hxx | 175 ---- stella/src/win32/ConfigPage.cxx | 164 ---- stella/src/win32/ConfigPage.hxx | 46 - stella/src/win32/ControlHost.cxx | 1276 -------------------------- stella/src/win32/CoolCaption.cxx | 284 ------ stella/src/win32/CoolCaption.hxx | 51 - stella/src/win32/DocPage.cxx | 153 --- stella/src/win32/DocPage.hxx | 57 -- stella/src/win32/FileDialog.cxx | 69 -- stella/src/win32/FileDialog.hxx | 51 - stella/src/win32/GlobalData.cxx | 39 - stella/src/win32/GlobalData.hxx | 67 -- stella/src/win32/HeaderCtrl.cxx | 200 ---- stella/src/win32/HeaderCtrl.hxx | 54 -- stella/src/win32/HyperLink.cxx | 352 ------- stella/src/win32/HyperLink.hxx | 66 -- stella/src/win32/MainDlg.cxx | 853 ----------------- stella/src/win32/MainDlg.hxx | 259 ------ stella/src/win32/PropertySheet.cxx | 260 ------ stella/src/win32/PropertySheet.hxx | 111 --- stella/src/win32/RoundButton.cxx | 625 ------------- stella/src/win32/RoundButton.hxx | 39 - stella/src/win32/Stella.dsp | 675 -------------- stella/src/win32/Stella.sln | 21 - stella/src/win32/Stella.vcproj | 637 ------------- stella/src/win32/StellaXMain.cxx | 183 ---- stella/src/win32/StellaXMain.hxx | 41 - stella/src/win32/TextButton3d.cxx | 186 ---- stella/src/win32/TextButton3d.hxx | 33 - stella/src/win32/Wnd.cxx | 75 -- stella/src/win32/Wnd.hxx | 39 - stella/src/win32/debug.cxx | 75 -- stella/src/win32/debug.hxx | 99 -- stella/src/win32/main.cxx | 94 -- stella/src/win32/pch.cxx | 88 -- stella/src/win32/pch.hxx | 139 --- stella/src/win32/resource.h | 87 -- stella/src/win32/stella.aps | Bin 45124 -> 0 bytes stella/src/win32/stella.ico | Bin 1078 -> 0 bytes stella/src/win32/stella.rc | 346 ------- stella/src/win32/tile.bmp | Bin 27318 -> 0 bytes 44 files changed, 8385 deletions(-) delete mode 100644 stella/src/win32/AboutPage.cxx delete mode 100644 stella/src/win32/AboutPage.hxx delete mode 100644 stella/src/win32/BrowseForFolder.cxx delete mode 100644 stella/src/win32/BrowseForFolder.hxx delete mode 100644 stella/src/win32/ConfigPage.cxx delete mode 100644 stella/src/win32/ConfigPage.hxx delete mode 100644 stella/src/win32/ControlHost.cxx delete mode 100644 stella/src/win32/CoolCaption.cxx delete mode 100644 stella/src/win32/CoolCaption.hxx delete mode 100644 stella/src/win32/DocPage.cxx delete mode 100644 stella/src/win32/DocPage.hxx delete mode 100644 stella/src/win32/FileDialog.cxx delete mode 100644 stella/src/win32/FileDialog.hxx delete mode 100644 stella/src/win32/GlobalData.cxx delete mode 100644 stella/src/win32/GlobalData.hxx delete mode 100644 stella/src/win32/HeaderCtrl.cxx delete mode 100644 stella/src/win32/HeaderCtrl.hxx delete mode 100644 stella/src/win32/HyperLink.cxx delete mode 100644 stella/src/win32/HyperLink.hxx delete mode 100644 stella/src/win32/MainDlg.cxx delete mode 100644 stella/src/win32/MainDlg.hxx delete mode 100644 stella/src/win32/PropertySheet.cxx delete mode 100644 stella/src/win32/PropertySheet.hxx delete mode 100644 stella/src/win32/RoundButton.cxx delete mode 100644 stella/src/win32/RoundButton.hxx delete mode 100644 stella/src/win32/Stella.dsp delete mode 100755 stella/src/win32/Stella.sln delete mode 100755 stella/src/win32/Stella.vcproj delete mode 100644 stella/src/win32/StellaXMain.cxx delete mode 100644 stella/src/win32/StellaXMain.hxx delete mode 100644 stella/src/win32/TextButton3d.cxx delete mode 100644 stella/src/win32/TextButton3d.hxx delete mode 100644 stella/src/win32/Wnd.cxx delete mode 100644 stella/src/win32/Wnd.hxx delete mode 100644 stella/src/win32/debug.cxx delete mode 100644 stella/src/win32/debug.hxx delete mode 100644 stella/src/win32/main.cxx delete mode 100644 stella/src/win32/pch.cxx delete mode 100644 stella/src/win32/pch.hxx delete mode 100644 stella/src/win32/resource.h delete mode 100755 stella/src/win32/stella.aps delete mode 100644 stella/src/win32/stella.ico delete mode 100755 stella/src/win32/stella.rc delete mode 100644 stella/src/win32/tile.bmp diff --git a/stella/src/win32/AboutPage.cxx b/stella/src/win32/AboutPage.cxx deleted file mode 100644 index 9cbbd08bc..000000000 --- a/stella/src/win32/AboutPage.cxx +++ /dev/null @@ -1,45 +0,0 @@ -//============================================================================ -// -// SSSS tt lll lll -// SS SS tt ll ll -// SS tttttt eeee ll ll aaaa -// SSSS tt ee ee ll ll aa -// SS tt eeeeee ll ll aaaaa -- "An Atari 2600 VCS Emulator" -// SS SS tt ee ll ll aa aa -// SSSS ttt eeeee llll llll aaaaa -// -// Copyright (c) 1995-2000 by Jeff Miller -// Copyright (c) 2004 by Stephen Anthony -// -// See the file "license" for information on usage and redistribution of -// this file, and for a DISCLAIMER OF ALL WARRANTIES. -// -// $Id: AboutPage.cxx,v 1.2 2004-05-27 22:02:35 stephena Exp $ -//============================================================================ - -#include "pch.hxx" -#include "AboutPage.hxx" -#include "resource.h" - -CHelpPage::CHelpPage() - : CPropertyPage(IDD_ABOUT_PAGE) -{ -} - -BOOL CHelpPage::OnInitDialog( HWND hwnd ) -{ - m_hlMail_JSM.SubclassDlgItem( hwnd, IDC_EMAIL_MAINTAINER ); - m_hlMail_JSM.SetURL( _T("mailto:sa666_666@hotmail.com?Subject=StellaX") ); - - m_hlWWW_JSM.SubclassDlgItem( hwnd, IDC_WEB_MAINTAINER ); - m_hlWWW_JSM.SetURL( _T("http://minbar.org") ); - - m_hlMail_Stella.SubclassDlgItem( hwnd, IDC_EMAIL_STELLA ); - m_hlMail_Stella.SetURL( _T("mailto:stella-main@lists.sourceforge.net") ); - - m_hlWWW_Stella.SubclassDlgItem( hwnd, IDC_WEB_STELLA ); - m_hlWWW_Stella.SetURL( _T("http://stella.sf.net") ); - - // return FALSE if SetFocus is called - return TRUE; -} diff --git a/stella/src/win32/AboutPage.hxx b/stella/src/win32/AboutPage.hxx deleted file mode 100644 index 053a094ce..000000000 --- a/stella/src/win32/AboutPage.hxx +++ /dev/null @@ -1,45 +0,0 @@ -//============================================================================ -// -// SSSS tt lll lll -// SS SS tt ll ll -// SS tttttt eeee ll ll aaaa -// SSSS tt ee ee ll ll aa -// SS tt eeeeee ll ll aaaaa -- "An Atari 2600 VCS Emulator" -// SS SS tt ee ll ll aa aa -// SSSS ttt eeeee llll llll aaaaa -// -// Copyright (c) 1995-2000 by Jeff Miller -// Copyright (c) 2004 by Stephen Anthony -// -// See the file "license" for information on usage and redistribution of -// this file, and for a DISCLAIMER OF ALL WARRANTIES. -// -// $Id: AboutPage.hxx,v 1.2 2004-05-27 22:02:35 stephena Exp $ -//============================================================================ - -#ifndef ABOUTPG_H -#define ABOUTPG_H -//FIXME#pragma once - -#include "PropertySheet.hxx" -#include "HyperLink.hxx" - -class CHelpPage : public CPropertyPage -{ - public: - CHelpPage(); - - protected: - virtual BOOL OnInitDialog( HWND hwnd ); - - private: - CHyperLink m_hlMail_JSM; - CHyperLink m_hlWWW_JSM; - CHyperLink m_hlMail_Stella; - CHyperLink m_hlWWW_Stella; - - CHelpPage( const CHelpPage& ); // no implementation - void operator=( const CHelpPage& ); // no implementation -}; - -#endif diff --git a/stella/src/win32/BrowseForFolder.cxx b/stella/src/win32/BrowseForFolder.cxx deleted file mode 100644 index 4f72c395d..000000000 --- a/stella/src/win32/BrowseForFolder.cxx +++ /dev/null @@ -1,226 +0,0 @@ -////////////////////////////////////////////////////////////////////// -// -// ShellBrowser.cpp: implementation of the CShellBrowser class. -// - -#include "pch.hxx" -#include "BrowseForFolder.hxx" - -#ifdef _DEBUG -#undef THIS_FILE -static char THIS_FILE[]=__FILE__; -#define new DEBUG_NEW -#endif - -////////////////////////////////////////////////////////////////////// -// -// Construction/Destruction -// - -#ifdef MFC -CBrowseForFolder::CBrowseForFolder( - const HWND hParent /*= NULL*/, - const LPITEMIDLIST pidl /*= NULL*/, - const int nTitleID /*= 0*/ - ) -{ - m_hwnd = NULL; - SetOwner(hParent); - SetRoot(pidl); - SetTitle(nTitleID); - m_bi.lpfn = BrowseCallbackProc; - m_bi.lParam = reinterpret_cast( this ); - m_bi.pszDisplayName = m_szSelected; -} -#endif - -CBrowseForFolder::CBrowseForFolder( - const HWND hParent, - const LPITEMIDLIST pidl, - LPCTSTR strTitle) -{ - m_hwnd = NULL; - - SetOwner(hParent); - - SetRoot(pidl); - - SetTitle(strTitle); - - m_bi.lpfn = BrowseCallbackProc; - m_bi.lParam = reinterpret_cast( this ); - m_bi.pszDisplayName = m_szSelected; -} - -CBrowseForFolder::~CBrowseForFolder() -{ - -} - -////////////////////////////////////////////////////////////////////// -// -// Implementation -// - -void CBrowseForFolder::SetOwner(const HWND hwndOwner) -{ - if (m_hwnd != NULL) - return; - - m_bi.hwndOwner = hwndOwner; -} - -void CBrowseForFolder::SetRoot(const LPITEMIDLIST pidl) -{ - if (m_hwnd != NULL) - return; - - m_bi.pidlRoot = pidl; -} - -LPCTSTR CBrowseForFolder::GetTitle() const -{ - return m_bi.lpszTitle; -} - -bool CBrowseForFolder::SetTitle( - LPCTSTR strTitle - ) -{ - if (m_hwnd != NULL) - return false; - - if ( strTitle == NULL ) - { - return false; - } - - if ( ! m_pchTitle.Set( strTitle ) ) - { - return false; - } - - m_bi.lpszTitle = m_pchTitle.Get(); - - return true; -} - -#ifdef MFC -bool CBrowseForFolder::SetTitle(const int nTitle) -{ - if (nTitle <= 0) - return false; - - CString strTitle; - if(!strTitle.LoadString(static_cast(nTitle))) - { - return false; - } - SetTitle(strTitle); - return true; -} -#endif - -void CBrowseForFolder::SetFlags(const UINT ulFlags) -{ - if (m_hwnd != NULL) - return; - - m_bi.ulFlags = ulFlags; -} - -LPCTSTR CBrowseForFolder::GetSelectedFolder( - void - ) const -{ - return m_szSelected; -} - -bool CBrowseForFolder::SelectFolder() -{ - bool bRet = false; - - LPITEMIDLIST pidl; - if ((pidl = ::SHBrowseForFolder(&m_bi)) != NULL) - { - m_strPath.Set( _T("") ); - if (SUCCEEDED(::SHGetPathFromIDList(pidl, m_szSelected))) - { - bRet = true; - m_strPath.Set( m_szSelected ); - } - - LPMALLOC pMalloc; - //Retrieve a pointer to the shell's IMalloc interface - if (SUCCEEDED(SHGetMalloc(&pMalloc))) - { - // free the PIDL that SHBrowseForFolder returned to us. - pMalloc->Free(pidl); - // release the shell's IMalloc interface - (void)pMalloc->Release(); - } - } - m_hwnd = NULL; - - return bRet; -} - -void CBrowseForFolder::OnInit() const -{ - -} - -void CBrowseForFolder::OnSelChanged(const LPITEMIDLIST pidl) const -{ - (void)pidl; -} - -void CBrowseForFolder::EnableOK(const bool bEnable) const -{ - if (m_hwnd == NULL) - return; - - // (void)SendMessage(m_hwnd, BFFM_ENABLEOK, static_cast(bEnable), NULL); - (void)SendMessage( m_hwnd, BFFM_ENABLEOK, NULL, static_cast(bEnable) ); -} - -void CBrowseForFolder::SetSelection(const LPITEMIDLIST pidl) const -{ - if (m_hwnd == NULL) - return; - - (void)SendMessage(m_hwnd, BFFM_SETSELECTION, FALSE, reinterpret_cast(pidl)); -} - -void CBrowseForFolder::SetSelection( - LPCTSTR strPath - ) const -{ - if (m_hwnd == NULL) - return; - - (void)SendMessage(m_hwnd, BFFM_SETSELECTION, TRUE, reinterpret_cast(strPath)); -} - -void CBrowseForFolder::SetStatusText( - LPCTSTR strText - ) const -{ - if (m_hwnd == NULL) - return; - - (void)SendMessage(m_hwnd, BFFM_SETSTATUSTEXT, NULL, reinterpret_cast(strText)); -} - -int __stdcall CBrowseForFolder::BrowseCallbackProc(HWND hwnd, UINT uMsg, LPARAM lParam, LPARAM lpData) -{ - CBrowseForFolder* pbff = reinterpret_cast( lpData ); - pbff->m_hwnd = hwnd; - if (uMsg == BFFM_INITIALIZED) - pbff->OnInit(); - else if (uMsg == BFFM_SELCHANGED) - pbff->OnSelChanged( reinterpret_cast( lParam )); - - return 0; -} - diff --git a/stella/src/win32/BrowseForFolder.hxx b/stella/src/win32/BrowseForFolder.hxx deleted file mode 100644 index 58cf1d638..000000000 --- a/stella/src/win32/BrowseForFolder.hxx +++ /dev/null @@ -1,175 +0,0 @@ -////////////////////////////////////////////////////////////////////// -// -// ShellBrowser.h: interface for the CShellBrowser class. -// -// Copyright 1998 Scott D. Killen -// -////////////////////////////////////////////////////////////////////// - -#ifndef __SHELLBROWSER_H__ -#define __SHELLBROWSER_H__ - -#if _MSC_VER >= 1000 -#pragma once -#endif // _MSC_VER >= 1000 - -#include - -///////////////////////////////////////////////////////////////////// -// -// CShellBrowser -// - -class CBrowseForFolder -{ -public: -#ifdef MFC - CBrowseForFolder(const HWND hParent = NULL, - const LPITEMIDLIST pidl = NULL, - const int nTitleID = 0); -#endif - - CBrowseForFolder(const HWND hParent = NULL, - const LPITEMIDLIST pidl = NULL, - LPCTSTR strTitle = NULL ); - - virtual ~CBrowseForFolder(); - - // - // Set the handle of the owner window for the dialog box. - // - void SetOwner(const HWND hwndOwner); - - // - // Set the root of the heirarchy that will be browsed. Get pidl from - // SHGetSpecialFolderLocation. This can be set to NULL to use the Virtual Folder - // that represents the Windows Desktop. - // - void SetRoot(const LPITEMIDLIST pidl); - - // - // Access a string that is displayed above the tree view control in the dialog box. - // This string can be used to specify instructions to the user. strTitle is a - // CString containing the text to be displayed. nTitle is the index of a string - // resource to be loaded. The return value is false if the resource could not be - // loaded. - // - LPCTSTR GetTitle() const; - bool SetTitle(LPCTSTR strTitle); -#ifdef MFC - bool SetTitle(const int nTitle); -#endif - - // - // ulFlags = Value specifying the types of folders to be listed in the dialog box - // as well as other options. This member can include zero or more of the following - // values: - // - // BIF_BROWSEFORCOMPUTER Only returns computers. If the user selects - // anything other than a computer, the OK button - // is grayed. - // - // BIF_BROWSEFORPRINTER Only returns printers. If the user selects - // anything other than a printer, the OK button - // is grayed. - // - // BIF_DONTGOBELOWDOMAIN Does not include network folders below the - // domain level in the tree view control. - // - // BIF_RETURNFSANCESTORS Only returns file system ancestors. If the user - // selects anything other than a file system - // ancestor, the OK button is grayed. - // - // BIF_RETURNONLYFSDIRS Only returns file system directories. If the - // user selects folders that are not part of the - // file system, the OK button is grayed. - // - // BIF_STATUSTEXT Includes a status area in the dialog box. The - // callback function can set the status text by - // sending messages to the dialog box. - // - UINT GetFlags() const; - void SetFlags(const UINT ulFlags); - - // - // Call GetSelectedFolder to retrieve the folder selected by the user. - // - LPCTSTR GetSelectedFolder() const; - - // - // Function to retreive the image associated with the selected folder. The image is - // specified as an index to the system image list. - // - int GetImage() const; - - // - // Call SelectFolder to display the dialog and get a selection from the user. Use - // GetSelectedFolder and GetImage to get the results of the dialog. - // - bool SelectFolder(); - -protected: - // - // OnInit is called before the dialog is displayed on the screen. - // - virtual void OnInit() const; - - // - // OnSelChanged is called whenever the user selects a different directory. pidl is - // the LPITEMIDLIST of the new selection. Use SHGetPathFromIDList to retrieve the - // path of the selection. - // - virtual void OnSelChanged(const LPITEMIDLIST pidl) const; - - // - // Call EnableOK to enable the OK button on the active dialog. If bEnable is true - // then the button is enabled, otherwise it is disabled. - // NOTE -- This function should only be called within overrides of OnInit and - // OnSelChanged. - // - void EnableOK(const bool bEnable) const; - - // - // Call SetSelection to set the selection in the active dialog. pidl is the - // LPITEMIDLIST - // of the path to be selected. strPath is a CString containing the path to be - // selected. - // NOTE -- This function should only be called within overrides of OnInit and - // OnSelChanged. - // - void SetSelection(const LPITEMIDLIST pidl) const; - void SetSelection(LPCTSTR strPath) const; - - // - // Call SetStatusText to set the text in the Status area in the active dialog. - // strText is the text to be displayed. - // NOTE -- This function should only be called within overrides of OnInit and - // OnSelChanged. - // - void SetStatusText(LPCTSTR strText) const; - -private: - static int __stdcall BrowseCallbackProc(HWND hwnd, - UINT uMsg, - LPARAM lParam, - LPARAM lpData); - - CSimpleString m_pchTitle; - - BROWSEINFO m_bi; - char m_szSelected[MAX_PATH]; - CSimpleString m_strPath; - HWND m_hwnd; -}; - -inline UINT CBrowseForFolder::GetFlags() const -{ - return m_bi.ulFlags; -} - -inline int CBrowseForFolder::GetImage() const -{ - return m_bi.iImage; -} - -#endif // __SHELLBROWSER_H__ diff --git a/stella/src/win32/ConfigPage.cxx b/stella/src/win32/ConfigPage.cxx deleted file mode 100644 index cd8a618b4..000000000 --- a/stella/src/win32/ConfigPage.cxx +++ /dev/null @@ -1,164 +0,0 @@ -//============================================================================ -// -// SSSS tt lll lll -// SS SS tt ll ll -// SS tttttt eeee ll ll aaaa -// SSSS tt ee ee ll ll aa -// SS tt eeeeee ll ll aaaaa -- "An Atari 2600 VCS Emulator" -// SS SS tt ee ll ll aa aa -// SSSS ttt eeeee llll llll aaaaa -// -// Copyright (c) 1995-2000 by Jeff Miller -// Copyright (c) 2004 by Stephen Anthony -// -// See the file "license" for information on usage and redistribution of -// this file, and for a DISCLAIMER OF ALL WARRANTIES. -// -// $Id: ConfigPage.cxx,v 1.3 2004-05-28 23:16:26 stephena Exp $ -//============================================================================ - -#include "pch.hxx" -#include "ConfigPage.hxx" -#include "resource.h" -#include "BrowseForFolder.hxx" - -#include "bspf.hxx" -#include "Settings.hxx" - - -CConfigPage::CConfigPage( CGlobalData& rGlobalData ) - : myGlobalData( rGlobalData ), - CPropertyPage( IDD_CONFIG_PAGE ) -{ -} - -BOOL CConfigPage::OnInitDialog( HWND hwnd ) -{ - // return FALSE if SetFocus is called - m_hwnd = hwnd; - HWND hwndCtrl; - - // Reload settings just in case the emulation changed them - myGlobalData.settings().loadConfig(); - - // Set up ROMPATH - hwndCtrl = ::GetDlgItem( hwnd, IDC_ROMPATH ); - ::SendMessage( hwndCtrl, EM_LIMITTEXT, MAX_PATH, 0 ); - ::SetWindowText( hwndCtrl, - myGlobalData.settings().getString("romdir").c_str() ); - - // Set up PADDLE - hwndCtrl = ::GetDlgItem( hwnd, IDC_PADDLE ); - TCHAR psz[4] = _T("0"); - TCHAR i; - for ( i = 0; i < 4; ++i ) - { - psz[0] = _T('0') + i; - ::SendMessage( hwndCtrl, CB_INSERTSTRING, (WPARAM)-1, (LPARAM)psz ); - } - ::SendMessage( hwndCtrl, CB_SETCURSEL, - myGlobalData.settings().getInt("paddle"), 0 ); - - // Set up Video mode - int videomode = 0; - hwndCtrl = ::GetDlgItem( hwnd, IDC_VIDEO ); - ::SendMessage( hwndCtrl, CB_INSERTSTRING, (WPARAM)-1, (LPARAM)"Software" ); - ::SendMessage( hwndCtrl, CB_INSERTSTRING, (WPARAM)-1, (LPARAM)"OpenGL" ); - if(myGlobalData.settings().getString("video") == "soft") - videomode = 0; - else if(myGlobalData.settings().getString("video") == "gl") - videomode = 1; - ::SendMessage( hwndCtrl, CB_SETCURSEL, videomode, 0 ); - - // Set up Aspect Ratio - hwndCtrl = ::GetDlgItem( hwnd, IDC_ASPECT ); - ::SendMessage( hwndCtrl, EM_LIMITTEXT, MAX_PATH, 0 ); - ::SetWindowText( hwndCtrl, - myGlobalData.settings().getString("gl_aspect").c_str() ); - - // Set up SOUND - hwndCtrl = ::GetDlgItem( hwnd, IDC_SOUND ); - ::SendMessage( hwndCtrl, BM_SETCHECK, - myGlobalData.settings().getBool("sound") - ? BST_UNCHECKED : BST_CHECKED, 0 ); - - return TRUE; -} - -void CConfigPage::OnDestroy( void ) -{ -} - -LONG CConfigPage::OnApply( LPPSHNOTIFY lppsn ) -{ - UNUSED_ALWAYS( lppsn ); - - // Apply the changes - // HWND hwnd = lppsn->hdr.hwndFrom; <<-- points to the sheet! - - HWND hwndCtrl; - TCHAR buffer[ MAX_PATH ]; - string str; - int i; - bool b; - - // RomPath - hwndCtrl = ::GetDlgItem( m_hwnd, IDC_ROMPATH ); - ASSERT( hwndCtrl ); - ::GetWindowText( hwndCtrl, buffer, MAX_PATH ); - myGlobalData.settings().setString( "romdir", buffer ); - - // Paddle - hwndCtrl = ::GetDlgItem( m_hwnd, IDC_PADDLE ); - ASSERT( hwndCtrl ); - myGlobalData.settings().setInt( "paddle", - ::SendMessage( hwndCtrl, CB_GETCURSEL, 0, 0 ) ); - - // VideoMode - hwndCtrl = ::GetDlgItem( m_hwnd, IDC_VIDEO ); - ASSERT( hwndCtrl ); - i = ::SendMessage( hwndCtrl, CB_GETCURSEL, 0, 0 ); - if( i == 0 ) - str = "soft"; - else if( i == 1 ) - str = "gl"; - else - str = "soft"; - myGlobalData.settings().setString( "video", str ); - - // AspectRatio - hwndCtrl = ::GetDlgItem( m_hwnd, IDC_ASPECT ); - ASSERT( hwndCtrl ); - ::GetWindowText( hwndCtrl, buffer, MAX_PATH ); - myGlobalData.settings().setString( "gl_aspect", buffer ); - - // Sound - hwndCtrl = ::GetDlgItem( m_hwnd, IDC_SOUND ); - ASSERT( hwndCtrl ); - if( ::SendMessage( hwndCtrl, BM_GETCHECK, 0, 0 ) == BST_CHECKED ) - b = false; - else - b = true; - myGlobalData.settings().setBool( "sound", b ); - - // Finally, save the config file - myGlobalData.settings().saveConfig(); - - return PSNRET_NOERROR; -} - -BOOL CConfigPage::OnCommand( WORD wNotifyCode, WORD wID, HWND hwndCtl ) -{ - UNUSED_ALWAYS( wNotifyCode ); - UNUSED_ALWAYS( hwndCtl ); - - if ( wID == IDC_BROWSE ) - { - CBrowseForFolder bff( m_hwnd ); - bff.SetFlags( BIF_RETURNONLYFSDIRS ); - if ( bff.SelectFolder() ) - ::SetDlgItemText( m_hwnd, IDC_ROMPATH, bff.GetSelectedFolder() ); - } - - return FALSE; -} diff --git a/stella/src/win32/ConfigPage.hxx b/stella/src/win32/ConfigPage.hxx deleted file mode 100644 index cfb1d0c64..000000000 --- a/stella/src/win32/ConfigPage.hxx +++ /dev/null @@ -1,46 +0,0 @@ -//============================================================================ -// -// SSSS tt lll lll -// SS SS tt ll ll -// SS tttttt eeee ll ll aaaa -// SSSS tt ee ee ll ll aa -// SS tt eeeeee ll ll aaaaa -- "An Atari 2600 VCS Emulator" -// SS SS tt ee ll ll aa aa -// SSSS ttt eeeee llll llll aaaaa -// -// Copyright (c) 1995-2000 by Jeff Miller -// Copyright (c) 2004 by Stephen Anthony -// -// See the file "license" for information on usage and redistribution of -// this file, and for a DISCLAIMER OF ALL WARRANTIES. -// -// $Id: ConfigPage.hxx,v 1.3 2004-05-28 23:16:26 stephena Exp $ -//============================================================================ - -#ifndef CONFIGPG_H -#define CONFIGPG_H - -#include "PropertySheet.hxx" -#include "GlobalData.hxx" - -class CConfigPage : public CPropertyPage -{ - public: - CConfigPage( CGlobalData& rGlobalData ); - - protected: - virtual BOOL OnInitDialog( HWND hwnd ); - virtual void OnDestroy(); - virtual LONG OnApply( LPPSHNOTIFY lppsn ); - - virtual BOOL OnCommand( WORD /* wNotifyCode */, WORD /* wID */, HWND /* hwndCtl */ ); - - private: - CGlobalData& myGlobalData; - HWND m_hwnd; - - CConfigPage( const CConfigPage& ); // no implementation - void operator=( const CConfigPage& ); // no implementation -}; - -#endif diff --git a/stella/src/win32/ControlHost.cxx b/stella/src/win32/ControlHost.cxx deleted file mode 100644 index 278abd33b..000000000 --- a/stella/src/win32/ControlHost.cxx +++ /dev/null @@ -1,1276 +0,0 @@ -// -// StellaX -// Jeff Miller 05/02/2000 -// - -#include "pch.hxx" -#include "ControlHost.hxx" - -#include -#include - -#pragma comment(lib, "oleaut32") - -CActiveXControl::CActiveXControl( - ) : \ - m_piDispatch( NULL ) -{ - TRACE( "CActiveXControl::CActiveXControl" ); -} - -CActiveXControl::~CActiveXControl( - ) -{ - TRACE( "CActiveXControl::~CActiveXControl" ); - - if ( m_piDispatch ) - { - m_piDispatch->Release(); - m_piDispatch = NULL; - } -} - -HRESULT CActiveXControl::CreateInstance( - void - ) -{ - TRACE( "CActiveXControl::CreateInstance" ); - - if ( m_piDispatch != NULL ) - { - return S_OK; - } - - return ::CoCreateInstance(GetCLSID(), NULL, - CLSCTX_INPROC_SERVER, IID_IDispatch, (void**)&m_piDispatch); -} - -void CActiveXControl::OnInitialUpdate( - void - ) -{ - TRACE( "CActiveXControl::OnInitialUpdate" ); -} - -HRESULT CActiveXControl::PutPropertyByName( - LPCOLESTR lpsz, - VARIANT* pVar - ) -{ - TRACE( "CActiveXControl::PutPropertyByName" ); - - if (m_piDispatch == NULL) - return E_UNEXPECTED; - - if (pVar == NULL) - return E_INVALIDARG; - - DISPID dwDispID; - HRESULT hr = GetIDOfName(lpsz, &dwDispID); - if (SUCCEEDED(hr)) - { - hr = PutProperty(m_piDispatch, dwDispID, pVar); - } - - return hr; -} - -HRESULT CActiveXControl::GetIDOfName( - LPCOLESTR lpsz, - DISPID* pdispid - ) -{ - TRACE( "CActiveXControl::GetIDOfName" ); - - if (m_piDispatch == NULL) - { - return E_UNEXPECTED; - } - - return m_piDispatch->GetIDsOfNames( IID_NULL, - (LPOLESTR*)&lpsz, - 1, - LOCALE_USER_DEFAULT, - pdispid ); -} - -HRESULT CActiveXControl::PutProperty( - IDispatch* pDisp, - DISPID dwDispID, - VARIANT* pVar - ) -{ - TRACE( "CActiveXControl::PutProperty" ); - - DISPPARAMS dispparams = {NULL, NULL, 1, 1}; - dispparams.rgvarg = pVar; - DISPID dispidPut = DISPID_PROPERTYPUT; - dispparams.rgdispidNamedArgs = &dispidPut; - - if (pVar->vt == VT_UNKNOWN || pVar->vt == VT_DISPATCH || - (pVar->vt & VT_ARRAY) || (pVar->vt & VT_BYREF)) - { - HRESULT hr = pDisp->Invoke(dwDispID, IID_NULL, - LOCALE_USER_DEFAULT, DISPATCH_PROPERTYPUTREF, - &dispparams, NULL, NULL, NULL); - if (SUCCEEDED(hr)) - return hr; - } - - return pDisp->Invoke( dwDispID, - IID_NULL, - LOCALE_USER_DEFAULT, - DISPATCH_PROPERTYPUT, - &dispparams, - NULL, - NULL, - NULL ); -} - -HRESULT CActiveXControl::GetProperty( - IDispatch* pDisp, - DISPID dwDispID, - VARIANT* pVar - ) -{ - TRACE( "CActiveXControl::GetProperty" ); - - DISPPARAMS dispparamsNoArgs = { NULL, NULL, 0, 0 }; - - return pDisp->Invoke( dwDispID, - IID_NULL, - LOCALE_USER_DEFAULT, - DISPATCH_PROPERTYGET, - &dispparamsNoArgs, - pVar, - NULL, - NULL ); -} - -// Invoke a method by DISPID with a single parameter - -HRESULT CActiveXControl::Invoke1( - DISPID dispid, - VARIANT* pvarParam1, - VARIANT* pvarRet /* = NULL */ - ) -{ - TRACE( "CActiveXControl::Invoke1" ); - - if ( m_piDispatch == NULL ) - { - return E_FAIL; - } - - DISPPARAMS dispparams = { pvarParam1, NULL, 1, 0 }; - - return m_piDispatch->Invoke( dispid, - IID_NULL, - LOCALE_USER_DEFAULT, - DISPATCH_METHOD, - &dispparams, - pvarRet, - NULL, - NULL ); -} - -// Invoke a method by name with a single parameter - -HRESULT CActiveXControl::Invoke1( - LPCOLESTR lpszName, - VARIANT* pvarParam1, - VARIANT* pvarRet /* = NULL */ - ) -{ - TRACE( "CActiveXControl::Invoke1" ); - - HRESULT hr; - DISPID dispid; - - hr = GetIDOfName( lpszName, &dispid ); - if ( SUCCEEDED(hr) ) - { - hr = Invoke1( dispid, pvarParam1, pvarRet ); - } - - return hr; -} - -// --------------------------------------------------------------------------- - -CControlHost::CControlHost( - CActiveXControl* pControl - ) : \ - _hwnd(NULL), - _punkOuter(NULL), - _cRef(0), - m_pControl(pControl) -{ - TRACE( "CControlHost::CControlHost" ); -} - -CControlHost::~CControlHost( - ) -{ - TRACE( "CControlHost::~CControlHost" ); - - // The extra addref is done here to make sure that the last Release - // call in DeleteControl doesn't do the delete this - - AddRef(); - - DeleteControl(); // insurance -} - - -HRESULT CControlHost::SetHwnd( - HWND hwnd - ) -{ - TRACE( "CControlHost::SetHwnd" ); - - _hwnd = hwnd; - - if ( ! GetClientRect( _hwnd, &_rcPos ) ) - { - SetRectEmpty( &_rcPos ); - } - - return S_OK; -} - -HRESULT CControlHost::CreateControl( - void - ) -{ - TRACE( "CControlHost::CreateControl" ); - - HRESULT hr; // standard ole return code - IPersistStreamInit *pps; // IPersistStreamInit interface pointer - - if (m_pControl == NULL) - { - return E_UNEXPECTED; - } - - hr = m_pControl->CreateInstance(); - if (hr != S_OK) - { - return hr; - } - - IOleObject* piOleObject = NULL; - hr = m_pControl->GetDispInterfaceNoAddRef()-> - QueryInterface( IID_IOleObject, - (void**)&piOleObject ); - if (hr != S_OK) - { - return hr; - } - - AddRef(); // addref the container - - piOleObject->SetClientSite(this); - - // Controls like to know they have been initialized by getting - // called on their InitNew method. - - hr = piOleObject->QueryInterface( IID_IPersistStreamInit, - (LPVOID *)&pps ); - if (SUCCEEDED(hr)) - { - pps->InitNew(); - pps->Release(); - } - - // The control creation succeeded, lets create the model. - - m_pControl->OnInitialUpdate(); - - // Tell the control to activate and show itself. - - piOleObject->DoVerb(OLEIVERB_INPLACEACTIVATE, NULL, this, 0, _hwnd, - &_rcPos); - piOleObject->DoVerb(OLEIVERB_SHOW, NULL, this, 0, _hwnd, &_rcPos); - - - // cache some frequently needed interface pointers - // cache the control's window handle - - _hwndControl = NULL; - IOleInPlaceActiveObject *pipao = NULL; - hr = piOleObject->QueryInterface(IID_IOleInPlaceActiveObject, - (void**) &pipao); - if (SUCCEEDED(hr)) - { - pipao->GetWindow(&_hwndControl); - pipao->Release(); - } - - piOleObject->Release(); - - return hr; -} - -HRESULT CControlHost::DeleteControl( - void - ) -{ - TRACE( "CControlHost::DeleteControl" ); - - // Close the Control and release the cached pointers. - - if (m_pControl != NULL) - { - IOleObject* piOleObject = NULL; - - if (m_pControl->GetDispInterfaceNoAddRef()->QueryInterface( - IID_IOleObject, (LPVOID *)&piOleObject) == S_OK) - { - piOleObject->DoVerb(OLEIVERB_HIDE, NULL, this, 0, _hwnd, NULL); - piOleObject->Close(OLECLOSE_NOSAVE); - piOleObject->SetClientSite(NULL); - - piOleObject->Release(); - } - - Release(); - - delete m_pControl; - m_pControl = NULL; - } - - return (S_OK); -} - -HRESULT CControlHost::QueryObject( - REFIID riid, - void **ppvObject - ) -{ - TRACE( "CControlHost::QueryObject" ); - - HRESULT hr = E_POINTER; - - if (ppvObject) - { - if (m_pControl) - { - IDispatch* piDispatch = NULL; - if (m_pControl->GetDispInterface(&piDispatch) == S_OK) - { - hr = piDispatch->QueryInterface(riid, ppvObject); - piDispatch->Release(); - } - } - else - { - *ppvObject = NULL; - hr = OLE_E_NOCONNECTION; - } - } - - return hr; -} - -////////////////////////////////////////////////////////////////////////// -// IUnknown methods - -HRESULT CControlHost::QueryInterface( - REFIID riid, - LPVOID* ppvObj - ) -{ - LPVOID pvObj = NULL; - -#ifdef _DEBUG - LPOLESTR psz; - if ( StringFromIID( riid, &psz ) == S_OK ) - { - TRACE( "CControlHost::QueryInterface - riid = %S", psz ); - CoTaskMemFree( psz ); - } -#endif - - if ( IsEqualIID( riid, IID_IOleInPlaceSite ) ) - { - pvObj = (IOleInPlaceSite *)this; - } -#ifdef IMPLEMENT_IOLECONTROLSITE - else if ( IsEqualIID( riid, IID_IOleControlSite ) ) - { - pvObj = (IOleControlSite *)this; - } -#endif -#ifdef IMPLEMENT_IOLEINPLACESITEWINDOWLESS - else if ( IsEqualIID( riid, IID_IOleInPlaceSiteWindowless ) ) - { - pvObj = (IOleInPlaceSiteWindowless *)this; - } -#endif - else if ( IsEqualIID( riid, IID_IDispatch ) ) - { - pvObj = (IDispatch *)this; - } - - if( pvObj ) - { - AddRef(); - } - - *ppvObj = pvObj; - - return pvObj ? S_OK : E_NOINTERFACE; -} - -ULONG CControlHost::AddRef( - void - ) -{ - OutputDebugString("CControlHost::AddRef\n"); - - return (_cRef++); // Not thread safe -} - -ULONG CControlHost::Release( - void - ) -{ - OutputDebugString("CControlHost::Release\n"); - - _cRef--; // Not thread safe - - if (_cRef > 0) - { - return _cRef; - } - - _cRef = 0; - delete this; - - return 0; -} - -////////////////////////////////////////////////////////////////////////// -// IOleClientSite methods - -HRESULT CControlHost::SaveObject( - void - ) -{ - TRACE( "CControlHost::SaveObject" ); - - return E_NOTIMPL; -} - -HRESULT CControlHost::GetMoniker( - DWORD dwAssign, - DWORD dwWhichMoniker, - LPMONIKER * ppMk - ) -{ - TRACE( "CControlHost::GetMoniker" ); - - UNUSED_ALWAYS( dwAssign ); - UNUSED_ALWAYS( dwWhichMoniker ); - - if ( ppMk ) - { - *ppMk = NULL; - } - - return E_NOTIMPL; -} - -HRESULT CControlHost::GetContainer( - LPOLECONTAINER * ppContainer - ) -{ - TRACE( "CControlHost::GetContainer" ); - - if ( ppContainer ) - { - *ppContainer = NULL; - } - - return E_NOTIMPL; -} - -HRESULT CControlHost::ShowObject( - void - ) -{ - TRACE( "CControlHost::ShowObject" ); - - return S_OK; -} - -HRESULT CControlHost::OnShowWindow( - BOOL fShow - ) -{ - TRACE( "CControlHost::OnShowWindow" ); - - UNUSED_ALWAYS( fShow ); - - return S_OK; -} - -HRESULT CControlHost::RequestNewObjectLayout( - void - ) -{ - TRACE( "CControlHost::RequestNewObjectLayout" ); - - return E_NOTIMPL; -} - -////////////////////////////////////////////////////////////////////////// -// IOleWindow methods - -HRESULT CControlHost::GetWindow( - HWND* lphwnd - ) -{ - TRACE( "CControlHost::GetWindow" ); - - *lphwnd = _hwnd; - - return ( _hwnd == NULL ) ? S_FALSE : S_OK; -} - -HRESULT CControlHost::ContextSensitiveHelp( - BOOL fEnterMode - ) -{ - TRACE( "CControlHost::ContextSensitiveHelp" ); - - UNUSED_ALWAYS( fEnterMode ); - - return E_NOTIMPL; -} - -////////////////////////////////////////////////////////////////////////// -// IOleInPlaceSite methods - -HRESULT CControlHost::CanInPlaceActivate( - void - ) -{ - TRACE( "CControlHost::CanInPlaceActivate" ); - - return S_OK; -} - -HRESULT CControlHost::OnInPlaceActivate( - void - ) -{ - TRACE( "CControlHost::OnInPlaceActivate" ); - - return S_OK; -} - -HRESULT CControlHost::OnUIActivate( - void - ) -{ - TRACE( "CControlHost::OnUIActivate" ); - - return S_OK; -} - -HRESULT CControlHost::GetWindowContext( - IOleInPlaceFrame** ppFrame, - IOleInPlaceUIWindow** ppIIPUIWin, - LPRECT lprcPosRect, - LPRECT lprcClipRect, - LPOLEINPLACEFRAMEINFO lpFrameInfo - ) -{ - TRACE( "CControlHost::GetWindowContext" ); - - *ppFrame = this; - AddRef(); - - *ppIIPUIWin = NULL; - - CopyRect(lprcPosRect, &_rcPos); - CopyRect(lprcClipRect, &_rcPos); - - lpFrameInfo->cb = sizeof(OLEINPLACEFRAMEINFO); - lpFrameInfo->fMDIApp = FALSE; - lpFrameInfo->hwndFrame = _hwnd; - lpFrameInfo->haccel = 0; - lpFrameInfo->cAccelEntries = 0; - - return S_OK; -} - -HRESULT CControlHost::Scroll( - SIZE scrollExtent - ) -{ - TRACE( "CControlHost::Scroll" ); - - UNUSED_ALWAYS( scrollExtent ); - - return E_NOTIMPL; -} - -HRESULT CControlHost::OnUIDeactivate( - BOOL fUndoable - ) -{ - TRACE( "CControlHost::OnUIDeactivate" ); - - UNUSED_ALWAYS( fUndoable ); - - return S_OK; -} - -HRESULT CControlHost::OnInPlaceDeactivate( - void - ) -{ - TRACE( "CControlHost::OnInPlaceDeactivate" ); - - return S_OK; -} - -HRESULT CControlHost::DiscardUndoState( - void - ) -{ - TRACE( "CControlHost::DiscardUndoState" ); - - return S_OK; -} - -HRESULT CControlHost::DeactivateAndUndo( - void - ) -{ - TRACE( "CControlHost::DeactivateAndUndo" ); - - return S_OK; -} - -HRESULT CControlHost::OnPosRectChange( - LPCRECT lprcPosRect - ) -{ - TRACE( "CControlHost::OnPosRectChange" ); - - RECT rcPos, rcClient; - HWND hwnd; - GetWindow(&hwnd); - GetClientRect(hwnd, &rcClient); - GetWindowRect(hwnd, &rcPos); - - if(rcClient.bottom < lprcPosRect->bottom) - rcPos.bottom += lprcPosRect->bottom - rcClient.bottom; - else - rcPos.bottom -= rcClient.bottom - lprcPosRect->bottom; - - if(rcClient.right < lprcPosRect->right) - rcPos.right += lprcPosRect->right - rcClient.right; - else - rcPos.right -= rcClient.right - lprcPosRect->right; - - MoveWindow( hwnd, - rcPos.left, - rcPos.top, - rcPos.right - rcPos.left, - rcPos.bottom - rcPos.top, - TRUE); - - return S_OK; -} - -#ifdef IMPLEMENT_IOLEINPLACESITEWINDOWLESS - -////////////////////////////////////////////////////////////////////////// -// IOleInPlaceSiteEx methods - -HRESULT CControlHost::OnInPlaceActivateEx( - BOOL *pfNoRedraw, - DWORD dwFlags - ) -{ - TRACE( "CControlHost::OnInPlaceActivateEx" ); - - UNUSED_ALWAYS( pfNoRedraw ); - UNUSED_ALWAYS( dwFlags ); - - if ( m_pControl == NULL ) - { - return E_FAIL; - } - - OleLockRunning( m_pControl->GetDispInterfaceNoAddRef(), - TRUE, - FALSE ); - - return S_OK; -} - -HRESULT CControlHost::OnInPlaceDeactivateEx( - BOOL fNoRedraw - ) -{ - TRACE( "CControlHost::OnInPlaceDeactivateEx" ); - - UNUSED_ALWAYS( fNoRedraw ); - - if ( m_pControl == NULL ) - { - return E_FAIL; - } - - OleLockRunning( m_pControl->GetDispInterfaceNoAddRef(), - FALSE, - FALSE ); - - return S_OK; -} - - -HRESULT CControlHost::RequestUIActivate( - void - ) -{ - TRACE( "CControlHost::RequestUIActivate" ); - - return S_OK; -} - - -////////////////////////////////////////////////////////////////////////// -// IOleInPlaceSiteWindowless methods - -HRESULT CControlHost::CanWindowlessActivate( - void - ) -{ - TRACE( "CControlHost::CanWindowlessActivate" ); - - return TRUE; // m_bCanWindowlessActivate); -} - -HRESULT CControlHost::GetCapture( - void - ) -{ - TRACE( "CControlHost::GetCapture" ); - - return E_NOTIMPL; -} - -HRESULT CControlHost::SetCapture( - BOOL fCapture - ) -{ - TRACE( "CControlHost::SetCapture" ); - - if (fCapture) - { - ::SetCapture(_hwnd); - _bCapture = TRUE; - } - else - { - ::ReleaseCapture(); - _bCapture = FALSE; - } - - return S_OK; -} - -HRESULT CControlHost::GetFocus( - void - ) -{ - TRACE( "CControlHost::GetFocus" ); - - return S_OK; -} - -HRESULT CControlHost::SetFocus( - BOOL fFocus - ) -{ - TRACE( "CControlHost::SetFocus" ); - - UNUSED_ALWAYS( fFocus ); - - return S_OK; -} - -HRESULT CControlHost::GetDC( - LPCRECT pRect, - DWORD grfFlags, - HDC* phDC - ) -{ - TRACE( "CControlHost::GetDC" ); - - UNUSED_ALWAYS( pRect ); - UNUSED_ALWAYS( grfFlags ); - - if (!phDC) - { - return E_POINTER; - } - - *phDC = ::GetDC(_hwnd); - - return S_OK; -} - -HRESULT CControlHost::ReleaseDC( - HDC hDC - ) -{ - TRACE( "CControlHost::ReleaseDC" ); - - ::ReleaseDC(_hwnd, hDC); - - return S_OK; -} - -HRESULT CControlHost::InvalidateRect( - LPCRECT pRect, - BOOL fErase - ) -{ - TRACE( "CControlHost::InvalidateRect" ); - - ::InvalidateRect(_hwnd, pRect, fErase); - - return S_OK; -} - -HRESULT CControlHost::InvalidateRgn( - HRGN hRGN, - BOOL fErase - ) -{ - TRACE( "CControlHost::InvalidateRgn" ); - - ::InvalidateRgn(_hwnd, hRGN, fErase); - - return S_OK; -} - -HRESULT CControlHost::ScrollRect( - INT dx, - INT dy, - LPCRECT pRectScroll, - LPCRECT pRectClip - ) -{ - TRACE( "CControlHost::ScrollRect" ); - - UNUSED_ALWAYS( dx ); - UNUSED_ALWAYS( dy ); - UNUSED_ALWAYS( pRectScroll ); - UNUSED_ALWAYS( pRectClip ); - - return S_OK; -} - -HRESULT CControlHost::AdjustRect( - LPRECT prc - ) -{ - TRACE( "CControlHost::AdjustRect" ); - - UNUSED_ALWAYS( prc ); - - return S_OK; -} - -HRESULT CControlHost::OnDefWindowMessage( - UINT msg, - WPARAM wParam, - LPARAM lParam, - LRESULT* plResult - ) -{ - TRACE( "CControlHost::OnDefWindowMessage" ); - - *plResult = ::DefWindowProc(_hwnd, msg, wParam, lParam); - - return S_OK; -} - -#endif - -////////////////////////////////////////////////////////////////////////// -// IOleInPlaceUIWindow methods - -HRESULT CControlHost::GetBorder( - LPRECT lprectBorder - ) -{ - TRACE( "CControlHost::GetBorder" ); - - UNUSED_ALWAYS( lprectBorder ); - - return E_NOTIMPL; -} - -HRESULT CControlHost::RequestBorderSpace( - LPCBORDERWIDTHS lpborderwidths - ) -{ - TRACE( "CControlHost::RequestBorderSpace" ); - - UNUSED_ALWAYS( lpborderwidths ); - - return E_NOTIMPL; -} - -HRESULT CControlHost::SetBorderSpace( - LPCBORDERWIDTHS lpborderwidths - ) -{ - TRACE( "CControlHost::SetBorderSpace" ); - - if( _punkOuter ) - { - return ((CControlHost*)_punkOuter)->SetBorderSpace( lpborderwidths ); - } - - return E_NOTIMPL; -} - -HRESULT CControlHost::SetActiveObject( - IOleInPlaceActiveObject* pActiveObject, - LPCOLESTR lpszObjName - ) -{ - TRACE( "CControlHost::SetActiveObject" ); - - UNUSED_ALWAYS( pActiveObject ); - UNUSED_ALWAYS( lpszObjName ); - - return E_NOTIMPL; -} - -////////////////////////////////////////////////////////////////////////// -// IOleInPlaceFrame methods - -HRESULT CControlHost::InsertMenus( - HMENU hmenuShared, - LPOLEMENUGROUPWIDTHS lpMenuWidths - ) -{ - TRACE( "CControlHost::InsertMenus" ); - - UNUSED_ALWAYS( hmenuShared ); - UNUSED_ALWAYS( lpMenuWidths ); - - return E_NOTIMPL; -} - -HRESULT CControlHost::SetMenu( - HMENU hmenuShared, - HOLEMENU holemenu, - HWND hwndActiveObject - ) -{ - TRACE( "CControlHost::SetMenu" ); - - UNUSED_ALWAYS( hmenuShared ); - UNUSED_ALWAYS( holemenu ); - UNUSED_ALWAYS( hwndActiveObject ); - - return E_NOTIMPL; -} - -HRESULT CControlHost::RemoveMenus( - HMENU hmenuShared - ) -{ - TRACE( "CControlHost::RemoveMenus" ); - - UNUSED_ALWAYS( hmenuShared ); - - return E_NOTIMPL; -} - -HRESULT CControlHost::SetStatusText( - LPCOLESTR pszStatusText - ) -{ - TRACE( "CControlHost::SetStatusText" ); - - UNUSED_ALWAYS( pszStatusText ); - - return E_NOTIMPL; -} - -HRESULT CControlHost::EnableModeless( - BOOL fEnable - ) -{ - TRACE( "CControlHost::EnableModeless" ); - - UNUSED_ALWAYS( fEnable ); - - return E_NOTIMPL; -} - -HRESULT CControlHost::TranslateAccelerator( - LPMSG lpmsg, - WORD wID - ) -{ - TRACE( "CControlHost::TranslateAccelerator" ); - - UNUSED_ALWAYS( lpmsg ); - UNUSED_ALWAYS( wID ); - - return E_NOTIMPL; -} - -#ifdef IMPLEMENT_IOLECONTROLSITE - -////////////////////////////////////////////////////////////////////////// -// IOleControlSite methods - -HRESULT CControlHost::OnControlInfoChanged( - void - ) -{ - TRACE( "CControlHost::OnControlInfoChanged" ); - - return E_NOTIMPL; -} - -HRESULT CControlHost::LockInPlaceActive( - BOOL fLock - ) -{ - TRACE( "CControlHost::LockInPlaceActive" ); - - UNUSED_ALWAYS( fLock ); - - return E_NOTIMPL; -} - -HRESULT CControlHost::GetExtendedControl( - IDispatch** ppDisp - ) -{ - TRACE( "CControlHost::GetExtendedControl" ); - - if (ppDisp == NULL) - { - return E_INVALIDARG; - } - - *ppDisp = (IDispatch *)this; - AddRef(); - - return S_OK; -} - -HRESULT CControlHost::TransformCoords( - POINTL *pptlHimetric, - POINTF *pptfContainer, - DWORD dwFlags - ) -{ - TRACE( "CControlHost::TransformCoords" ); - - UNUSED_ALWAYS( pptlHimetric ); - UNUSED_ALWAYS( pptfContainer ); - UNUSED_ALWAYS( dwFlags ); - - return E_NOTIMPL; -} - -HRESULT CControlHost::TranslateAccelerator( - LPMSG pMsg, - DWORD grfModifiers - ) -{ - TRACE( "CControlHost::TranslateAccelerator" ); - - UNUSED_ALWAYS( pMsg ); - UNUSED_ALWAYS( grfModifiers ); - - return S_FALSE; -} - -HRESULT CControlHost::OnFocus( - BOOL fGotFocus - ) -{ - TRACE( "CControlHost::OnFocus" ); - - UNUSED_ALWAYS( fGotFocus ); - - return E_NOTIMPL; -} - -HRESULT CControlHost::ShowPropertyFrame( - void - ) -{ - TRACE( "CControlHost::ShowPropertyFrame" ); - - return E_NOTIMPL; -} - -#endif - -////////////////////////////////////////////////////////////////////////// -// IDispatch methods - -HRESULT CControlHost::GetIDsOfNames( - REFIID riid, - OLECHAR FAR* FAR* rgszNames, - unsigned int cNames, - LCID lcid, - DISPID FAR* rgdispid - ) -{ - UNUSED_ALWAYS( riid ); - UNUSED_ALWAYS( lcid ); - - HRESULT hr; // standard ole return code - LPOLESTR pName; - DISPID *pdispid; - - hr = S_OK; - pName = *rgszNames; - pdispid = rgdispid; - - for (UINT i=0; ibstrVal) - pvarResult->bstrVal = ::SysAllocString(L""); - - hr = S_OK; - - // If we STILL don't have a bstrVal. Clean up and return an empty variant. - if (!pvarResult->bstrVal) - { - VariantInit(pvarResult); - hr = E_FAIL; - } - - break; - - case DISPID_AMBIENT_USERMODE: - case DISPID_AMBIENT_MESSAGEREFLECT: - pvarResult->vt = VT_BOOL; - pvarResult->boolVal = TRUE; - hr = S_OK; - break; - - case DISPID_AMBIENT_SHOWHATCHING: - case DISPID_AMBIENT_SHOWGRABHANDLES: - case DISPID_AMBIENT_SUPPORTSMNEMONICS: - pvarResult->vt = VT_BOOL; - pvarResult->boolVal = FALSE; - hr = S_OK; - break; - - // Not yet implemented! - case DISPID_AMBIENT_BACKCOLOR: - case DISPID_AMBIENT_FORECOLOR: - case DISPID_AMBIENT_UIDEAD: - case DISPID_AMBIENT_AUTOCLIP: - hr = S_OK; - break; - - // Extender Properties - case DISPID_BASEHREF: - case DISPID_ALIGN: - hr = DISP_E_MEMBERNOTFOUND; - break; - - default: - hr = DISP_E_MEMBERNOTFOUND; - } - - return hr; -} - diff --git a/stella/src/win32/CoolCaption.cxx b/stella/src/win32/CoolCaption.cxx deleted file mode 100644 index f619590f0..000000000 --- a/stella/src/win32/CoolCaption.cxx +++ /dev/null @@ -1,284 +0,0 @@ -// -// StellaX -// Jeff Miller 05/01/2000 -// - -#include "pch.hxx" -#include "CoolCaption.hxx" - -// MAKE SURE STYLE IS JUST "TITLE BAR" ! - -CCoolCaption::CCoolCaption( - ) : \ - m_hfont( NULL ), - m_tszCaption( NULL ), - m_fIsActive( FALSE ), - m_hDlg( NULL ) -{ -} - -void CCoolCaption::OnInitDialog( - HWND hDlg - ) -{ - m_hDlg = hDlg; - - CalculateNCArea(); -} - -void CCoolCaption::OnDestroy( - void - ) -{ - if ( m_hDlg == NULL ) - { - return; - } - - if ( m_hfont ) - { - ::DeleteObject( m_hfont ); - } - - delete[] m_tszCaption; - m_tszCaption = NULL; -} - -void CCoolCaption::CalculateNCArea( - ) -{ - if ( m_hDlg == NULL ) - { - return; - } - - ::GetWindowRect(m_hDlg, &m_rcWindow); - m_cxWindow = (m_rcWindow.right - m_rcWindow.left); - m_cyWindow = (m_rcWindow.bottom - m_rcWindow.top); - - m_cxFrame = ::GetSystemMetrics(SM_CXFRAME); - m_cyFrame = ::GetSystemMetrics(SM_CYFRAME); - - m_cxButtonSize = ::GetSystemMetrics(SM_CXSIZE); - - const int cyCaption = ::GetSystemMetrics(SM_CYCAPTION); - - // This is the size of the caption - - ::SetRect(&m_rcCaption, 0, 0, m_cxWindow, cyCaption + m_cyFrame); - - // calculate position of buttons - - SetRect(&m_rcClose, - m_cxWindow - m_cxFrame - m_cxButtonSize + 1, - m_rcCaption.top + m_cyFrame + 1, - m_cxWindow - m_cxFrame - 1, - m_rcCaption.bottom - m_cyFrame - ); - - CopyRect(&m_rcMin, &m_rcClose); - OffsetRect(&m_rcMin, -(m_cxButtonSize-2), 0); - - // figure out union of all buttons - - RECT rcButtons; - UnionRect(&rcButtons, &m_rcClose, &m_rcMin); - - SetRect(&m_rcTextArea, m_cxFrame, m_rcCaption.top+m_cyFrame, - rcButtons.left-m_cxFrame, m_rcCaption.bottom-m_cyFrame); - - // Make bold caption font - - m_hfont = (HFONT)SendMessage(m_hDlg, WM_GETFONT, 0, 0); - LOGFONT lf; - GetObject(m_hfont, sizeof(lf), &lf); - lf.lfWeight = FW_BOLD; - m_hfont = CreateFontIndirect(&lf); - - // Get caption text - - int nCaptionLength = GetWindowTextLength(m_hDlg); - m_tszCaption = new TCHAR[nCaptionLength + 2]; - GetWindowText(m_hDlg, m_tszCaption, nCaptionLength+1); -} - - -void CCoolCaption::OnNcPaint( - HRGN hrgn - ) -{ - UNUSED_ALWAYS( hrgn ); - - if ( m_hDlg == NULL ) - { - return; - } - - HDC hdc = GetWindowDC(m_hDlg); - - // Fill in the NC area with the proper color - - HPEN hpen, hpenOld; - - hpen = CreatePen(PS_SOLID, 1, m_fIsActive ? - GetSysColor(COLOR_ACTIVECAPTION) : \ - GetSysColor(COLOR_INACTIVECAPTION)); - hpenOld = (HPEN)SelectObject(hdc, hpen); - - for (long x = 0; x < m_cxWindow; ++x) - { - if (x < m_cxFrame-1 || x > m_cxWindow-m_cxFrame) - { - // left, right must go from top to bottom - - MoveToEx(hdc, x, 0, NULL); - LineTo(hdc, x, m_rcWindow.bottom); - } - else - { - // otherwise just do top and bottom - - MoveToEx(hdc, x, 0, NULL); - LineTo(hdc, x, m_rcCaption.bottom); - - MoveToEx(hdc, x, m_cyWindow-m_cyFrame, NULL); - LineTo(hdc, x, m_cyWindow); - } - } - - SelectObject(hdc, hpenOld); - DeleteObject(hpen); - - // Draw the close button - - DrawFrameControl(hdc, &m_rcClose, DFC_CAPTION, DFCS_CAPTIONCLOSE); - - // draw the minimize button - - DrawFrameControl(hdc, &m_rcMin, DFC_CAPTION, DFCS_CAPTIONMIN); - - // Draw the caption text - - SetTextColor(hdc, m_fIsActive ? GetSysColor(COLOR_CAPTIONTEXT) : \ - GetSysColor(COLOR_INACTIVECAPTIONTEXT)); - SetBkMode(hdc, TRANSPARENT); - - HFONT hfontOld = (HFONT)SelectObject(hdc, m_hfont); - - // calculate width / height of text - - SIZE sizeText; - GetTextExtentPoint(hdc, m_tszCaption, lstrlen(m_tszCaption), &sizeText); - - DrawText(hdc, m_tszCaption, -1, &m_rcTextArea, - DT_END_ELLIPSIS | DT_EXTERNALLEADING | - DT_NOPREFIX | DT_SINGLELINE | DT_VCENTER); - - SelectObject(hdc, hfontOld); - - // Draw the docking grippers - - const int nTextRight = m_rcTextArea.left + sizeText.cx + m_cxFrame; - - // right top - - COLORREF cr3dHilight = GetSysColor(COLOR_3DHILIGHT); - COLORREF cr3dShadow = GetSysColor(COLOR_3DSHADOW); - - Draw3dRect(hdc, nTextRight+m_cxFrame, 8, - m_rcTextArea.right-(nTextRight+m_cxFrame), 3, - cr3dHilight, cr3dShadow); - - // right bottom - - Draw3dRect(hdc, nTextRight+m_cxFrame, 12, - m_rcTextArea.right-(nTextRight+m_cxFrame), 3, - cr3dHilight, cr3dShadow); - - ReleaseDC(m_hDlg, hdc); -} - -void CCoolCaption::OnNcActivate( - BOOL fActive - ) -{ - if (m_hDlg == NULL) - return; - - m_fIsActive = fActive; - - // This fixes a problem where alt-tab wont repaint the NC area - - RedrawWindow(m_hDlg, NULL, NULL, - RDW_INVALIDATE | RDW_FRAME | RDW_UPDATENOW | RDW_ERASE); -} - -BOOL CCoolCaption::OnNCLButtonDown( - INT nHitTest, - POINTS pts - ) -{ - UNUSED_ALWAYS( nHitTest ); - - if ( m_hDlg == NULL ) - { - return FALSE; - } - - // Get the point in client units - - RECT rcWindow; - GetWindowRect(m_hDlg, &rcWindow); - - POINT pt = { pts.x, pts.y }; - pt.x -= rcWindow.left; - pt.y -= rcWindow.top; - - if (PtInRect(&m_rcClose, pt)) - { - // This isn't closing it! - // SendMessage(m_hDlg, WM_CLOSE, 0, 0); - EndDialog(m_hDlg, IDCANCEL); - return TRUE; - } - - if (PtInRect(&m_rcMin, pt)) - { - ShowWindow(m_hDlg, SW_MINIMIZE); - return TRUE; - } - - return FALSE; -} - -void CCoolCaption::FillSolidRect( - HDC hdc, - int x, - int y, - int cx, - int cy, - COLORREF clr - ) -{ - COLORREF cr = SetBkColor(hdc, clr); - RECT rect = { x, y, x+cx, y+cy }; - ExtTextOut(hdc, 0, 0, ETO_OPAQUE, &rect, NULL, 0, NULL); - SetBkColor(hdc, cr); -} - -void CCoolCaption::Draw3dRect( - HDC hdc, - int x, - int y, - int cx, - int cy, - COLORREF clrTopLeft, - COLORREF clrBottomRight - ) -{ - FillSolidRect(hdc, x, y, cx - 1, 1, clrTopLeft); - FillSolidRect(hdc, x, y, 1, cy - 1, clrTopLeft); - FillSolidRect(hdc, x + cx, y, -1, cy, clrBottomRight); - FillSolidRect(hdc, x, y + cy, cx, -1, clrBottomRight); -} - diff --git a/stella/src/win32/CoolCaption.hxx b/stella/src/win32/CoolCaption.hxx deleted file mode 100644 index c10d78eb4..000000000 --- a/stella/src/win32/CoolCaption.hxx +++ /dev/null @@ -1,51 +0,0 @@ -// -// StellaX -// Jeff Miller 05/01/2000 -// - -#ifndef COOLCAP_H -#define COOLCAP_H -#pragma once - -class CCoolCaption -{ -public: - CCoolCaption(); - - void OnInitDialog(HWND hDlg); - void OnDestroy(); - - void OnNcPaint(HRGN); - void OnNcActivate(BOOL); - BOOL OnNCLButtonDown(INT, POINTS); - -protected: - - HWND m_hDlg; - -private: - - void CalculateNCArea(void); - void FillSolidRect(HDC hdc, int x, int y, int cx, int cy, COLORREF clr); - void Draw3dRect(HDC hdc, int x, int y, int cx, int cy, - COLORREF clrTopLeft, COLORREF clrBottomRight); - - BOOL m_fIsActive; - RECT m_rcWindow; - int m_cxWindow; - int m_cyWindow; - int m_cxFrame; - int m_cyFrame; - int m_cxButtonSize; - RECT m_rcClose; - RECT m_rcMin; - RECT m_rcCaption; - RECT m_rcTextArea; - HFONT m_hfont; - LPTSTR m_tszCaption; - - CCoolCaption( const CCoolCaption& ); // no implementation - void operator=( const CCoolCaption& ); // no implementation -}; - -#endif diff --git a/stella/src/win32/DocPage.cxx b/stella/src/win32/DocPage.cxx deleted file mode 100644 index 0aac1991d..000000000 --- a/stella/src/win32/DocPage.cxx +++ /dev/null @@ -1,153 +0,0 @@ -// -// StellaX -// Jeff Miller 05/12/2000 -// -#include "pch.hxx" -#include "DocPage.hxx" -#include "resource.h" - -#include - -static LPCTSTR g_ctszDocFile = _T("\\docs\\stella.pdf"); - -const CLSID CPDFControl::clsid = { 0xCA8A9780, 0x280D, 0x11CF, - { 0xA2, 0x4D, 0x44, 0x45, 0x53, 0x54, 0x00, 0x00 } }; - -void CPDFControl::OnInitialUpdate( - void - ) -{ - // This will do a control.src = "c:\temp\a.pdf" - - IDispatch* piDispatch = NULL; - if (GetDispInterface(&piDispatch) != S_OK) - return; - - TCHAR tszDir[MAX_PATH + 1]; - ::GetCurrentDirectory(MAX_PATH, tszDir); - lstrcat(tszDir, g_ctszDocFile); - - VARIANT var; - VariantInit(&var); - var.vt = VT_BSTR; - -#if defined(_UNICODE) - BSTR bstr = ::SysAllocString(tszDir); - if (bstr == NULL) - return; -#else - int nLen = ::MultiByteToWideChar(CP_ACP, 0, tszDir, -1, NULL, NULL); - BSTR bstr = ::SysAllocStringLen(NULL, nLen); - if (bstr == NULL) - return; - ::MultiByteToWideChar(CP_ACP, 0, tszDir, -1, bstr, nLen); -#endif - - var.bstrVal = bstr; - - if (PutPropertyByName(L"src", &var) != S_OK) - { - VariantClear(&var); - piDispatch->Release(); - return; - } - - VariantClear(&var); - - // The following features are only in PDF 4.0 + - - VARIANT varRet; - VariantInit(&var); - - // This will do a control.setZoom(90) - - V_VT(&var) = VT_I1; - V_I1(&var) = 90; - - if (Invoke1(L"setZoom", &var, &varRet) != S_OK) - { - VariantClear(&var); - piDispatch->Release(); - return; - } - - VariantClear(&var); - VariantClear(&varRet); - - piDispatch->Release(); -} - -CDocPage::CDocPage( - ) : \ - CPropertyPage(IDD_DOC_PAGE), - m_pHost(NULL) -{ -} - -BOOL CDocPage::OnInitDialog( - HWND hwnd - ) -{ - TCHAR tszDir[MAX_PATH + 1]; - ::GetCurrentDirectory(MAX_PATH, tszDir); - lstrcat(tszDir, g_ctszDocFile); - - // verify file exists - - WIN32_FIND_DATA findFileData; - HANDLE hFind = ::FindFirstFile(tszDir, &findFileData); - if (hFind == INVALID_HANDLE_VALUE) - { - TCHAR tszMsg[MAX_PATH * 2]; - lstrcpy(tszMsg, _T("ERROR: Cannot find ")); - lstrcat(tszMsg, tszDir); - - HWND hwndInst = ::GetDlgItem(hwnd, IDC_INSTRUCTIONS); - ::SetWindowText(hwndInst, tszMsg); - ::ShowWindow(hwndInst, SW_SHOW); - - return TRUE; - } - ::FindClose(hFind); - - m_pHost = new CControlHost(new CPDFControl); - m_pHost->SetHwnd(hwnd); - - if (m_pHost->CreateControl() != S_OK) - { - ::ShowWindow(::GetDlgItem(hwnd, IDC_INSTRUCTIONS), SW_SHOW); - ::ShowWindow(::GetDlgItem(hwnd, IDC_ADOBE), SW_SHOW); - - m_hlAdobe.SubclassDlgItem(hwnd, IDC_ADOBE); - m_hlAdobe.SetURL(_T("http://www.adobe.com/prodindex/acrobat/alternate.html")); - - m_pHost = NULL; - } - - // return FALSE if SetFocus is called - return TRUE; -} - -void CDocPage::OnDestroy( - void - ) -{ - delete m_pHost; -} - -void CDocPage::OnActivate( - UINT state, - HWND hwndActDeact, - BOOL fMinimized - ) -{ - if ( state == WA_ACTIVE && !fMinimized && m_pHost ) - { - HWND hwnd = m_pHost->GetControlHWND(); - if ( hwnd ) - { - ::InvalidateRect( hwnd, NULL, TRUE ); - ::UpdateWindow( hwnd ); - } - } -} diff --git a/stella/src/win32/DocPage.hxx b/stella/src/win32/DocPage.hxx deleted file mode 100644 index d32faa6d0..000000000 --- a/stella/src/win32/DocPage.hxx +++ /dev/null @@ -1,57 +0,0 @@ -// -// StellaX -// Jeff Miller 05/12/2000 -// -#ifndef DOCPG_H -#define DOCPG_H -#pragma once - -#include "PropertySheet.hxx" -#include "ControlHost.hxx" -#include "HyperLink.hxx" - -class CPDFControl : public CActiveXControl -{ -public: - - CPDFControl() : CActiveXControl() - { - } - - REFCLSID GetCLSID() { return clsid; } - void OnInitialUpdate(); - -protected: - - static const CLSID clsid; - -private: - - CPDFControl( const CPDFControl& ); // no implementation - void operator=( const CPDFControl& ); // no implementation - -}; - -class CDocPage : public CPropertyPage -{ -public: - - CDocPage(); - -protected: - - virtual BOOL OnInitDialog(HWND hwnd); - virtual void OnDestroy(); - virtual void OnActivate( UINT state, HWND hwndActDeact, BOOL fMinimized ); - -private: - - CHyperLink m_hlAdobe; - CControlHost* m_pHost; - - CDocPage( const CDocPage& ); // no implementation - void operator=( const CDocPage& ); // no implementation - -}; - -#endif diff --git a/stella/src/win32/FileDialog.cxx b/stella/src/win32/FileDialog.cxx deleted file mode 100644 index 663a02804..000000000 --- a/stella/src/win32/FileDialog.cxx +++ /dev/null @@ -1,69 +0,0 @@ -// -// StellaX -// Jeff Miller 05/01/2000 -// -#include "pch.hxx" -#include "FileDialog.hxx" - -CFileDialog::CFileDialog( - BOOL bOpenFileDialog, // TRUE for FileOpen, FALSE for FileSaveAs - LPCTSTR lpszDefExt /* = NULL */, - LPCTSTR lpszFileName /* = NULL */, - DWORD dwFlags /* = OFN_HIDEREADONLY | OFN_OVERWRITEPROMPT */, - LPCTSTR lpszFilter /* = NULL */, - HWND hwndParent /* = NULL */ - ) -{ - UNUSED_ALWAYS( hwndParent ); - - memset(&m_ofn, 0, sizeof(m_ofn)); // initialize structure to 0/NULL - m_szFileName[0] = '\0'; - m_szFileTitle[0] = '\0'; - - m_bOpenFileDialog = bOpenFileDialog; - - m_ofn.lStructSize = sizeof(m_ofn); - m_ofn.lpstrFile = m_szFileName; - m_ofn.nMaxFile = _countof(m_szFileName); - m_ofn.lpstrDefExt = lpszDefExt; - m_ofn.lpstrFileTitle = (LPTSTR)m_szFileTitle; - m_ofn.nMaxFileTitle = _countof(m_szFileTitle); - m_ofn.Flags = (dwFlags | OFN_EXPLORER); - m_ofn.hInstance = NULL; - - // setup initial file name - if (lpszFileName != NULL) - lstrcpyn(m_szFileName, lpszFileName, _countof(m_szFileName)); - - // Translate filter into commdlg format (lots of \0) - if (lpszFilter != NULL) - { - lstrcpy(m_szFilter, lpszFilter); - LPTSTR pch = m_szFilter; // modify the buffer in place - // MFC delimits with '|' not '\0' - while ((pch = _tcschr(pch, '|')) != NULL) - *pch++ = '\0'; - m_ofn.lpstrFilter = m_szFilter; - // do not call ReleaseBuffer() since the string contains '\0' characters - } -} - -int CFileDialog::DoModal( - void - ) -{ - int nResult; - - if (m_bOpenFileDialog) - { - nResult = ::GetOpenFileName(&m_ofn); - } - else - { - nResult = ::GetSaveFileName(&m_ofn); - } - - return nResult ? nResult : IDCANCEL; -} - - diff --git a/stella/src/win32/FileDialog.hxx b/stella/src/win32/FileDialog.hxx deleted file mode 100644 index 65dcb4fd7..000000000 --- a/stella/src/win32/FileDialog.hxx +++ /dev/null @@ -1,51 +0,0 @@ -// -// StellaX -// Jeff Miller 05/01/2000 -// -#ifndef FILEDLG_H -#define FILEDLG_H -#pragma once - -class CFileDialog -{ -public: - - OPENFILENAME m_ofn; - - CFileDialog(BOOL bOpenFileDialog, // TRUE for FileOpen, FALSE for FileSaveAs - LPCTSTR lpszDefExt = NULL, - LPCTSTR lpszFileName = NULL, - DWORD dwFlags = OFN_HIDEREADONLY | OFN_OVERWRITEPROMPT, - LPCTSTR lpszFilter = NULL, - HWND hwndParent = NULL); - - virtual int DoModal(); - - LPCTSTR GetPathName() const - { - return m_ofn.lpstrFile; - } - - LPCTSTR GetFileName() const - { - return m_ofn.lpstrFileTitle; - } - -protected: - - BOOL m_bOpenFileDialog; // TRUE for file open, FALSE for file save - - TCHAR m_szFilter[1024]; // filter string - // separate fields with '|', terminate with '||\0' - - TCHAR m_szFileTitle[64]; // contains file title after return - TCHAR m_szFileName[_MAX_PATH]; // contains full path name after return - -private: - - CFileDialog( const CFileDialog& ); // no implementation - void operator=( const CFileDialog& ); // no implementation - -}; - -#endif \ No newline at end of file diff --git a/stella/src/win32/GlobalData.cxx b/stella/src/win32/GlobalData.cxx deleted file mode 100644 index de6157572..000000000 --- a/stella/src/win32/GlobalData.cxx +++ /dev/null @@ -1,39 +0,0 @@ -//============================================================================ -// -// SSSS tt lll lll -// SS SS tt ll ll -// SS tttttt eeee ll ll aaaa -// SSSS tt ee ee ll ll aa -// SS tt eeeeee ll ll aaaaa -- "An Atari 2600 VCS Emulator" -// SS SS tt ee ll ll aa aa -// SSSS ttt eeeee llll llll aaaaa -// -// Copyright (c) 1995-2000 by Jeff Miller -// Copyright (c) 2004 by Stephen Anthony -// -// See the file "license" for information on usage and redistribution of -// this file, and for a DISCLAIMER OF ALL WARRANTIES. -// -// $Id: GlobalData.cxx,v 1.3 2004-05-28 23:16:26 stephena Exp $ -//============================================================================ - -#include "pch.hxx" -#include "resource.h" - -#include "Settings.hxx" -#include "SettingsWin32.hxx" -#include "GlobalData.hxx" - - -CGlobalData::CGlobalData( HINSTANCE hInstance ) - : myInstance(hInstance) -{ - myPathName[0] = _T('\0'); - mySettings = new SettingsWin32(); -} - -CGlobalData::~CGlobalData() -{ - if(mySettings) - delete mySettings; -} diff --git a/stella/src/win32/GlobalData.hxx b/stella/src/win32/GlobalData.hxx deleted file mode 100644 index 5b9e4bbb3..000000000 --- a/stella/src/win32/GlobalData.hxx +++ /dev/null @@ -1,67 +0,0 @@ -//============================================================================ -// -// SSSS tt lll lll -// SS SS tt ll ll -// SS tttttt eeee ll ll aaaa -// SSSS tt ee ee ll ll aa -// SS tt eeeeee ll ll aaaaa -- "An Atari 2600 VCS Emulator" -// SS SS tt ee ll ll aa aa -// SSSS ttt eeeee llll llll aaaaa -// -// Copyright (c) 1995-2000 by Jeff Miller -// Copyright (c) 2004 by Stephen Anthony -// -// See the file "license" for information on usage and redistribution of -// this file, and for a DISCLAIMER OF ALL WARRANTIES. -// -// $Id: GlobalData.hxx,v 1.3 2004-05-28 23:16:26 stephena Exp $ -//============================================================================ - -#ifndef GLOBAL_DATA_HXX -#define GLOBAL_DATA_HXX - -#include "pch.hxx" -#include "bspf.hxx" - -class CConfigPage; -class Settings; - -class CGlobalData -{ - friend CConfigPage; - - public: - CGlobalData( HINSTANCE hInstance ); - ~CGlobalData( void ); - - LPCTSTR PathName( void ) const - { - if ( myPathName[0] == _T('\0') ) - return NULL; - - return myPathName; - } - - HINSTANCE ModuleInstance( void ) const - { - return myInstance; - } - - Settings& settings( void ) - { - return *mySettings; - } - - private: - Settings* mySettings; - - string myArgumentList; - - HINSTANCE myInstance; - TCHAR myPathName[ MAX_PATH ]; - - CGlobalData( const CGlobalData& ); // no implementation - void operator=( const CGlobalData& ); // no implementation -}; - -#endif diff --git a/stella/src/win32/HeaderCtrl.cxx b/stella/src/win32/HeaderCtrl.cxx deleted file mode 100644 index d00f1a0c7..000000000 --- a/stella/src/win32/HeaderCtrl.cxx +++ /dev/null @@ -1,200 +0,0 @@ -// -// StellaX -// Jeff Miller 05/01/2000 -// -#include "pch.hxx" -#include "HeaderCtrl.hxx" - -CHeaderCtrl::CHeaderCtrl( - ) : \ - m_nSortCol(0), - m_fSortAsc(TRUE) -{ -} - - -LRESULT CHeaderCtrl::WndProc( - HWND hWnd, - UINT msg, - WPARAM wParam, - LPARAM lParam, - BOOL& rfHandled - ) -{ - switch ( msg ) - { - case WM_DRAWITEM: - rfHandled = TRUE; - OnDrawItem(hWnd, (UINT)wParam, (LPDRAWITEMSTRUCT)lParam); - return TRUE; - } - - return 0; -} - -void CHeaderCtrl::SetSortCol( - int nCol, - BOOL bAsc - ) -{ - m_nSortCol = nCol; - m_fSortAsc = bAsc; - - // change this item to owner draw - - HWND hwndHeader = ::GetDlgItem( *this, 0 ); - - HDITEM hdi; - hdi.mask = HDI_FORMAT; - Header_GetItem(hwndHeader, nCol, &hdi); - hdi.fmt |= HDF_OWNERDRAW; - Header_SetItem(hwndHeader, nCol, &hdi); - - // repaint the header - - ::InvalidateRect(hwndHeader, NULL, TRUE); -} - -void CHeaderCtrl::OnDrawItem( - HWND hwnd, - UINT idCtl, - LPDRAWITEMSTRUCT lpdis - ) -{ - UNUSED_ALWAYS( idCtl ); - - HDC hdc = lpdis->hDC; - - RECT rcLabel; - ::CopyRect( &rcLabel, &(lpdis->rcItem) ); - - /* save the DC */ - - int nSavedDC = ::SaveDC( hdc ); - - /* set clip region to column */ - - HRGN hrgn = ::CreateRectRgnIndirect( &rcLabel ); - SelectObject( hdc, hrgn ); - DeleteObject( hrgn ); - - /* draw the background */ - - ::FillRect( hdc, &rcLabel, ::GetSysColorBrush(COLOR_3DFACE) ); - - /* offset the label */ - - SIZE size; - ::GetTextExtentPoint32( hdc, _T(" "), 1, &size ); - int nOffset = size.cx * 2; - - /* get the column text and format */ - - TCHAR tszText[255 + 1]; - HDITEM hdi; - hdi.mask = HDI_TEXT | HDI_FORMAT; - hdi.pszText = tszText; - hdi.cchTextMax = 255; - Header_GetItem( GetDlgItem(hwnd, 0), lpdis->itemID, &hdi ); - - /* determine format for drawing label */ - - UINT uFormat = DT_SINGLELINE | DT_NOPREFIX | DT_NOCLIP | - DT_VCENTER | DT_END_ELLIPSIS; - - /* determine justification */ - - if (hdi.fmt & HDF_CENTER) - { - uFormat |= DT_CENTER; - } - else if (hdi.fmt & HDF_RIGHT) - { - uFormat |= DT_RIGHT; - } - else - { - uFormat |= DT_LEFT; - } - - /* adjust the rect if selected */ - - if (lpdis->itemState & ODS_SELECTED) - { - rcLabel.left++; - rcLabel.top += 2; - rcLabel.right++; - } - - /* adjust rect for sort arrow */ - - if ( lpdis->itemID == m_nSortCol ) - { - rcLabel.right -= (3 * nOffset); - } - - rcLabel.left += nOffset; - rcLabel.right -= nOffset; - - /* draw label */ - - if ( rcLabel.left < rcLabel.right ) - { - ::DrawText(hdc, tszText, -1, &rcLabel, uFormat ); - } - - /* draw the arrow */ - - if ( lpdis->itemID == m_nSortCol ) - { - RECT rcIcon; - HPEN hpenLight, hpenShadow, hpenOld; - - ::CopyRect( &rcIcon, &(lpdis->rcItem) ); - - hpenLight = ::CreatePen( PS_SOLID, 1, GetSysColor(COLOR_3DHILIGHT) ); - hpenShadow = ::CreatePen( PS_SOLID, 1, GetSysColor(COLOR_3DSHADOW) ); - hpenOld = (HPEN)::SelectObject( hdc, hpenLight ); - - if (m_fSortAsc) - { - /* draw triangle pointing up */ - - ::MoveToEx( hdc, rcIcon.right - 2 * nOffset, nOffset - 1, NULL ); - ::LineTo( hdc, rcIcon.right - 3 * nOffset / 2, - rcIcon.bottom - nOffset ); - ::LineTo( hdc, rcIcon.right - 5 * nOffset / 2 - 2, - rcIcon.bottom - nOffset ); - ::MoveToEx( hdc, rcIcon.right - 5 * nOffset / 2 - 1, - rcIcon.bottom - nOffset, NULL ); - - ::SelectObject( hdc, hpenShadow ); - ::LineTo( hdc, rcIcon.right - 2 * nOffset, nOffset - 2 ); - } - else - { - /* draw triangle pointing down */ - - ::MoveToEx( hdc, rcIcon.right - 3 * nOffset / 2, nOffset - 1, - NULL ); - ::LineTo( hdc, rcIcon.right - 2 * nOffset - 1, - rcIcon.bottom - nOffset ); - ::LineTo( hdc, rcIcon.right - 2 * nOffset - 1, - rcIcon.bottom - nOffset ); - ::MoveToEx( hdc, rcIcon.right - 2 * nOffset - 1, - rcIcon.bottom - nOffset, NULL ); - - ::SelectObject( hdc, hpenShadow ); - ::LineTo( hdc, rcIcon.right - 5 * nOffset / 2 - 1, - nOffset - 1 ); - ::LineTo( hdc, rcIcon.right - 3 * nOffset / 2, - nOffset - 1 ); - } - - ::SelectObject( hdc, hpenOld ); - ::DeleteObject( hpenShadow ); - ::DeleteObject( hpenLight ); - } - - ::RestoreDC( hdc, nSavedDC ); -} diff --git a/stella/src/win32/HeaderCtrl.hxx b/stella/src/win32/HeaderCtrl.hxx deleted file mode 100644 index 156ade0b3..000000000 --- a/stella/src/win32/HeaderCtrl.hxx +++ /dev/null @@ -1,54 +0,0 @@ -// -// StellaX -// Jeff Miller 05/01/2000 -// -#ifndef HDRCTL_H -#define HDRCTL_H -#pragma once - -#include "Wnd.hxx" - -class CHeaderCtrl : public CWnd -{ -public: - - CHeaderCtrl(); - - void SetSortCol(int nCol, BOOL fAscending); - int GetSortCol(void) const; - BOOL GetSortAsc(void) const; - -protected: - - LRESULT WndProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM lParam, - BOOL& rfHandled); - -private: - - void OnDrawItem(HWND hwnd, UINT idCtl, LPDRAWITEMSTRUCT lpdis); - - UINT m_nSortCol; - BOOL m_fSortAsc; - - CHeaderCtrl( const CHeaderCtrl& ); // no implementation - void operator=( const CHeaderCtrl& ); // no implementation - -}; - -inline int CHeaderCtrl::GetSortCol -( - void -) const -{ - return m_nSortCol; -} - -inline BOOL CHeaderCtrl::GetSortAsc -( - void -) const -{ - return m_fSortAsc; -} - -#endif diff --git a/stella/src/win32/HyperLink.cxx b/stella/src/win32/HyperLink.cxx deleted file mode 100644 index 5e597c7be..000000000 --- a/stella/src/win32/HyperLink.cxx +++ /dev/null @@ -1,352 +0,0 @@ -// -// StellaX -// Jeff Miller 05/01/2000 -// -#include "pch.hxx" -#include "HyperLink.hxx" - -#include - -CHyperLink::CHyperLink( - ) : \ - m_bOverControl(FALSE), - m_bVisited(FALSE), - m_hFont(NULL), - m_hLinkCursor(NULL) -{ - m_crLinkColor = RGB( 0, 0, 238); // Blue - m_crVisitedColor = RGB( 85, 26, 139); // Purple - m_crHoverColor = ::GetSysColor(COLOR_HIGHLIGHT); - - SetDefaultCursor(); -} - -CHyperLink::~CHyperLink( - ) -{ - if (m_hFont) - { - ::DeleteObject( m_hFont ); - m_hFont = NULL; - } -} - -void CHyperLink::SetURL( - LPCTSTR ctszURL - ) -{ - if (ctszURL == NULL) - return; - - lstrcpy(m_tszURL, ctszURL); - -} - -void CHyperLink::PreSubclassWindow( - HWND hwnd - ) -{ - ::GetWindowText( hwnd, m_tszText, MAX_HYPERLINK_TEXT_LEN ); - - m_hFont = (HFONT)::SendMessage(hwnd, WM_GETFONT, 0, 0); -} - -LRESULT CHyperLink::WndProc( - HWND hwnd, - UINT msg, - WPARAM wParam, - LPARAM lParam, - BOOL& rfHandled - ) -{ - switch (msg) - { - case WM_PAINT: - rfHandled = TRUE; - return OnPaint(hwnd); - - case WM_SETCURSOR: - rfHandled = TRUE; - return OnSetCursor(hwnd, LOWORD(lParam), HIWORD(lParam)); - - case WM_LBUTTONUP: - rfHandled = TRUE; - return OnLButtonUp(hwnd, wParam, LOWORD(lParam), - HIWORD(lParam)); - - case WM_MOUSEMOVE: - rfHandled = TRUE; - return OnMouseMove(hwnd, wParam, LOWORD(lParam), - HIWORD(lParam)); - } - - return 0; -} - -LRESULT CHyperLink::OnPaint( - HWND hwnd - ) -{ - PAINTSTRUCT ps; - HDC hdc = BeginPaint(hwnd, &ps); - - SelectObject(hdc, m_hFont); - - if (m_bOverControl) - { - SetTextColor(hdc, m_crHoverColor); - } - else if (m_bVisited) - { - SetTextColor(hdc, m_crVisitedColor); - } - else - { - SetTextColor(hdc, m_crLinkColor); - } - - ::SetBkMode( hdc, TRANSPARENT ); - - ::TextOut( hdc, 0, 0, m_tszText, lstrlen(m_tszText) ); - - EndPaint(hwnd, &ps); - return 0; -} - -BOOL CHyperLink::OnSetCursor( - HWND hwnd, - WORD nHittest, - WORD wMouseMsg - ) -{ - UNUSED_ALWAYS( hwnd ); - UNUSED_ALWAYS( nHittest ); - UNUSED_ALWAYS( wMouseMsg ); - - if (m_hLinkCursor) - { - ::SetCursor(m_hLinkCursor); - return TRUE; - } - - return FALSE; -} - -LRESULT CHyperLink::OnLButtonUp( - HWND hwnd, - WPARAM fwKeys, - WORD xPos, - WORD yPos - ) -{ - UNUSED_ALWAYS( fwKeys ); - UNUSED_ALWAYS( xPos ); - UNUSED_ALWAYS( yPos ); - - int result = (int)GotoURL(m_tszURL, SW_SHOW); - m_bVisited = (result > HINSTANCE_ERROR); - if (!m_bVisited) - { - MessageBeep(MB_ICONEXCLAMATION); - ReportError(result); - } - else - { - m_bVisited = TRUE; - InvalidateRect(hwnd, NULL, FALSE); - } - - return 0; -} - -LRESULT CHyperLink::OnMouseMove( - HWND hwnd, - WPARAM fwKeys, - WORD xPos, - WORD yPos - ) -{ - UNUSED_ALWAYS( fwKeys ); - - // call defwindowproc? - - if (m_bOverControl) - { - RECT rc; - GetClientRect(hwnd, &rc); - - POINT pt = { xPos, yPos }; - if (!PtInRect(&rc, pt)) - { - m_bOverControl = FALSE; - ReleaseCapture(); - RedrawWindow(hwnd, NULL, NULL, - RDW_INVALIDATE | RDW_UPDATENOW | RDW_ERASE); - } - } - else - { - m_bOverControl = TRUE; - RedrawWindow(hwnd, NULL, NULL, - RDW_INVALIDATE | RDW_UPDATENOW | RDW_ERASE); - SetCapture(hwnd); - } - - return 0; -} - -// The following appeared in Paul DiLascia's Jan 1998 MSJ articles. -// It loads a "hand" cursor from the winhlp32.exe module - -void CHyperLink::SetDefaultCursor( - void - ) -{ - if (m_hLinkCursor == NULL) // No cursor handle - load our own - { - // Get the windows directory - - TCHAR tszWndDir[MAX_PATH + 1]; - GetWindowsDirectory(tszWndDir, MAX_PATH); - - lstrcat(tszWndDir, _T("\\winhlp32.exe")); - - // This retrieves cursor #106 from winhlp32.exe, which is a hand pointer - HMODULE hModule = LoadLibrary(tszWndDir); - if (hModule) { - HCURSOR hHandCursor = ::LoadCursor(hModule, MAKEINTRESOURCE(106)); - if (hHandCursor) - m_hLinkCursor = CopyCursor(hHandCursor); - } - FreeLibrary(hModule); - } -} - -LONG CHyperLink::GetRegKey( - HKEY key, - LPCTSTR subkey, - LPTSTR retdata - ) -{ - HKEY hkey; - LONG retval = RegOpenKeyEx(key, subkey, 0, KEY_QUERY_VALUE, &hkey); - - if (retval == ERROR_SUCCESS) { - long datasize = MAX_PATH; - TCHAR data[MAX_PATH]; - RegQueryValue(hkey, NULL, data, &datasize); - lstrcpy(retdata,data); - RegCloseKey(hkey); - } - - return retval; -} - -void CHyperLink::ReportError( - int nError - ) -{ - TCHAR tsz[MAX_HYPERLINK_TEXT_LEN + 1]; - switch (nError) - { - case 0: - lstrcpy(tsz, _T("The operating system is out\nof memory or resources.")); - break; - - case SE_ERR_PNF: - lstrcpy(tsz, _T("The specified path was not found.")); - break; - - case SE_ERR_FNF: - lstrcpy(tsz, _T("The specified file was not found.")); - break; - - case ERROR_BAD_FORMAT: - lstrcpy(tsz, _T("The .EXE file is invalid\n(non-Win32 .EXE or error in .EXE image).")); - break; - - case SE_ERR_ACCESSDENIED: - lstrcpy(tsz, _T("The operating system denied\naccess to the specified file.")); - break; - - case SE_ERR_ASSOCINCOMPLETE: - lstrcpy(tsz,_T("The filename association is\nincomplete or invalid.")); - break; - - case SE_ERR_DDEBUSY: - lstrcpy(tsz, _T("The DDE transaction could not\nbe completed because other DDE transactions\nwere being processed.")); - break; - - case SE_ERR_DDEFAIL: - lstrcpy(tsz, _T("The DDE transaction failed.")); - break; - - case SE_ERR_DDETIMEOUT: - lstrcpy(tsz, _T("The DDE transaction could not\nbe completed because the request timed out.")); - break; - - case SE_ERR_DLLNOTFOUND: - lstrcpy(tsz, _T("The specified dynamic-link library was not found.")); - break; - - case SE_ERR_NOASSOC: - lstrcpy(tsz, __T("There is no application associated\nwith the given filename extension.")); - break; - - case SE_ERR_OOM: - lstrcpy(tsz, _T("There was not enough memory to complete the operation.")); - break; - - case SE_ERR_SHARE: - lstrcpy(tsz, _T("A sharing violation occurred.")); - break; - - default: - wsprintf(tsz, _T("Unknown error %d occurred."), nError); - break; - } - - TCHAR tszCaption[MAX_HYPERLINK_TEXT_LEN + 1]; - lstrcpy(tszCaption, _T("Unable to open hyperlink")); - - MessageBox(NULL, tsz, tszCaption, MB_ICONEXCLAMATION | MB_OK); -} - -HINSTANCE CHyperLink::GotoURL( - LPCTSTR url, - int showcmd - ) -{ - TCHAR key[MAX_PATH + MAX_PATH]; - - // First try ShellExecute() - HINSTANCE result = ShellExecute(NULL, _T("open"), url, NULL,NULL, showcmd); - - // If it failed, get the .htm regkey and lookup the program - if ((UINT)result <= HINSTANCE_ERROR) { - - if (GetRegKey(HKEY_CLASSES_ROOT, _T(".htm"), key) == ERROR_SUCCESS) { - lstrcat(key, _T("\\shell\\open\\command")); - - if (GetRegKey(HKEY_CLASSES_ROOT,key,key) == ERROR_SUCCESS) { - TCHAR *pos; - pos = _tcsstr(key, _T("\"%1\"")); - if (pos == NULL) { // No quotes found - pos = strstr(key, _T("%1")); // Check for %1, without quotes - if (pos == NULL) // No parameter at all... - pos = key+lstrlen(key)-1; - else - *pos = '\0'; // Remove the parameter - } - else - *pos = '\0'; // Remove the parameter - - lstrcat(pos, _T(" ")); - lstrcat(pos, url); - result = (HINSTANCE) WinExec(key,showcmd); - } - } - } - - return result; -} diff --git a/stella/src/win32/HyperLink.hxx b/stella/src/win32/HyperLink.hxx deleted file mode 100644 index 24646ccce..000000000 --- a/stella/src/win32/HyperLink.hxx +++ /dev/null @@ -1,66 +0,0 @@ -// -// StellaX -// Jeff Miller 05/01/2000 -// -#ifndef HYPERLINK_H -#define HYPERLINK_H -#pragma once - -#define MAX_HYPERLINK_TEXT_LEN 256 -#define MAX_HYPERLINK_URL 256 - -#include "Wnd.hxx" - -class CHyperLink : public CWnd -{ -public: - CHyperLink(); - ~CHyperLink(); - - void SetURL(LPCTSTR ctszURL); - -protected: - - virtual void PreSubclassWindow(HWND hwnd); - virtual LRESULT WndProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM lParam, - BOOL& rfHandled); - -private: - - void SetDefaultCursor(); - LONG GetRegKey(HKEY key, LPCTSTR subkey, LPTSTR retdata); - void ReportError(int nError); - HINSTANCE GotoURL(LPCTSTR url, int showcmd); - - static LRESULT CALLBACK WndProc(HWND hWnd, UINT msg, - WPARAM wParam, LPARAM lParam); - - HBRUSH OnCtlColorStatic(HWND hwnd, HDC hdcStatic, HWND hwndStatic); - BOOL OnSetCursor(HWND hwnd, WORD nHittest, WORD wMouseMsg); - LRESULT OnPaint(HWND hwnd); - LRESULT OnLButtonUp(HWND, WPARAM, WORD, WORD); - LRESULT OnMouseMove(HWND, WPARAM, WORD, WORD); - - // Stuff from the control - - TCHAR m_tszText[MAX_HYPERLINK_TEXT_LEN + 1]; - HFONT m_hFont; - - // link specific - - COLORREF m_crLinkColor; - COLORREF m_crVisitedColor; - COLORREF m_crHoverColor; - - BOOL m_bOverControl; - BOOL m_bVisited; - - HCURSOR m_hLinkCursor; - - TCHAR m_tszURL[MAX_HYPERLINK_URL + 1]; - - CHyperLink( const CHyperLink& ); // no implementation - void operator=( const CHyperLink& ); // no implementation -}; - -#endif diff --git a/stella/src/win32/MainDlg.cxx b/stella/src/win32/MainDlg.cxx deleted file mode 100644 index dbedb72b7..000000000 --- a/stella/src/win32/MainDlg.cxx +++ /dev/null @@ -1,853 +0,0 @@ -//============================================================================ -// -// SSSS tt lll lll -// SS SS tt ll ll -// SS tttttt eeee ll ll aaaa -// SSSS tt ee ee ll ll aa -// SS tt eeeeee ll ll aaaaa -- "An Atari 2600 VCS Emulator" -// SS SS tt ee ll ll aa aa -// SSSS ttt eeeee llll llll aaaaa -// -// Copyright (c) 1995-2000 by Jeff Miller -// Copyright (c) 2004 by Stephen Anthony -// -// See the file "license" for information on usage and redistribution of -// this file, and for a DISCLAIMER OF ALL WARRANTIES. -// -// $Id: MainDlg.cxx,v 1.3 2004-05-28 23:16:26 stephena Exp $ -//============================================================================ - -#include "pch.hxx" -#include "MainDlg.hxx" -#include "GlobalData.hxx" -#include "PropertySheet.hxx" -#include "AboutPage.hxx" -#include "DocPage.hxx" -#include "ConfigPage.hxx" -#include "resource.h" -#include "Settings.hxx" - -#define BKGND_BITMAP_TOP 64 -#define BKGND_BITMAP_BOTTOM 355 - -// NOTE: LVS_OWNERDATA doesn't support LVM_SORTITEMS! - -// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -inline LPARAM ListView_GetItemData( HWND hwndList, int iItem ) -{ - LVITEM lvi; - lvi.mask = LVIF_PARAM; - lvi.iItem = iItem; - lvi.iSubItem = 0; - - ListView_GetItem(hwndList, &lvi); - - return lvi.lParam; -} - -// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -CMainDlg::CMainDlg( CGlobalData& rGlobalData, HINSTANCE hInstance ) - : myGlobalData(rGlobalData), - m_hInstance(hInstance) -{ -} - -// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -void CMainDlg::ClearList( void ) -{ - int nCount = ListView_GetItemCount( m_hwndList ); - - for (int i = 0; i < nCount; ++i) - delete (CListData*)ListView_GetItemData( m_hwndList, i ); - - ListView_DeleteAllItems( m_hwndList ); -} - -// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -int CMainDlg::DoModal( HWND hwndParent ) -{ - return DialogBoxParam( m_hInstance, - MAKEINTRESOURCE(IDD), - hwndParent, - StaticDialogFunc, - (LPARAM)this ); -} - -// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -BOOL CALLBACK -CMainDlg::StaticDialogFunc( HWND hDlg, UINT uMsg, WPARAM wParam, LPARAM lParam ) -{ - CMainDlg* pDlg; - - switch ( uMsg ) - { - case WM_INITDIALOG: - pDlg = reinterpret_cast( lParam ); - pDlg->m_hwnd = hDlg; - (void)::SetWindowLong( hDlg, DWL_USER, reinterpret_cast( pDlg ) ); - break; - - default: - pDlg = reinterpret_cast( ::GetWindowLong( hDlg, DWL_USER ) ); - if ( pDlg == NULL ) - return FALSE; - break; - } - - return pDlg->DialogFunc( uMsg, wParam, lParam ); -} - -// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -BOOL CALLBACK -CMainDlg::DialogFunc( UINT uMsg, WPARAM wParam, LPARAM lParam ) -{ - BOOL b; - - switch (uMsg) - { - case WM_COMMAND: - return OnCommand( LOWORD(wParam), (HWND)lParam, HIWORD(wParam) ); - - case WM_CTLCOLORSTATIC: - b = (BOOL)OnCtlColorStatic( (HDC)wParam, (HWND)lParam ); - if (b) - return b; - break; - - case WM_ERASEBKGND: - if ( OnEraseBkgnd( (HDC)wParam ) ) - return TRUE; - break; - - case WM_INITDIALOG: - return OnInitDialog( ); - - case WM_NOTIFY: - return OnNotify( (int)wParam, (LPNMHDR)lParam ); - - case WM_PALETTECHANGED: - TRACE( "WM_PALETTECHANGED from maindlg" ); - return FALSE; - - case WM_QUERYNEWPALETTE: - TRACE( "WM_QUERYNEWPALETTE from maindlg" ); - return FALSE; - - // Cool caption handlers - case WM_DESTROY: - OnDestroy( ); - break; - - case WM_DRAWITEM: - // Forward this onto the control - ::SendMessage( ((LPDRAWITEMSTRUCT)lParam)->hwndItem, WM_DRAWITEM, wParam, lParam ); - return TRUE; - - case WM_NCPAINT: - // DefWindowProc(hDlg, uMsg, wParam, lParam); - OnNcPaint( (HRGN)wParam ); - return TRUE; - - case WM_NCACTIVATE: - OnNcActivate( (BOOL)wParam ); - // When the fActive parameter is FALSE, an application should return - // TRUE to indicate that the system should proceed with the default - // processing - SetWindowLong( m_hwnd, DWL_MSGRESULT, TRUE ); - return TRUE; - - case WM_NCLBUTTONDOWN: - return OnNcLButtonDown( (INT)wParam, MAKEPOINTS(lParam) ); - - case WM_SYSCOMMAND: - // Allow Alt-F4 to close the window - if ( wParam == SC_CLOSE ) - ::EndDialog( m_hwnd, IDCANCEL ); - break; - } - - // Message not handled - return FALSE; -} - -// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -BOOL CMainDlg::OnInitDialog( void ) -{ - DWORD dwRet; - - HWND hwnd = *this; - - dwRet = m_stella.Initialize(); - if ( dwRet != ERROR_SUCCESS ) - { - MessageBoxFromWinError( dwRet, _T("CStellaX::Initialize") ); - SendMessage( hwnd, WM_CLOSE, 0, 0 ); - return FALSE; - } - - // Set dialog icon - HICON hicon = ::LoadIcon(m_hInstance, MAKEINTRESOURCE(IDI_APP)); - ::SendMessage( hwnd, WM_SETICON, ICON_BIG, (LPARAM)hicon ); - ::SendMessage( hwnd, WM_SETICON, ICON_SMALL, (LPARAM)hicon ); - - // Make the Rom note have bold text - HWND hwndCtrl; - - hwndCtrl = ::GetDlgItem( hwnd, IDC_ROMNOTE ); - - HFONT hfont = (HFONT)::SendMessage( hwndCtrl, WM_GETFONT, 0, 0 ); - - LOGFONT lf; - ::GetObject( hfont, sizeof(LOGFONT), &lf ); - lf.lfWeight = FW_BOLD; - - m_hfontRomNote = ::CreateFontIndirect( &lf ); - if ( m_hfontRomNote ) - ::SendMessage( hwndCtrl, WM_SETFONT, (WPARAM)m_hfontRomNote, 0 ); - - // Do subclassing - m_CoolCaption.OnInitDialog( hwnd ); - m_header.SubclassDlgItem( hwnd, IDC_ROMLIST ); - m_btn3d.SubclassDlgItem( hwnd, IDC_TITLE ); - m_btnPlay.SubclassDlgItem( hwnd, IDC_PLAY ); - m_btnHelp.SubclassDlgItem( hwnd, IDC_ABOUT ); - m_btnConfig.SubclassDlgItem( hwnd, IDC_CONFIG ); - m_btnExit.SubclassDlgItem( hwnd, IDC_EXIT ); - - const int nMaxString = 256; - TCHAR psz[nMaxString + 1]; - - // Initialize the list view - m_hwndList = ::GetDlgItem( hwnd, IDC_ROMLIST ); - ASSERT( m_hwndList ); - - // LVS_EX_ONECLICKACTIVATE was causing a/vs in kernel32 - ::SendMessage( m_hwndList, LVM_SETEXTENDEDLISTVIEWSTYLE, - 0, LVS_EX_FULLROWSELECT ); - - RECT rc; - ::GetClientRect( m_hwndList, &rc ); - - LONG lTotalWidth = rc.right-rc.left - GetSystemMetrics(SM_CXVSCROLL); - int cx = lTotalWidth / CListData::GetColumnCount(); - - for (int i = 0; i < CListData::GetColumnCount(); ++i) - { - ::LoadString( m_hInstance, CListData::GetColumnNameIdForColumn( i ), - psz, nMaxString ); - - LV_COLUMN lvc; - lvc.mask = LVCF_FMT | LVCF_TEXT | LVCF_WIDTH; - lvc.fmt = LVCFMT_LEFT; - lvc.cx = cx; - lvc.pszText = psz; - ListView_InsertColumn( m_hwndList, i, &lvc ); - } - - DWORD dwError = PopulateRomList(); - if ( dwError != ERROR_SUCCESS ) - { - MessageBoxFromWinError( dwError, _T("PopulateRomList") ); - return FALSE; - } - - // if items added, select first item and enable play button - int nCount = ListView_GetItemCount( m_hwndList ); - if (nCount != 0) - { - m_header.SetSortCol( 0, TRUE ); - ListView_SortItems( m_hwndList, ListViewCompareFunc, (LPARAM)this ); - ListView_SetItemState( m_hwndList, 0, LVIS_SELECTED | LVIS_FOCUSED, - LVIS_SELECTED | LVIS_FOCUSED ); - } - else - { - ::EnableWindow(::GetDlgItem( hwnd, IDC_PLAY), FALSE ); - } - - // Show status text - TCHAR pszStatus[256 + 1]; - LoadString(m_hInstance, IDS_STATUSTEXT, pszStatus, 256); - wsprintf( psz, pszStatus, nCount ); - SetDlgItemText( hwnd, IDC_ROMCOUNT, psz ); - - // Show rom path - SetDlgItemText( hwnd, IDC_ROMPATH, - myGlobalData.settings().getString("romdir").c_str() ); - - // Set default button - ::SendMessage( hwnd, DM_SETDEFID, IDC_PLAY, 0 ); - - // return FALSE if SetFocus is called - return TRUE; -} - -// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -BOOL CMainDlg::OnCommand( int id, HWND hwndCtl, UINT codeNotify ) -{ - UNUSED_ALWAYS( hwndCtl ); - UNUSED_ALWAYS( codeNotify ); - - HWND hwnd = *this; - CListData* pListData; - - int nItem; - - switch (id) - { - case IDC_PLAY: - nItem = (int)::SendMessage( m_hwndList, LVM_GETNEXTITEM, - (WPARAM)-1, MAKELPARAM( LVNI_SELECTED, 0 ) ); - ASSERT( nItem != -1 ); - if ( nItem == -1 ) - { - ::MessageBox( m_hInstance, hwnd, IDS_NO_ITEM_SELECTED ); - return TRUE; - } - - pListData = (CListData*)ListView_GetItemData( m_hwndList, nItem ); - - TCHAR pszPathName[ MAX_PATH + 1 ]; - lstrcpy( pszPathName, myGlobalData.settings().getString("romdir").c_str() ); - lstrcat( pszPathName, _T("\\") ); - lstrcat( pszPathName, - pListData->GetTextForColumn( CListData::FILENAME_COLUMN ) ); - - // Play the game! - ::EnableWindow( hwnd, FALSE ); - - (void)m_stella.PlayROM( hwnd, pszPathName, - pListData->GetTextForColumn( CListData::NAME_COLUMN ), - myGlobalData ); - - ::EnableWindow( hwnd, TRUE ); - - // Set focus back to the rom list - ::SetFocus( m_hwndList ); - - return TRUE; - break; // case IDC_PLAY - - case IDC_EXIT: - ClearList(); - ::EndDialog( hwnd, IDCANCEL ); - return TRUE; - break; // case IDC_EXIT - - case IDC_CONFIG: - { - CPropertySheet ps( _T("Configure"), hwnd ); - - CConfigPage pgConfig( myGlobalData ); - ps.AddPage( &pgConfig ); - - (void)ps.DoModal(); - - return TRUE; - break; // case IDC_CONFIG - } - - case IDC_ABOUT: - { - CPropertySheet ps(_T("Help"), hwnd); - - CHelpPage pgAbout; - ps.AddPage(&pgAbout); - - CDocPage pgDoc; - ps.AddPage(&pgDoc); - - ps.DoModal(); - return TRUE; - break; // case IDC_ABOUT - } - } - - return FALSE; -} - -// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -BOOL CMainDlg::OnNotify( int idCtrl, LPNMHDR pnmh ) -{ - UNUSED_ALWAYS( idCtrl ); - - switch ( pnmh->code ) - { - case LVN_GETDISPINFO: - OnGetDispInfo( (NMLVDISPINFO*)pnmh ); - return TRUE; - - case LVN_COLUMNCLICK: - OnColumnClick( (LPNMLISTVIEW)pnmh ); - return TRUE; - - case LVN_ITEMCHANGED: - OnItemChanged( (LPNMLISTVIEW)pnmh ); - return TRUE; - - case NM_DBLCLK: - // send out an ok click to play - ::SendDlgItemMessage( *this, IDC_PLAY, BM_CLICK, 0, 0 ); - return TRUE; - } - - // not handled - return FALSE; -} - -// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -static void ScreenToClient( HWND hwnd, LPRECT lpRect ) -{ - ::ScreenToClient(hwnd, (LPPOINT)lpRect); - ::ScreenToClient(hwnd, ((LPPOINT)lpRect)+1); -} - -// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -static void FillSolidRect( HDC hdc, LPCRECT lpRect, COLORREF clr ) -{ - COLORREF crOld = ::SetBkColor(hdc, clr); - ::ExtTextOut(hdc, 0, 0, ETO_OPAQUE, lpRect, NULL, 0, NULL); - ::SetBkColor(hdc, crOld); -} - -// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -BOOL CMainDlg::OnEraseBkgnd( HDC hdc ) -{ - // don't do this in 256 color - - if (GetDeviceCaps(hdc, RASTERCAPS) & RC_PALETTE) - return FALSE; - - RECT rcWindow; - ::GetWindowRect( *this, &rcWindow ); - ::ScreenToClient( *this, &rcWindow ); - - FillSolidRect( hdc, &rcWindow, ::GetSysColor( COLOR_3DFACE ) ); - - RECT rc; - ::SetRect( &rc, rcWindow.left, BKGND_BITMAP_TOP, rcWindow.right, BKGND_BITMAP_BOTTOM ); - - long lWidth = rc.right - rc.left; - long lHeight = rc.bottom - rc.top; - - HDC hdcMem = CreateCompatibleDC(hdc); - - HBITMAP hbmpTile = LoadBitmap( m_hInstance, MAKEINTRESOURCE(IDB_TILE) ); - - BITMAP bm; - GetObject(hbmpTile, sizeof(bm), &bm); - - HBITMAP hbmpOld = (HBITMAP)SelectObject(hdcMem, hbmpTile); - - for (long x = 0; x < lWidth; x += bm.bmWidth) - { - for (long y = 0; y < lHeight; y += bm.bmHeight) - { - ::BitBlt( hdc, - rc.left + x, rc.top + y, - ( (rc.left + x + bm.bmWidth) > rc.right ) ? rc.right-(rc.left+x) : bm.bmWidth, - ( (rc.top + y + bm.bmHeight) > rc.bottom ) ? rc.bottom-(rc.top+y) : bm.bmHeight, - hdcMem, - 0, 0, SRCCOPY ); - } - } - - SelectObject(hdcMem, hbmpOld); - DeleteObject(hbmpTile); - DeleteDC(hdcMem); - - return TRUE; -} - -// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -HBRUSH CMainDlg::OnCtlColorStatic( HDC hdcStatic, HWND hwndStatic ) -{ - // don't do this in 256 color - - if (GetDeviceCaps(hdcStatic, RASTERCAPS) & RC_PALETTE) - return FALSE; - - if ((GetWindowLong(hwndStatic, GWL_STYLE) & SS_ICON) == SS_ICON) - return NULL; - - SetBkMode(hdcStatic, TRANSPARENT); - - return (HBRUSH)GetStockObject(NULL_BRUSH); -} - -// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -DWORD CMainDlg::PopulateRomList( void ) -{ - TRACE("CMainDlg::PopulateRomList"); - - DWORD dwRet; - -#ifdef _DEBUG - DWORD dwStartTick = ::GetTickCount(); -#endif - - ClearList(); - - // REVIEW: Support .zip files? - - TCHAR pszPath[ MAX_PATH ]; - - lstrcpy( pszPath, myGlobalData.settings().getString("romdir").c_str() ); - lstrcat( pszPath, _T("\\*.bin") ); - - WIN32_FIND_DATA ffd; - HANDLE hFind = FindFirstFile( pszPath, &ffd ); - - ListView_SetItemCount( m_hwndList, 100 ); - - int iItem = 0; - - BOOL fDone = (hFind == INVALID_HANDLE_VALUE); - while (!fDone) - { - // - // File metadata will be read in ReadRomData() - // - - CListData* pListData = new CListData; - if( pListData == NULL ) - { - return ERROR_NOT_ENOUGH_MEMORY; - } - - dwRet = pListData->Initialize(); - if ( dwRet != ERROR_SUCCESS ) - { - return dwRet; - } - - if ( ! pListData->m_strFileName.Set( ffd.cFileName ) ) - { - return FALSE; - } - - LV_ITEM lvi; - - lvi.mask = LVIF_TEXT | LVIF_PARAM; - lvi.iItem = iItem++; - lvi.iSubItem = 0; - lvi.pszText = LPSTR_TEXTCALLBACK; - lvi.lParam = (LPARAM)pListData; - int nItem = ListView_InsertItem( m_hwndList, &lvi ); - - ASSERT( nItem != -1 ); - - ListView_SetItemText( m_hwndList, nItem, - CListData::FILENAME_COLUMN, LPSTR_TEXTCALLBACK ); - ListView_SetItemText(m_hwndList, nItem, - CListData::MANUFACTURER_COLUMN, LPSTR_TEXTCALLBACK); - ListView_SetItemText( m_hwndList, nItem, - CListData::RARITY_COLUMN, LPSTR_TEXTCALLBACK ); - - // go to the next rom file - - fDone = !FindNextFile(hFind, &ffd); - } - - if ( hFind != INVALID_HANDLE_VALUE ) - { - VERIFY( ::FindClose( hFind ) ); - } - -#ifdef _DEBUG - TRACE("\tElapsed ticks for PopulateRomList = %ld", ::GetTickCount()-dwStartTick); -#endif - - return ERROR_SUCCESS; -} - -DWORD CMainDlg::ReadRomData( - CListData* pListData - ) const -{ - // Add stella binary output for stella.pro info - // There should be no parsing of stella.pro in this application - // FIXME -/* - - // TODO: Move this method to ListData class (?) - - if ( pListData == NULL ) - { - ASSERT( FALSE ); - return ERROR_BAD_ARGUMENTS; - } - - // attempt to read the rom file - - TCHAR pszPath[MAX_PATH + 1]; - - lstrcpy( pszPath, myGlobalData.RomDir() ); - lstrcat( pszPath, _T("\\") ); - lstrcat( pszPath, pListData->GetTextForColumn( CListData::FILENAME_COLUMN ) ); - - HANDLE hFile; - - hFile = CreateFile( pszPath, - GENERIC_READ, - FILE_SHARE_READ, - NULL, - OPEN_EXISTING, - FILE_ATTRIBUTE_NORMAL, - NULL ); - if (hFile == INVALID_HANDLE_VALUE) - { - return GetLastError(); - } - - DWORD dwFileSize = ::GetFileSize( hFile, NULL ); - - BYTE* pImage = new BYTE[dwFileSize]; - if ( pImage == NULL ) - { - return ERROR_NOT_ENOUGH_MEMORY; - } - - DWORD dwRead; - - if ( ::ReadFile( hFile, pImage, dwFileSize, &dwRead, NULL ) ) - { - // Read the file, now check the md5 - - std::string md5 = MD5( pImage, dwFileSize ); - - // search through the properties set for this MD5 - - PropertiesSet& propertiesSet = m_stella.GetPropertiesSet(); - - uInt32 setSize = propertiesSet.size(); - - for (uInt32 i = 0; i < setSize; ++i) - { - if (propertiesSet.get(i).get("Cartridge.MD5") == md5) - { - // got it! - break; - } - } - - if (i != setSize) - { - const Properties& properties = propertiesSet.get(i); - - if ( ! pListData->m_strManufacturer.Set( - properties.get("Cartridge.Manufacturer").c_str() ) ) - { - return ERROR_NOT_ENOUGH_MEMORY; - } - - if ( ! pListData->m_strName.Set( - properties.get("Cartridge.Name").c_str() ) ) - { - return ERROR_NOT_ENOUGH_MEMORY; - } - - if (! pListData->m_strRarity.Set( - properties.get("Cartridge.Rarity").c_str() ) ) - { - return ERROR_NOT_ENOUGH_MEMORY; - } - - if ( ! pListData->m_strNote.Set( - properties.get("Cartridge.Note").c_str() ) ) - { - return ERROR_NOT_ENOUGH_MEMORY; - } - } - else - { - // - // Any output here should be appended to the emucore\stella.pro file - // - - TRACE( "\"Cartridge.MD5\" \"%s\"\n\"Cartridge.Name\" \"%s\"\n\"\"\n", - md5.c_str(), - pListData->GetTextForColumn( CListData::FILENAME_COLUMN ) ); - } - } - - delete[] pImage; - - VERIFY( ::CloseHandle( hFile ) ); - - pListData->m_fPopulated = TRUE; -*/ - return ERROR_SUCCESS; -} - -void CMainDlg::OnColumnClick( - LPNMLISTVIEW pnmv - ) -{ - HCURSOR hcur = ::SetCursor(::LoadCursor(NULL, IDC_WAIT)); - - m_header.SetSortCol(pnmv->iSubItem, TRUE); - ListView_SortItems(pnmv->hdr.hwndFrom, ListViewCompareFunc, (LPARAM)this); - - // ensure the selected item is visible - - int nItem = ListView_GetNextItem( m_hwndList, -1, LVNI_SELECTED ); - if (nItem != -1) - { - ListView_EnsureVisible( m_hwndList, nItem, TRUE ); - } - - ::SetCursor(hcur); -} - -void CMainDlg::OnItemChanged( - LPNMLISTVIEW pnmv - ) -{ - HWND hwnd = *this; - - HWND hwndNote = ::GetDlgItem( hwnd, IDC_ROMNOTE ); - - RECT rc; - ::GetWindowRect(hwndNote, &rc); - ::ScreenToClient( hwnd, (LPPOINT)&rc ); - ::ScreenToClient( hwnd, ((LPPOINT)&rc)+1 ); - - int iItem = ListView_GetNextItem(pnmv->hdr.hwndFrom, -1, LVNI_SELECTED); - if (iItem == -1) - { - ::SetWindowText( hwndNote, _T("") ); - ::EnableWindow( ::GetDlgItem( hwnd, IDC_PLAY ), FALSE ); - ::InvalidateRect( hwnd, &rc, TRUE ); - return; - } - - CListData* pListData = (CListData*)ListView_GetItemData( - pnmv->hdr.hwndFrom, - pnmv->iItem ); - - ::SetWindowText( hwndNote, pListData->GetNote() ); - ::InvalidateRect( hwnd, &rc, TRUE ); - ::EnableWindow( ::GetDlgItem( hwnd, IDC_PLAY ), TRUE ); -} - -// --------------------------------------------------------------------------- -// LPSTR_TEXTCALLBACK message handlers - -void CMainDlg::OnGetDispInfo( - NMLVDISPINFO* pnmv - ) -{ - // Provide the item or subitem's text, if requested. - - if ( ! (pnmv->item.mask & LVIF_TEXT ) ) - { - return; - } - - CListData* pListData = (CListData*)ListView_GetItemData( - pnmv->hdr.hwndFrom, - pnmv->item.iItem ); - ASSERT( pListData ); - if ( pListData == NULL ) - { - return; - } - - if ( ! pListData->IsPopulated() ) - { - ReadRomData( pListData ); - } - - pnmv->item.pszText = const_cast( pListData->GetTextForColumn(pnmv->item.iSubItem) ); - // ASSERT( pnmv->item.pszText ); -} - -int CALLBACK CMainDlg::ListViewCompareFunc( - LPARAM lParam1, - LPARAM lParam2, - LPARAM lParamSort - ) -{ - CMainDlg* pThis = reinterpret_cast( lParamSort ); - - // - // I assume that the metadata for column 0 is always available, - // while other column metadata requires a call to ReadRomData - // - - int nSortCol = pThis->m_header.GetSortCol(); - - CListData* pItem1 = reinterpret_cast( lParam1 ); - if ( ! pItem1->IsPopulated() && nSortCol != 0 ) - { - pThis->ReadRomData( pItem1 ); - } - - CListData* pItem2 = reinterpret_cast( lParam2 ); - if ( ! pItem2->IsPopulated() && nSortCol != 0 ) - { - pThis->ReadRomData( pItem2 ); - } - - LPCTSTR pszItem1 = pItem1->GetTextForColumn( nSortCol ); - LPCTSTR pszItem2 = pItem2->GetTextForColumn( nSortCol ); - - // - // put blank items last - // - - if ( pszItem1 == NULL || pszItem1[0] == _T('\0') ) - { - return 1; - } - - if ( pszItem2 == NULL || pszItem2[0] == _T('\0') ) - { - return -1; - } - - // - // Compare the specified column. - // - - return lstrcmpi( pszItem1, pszItem2 ); -} - -// --------------------------------------------------------------------------- -// Cool caption message handlers - -void CMainDlg::OnDestroy( - void - ) -{ - m_CoolCaption.OnDestroy(); - - if ( m_hfontRomNote ) - { - ::DeleteObject( m_hfontRomNote ); - m_hfontRomNote = NULL; - } -} - -void CMainDlg::OnNcPaint( - HRGN hrgn - ) -{ - m_CoolCaption.OnNcPaint( hrgn ); -} - -void CMainDlg::OnNcActivate( - BOOL fActive - ) -{ - m_CoolCaption.OnNcActivate( fActive ); -} - -BOOL CMainDlg::OnNcLButtonDown( - INT nHitTest, - POINTS pts - ) -{ - return m_CoolCaption.OnNCLButtonDown( nHitTest, pts ); -} diff --git a/stella/src/win32/MainDlg.hxx b/stella/src/win32/MainDlg.hxx deleted file mode 100644 index 5b9718bb5..000000000 --- a/stella/src/win32/MainDlg.hxx +++ /dev/null @@ -1,259 +0,0 @@ -// -// StellaX -// Jeff Miller 05/10/2000 -// -#ifndef MAINDLG_H -#define MAINDLG_H -#pragma once - -#include "resource.h" - -class CGlobalData; - -#include "StellaXMain.hxx" -#include "CoolCaption.hxx" -#include "TextButton3d.hxx" -#include "HeaderCtrl.hxx" -#include "RoundButton.hxx" - -class CMainDlg; - -class CListData -{ - friend CMainDlg; - -public: - - CListData() : - m_fPopulated( FALSE ) - { - } - - DWORD Initialize() - { - // - // ListView control doesn't like NULLs returned, so initialize all - // - - if ( ! m_strName.Set( _T("") ) ) - { - return ERROR_NOT_ENOUGH_MEMORY; - } - - if ( ! m_strManufacturer.Set( _T("") ) ) - { - return ERROR_NOT_ENOUGH_MEMORY; - } - - if ( ! m_strRarity.Set( _T("") ) ) - { - return ERROR_NOT_ENOUGH_MEMORY; - } - - if ( ! m_strFileName.Set( _T("") ) ) - { - return ERROR_NOT_ENOUGH_MEMORY; - } - - if ( ! m_strNote.Set( _T("") ) ) - { - return ERROR_NOT_ENOUGH_MEMORY; - } - - return ERROR_SUCCESS; - } - - // - // MetaData - // - - static int GetColumnCount( void ) - { - return 4; - } - - enum ColumnIndex - { - FILENAME_COLUMN, - NAME_COLUMN, - MANUFACTURER_COLUMN, - RARITY_COLUMN, - }; - - static UINT GetColumnNameIdForColumn( int nCol ) - { - UINT uID = 0; - - switch ( nCol ) - { - case NAME_COLUMN: - uID = IDS_NAME; - break; - - case MANUFACTURER_COLUMN: - uID = IDS_MANUFACTURER; - break; - - case RARITY_COLUMN: - uID = IDS_RARITY; - break; - - case FILENAME_COLUMN: - uID = IDS_FILENAME; - break; - - default: - ASSERT(FALSE); - break; - } - - return uID; - } - - LPCTSTR GetTextForColumn( int nCol ) const - { - LPCTSTR pszText = NULL; - - switch (nCol) - { - case NAME_COLUMN: - pszText = m_strName.Get(); - break; - - case MANUFACTURER_COLUMN: - pszText = m_strManufacturer.Get(); - break; - - case RARITY_COLUMN: - pszText = m_strRarity.Get(); - break; - - case FILENAME_COLUMN: - pszText = m_strFileName.Get(); - break; - - default: - ASSERT( FALSE ); - break; - } - - return pszText; - } - - LPCTSTR GetNote( void ) const - { - return m_strNote.Get(); - } - - BOOL IsPopulated( void ) const - { - return m_fPopulated; - } - -private: - - CSimpleString m_strName; - CSimpleString m_strManufacturer; - CSimpleString m_strRarity; - CSimpleString m_strFileName; - CSimpleString m_strNote; - BOOL m_fPopulated; - -private: - -CListData( const CListData& ); // no implementation -void operator=( const CListData& ); // no implementation - -}; - -// --------------------------------------------------------------------------- - -class CMainDlg -{ -public: - - enum { IDD = IDD_MAIN }; - - CMainDlg( CGlobalData& rGlobalData, HINSTANCE hInstance ); - - virtual int DoModal( HWND hwndParent ); - - operator HWND( void ) const - { - return m_hwnd; - } - -private: - - HWND m_hwnd; - - CCoolCaption m_CoolCaption; - CTextButton3d m_btn3d; - CHeaderCtrl m_header; - CRoundButton m_btnPlay; - CRoundButton m_btnHelp; - CRoundButton m_btnConfig; - CRoundButton m_btnExit; - - // - // Message handlers - // - - BOOL OnInitDialog( void ); - BOOL OnCommand( int id, HWND hwndCtl, UINT codeNotify ); - BOOL OnNotify( int idCtrl, LPNMHDR pnmh ); - BOOL OnEraseBkgnd( HDC hdc ); - HBRUSH OnCtlColorStatic( HDC hdcStatic, HWND hwndStatic ); - - // - // wm_notify handlers - // - - void OnGetDispInfo( NMLVDISPINFO* pnmh ); - - void OnColumnClick( LPNMLISTVIEW pnmv ); - void OnItemChanged( LPNMLISTVIEW pnmv ); - - // - // cool caption handlers - // - - void OnDestroy( void ); - void OnNcPaint( HRGN hrgn ); - void OnNcActivate( BOOL fActive ); - BOOL OnNcLButtonDown( INT nHitTest, POINTS pts ); - - // - // callback methods - // - - BOOL CALLBACK DialogFunc( UINT uMsg, WPARAM wParam, LPARAM lParam ); - - static BOOL CALLBACK StaticDialogFunc( HWND hDlg, UINT uMsg, WPARAM wParam, LPARAM lParam ); - static int CALLBACK ListViewCompareFunc( LPARAM lParam1, LPARAM lParam2, LPARAM lParamSort ); - - // internal data - - DWORD PopulateRomList(); - DWORD ReadRomData( CListData* ) const; - - HINSTANCE m_hInstance; - - // stuff in list - - HWND m_hwndList; - void ClearList(); - - HFONT m_hfontRomNote; - - // Stella stuff - - CGlobalData& myGlobalData; - CStellaXMain m_stella; - -CMainDlg( const CMainDlg& ); // no implementation -void operator=( const CMainDlg& ); // no implementation - -}; - -#endif diff --git a/stella/src/win32/PropertySheet.cxx b/stella/src/win32/PropertySheet.cxx deleted file mode 100644 index 66b8a52e7..000000000 --- a/stella/src/win32/PropertySheet.cxx +++ /dev/null @@ -1,260 +0,0 @@ -// -// StellaX -// Jeff Miller 05/02/2000 -// -#include "pch.hxx" -#include "PropertySheet.hxx" - -#pragma comment(lib, "comctl32") - -#include -typedef struct DLGTEMPLATEEX -{ - WORD dlgVer; - WORD signature; - DWORD helpID; - DWORD exStyle; - DWORD style; - WORD cDlgItems; - short x; - short y; - short cx; - short cy; -} DLGTEMPLATEEX, *LPDLGTEMPLATEEX; -#include - -CPropertyPage::CPropertyPage( - UINT nIDTemplate, - UINT nIDCaption /* = 0 */ - ) -{ - UNUSED_ALWAYS( nIDCaption ); - - ZeroMemory(&m_psp, sizeof(m_psp)); - m_psp.dwSize = sizeof(m_psp); - m_psp.dwFlags = PSP_USECALLBACK; - // m_psp.hInstance = hInstance; - m_psp.pszTemplate = MAKEINTRESOURCE(nIDTemplate); - m_psp.pfnDlgProc = StaticDlgProc; - m_psp.lParam = (LPARAM)this; - m_psp.pfnCallback = StaticCallback; -} - -UINT CALLBACK CPropertyPage::StaticCallback( - HWND hwnd, - UINT uMsg, - LPPROPSHEETPAGE ppsp - ) -{ - UNUSED_ALWAYS( hwnd ); - UNUSED_ALWAYS( ppsp ); - - switch (uMsg) - { - case PSPCB_CREATE: - // ppsp->lParam holds create lParam - return TRUE; - - case PSPCB_RELEASE: - break; - } - - return 0; -} - -BOOL CALLBACK CPropertyPage::StaticDlgProc( - HWND hwnd, - UINT uMsg, - WPARAM wParam, - LPARAM lParam - ) -{ - CPropertyPage* pPage = NULL; - - switch ( uMsg ) - { - case WM_INITDIALOG: - pPage = reinterpret_cast( - reinterpret_cast( lParam )->lParam ); - (void)::SetWindowLong( hwnd, - DWL_USER, - reinterpret_cast( pPage ) ); - break; - - default: - pPage = reinterpret_cast( - ::GetWindowLong( hwnd, DWL_USER ) ); - if ( pPage == NULL ) - { - return FALSE; - } - break; - } - - return pPage->DlgProc( hwnd, uMsg, wParam, lParam ); -} - -BOOL CALLBACK CPropertyPage::DlgProc( - HWND hwnd, - UINT msg, - WPARAM wParam, - LPARAM lParam - ) -{ - switch (msg) - { - case WM_ACTIVATE: - OnActivate( (UINT)LOWORD(wParam), (HWND)lParam, (BOOL)HIWORD(wParam) ); - return TRUE; - - case WM_INITDIALOG: - return OnInitDialog( hwnd ); - - case WM_DESTROY: - OnDestroy( ); - return TRUE; - - case WM_COMMAND: - return OnCommand( HIWORD(wParam), LOWORD(wParam), (HWND)lParam ); - - case WM_NOTIFY: - // Handle PSN_QUERYCANCEL? - // Handle PSN_KILLACTIVE? - - switch (((LPNMHDR)lParam)->code) - { - case PSN_SETACTIVE: - ::SetWindowLong(hwnd, DWL_MSGRESULT, OnSetActive( (LPPSHNOTIFY)lParam ) ); - return TRUE; - - case PSN_KILLACTIVE: - ::SetWindowLong(hwnd, DWL_MSGRESULT, OnKillActive( (LPPSHNOTIFY)lParam ) ); - return TRUE; - - case PSN_APPLY: - ::SetWindowLong( hwnd, DWL_MSGRESULT, OnApply( (LPPSHNOTIFY)lParam) ); - return TRUE; - - case PSN_RESET: - OnReset( (LPPSHNOTIFY)lParam ); - return TRUE; - } - - return OnNotify( (int)wParam, (LPNMHDR)lParam ); - } - - return FALSE; -} - - -// -// CPropertySheet -// - -CPropertySheet::CPropertySheet -( - LPCTSTR pszCaption, - HWND hwndParent, - UINT nStartPage /* = 0 */ -) :\ - m_strCaption( pszCaption ) -{ - ZeroMemory(&m_psh, sizeof(m_psh)); - m_psh.dwSize = sizeof(m_psh); - m_psh.dwFlags = PSH_NOAPPLYNOW | PSH_PROPSHEETPAGE | PSH_USECALLBACK; - m_psh.hwndParent = hwndParent; - m_psh.hInstance = (HINSTANCE)GetWindowLong(hwndParent, GWL_HINSTANCE); - m_psh.pszCaption = m_strCaption.c_str(); - m_psh.nStartPage = nStartPage; - m_psh.pfnCallback = StaticCallback; -} - -CPropertySheet::~CPropertySheet( - ) -{ - // BUGBUG: This is static! - - /* - if ( m_hfontLogo ) - { - ::DeleteObject( m_hfontLogo ); - m_hfontLogo = NULL; - } - */ -} - -void CPropertySheet::AddPage( - CPropertyPage* pPage - ) -{ - if (pPage) - { - m_pages.push_back(pPage); - } -} - -int CPropertySheet::DoModal( - void - ) -{ - int nSize = m_pages.size(); - - if (nSize == 0) - return IDCANCEL; - - PROPSHEETPAGE* pspage = new PROPSHEETPAGE[nSize]; - for (int i = 0; i < nSize; ++i) - { - CopyMemory(&(pspage[i]), m_pages[i]->GetPropSheetPage(), - sizeof(PROPSHEETPAGE)); - pspage[i].hInstance = m_psh.hInstance; - } - - m_psh.nPages = nSize; - m_psh.ppsp = pspage; - - int nRet = ::PropertySheet( &m_psh ); - - delete[] pspage; - - return nRet; -} - -int CALLBACK CPropertySheet::StaticCallback( - HWND hwnd, - UINT uMsg, - LPARAM lParam - ) -{ - UNUSED_ALWAYS( hwnd ); - - switch (uMsg) - { - case PSCB_INITIALIZED: - // Property sheet is being initialized - - return TRUE; - - case PSCB_PRECREATE: - // Property sheet is about to be created - - - // - // Remove the DS_CONTEXTHELP style from the dialog template - // (This will remove the "?" in the top right corner) - // - - if ( ( (LPDLGTEMPLATEEX)lParam )->signature == 0xFFFF) - { - ( (LPDLGTEMPLATEEX)lParam )->style &= ~DS_CONTEXTHELP; - } - else - { - ( (LPDLGTEMPLATE)lParam )->style &= ~DS_CONTEXTHELP; - } - return TRUE; - - } - - return 0; -} diff --git a/stella/src/win32/PropertySheet.hxx b/stella/src/win32/PropertySheet.hxx deleted file mode 100644 index 561f9def0..000000000 --- a/stella/src/win32/PropertySheet.hxx +++ /dev/null @@ -1,111 +0,0 @@ -// -// StellaX -// Jeff Miller 05/02/2000 -// -#ifndef PROPSHT_H -#define PROPSHT_H -#pragma once - -#include -#include -#include - -class CPropertyPage -{ -public: - - CPropertyPage( UINT nIDTemplate, UINT nIDCaption = 0 ); - - const PROPSHEETPAGE* GetPropSheetPage(); - -protected: - - // - // Overridable callbacks - // - - virtual void OnActivate( UINT state, HWND hwndActDeact, BOOL fMinimized ) - { - } - - virtual BOOL OnInitDialog( HWND /* hwnd */ ) - { - return FALSE; - } - - virtual void OnDestroy( void ) - { - } - - virtual BOOL OnSetActive( LPPSHNOTIFY /* lppsn */ ) - { - return 0; - } - - virtual BOOL OnKillActive( LPPSHNOTIFY /* lppsn */ ) - { - return FALSE; - } - - virtual LONG OnApply( LPPSHNOTIFY /* lppsn */ ) - { - return PSNRET_NOERROR; - } - - virtual void OnReset( LPPSHNOTIFY /* lppsn */ ) - { - } - - virtual BOOL OnCommand( WORD /* wNotifyCode */, WORD /* wID */, HWND /* hwndCtl */ ) - { - return FALSE; - } - - virtual BOOL OnNotify( int /* idCtrl */, LPNMHDR /* pnmh */ ) - { - return FALSE; - } - -private: - - static UINT CALLBACK StaticCallback( HWND hwnd, UINT uMsg, LPPROPSHEETPAGE ppsp ); - - static BOOL CALLBACK StaticDlgProc( HWND hwnd, UINT msg, WPARAM wParam, LPARAM lParam ); - BOOL CALLBACK DlgProc( HWND hwnd, UINT msg, WPARAM wParam, LPARAM lParam ); - - PROPSHEETPAGE m_psp; - - CPropertyPage( const CPropertyPage& ); // no implementation - void operator=( const CPropertyPage& ); // no implementation -}; - -inline const PROPSHEETPAGE* CPropertyPage::GetPropSheetPage( - void - ) -{ - return &m_psp; -} - -class CPropertySheet -{ -public: - - CPropertySheet( LPCTSTR pszCaption, HWND hwndParent, UINT nStartPage = 0 ); - ~CPropertySheet( ); - - void AddPage( CPropertyPage* pPage ); - virtual int DoModal( void ); - -private: - - static int CALLBACK StaticCallback( HWND hwndDlg, UINT uMsg, LPARAM lParam ); - - PROPSHEETHEADER m_psh; - std::vector m_pages; - std::string m_strCaption; - - CPropertySheet( const CPropertySheet& ); // no implementation - void operator=( const CPropertySheet& ); // no implementation -}; - -#endif diff --git a/stella/src/win32/RoundButton.cxx b/stella/src/win32/RoundButton.cxx deleted file mode 100644 index 0d5b5ca47..000000000 --- a/stella/src/win32/RoundButton.cxx +++ /dev/null @@ -1,625 +0,0 @@ -// -// StellaX -// Jeff Miller 05/01/2000 -// -#include "pch.hxx" -#include "RoundButton.hxx" -#include -#include - -// prototypes -COLORREF GetColour(double dAngle, COLORREF crBright, COLORREF crDark); - -void DrawCircle( HDC hdc, const POINT& p, LONG lRadius, - COLORREF crColour, BOOL bDashed = FALSE); - -void DrawCircleLeft( HDC hdc, const POINT& p, LONG lRadius, - COLORREF crBright, COLORREF crDark); - -void DrawCircleRight( HDC hdc, const POINT& p, LONG lRadius, - COLORREF crBright, COLORREF crDark); - - -// Calculate colour for a point at the given angle by performing a linear -// interpolation between the colours crBright and crDark based on the cosine -// of the angle between the light source and the point. -// -// Angles are measured from the +ve x-axis (i.e. (1,0) = 0 degrees, (0,1) = 90 degrees ) -// But remember: +y points down! - -COLORREF GetColour( - double dAngle, - COLORREF crBright, - COLORREF crDark - ) -{ -#define Rad2Deg 180.0/3.1415 - -// For better light-continuity along the edge of a stretched button: -// LIGHT_SOURCE_ANGLE == -1.88 - -//#define LIGHT_SOURCE_ANGLE -2.356 // -2.356 radians = -135 degrees, i.e. From top left -#define LIGHT_SOURCE_ANGLE -1.88 - - ASSERT(dAngle > -3.1416 && dAngle < 3.1416); - double dAngleDifference = LIGHT_SOURCE_ANGLE - dAngle; - - if (dAngleDifference < -3.1415) dAngleDifference = 6.293 + dAngleDifference; - else if (dAngleDifference > 3.1415) dAngleDifference = 6.293 - dAngleDifference; - - double Weight = 0.5*(cos(dAngleDifference)+1.0); - - BYTE Red = (BYTE) (Weight*GetRValue(crBright) + (1.0-Weight)*GetRValue(crDark)); - BYTE Green = (BYTE) (Weight*GetGValue(crBright) + (1.0-Weight)*GetGValue(crDark)); - BYTE Blue = (BYTE) (Weight*GetBValue(crBright) + (1.0-Weight)*GetBValue(crDark)); - - //TRACE("LightAngle = %0.0f, Angle = %3.0f, Diff = %3.0f, Weight = %0.2f, RGB %3d,%3d,%3d\n", - // LIGHT_SOURCE_ANGLE*Rad2Deg, dAngle*Rad2Deg, dAngleDifference*Rad2Deg, Weight,Red,Green,Blue); - - return RGB(Red, Green, Blue); -} - -void DrawCircle( - HDC hdc, - const POINT& p, - LONG lRadius, - COLORREF crColour, - BOOL bDashed - ) -{ - const int nDashLength = 1; - LONG lError, lXoffset, lYoffset; - int nDash = 0; - BOOL bDashOn = TRUE; - - //Check to see that the coordinates are valid - ASSERT( (p.x + lRadius <= LONG_MAX) && (p.y + lRadius <= LONG_MAX) ); - ASSERT( (p.x - lRadius >= LONG_MIN) && (p.y - lRadius >= LONG_MIN) ); - - //Set starting values - lXoffset = lRadius; - lYoffset = 0; - lError = -lRadius; - - do - { - if (bDashOn) - { - ::SetPixelV(hdc, p.x + lXoffset, p.y + lYoffset, crColour); - ::SetPixelV(hdc, p.x + lXoffset, p.y - lYoffset, crColour); - ::SetPixelV(hdc, p.x + lYoffset, p.y + lXoffset, crColour); - ::SetPixelV(hdc, p.x + lYoffset, p.y - lXoffset, crColour); - ::SetPixelV(hdc, p.x - lYoffset, p.y + lXoffset, crColour); - ::SetPixelV(hdc, p.x - lYoffset, p.y - lXoffset, crColour); - ::SetPixelV(hdc, p.x - lXoffset, p.y + lYoffset, crColour); - ::SetPixelV(hdc, p.x - lXoffset, p.y - lYoffset, crColour); - } - - //Advance the error term and the constant X axis step - lError += lYoffset++; - - //Check to see if error term has overflowed - if ((lError += lYoffset) >= 0) - lError -= --lXoffset * 2; - - if (bDashed && (++nDash == nDashLength)) - { - nDash = 0; - bDashOn = !bDashOn; - } - - } while (lYoffset <= lXoffset); //Continue until halfway point -} - -// The original Drawcircle function is split up into DrawCircleRight and DrawCircleLeft -// to make stretched buttons - -void DrawCircleRight( - HDC hdc, - const POINT& p, - LONG lRadius, - COLORREF crBright, - COLORREF crDark - ) -{ - LONG lError, lXoffset, lYoffset; - - //Check to see that the coordinates are valid - ASSERT( (p.x + lRadius <= LONG_MAX) && (p.y + lRadius <= LONG_MAX) ); - ASSERT( (p.x - lRadius >= LONG_MIN) && (p.y - lRadius >= LONG_MIN) ); - - //Set starting values - lXoffset = lRadius; - lYoffset = 0; - lError = -lRadius; - - do - { - const double Pi = 3.141592654, - Pi_on_2 = Pi * 0.5; - COLORREF crColour; - long double dAngle = atan2((long double)lYoffset, (long double)lXoffset); - - //Draw the current pixel, reflected across all four arcs - - crColour = GetColour(dAngle, crBright, crDark); - ::SetPixelV(hdc, p.x + lXoffset, p.y + lYoffset, crColour); - - crColour = GetColour(Pi_on_2 - dAngle, crBright, crDark); - ::SetPixelV(hdc, p.x + lYoffset, p.y + lXoffset, crColour); - - crColour = GetColour(-Pi_on_2 + dAngle, crBright, crDark); - ::SetPixelV(hdc, p.x + lYoffset, p.y - lXoffset, crColour); - - crColour = GetColour(-dAngle, crBright, crDark); - ::SetPixelV(hdc, p.x + lXoffset, p.y - lYoffset, crColour); - - //Advance the error term and the constant X axis step - lError += lYoffset++; - - //Check to see if error term has overflowed - if ((lError += lYoffset) >= 0) - lError -= --lXoffset * 2; - - } while (lYoffset <= lXoffset); //Continue until halfway point -} - -// The original Drawcircle function is split up into DrawCircleRight and DrawCircleLeft -// to make stretched buttons - -void DrawCircleLeft( - HDC hdc, - const POINT& p, - LONG lRadius, - COLORREF crBright, - COLORREF crDark - ) -{ - LONG lError, lXoffset, lYoffset; - - //Check to see that the coordinates are valid - ASSERT( (p.x + lRadius <= LONG_MAX) && (p.y + lRadius <= LONG_MAX) ); - ASSERT( (p.x - lRadius >= LONG_MIN) && (p.y - lRadius >= LONG_MIN) ); - - //Set starting values - lXoffset = lRadius; - lYoffset = 0; - lError = -lRadius; - - do - { - const double Pi = 3.141592654, - Pi_on_2 = Pi * 0.5; - COLORREF crColour; - long double dAngle = atan2((long double)lYoffset, (long double)lXoffset); - - //Draw the current pixel, reflected across all eight arcs - - crColour = GetColour(Pi_on_2 + dAngle, crBright, crDark); - ::SetPixelV(hdc, p.x - lYoffset, p.y + lXoffset, crColour); - - crColour = GetColour(Pi - dAngle, crBright, crDark); - ::SetPixelV(hdc, p.x - lXoffset, p.y + lYoffset, crColour); - - crColour = GetColour(-Pi + dAngle, crBright, crDark); - ::SetPixelV(hdc, p.x - lXoffset, p.y - lYoffset, crColour); - - crColour = GetColour(-Pi_on_2 - dAngle, crBright, crDark); - ::SetPixelV(hdc, p.x - lYoffset, p.y - lXoffset, crColour); - - //Advance the error term and the constant X axis step - lError += lYoffset++; - - //Check to see if error term has overflowed - if ((lError += lYoffset) >= 0) - lError -= --lXoffset * 2; - - } while (lYoffset <= lXoffset); //Continue until halfway point -} - -///////////////////////////////////////////////////////////////////////////// - -static void ClientToScreen( - HWND hwnd, - LPRECT lpRect - ) -{ - ::ClientToScreen(hwnd, (LPPOINT)lpRect); - ::ClientToScreen(hwnd, ((LPPOINT)lpRect)+1); -} - -static void ScreenToClient( - HWND hwnd, - LPRECT lpRect - ) -{ - ::ScreenToClient(hwnd, (LPPOINT)lpRect); - ::ScreenToClient(hwnd, ((LPPOINT)lpRect)+1); -} - -static void FillSolidRect( - HDC hdc, - LPCRECT lpRect, - COLORREF clr - ) -{ - COLORREF crOld = ::SetBkColor(hdc, clr); - ::ExtTextOut(hdc, 0, 0, ETO_OPAQUE, lpRect, NULL, 0, NULL); - ::SetBkColor(hdc, crOld); -} - -////////////////////////////////////////////////////////////////////////////// - -CRoundButton::CRoundButton( - ) : \ - m_hrgn( NULL ), - m_fDrawDashedFocusCircle( TRUE ), - m_fStretch( FALSE ) -{ -} - -CRoundButton::~CRoundButton( - ) -{ - if ( m_hrgn ) - { - ::DeleteObject( m_hrgn ); - } -} - -void CRoundButton::PreSubclassWindow( - HWND hwnd - ) -{ - RECT rect; - ::GetClientRect( hwnd, &rect ); - - m_fStretch = (rect.right-rect.left) > (rect.bottom-rect.top); - - if ( ! m_fStretch ) - { - rect.bottom = rect.right = min ( rect.bottom, rect.right ); - } - - m_ptCenter.x = m_ptLeft.x = m_ptRight.x = ((rect.right-rect.left)/2); - m_ptCenter.y = m_ptLeft.y = m_ptRight.y = ((rect.bottom-rect.top)/2); - - m_nRadius = rect.bottom/2 - 1; - - m_ptLeft.x = m_nRadius; - m_ptRight.x = rect.right - m_nRadius - 1; - - ::SetWindowRgn( hwnd, NULL, FALSE ); - m_hrgn = ::CreateEllipticRgnIndirect( &rect ); - ::SetWindowRgn( hwnd, m_hrgn, TRUE ); - - ::ClientToScreen( hwnd, &rect ); - - HWND hwndParent = ::GetParent( hwnd ); - if ( hwndParent ) - { - ::ScreenToClient( hwndParent, &rect ); - } - - if ( ! m_fStretch ) - { - ::MoveWindow( hwnd, rect.left, rect.top, - rect.right-rect.left, rect.bottom-rect.top, TRUE ); - } -} - -LRESULT CRoundButton::WndProc( - HWND hWnd, - UINT msg, - WPARAM wParam, - LPARAM lParam, - BOOL& rfHandled - ) -{ - switch (msg) - { - case WM_DRAWITEM: - rfHandled = TRUE; - OnDrawItem(hWnd, (UINT)wParam, (LPDRAWITEMSTRUCT)lParam); - return TRUE; - - case WM_ERASEBKGND: - // don't do erasing - return TRUE; - } - - return 0; -} - -void CRoundButton::OnDrawItem( - HWND hwnd, - UINT idCtl, - LPDRAWITEMSTRUCT lpdis - ) -{ - UNUSED_ALWAYS( idCtl ); - - HDC hdc = lpdis->hDC; - RECT& rect = lpdis->rcItem; - UINT state = lpdis->itemState; - UINT nStyle = GetWindowLong(hwnd, GWL_STYLE); - int nRadius = m_nRadius; - - int nSavedDC = ::SaveDC( hdc ); - - ::SelectObject( hdc, ::GetStockObject( NULL_BRUSH ) ); - ::FillSolidRect( hdc, &rect, ::GetSysColor(COLOR_BTNFACE) ); - - // Draw the focus circle around the button for non-stretched buttons - - if ( (state & ODS_FOCUS) && m_fDrawDashedFocusCircle && !m_fStretch ) - { - DrawCircle( hdc, m_ptCenter, nRadius--, RGB( 0, 0, 0) ); - } - - // Draw the raised/sunken edges of the button (unless flat) - - if ( nStyle & BS_FLAT ) - { - if ( m_fStretch ) - { - // for stretched buttons: draw left and right arcs and connect the with lines - - HPEN hpenOld; - - RECT rectLeftBound; - ::SetRect( &rectLeftBound, 0, 0, nRadius*2, nRadius*2 ); - - RECT rectRightBound; - ::SetRect( &rectRightBound, m_ptRight.x-nRadius, 0, m_ptRight.x+nRadius, nRadius*2 ); - - hpenOld = (HPEN)::SelectObject( hdc, - ::CreatePen( PS_SOLID, 1, ::GetSysColor(COLOR_3DDKSHADOW) ) ); - - ::Arc( hdc, - rectLeftBound.left, rectLeftBound.top, rectLeftBound.right, rectLeftBound.bottom, - m_ptLeft.x, 0, - m_ptLeft.x, nRadius*2 ); - - ::Arc( hdc, - rectRightBound.left, rectRightBound.top, rectRightBound.right, rectRightBound.bottom, - m_ptRight.x, nRadius*2, - m_ptRight.x, 0 ); - - ::MoveToEx( hdc, m_ptLeft.x, 0, NULL ); - ::LineTo( hdc, m_ptRight.x, 0 ); - - ::MoveToEx( hdc, m_ptLeft.x, nRadius*2-1, NULL ); - ::LineTo( hdc, m_ptRight.x, nRadius*2-1 ); - - nRadius--; - - ::InflateRect( &rectLeftBound, -1, -1 ); - ::InflateRect( &rectRightBound, -1, -1 ); - - ::DeleteObject( ::SelectObject( hdc, - ::CreatePen( PS_SOLID, 1, ::GetSysColor( COLOR_3DHIGHLIGHT ) ) ) ); - - ::Arc( hdc, - rectLeftBound.left, rectLeftBound.top, rectLeftBound.right, rectLeftBound.bottom, - m_ptLeft.x, 1, - m_ptLeft.x, nRadius*2 ); - - ::Arc( hdc, - rectRightBound.left, rectRightBound.top, rectRightBound.right, rectRightBound.bottom, - m_ptRight.x, nRadius*2, - m_ptRight.x, 0 ); - - ::MoveToEx( hdc, m_ptLeft.x, 1, NULL ); - ::LineTo( hdc, m_ptRight.x, 1 ); - - ::MoveToEx( hdc, m_ptLeft.x, nRadius*2, NULL ); - ::LineTo( hdc, m_ptRight.x, nRadius*2 ); - - ::DeleteObject( ::SelectObject( hdc, hpenOld ) ); - } - else - { - // for non-stretched buttons: draw two circles - - DrawCircle( hdc, m_ptCenter, nRadius--, ::GetSysColor(COLOR_3DDKSHADOW) ); - DrawCircle( hdc, m_ptCenter, nRadius--, ::GetSysColor(COLOR_3DHIGHLIGHT) ); - } - } - else - { - if (state & ODS_SELECTED) - { - // draw the circular segments for stretched AND non-stretched buttons - - DrawCircleLeft( hdc, m_ptLeft, nRadius, - ::GetSysColor(COLOR_3DDKSHADOW), ::GetSysColor(COLOR_3DHIGHLIGHT) ); - DrawCircleRight( hdc, m_ptRight, nRadius, - ::GetSysColor(COLOR_3DDKSHADOW), ::GetSysColor(COLOR_3DHIGHLIGHT) ); - DrawCircleLeft( hdc, m_ptLeft, nRadius-1, - ::GetSysColor(COLOR_3DSHADOW), ::GetSysColor(COLOR_3DLIGHT) ); - DrawCircleRight( hdc, m_ptRight, nRadius-1, - ::GetSysColor(COLOR_3DSHADOW), ::GetSysColor(COLOR_3DLIGHT) ); - - if ( m_fStretch ) - { - // draw connecting lines for stretched buttons only - - HPEN hpenOld; - - hpenOld = (HPEN)::SelectObject( hdc, - (HPEN)::CreatePen( PS_SOLID, 1, ::GetSysColor(COLOR_3DDKSHADOW) ) ); - - ::MoveToEx( hdc, m_ptLeft.x, 1, NULL ); - ::LineTo( hdc, m_ptRight.x, 1 ); - - ::DeleteObject( ::SelectObject( hdc, - ::CreatePen( PS_SOLID, 1, ::GetSysColor(COLOR_3DSHADOW) ) ) ); - - ::MoveToEx( hdc, m_ptLeft.x, 2, NULL ); - ::LineTo( hdc, m_ptRight.x, 2 ); - - ::DeleteObject( ::SelectObject( hdc, - ::CreatePen( PS_SOLID, 1, ::GetSysColor( COLOR_3DLIGHT ) ) ) ); - - ::MoveToEx( hdc, m_ptLeft.x, m_ptLeft.y + nRadius-1, NULL ); - ::LineTo( hdc, m_ptRight.x, m_ptLeft.y + nRadius-1 ); - - ::DeleteObject( ::SelectObject( hdc, - ::CreatePen( PS_SOLID, 1, ::GetSysColor( COLOR_3DHIGHLIGHT ) ) ) ); - - ::MoveToEx( hdc, m_ptLeft.x, m_ptLeft.y + nRadius, NULL ); - ::LineTo( hdc, m_ptRight.x, m_ptLeft.y + nRadius ); - - ::DeleteObject( ::SelectObject( hdc, hpenOld ) ); - } - } - else - { - // draw the circular segments for stretched AND non-stretched buttons - - DrawCircleLeft( hdc, m_ptLeft, nRadius, - ::GetSysColor(COLOR_3DHIGHLIGHT), ::GetSysColor(COLOR_3DDKSHADOW) ); - - DrawCircleRight( hdc, m_ptRight, nRadius, - ::GetSysColor(COLOR_3DHIGHLIGHT), ::GetSysColor(COLOR_3DDKSHADOW) ); - - DrawCircleLeft( hdc, m_ptLeft, nRadius - 1, - ::GetSysColor(COLOR_3DLIGHT), ::GetSysColor(COLOR_3DSHADOW) ); - - DrawCircleRight( hdc, m_ptRight, nRadius - 1, - ::GetSysColor(COLOR_3DLIGHT), ::GetSysColor(COLOR_3DSHADOW) ); - - // draw connecting lines for stretch buttons - - if ( m_fStretch ) - { - HPEN hpenOld; - - hpenOld = (HPEN)::SelectObject( hdc, - ::CreatePen( PS_SOLID, 1, - ::GetPixel( hdc, m_ptLeft.x, 1 ) ) ); - - ::MoveToEx( hdc, m_ptLeft.x, 1, NULL ); - ::LineTo( hdc, m_ptRight.x , 1); - - ::DeleteObject( ::SelectObject( hdc, - ::CreatePen( PS_SOLID, 1, - ::GetPixel( hdc, m_ptLeft.x, 2 ) ) ) ); - - ::MoveToEx( hdc, m_ptLeft.x, 2, NULL ); - ::LineTo( hdc, m_ptRight.x, 2 ); - - ::DeleteObject( ::SelectObject( hdc, - ::CreatePen( PS_SOLID, 1, - ::GetPixel( hdc, m_ptLeft.x, m_ptLeft.y+nRadius ) ) ) ); - - ::MoveToEx( hdc, m_ptLeft.x, m_ptLeft.y + nRadius, NULL ); - ::LineTo( hdc, m_ptRight.x, m_ptLeft.y + nRadius ); - - ::DeleteObject( ::SelectObject( hdc, - ::CreatePen( PS_SOLID, 1, - ::GetPixel( hdc, m_ptLeft.x, m_ptLeft.y+nRadius-1 ) ) ) ); - - ::MoveToEx( hdc, m_ptLeft.x, m_ptLeft.y + nRadius - 1, NULL ); - ::LineTo( hdc, m_ptRight.x, m_ptLeft.y + nRadius - 1 ); - - ::DeleteObject( ::SelectObject( hdc, hpenOld ) ); - } - } - } - - // Draw the text if there is any - - TCHAR pszText[ 256 ]; - int cch = ::GetWindowText( hwnd, pszText, 255 ); - - if ( cch != 0 ) - { - HRGN hrgn; - - if ( m_fStretch ) - { - hrgn = ::CreateRectRgn( m_ptLeft.x - nRadius / 2, m_ptCenter.y - nRadius, - m_ptRight.x + nRadius / 2, m_ptCenter.y + nRadius ); - } - else - { - hrgn = CreateEllipticRgn( m_ptCenter.x - nRadius, m_ptCenter.y - nRadius, - m_ptCenter.x + nRadius, m_ptCenter.y + nRadius ); - } - - ::SelectClipRgn( hdc, hrgn ); - - SIZE size; - ::GetTextExtentPoint32( hdc, pszText, cch, &size ); - - POINT pt = { m_ptCenter.x - size.cx / 2, m_ptCenter.y - size.cy / 2 - 1 }; - POINT pt2 = { m_ptCenter.x + size.cx/2, m_ptCenter.y + size.cy/2 + 1 }; - - if ( state & ODS_SELECTED ) - { - ++( pt.x ); - ++( pt.y ); - } - - ::SetBkMode( hdc, TRANSPARENT ); - -#if 0 - if ( state & ODS_DISABLED ) - { - ::DrawState( hdc, NULL, NULL, (LPARAM)pszText, (WPARAM)cch, - pt.x, pt.y, size.cx, size.cy, DSS_DISABLED ); - } - else -#endif - { - // give text a 3d-look - - RECT pos; - ::SetRect( &pos, pt.x, pt.y, pt2.x, pt2.y ); - - COLORREF crOld = ::SetTextColor( hdc, - ( state & ODS_DISABLED ) ? - ::GetSysColor( COLOR_GRAYTEXT ) : - ::GetSysColor( COLOR_WINDOWTEXT ) ); - - if ( state & ODS_FOCUS ) - { - LOGFONT lf; - ::GetObject( (HFONT)::SendMessage( hwnd, WM_GETFONT, 0, 0 ), - sizeof(LOGFONT), &lf ); - - lf.lfWeight = FW_BOLD; - - HFONT hfontOld = (HFONT)::SelectObject( hdc, ::CreateFontIndirect( &lf ) ); - - ::DrawText( hdc, pszText, -1, &pos, DT_SINGLELINE | DT_CENTER ); - - ::DeleteObject( ::SelectObject( hdc, hfontOld) ); - - } - else - { - ::DrawText( hdc, pszText, -1, &pos, DT_SINGLELINE | DT_CENTER ); - } - - ::SetTextColor( hdc, crOld ); - } - - ::SelectClipRgn( hdc, NULL ); - - DeleteObject( hrgn ); - } - -#if 0 - // draw the focus circle on the inside - - if ( (state & ODS_FOCUS) && m_fDrawDashedFocusCircle && !m_fStretch ) - { - DrawCircle( hdc, m_ptCenter, nRadius-2, RGB(0, 0, 0), TRUE ); - } -#endif - - ::RestoreDC( hdc, nSavedDC ); -} diff --git a/stella/src/win32/RoundButton.hxx b/stella/src/win32/RoundButton.hxx deleted file mode 100644 index 6b22970e3..000000000 --- a/stella/src/win32/RoundButton.hxx +++ /dev/null @@ -1,39 +0,0 @@ -// -// StellaX -// Jeff Miller 05/01/2000 -// -#ifndef RNDBUT_H -#define RNDBUT_H - -#include "Wnd.hxx" - -class CRoundButton : public CWnd -{ -public: - - CRoundButton(); - ~CRoundButton(); - -protected: - - LRESULT WndProc( HWND hwnd, UINT uMsg, - WPARAM wParam, LPARAM lParam, BOOL& fHandled ); - virtual void PreSubclassWindow(HWND hwnd); - -private: - - void OnDrawItem(HWND hwnd, UINT idCtl, LPDRAWITEMSTRUCT lpdis); - - HRGN m_hrgn; - POINT m_ptCenter; - POINT m_ptLeft; - POINT m_ptRight; - int m_nRadius; - BOOL m_fDrawDashedFocusCircle; - BOOL m_fStretch; - - CRoundButton( const CRoundButton& ); // no implementation - void operator=( const CRoundButton& ); // no implementation -}; - -#endif diff --git a/stella/src/win32/Stella.dsp b/stella/src/win32/Stella.dsp deleted file mode 100644 index 877375bd7..000000000 --- a/stella/src/win32/Stella.dsp +++ /dev/null @@ -1,675 +0,0 @@ -# Microsoft Developer Studio Project File - Name="Stella" - Package Owner=<4> -# Microsoft Developer Studio Generated Build File, Format Version 6.00 -# ** DO NOT EDIT ** - -# TARGTYPE "Win32 (x86) Application" 0x0101 - -CFG=Stella - Win32 Debug -!MESSAGE This is not a valid makefile. To build this project using NMAKE, -!MESSAGE use the Export Makefile command and run -!MESSAGE -!MESSAGE NMAKE /f "Stella.mak". -!MESSAGE -!MESSAGE You can specify a configuration when running NMAKE -!MESSAGE by defining the macro CFG on the command line. For example: -!MESSAGE -!MESSAGE NMAKE /f "Stella.mak" CFG="Stella - Win32 Debug" -!MESSAGE -!MESSAGE Possible choices for configuration are: -!MESSAGE -!MESSAGE "Stella - Win32 Release" (based on "Win32 (x86) Application") -!MESSAGE "Stella - Win32 Debug" (based on "Win32 (x86) Application") -!MESSAGE - -# Begin Project -# PROP AllowPerConfigDependencies 0 -# PROP Scc_ProjName "" -# PROP Scc_LocalPath "" -CPP=cl.exe -MTL=midl.exe -RSC=rc.exe - -!IF "$(CFG)" == "Stella - Win32 Release" - -# PROP BASE Use_MFC 0 -# PROP BASE Use_Debug_Libraries 0 -# PROP BASE Output_Dir "Release" -# PROP BASE Intermediate_Dir "Release" -# PROP BASE Target_Dir "" -# PROP Use_MFC 0 -# PROP Use_Debug_Libraries 0 -# PROP Output_Dir "Release" -# PROP Intermediate_Dir "Release" -# PROP Ignore_Export_Lib 0 -# PROP Target_Dir "" -# ADD BASE CPP /nologo /W3 /GX /O2 /D "WIN32" /D "NDEBUG" /D "_WINDOWS" /YX /FD /c -# ADD CPP /nologo /W3 /GX /O2 /I "..\..\build" /I "..\..\emucore" /I "..\..\emucore\m6502\src" /I "..\..\emucore\m6502\src\bspf\src" /I "..\sound" /D "WIN32" /D "NDEBUG" /D "_WINDOWS" /D "BSPF_WIN32" /Fr /FD /c -# ADD BASE MTL /nologo /D "NDEBUG" /mktyplib203 /o /win32 "NUL" -# ADD MTL /nologo /D "NDEBUG" /mktyplib203 /o /win32 "NUL" -# ADD BASE RSC /l 0x409 /d "NDEBUG" -# ADD RSC /l 0x409 /d "NDEBUG" -BSC32=bscmake.exe -# ADD BASE BSC32 /nologo -# ADD BSC32 /nologo -LINK32=link.exe -# ADD BASE LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib /nologo /subsystem:windows /machine:I386 -# ADD LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib /nologo /subsystem:windows /debug /machine:I386 - -!ELSEIF "$(CFG)" == "Stella - Win32 Debug" - -# PROP BASE Use_MFC 0 -# PROP BASE Use_Debug_Libraries 1 -# PROP BASE Output_Dir "Debug" -# PROP BASE Intermediate_Dir "Debug" -# PROP BASE Target_Dir "" -# PROP Use_MFC 0 -# PROP Use_Debug_Libraries 1 -# PROP Output_Dir "Debug" -# PROP Intermediate_Dir "Debug" -# PROP Ignore_Export_Lib 0 -# PROP Target_Dir "" -# ADD BASE CPP /nologo /W3 /Gm /GX /Zi /Od /D "WIN32" /D "_DEBUG" /D "_WINDOWS" /YX /FD /c -# ADD CPP /nologo /W3 /Gm /GX /Zi /Od /I "..\..\build" /I "..\..\emucore" /I "..\..\emucore\m6502\src" /I "..\..\emucore\m6502\src\bspf\src" /I "..\sound" /D "WIN32" /D "_DEBUG" /D "_WINDOWS" /D "BSPF_WIN32" /FR /FD /c -# ADD BASE MTL /nologo /D "_DEBUG" /mktyplib203 /o /win32 "NUL" -# ADD MTL /nologo /D "_DEBUG" /mktyplib203 /o /win32 "NUL" -# ADD BASE RSC /l 0x409 /d "_DEBUG" -# ADD RSC /l 0x409 /d "_DEBUG" -BSC32=bscmake.exe -# ADD BASE BSC32 /nologo -# ADD BSC32 /nologo -LINK32=link.exe -# ADD BASE LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib /nologo /subsystem:windows /debug /machine:I386 /pdbtype:sept -# ADD LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib /nologo /subsystem:windows /profile /debug /machine:I386 - -!ENDIF - -# Begin Target - -# Name "Stella - Win32 Release" -# Name "Stella - Win32 Debug" -# Begin Group "M6502" - -# PROP Default_Filter "" -# Begin Source File - -SOURCE=..\..\emucore\m6502\src\D6502.cxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\m6502\src\D6502.hxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\m6502\src\Device.cxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\m6502\src\Device.hxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\m6502\src\M6502.cxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\m6502\src\M6502.hxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\m6502\src\M6502Hi.cxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\m6502\src\M6502Hi.hxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\m6502\src\M6502Low.cxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\m6502\src\M6502Low.hxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\m6502\src\NullDev.cxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\m6502\src\NullDev.hxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\m6502\src\System.cxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\m6502\src\System.hxx -# End Source File -# End Group -# Begin Group "Core" - -# PROP Default_Filter "" -# Begin Source File - -SOURCE=..\..\emucore\Booster.cxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\Booster.hxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\Cart.cxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\Cart.hxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\Cart2K.cxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\Cart2K.hxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\Cart3F.cxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\Cart3F.hxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\Cart4K.cxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\Cart4K.hxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\CartAR.cxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\CartAR.hxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\CartDPC.cxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\CartDPC.hxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\CartE0.cxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\CartE0.hxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\CartE7.cxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\CartE7.hxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\CartF4SC.cxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\CartF4SC.hxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\CartF6.cxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\CartF6.hxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\CartF6SC.cxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\CartF6SC.hxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\CartF8.cxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\CartF8.hxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\CartF8SC.cxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\CartF8SC.hxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\CartFASC.cxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\CartFASC.hxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\CartFE.cxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\CartFE.hxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\CartMC.cxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\CartMC.hxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\Console.cxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\Console.hxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\Control.cxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\Control.hxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\DefProps.cxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\DefProps.hxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\Driving.cxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\Driving.hxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\Event.cxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\Event.hxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\Joystick.cxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\Joystick.hxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\Keyboard.cxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\Keyboard.hxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\M6532.cxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\M6532.hxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\MD5.cxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\MD5.hxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\MediaSrc.cxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\MediaSrc.hxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\Paddles.cxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\Paddles.hxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\Props.cxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\Props.hxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\PropsSet.cxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\PropsSet.hxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\Random.cxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\Random.hxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\Sound.cxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\Sound.hxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\Switches.cxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\Switches.hxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\TIA.cxx -# End Source File -# Begin Source File - -SOURCE=..\..\emucore\TIA.hxx -# End Source File -# End Group -# Begin Group "Win32" - -# PROP Default_Filter "" -# Begin Source File - -SOURCE=.\AboutPage.cxx -# End Source File -# Begin Source File - -SOURCE=.\AboutPage.hxx -# End Source File -# Begin Source File - -SOURCE=.\AudioStream.cxx -# End Source File -# Begin Source File - -SOURCE=.\AudioStream.hxx -# End Source File -# Begin Source File - -SOURCE=.\BrowseForFolder.cxx -# End Source File -# Begin Source File - -SOURCE=.\BrowseForFolder.hxx -# End Source File -# Begin Source File - -SOURCE=.\ConfigPage.cxx -# End Source File -# Begin Source File - -SOURCE=.\ConfigPage.hxx -# End Source File -# Begin Source File - -SOURCE=.\ControlHost.cxx -# End Source File -# Begin Source File - -SOURCE=.\ControlHost.hxx -# End Source File -# Begin Source File - -SOURCE=.\CoolCaption.cxx -# End Source File -# Begin Source File - -SOURCE=.\CoolCaption.hxx -# End Source File -# Begin Source File - -SOURCE=.\debug.cxx -# End Source File -# Begin Source File - -SOURCE=.\debug.hxx -# End Source File -# Begin Source File - -SOURCE=.\DirectDraw.cxx -# End Source File -# Begin Source File - -SOURCE=.\DirectDraw.hxx -# End Source File -# Begin Source File - -SOURCE=.\DirectInput.cxx -# End Source File -# Begin Source File - -SOURCE=.\DirectInput.hxx -# End Source File -# Begin Source File - -SOURCE=.\DirectXFullScreen.cxx -# End Source File -# Begin Source File - -SOURCE=.\DirectXFullScreen.hxx -# End Source File -# Begin Source File - -SOURCE=.\DirectXWindow.cxx -# End Source File -# Begin Source File - -SOURCE=.\DirectXWindow.hxx -# End Source File -# Begin Source File - -SOURCE=.\DocPage.cxx -# End Source File -# Begin Source File - -SOURCE=.\DocPage.hxx -# End Source File -# Begin Source File - -SOURCE=.\FileDialog.cxx -# End Source File -# Begin Source File - -SOURCE=.\FileDialog.hxx -# End Source File -# Begin Source File - -SOURCE=.\GlobalData.cxx -# End Source File -# Begin Source File - -SOURCE=.\GlobalData.hxx -# End Source File -# Begin Source File - -SOURCE=.\HeaderCtrl.cxx -# End Source File -# Begin Source File - -SOURCE=.\HeaderCtrl.hxx -# End Source File -# Begin Source File - -SOURCE=.\HyperLink.cxx -# End Source File -# Begin Source File - -SOURCE=.\HyperLink.hxx -# End Source File -# Begin Source File - -SOURCE=.\main.cxx -# End Source File -# Begin Source File - -SOURCE=.\MainDlg.cxx -# End Source File -# Begin Source File - -SOURCE=.\MainDlg.hxx -# End Source File -# Begin Source File - -SOURCE=.\pch.cxx -# End Source File -# Begin Source File - -SOURCE=.\pch.hxx -# End Source File -# Begin Source File - -SOURCE=.\PropertySheet.cxx -# End Source File -# Begin Source File - -SOURCE=.\PropertySheet.hxx -# End Source File -# Begin Source File - -SOURCE=.\resource.h -# End Source File -# Begin Source File - -SOURCE=.\RoundButton.cxx -# End Source File -# Begin Source File - -SOURCE=.\RoundButton.hxx -# End Source File -# Begin Source File - -SOURCE=.\SoundWin32.cxx -# End Source File -# Begin Source File - -SOURCE=.\SoundWin32.hxx -# End Source File -# Begin Source File - -SOURCE=.\stella.rc -# End Source File -# Begin Source File - -SOURCE=.\StellaXMain.cxx -# End Source File -# Begin Source File - -SOURCE=.\StellaXMain.hxx -# End Source File -# Begin Source File - -SOURCE=.\TextButton3d.cxx -# End Source File -# Begin Source File - -SOURCE=.\TextButton3d.hxx -# End Source File -# Begin Source File - -SOURCE=.\Timer.cxx -# End Source File -# Begin Source File - -SOURCE=.\Timer.hxx -# End Source File -# Begin Source File - -SOURCE=.\Wnd.cxx -# End Source File -# Begin Source File - -SOURCE=.\Wnd.hxx -# End Source File -# End Group -# Begin Group "Sound" - -# PROP Default_Filter "" -# Begin Source File - -SOURCE=..\sound\TIASound.c -# End Source File -# Begin Source File - -SOURCE=..\sound\TIASound.h -# End Source File -# End Group -# Begin Source File - -SOURCE=..\..\emucore\m6502\src\bspf\src\bspf.hxx -# End Source File -# Begin Source File - -SOURCE=..\..\build\M6502Hi.ins -# End Source File -# Begin Source File - -SOURCE=..\..\build\M6502Low.ins -# End Source File -# Begin Source File - -SOURCE=.\STELLA.ICO -# End Source File -# Begin Source File - -SOURCE=.\tile.bmp -# End Source File -# End Target -# End Project diff --git a/stella/src/win32/Stella.sln b/stella/src/win32/Stella.sln deleted file mode 100755 index 2415c8948..000000000 --- a/stella/src/win32/Stella.sln +++ /dev/null @@ -1,21 +0,0 @@ -Microsoft Visual Studio Solution File, Format Version 8.00 -Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "Stella", "Stella.vcproj", "{9ACB50CD-C986-4105-9EEE-E70DCD4C925E}" - ProjectSection(ProjectDependencies) = postProject - EndProjectSection -EndProject -Global - GlobalSection(SolutionConfiguration) = preSolution - Debug = Debug - Release = Release - EndGlobalSection - GlobalSection(ProjectConfiguration) = postSolution - {9ACB50CD-C986-4105-9EEE-E70DCD4C925E}.Debug.ActiveCfg = Debug|Win32 - {9ACB50CD-C986-4105-9EEE-E70DCD4C925E}.Debug.Build.0 = Debug|Win32 - {9ACB50CD-C986-4105-9EEE-E70DCD4C925E}.Release.ActiveCfg = Release|Win32 - {9ACB50CD-C986-4105-9EEE-E70DCD4C925E}.Release.Build.0 = Release|Win32 - EndGlobalSection - GlobalSection(ExtensibilityGlobals) = postSolution - EndGlobalSection - GlobalSection(ExtensibilityAddIns) = postSolution - EndGlobalSection -EndGlobal diff --git a/stella/src/win32/Stella.vcproj b/stella/src/win32/Stella.vcproj deleted file mode 100755 index 9d3315d19..000000000 --- a/stella/src/win32/Stella.vcproj +++ /dev/null @@ -1,637 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - diff --git a/stella/src/win32/StellaXMain.cxx b/stella/src/win32/StellaXMain.cxx deleted file mode 100644 index afcff72e7..000000000 --- a/stella/src/win32/StellaXMain.cxx +++ /dev/null @@ -1,183 +0,0 @@ -// -// StellaX -// Jeff Miller 05/13/2000 -// - -#include -#include -#include -#include - -#include "resource.h" -#include "GlobalData.hxx" -#include "pch.hxx" -#include "StellaXMain.hxx" - -// -// CStellaXMain -// -// equivalent to main() in the DOS version of stella -// - - -CStellaXMain::CStellaXMain( - ) : \ - m_pPropertiesSet( NULL ) -{ - TRACE( "CStellaXMain::CStellaXMain" ); -} - -CStellaXMain::~CStellaXMain( - ) -{ - TRACE( "CStellaXMain::~CStellaXMain" ); -} - -DWORD CStellaXMain::Initialize( - void - ) -{ - return ERROR_SUCCESS; -} - -HRESULT CStellaXMain::PlayROM( - HWND hwnd, - LPCTSTR pszPathName, - LPCTSTR pszFriendlyName, - CGlobalData& rGlobalData - ) -{ - UNUSED_ALWAYS( hwnd ); - - HRESULT hr = S_OK; - - TRACE("CStellaXMain::PlayROM"); - - // - // show wait cursor while loading - // - - HCURSOR hcur = ::SetCursor( ::LoadCursor( NULL, IDC_WAIT ) ); - - // - // setup objects used here - // - - BYTE* pImage = NULL; - LPCTSTR pszFileName = NULL; - - // - // Load the rom file - // - - HANDLE hFile; - DWORD dwImageSize; - - hFile = ::CreateFile( pszPathName, - GENERIC_READ, - FILE_SHARE_READ, - NULL, - OPEN_EXISTING, - FILE_ATTRIBUTE_NORMAL, - NULL ); - if (hFile == INVALID_HANDLE_VALUE) - { - HINSTANCE hInstance = (HINSTANCE)::GetWindowLong( hwnd, GWL_HINSTANCE ); - - DWORD dwLastError = ::GetLastError(); - - TCHAR pszCurrentDirectory[ MAX_PATH + 1 ]; - ::GetCurrentDirectory( MAX_PATH, pszCurrentDirectory ); - - // ::MessageBoxFromGetLastError( pszPathName ); - TCHAR pszFormat[ 1024 ]; - LoadString( hInstance, - IDS_ROM_LOAD_FAILED, - pszFormat, 1023 ); - - LPTSTR pszLastError = NULL; - - FormatMessage( - FORMAT_MESSAGE_ALLOCATE_BUFFER | FORMAT_MESSAGE_FROM_SYSTEM, - NULL, - dwLastError, - MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT), - (LPTSTR)&pszLastError, - 0, - NULL); - - TCHAR pszError[ 1024 ]; - wsprintf( pszError, - pszFormat, - pszCurrentDirectory, - pszPathName, - dwLastError, - pszLastError ); - - ::MessageBox( hwnd, - pszError, - _T("Error"), - MB_OK | MB_ICONEXCLAMATION ); - - ::LocalFree( pszLastError ); - - hr = HRESULT_FROM_WIN32( ::GetLastError() ); - goto exit; - } - - dwImageSize = ::GetFileSize( hFile, NULL ); - - pImage = new BYTE[dwImageSize + 1]; - if ( pImage == NULL ) - { - hr = E_OUTOFMEMORY; - goto exit; - } - - DWORD dwActualSize; - if ( ! ::ReadFile( hFile, pImage, dwImageSize, &dwActualSize, NULL ) ) - { - VERIFY( ::CloseHandle( hFile ) ); - - MessageBoxFromGetLastError( pszPathName ); - - hr = HRESULT_FROM_WIN32( ::GetLastError() ); - goto exit; - } - - VERIFY( ::CloseHandle(hFile) ); - - // - // get just the filename - // - - pszFileName = _tcsrchr( pszPathName, _T('\\') ); - if ( pszFileName ) - { - ++pszFileName; - } - else - { - pszFileName = pszPathName; - } - - // restore cursor - - ::SetCursor( hcur ); - hcur = NULL; - - ::ShowWindow( hwnd, SW_HIDE ); - -// launch game here - - ::ShowWindow( hwnd, SW_SHOW ); - -exit: - - if ( hcur ) - { - ::SetCursor( hcur ); - } - - return hr; -} diff --git a/stella/src/win32/StellaXMain.hxx b/stella/src/win32/StellaXMain.hxx deleted file mode 100644 index 0fb82a83d..000000000 --- a/stella/src/win32/StellaXMain.hxx +++ /dev/null @@ -1,41 +0,0 @@ -// -// StellaX -// Jeff Miller 05/12/2000 -// -#ifndef STELLAX_H -#define STELLAX_H -#pragma once - -class PropertiesSet; -class CGlobalData; - -class CStellaXMain -{ -public: - - CStellaXMain(); - ~CStellaXMain(); - - DWORD Initialize( void ); - - HRESULT PlayROM( HWND hwnd, LPCTSTR ctszPathName, - LPCTSTR pszFriendlyName, - CGlobalData& rGlobalData ); - PropertiesSet& GetPropertiesSet() const; - -private: - - PropertiesSet* m_pPropertiesSet; - -CStellaXMain( const CStellaXMain& ); // no implementation -void operator=( const CStellaXMain& ); // no implementation -}; - -inline PropertiesSet& CStellaXMain::GetPropertiesSet( - void - ) const -{ - return *m_pPropertiesSet; -} - -#endif diff --git a/stella/src/win32/TextButton3d.cxx b/stella/src/win32/TextButton3d.cxx deleted file mode 100644 index e2ccb5760..000000000 --- a/stella/src/win32/TextButton3d.cxx +++ /dev/null @@ -1,186 +0,0 @@ -// -// StellaX -// Jeff Miller 10/12/1999 -// -#include "pch.hxx" -#include "TextButton3d.hxx" - -// button style should be VISIBLE / DISABLED / OWNERDRAW - -CTextButton3d::CTextButton3d -( -) -{ -} - -LRESULT CTextButton3d::WndProc -( - HWND hWnd, - UINT msg, - WPARAM wParam, - LPARAM lParam, - BOOL& rfHandled -) -{ - switch (msg) - { -#if 0 - - // TODO: re do this now that I send this message here - case WM_DRAWITEM: - rfHandled = TRUE; - pThis->OnDrawItem(hWnd, (UINT)wParam, (LPDRAWITEMSTRUCT)lParam); - return TRUE; -#endif - - case WM_PAINT: - rfHandled = TRUE; - OnPaint(hWnd, (HDC)wParam); - return TRUE; - - case WM_ERASEBKGND: - rfHandled = TRUE; - return OnEraseBkgnd(hWnd, (HDC)wParam); - } - - return 0; -} - -void CTextButton3d::OnPaint -( - HWND hwnd, - HDC hdcPaint -) -{ - PAINTSTRUCT ps; - HDC hdc = BeginPaint(hwnd, &ps); - - int cxClient, cyClient; - - RECT rc; - GetClientRect(hwnd, &rc); - - RECT rcClient; - CopyRect(&rcClient, &rc); - - // lpdis->rcItem, lpdis->itemState - - int l = GetWindowTextLength(hwnd); - LPTSTR text = new TCHAR[l + 2]; - if (text == NULL) - { - EndPaint(hwnd, &ps); - return; - } - GetWindowText(hwnd, text, l+1); - - HFONT hfont = (HFONT)SendMessage(hwnd, WM_GETFONT, 0, 0); - LOGFONT lf; - GetObject(hfont, sizeof(lf), &lf); - if (lf.lfHeight == 0) - lf.lfHeight = 20; - lf.lfWidth = 0; - lf.lfWeight = FW_BLACK; - lf.lfEscapement = 0; - lf.lfOrientation = 0; - HFONT hfontTry = CreateFontIndirect(&lf); - - HFONT hfontOld = (HFONT)SelectObject(hdc, hfontTry); - - rcClient.left += 3; - rcClient.top += 3; - rcClient.right -= 3; - rcClient.bottom -= 3; - - cxClient = rcClient.right - rcClient.left; - cyClient = rcClient.bottom - rcClient.top; - - SIZE sizeTextClient; - GetTextExtentPoint(hdc, text, lstrlen(text), - &sizeTextClient); - if (cxClient*sizeTextClient.cy > cyClient*sizeTextClient.cx) - { - lf.lfHeight = MulDiv(lf.lfHeight, cyClient, sizeTextClient.cy); - } - else - { - lf.lfHeight = MulDiv(lf.lfHeight, cxClient, sizeTextClient.cx); - } - - lf.lfHeight--; - - rcClient.left -= 3; - rcClient.top -= 3; - rcClient.right += 3; - rcClient.bottom += 3; - - cxClient = rcClient.right - rcClient.left; - cyClient = rcClient.bottom - rcClient.top; - - hfont = CreateFontIndirect(&lf); - SelectObject(hdc, hfont); - GetTextExtentPoint(hdc, text, lstrlen(text), - &sizeTextClient); - - int minx = rcClient.left + (cxClient - sizeTextClient.cx) / 2; - int miny = rcClient.top + (cyClient - sizeTextClient.cy) / 2; - - int iOldBkMode = SetBkMode(hdc, TRANSPARENT); - COLORREF crText = GetSysColor(COLOR_BTNTEXT); - COLORREF crOldText = SetTextColor(hdc, crText); - - int cx = minx; - int cy = miny; - - int s = 1; - cx += 3; - cy += 3; - - // draw 3D highlights - - SetTextColor(hdc, GetSysColor(COLOR_3DDKSHADOW)); - TextOut(hdc, cx-s*2, cy+s*2, text, lstrlen(text)); - TextOut(hdc, cx+s*2, cy-s*2, text, lstrlen(text)); - TextOut(hdc, cx+s*2, cy+s*2, text, lstrlen(text)); - SetTextColor(hdc, ::GetSysColor(COLOR_3DHILIGHT)); - TextOut(hdc, cx+s*1, cy-s*2, text, lstrlen(text)); - TextOut(hdc, cx-s*2, cy+s*1, text, lstrlen(text)); - TextOut(hdc, cx-s*2, cy-s*2, text, lstrlen(text)); - SetTextColor(hdc, GetSysColor(COLOR_3DSHADOW)); - TextOut(hdc, cx-s*1, cy+s*1, text, lstrlen(text)); - TextOut(hdc, cx+s*1, cy-s*1, text, lstrlen(text)); - TextOut(hdc, cx+s*1, cy+s*1, text, lstrlen(text)); - SetTextColor(hdc, GetSysColor(COLOR_3DLIGHT)); - TextOut(hdc, cx, cy-s*1, text, lstrlen(text)); - TextOut(hdc, cx-s*1, cy, text, lstrlen(text)); - TextOut(hdc, cx-s*1, cy-s*1, text, lstrlen(text)); - SetTextColor(hdc, crText); - - // draw the text - - TextOut(hdc, cx, cy, text, lstrlen(text)); - - // restore dc - - SetTextColor(hdc, crOldText); - SetBkMode(hdc, iOldBkMode); - SelectObject(hdc, hfontOld); - - DeleteObject(hfont); - DeleteObject(hfontTry); - - delete[] text; - - EndPaint(hwnd, &ps); -} - -BOOL CTextButton3d::OnEraseBkgnd -( - HWND hwnd, - HDC hdc -) -{ - // dont do any erasing - - return TRUE; -} diff --git a/stella/src/win32/TextButton3d.hxx b/stella/src/win32/TextButton3d.hxx deleted file mode 100644 index 51a221368..000000000 --- a/stella/src/win32/TextButton3d.hxx +++ /dev/null @@ -1,33 +0,0 @@ -// -// StellaX -// Jeff Miller 05/01/2000 -// -#ifndef TXTBTN_H -#define TXTBTN_H -#pragma once - -// derived from Roger Onslow's code - -#include "Wnd.hxx" - -class CTextButton3d : public CWnd -{ -public: - - CTextButton3d(); - -protected: - - LRESULT WndProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM lParam, - BOOL& rfHandled); - -private: - - void OnPaint(HWND, HDC); - BOOL OnEraseBkgnd(HWND, HDC); - - CTextButton3d( const CTextButton3d& ); // no implementation - void operator=( const CTextButton3d& ); // no implementation -}; - -#endif diff --git a/stella/src/win32/Wnd.cxx b/stella/src/win32/Wnd.cxx deleted file mode 100644 index b1e500d0e..000000000 --- a/stella/src/win32/Wnd.cxx +++ /dev/null @@ -1,75 +0,0 @@ -// -// StellaX -// Jeff Miller 05/01/2000 -// -#include "pch.hxx" -#include "Wnd.hxx" - -// REVIEW: Need to reset old wnd proc? - -CWnd::CWnd( - ) : \ - m_pOldWindowProc(NULL), - m_hwnd(NULL) -{ -} - -BOOL CWnd::SubclassDlgItem( - HWND hwndParent, - UINT nID - ) -{ - if ( nID == 0 || hwndParent == NULL ) - { - return FALSE; - } - - // can't subclass twice! - - if ( m_pOldWindowProc != NULL ) - { - return FALSE; - } - - m_hwnd = GetDlgItem( hwndParent, nID ); - if (m_hwnd == NULL) - { - ASSERT( FALSE ); - return FALSE; - } - - PreSubclassWindow( m_hwnd ); - - m_pOldWindowProc = (WNDPROC)GetWindowLong( m_hwnd, GWL_WNDPROC ); - SetWindowLong( m_hwnd, GWL_USERDATA, (LONG)this ); - SetWindowLong( m_hwnd, GWL_WNDPROC, (LONG)StaticWndProc ); - - return TRUE; -} - -void CWnd::PreSubclassWindow( - HWND hwnd - ) -{ - // no default behavior -} - -LRESULT CALLBACK CWnd::StaticWndProc( - HWND hWnd, - UINT msg, - WPARAM wParam, - LPARAM lParam - ) -{ - CWnd* pThis = (CWnd*)GetWindowLong(hWnd, GWL_USERDATA); - - BOOL fHandled = FALSE; - LRESULT lRes = pThis->WndProc( hWnd, msg, wParam, lParam, fHandled ); - - if (fHandled) - { - return lRes; - } - - return CallWindowProc( pThis->m_pOldWindowProc, hWnd, msg, wParam, lParam ); -} diff --git a/stella/src/win32/Wnd.hxx b/stella/src/win32/Wnd.hxx deleted file mode 100644 index ad14cf991..000000000 --- a/stella/src/win32/Wnd.hxx +++ /dev/null @@ -1,39 +0,0 @@ -// -// StellaX -// Jeff Miller 05/01/2000 -// -#ifndef WND_H -#define WND_H - -class CWnd -{ -public: - - CWnd(); - - BOOL SubclassDlgItem( HWND hwndParent, UINT nID ); - - operator HWND() const - { - return m_hwnd; - } - -protected: - - virtual void PreSubclassWindow( HWND hwnd ); - virtual LRESULT WndProc( HWND hwnd, UINT msg, WPARAM wParam, LPARAM lParam, - BOOL& rfHandled ) = 0; - -private: - - static LRESULT CALLBACK StaticWndProc( HWND hWnd, UINT msg, - WPARAM wParam, LPARAM lParam ); - - WNDPROC m_pOldWindowProc; - HWND m_hwnd; - - CWnd( const CWnd& ); // no implementation - void operator=( const CWnd& ); // no implementation -}; - -#endif diff --git a/stella/src/win32/debug.cxx b/stella/src/win32/debug.cxx deleted file mode 100644 index f4682d20b..000000000 --- a/stella/src/win32/debug.cxx +++ /dev/null @@ -1,75 +0,0 @@ -// -// StellaX -// Jeff Miller 04/27/2000 -// - -#include "debug.hxx" - -#ifdef _DEBUG // entire file - -// log file name (or NULL for no log) -- must be defined by client - -extern LPCTSTR g_ctszDebugLog; - -// --------------------------------------------------------------------------- -// DEBUG DEFINED - -void AFX_CDECL AfxTrace( - LPCTSTR lpszFormat, - ... - ) -{ - va_list args; - va_start(args, lpszFormat); - - int nBuf; - TCHAR szBuffer[512]; - - nBuf = _vsntprintf(szBuffer, _countof(szBuffer), lpszFormat, args); - - // was there an error? was the expanded string too long? - ASSERT(nBuf >= 0); - - if (nBuf < 511) - { - lstrcat(szBuffer, _T("\r\n")); - } - - _RPT0(_CRT_WARN, szBuffer); - - if (g_ctszDebugLog) - { - HANDLE hfile = CreateFile(g_ctszDebugLog, GENERIC_WRITE, 0, NULL, - OPEN_ALWAYS, FILE_ATTRIBUTE_NORMAL, NULL); - if (hfile != INVALID_HANDLE_VALUE) - { - SetFilePointer(hfile, 0, NULL, FILE_END); - - DWORD dw; - WriteFile(hfile, szBuffer, (lstrlen(szBuffer)+1)*sizeof(TCHAR), - &dw, NULL); - - CloseHandle(hfile); - } - } - - va_end(args); -} - -BOOL AFXAPI AfxAssertFailedLine( - LPCSTR lpszFileName, - int nLine, - LPCTSTR lpszCondition - ) -{ - // we remove WM_QUIT because if it is in the queue then the message box - // won't display - MSG msg; - BOOL bQuit = PeekMessage(&msg, NULL, WM_QUIT, WM_QUIT, PM_REMOVE); - BOOL bResult = _CrtDbgReport(_CRT_ASSERT, lpszFileName, nLine, NULL, lpszCondition); - if (bQuit) - PostQuitMessage(msg.wParam); - return bResult; -} - -#endif //_DEBUG diff --git a/stella/src/win32/debug.hxx b/stella/src/win32/debug.hxx deleted file mode 100644 index 9e198047c..000000000 --- a/stella/src/win32/debug.hxx +++ /dev/null @@ -1,99 +0,0 @@ -// -// StellaX -// Jeff Miller 05/27/1999 -// - -#ifndef _AFX -#define _AFX -#pragma once - -#include -#include - -// --------------------------------------------------------------------------- -// This file defines: -// _countof -// TRACE, TRACE0, TRACE1, TRACE2, TRACE3 -// ASSERT -// VERIFY -// DEBUG_ONLY - - - -// determine number of elements in an array (not bytes) -#define _countof(array) (sizeof(array)/sizeof(array[0])) - -// AFXAPI is used on global public functions -#ifndef AFXAPI - #define AFXAPI __stdcall -#endif - -// AFX_CDECL is used for rare functions taking variable arguments -#ifndef AFX_CDECL - #define AFX_CDECL __cdecl -#endif - - -#ifdef _DEBUG - -// --------------------------------------------------------------------------- -// DEBUG DEFINED - -#include - -#include -#include - -#include - -#ifndef AfxDebugBreak -#define AfxDebugBreak() _CrtDbgBreak() -#endif - -BOOL AFXAPI AfxAssertFailedLine(LPCSTR lpszFileName, int nLine, LPCTSTR lpszCondition); - -void AFX_CDECL AfxTrace(LPCTSTR lpszFormat, ...); - -#define TRACE ::AfxTrace -#define THIS_FILE __FILE__ -#define ASSERT(f) \ - do \ - { \ - if (!(f) && AfxAssertFailedLine(THIS_FILE, __LINE__, #f)) \ - AfxDebugBreak(); \ - } while (0) \ - -#define VERIFY(f) ASSERT(f) -#define DEBUG_ONLY(f) (f) - -// The following trace macros are provided for backward compatiblity -// (they also take a fixed number of parameters which provides -// some amount of extra error checking) -#define TRACE0(sz) ::AfxTrace(_T("%s"), _T(sz)) -#define TRACE1(sz, p1) ::AfxTrace(_T(sz), p1) -#define TRACE2(sz, p1, p2) ::AfxTrace(_T(sz), p1, p2) -#define TRACE3(sz, p1, p2, p3) ::AfxTrace(_T(sz), p1, p2, p3) - -#else // _DEBUG - -// --------------------------------------------------------------------------- -// DEBUG NOT DEFINED - -#ifdef AfxDebugBreak -#undef AfxDebugBreak -#endif -#define AfxDebugBreak() - -#define ASSERT(f) ((void)0) -#define VERIFY(f) ((void)(f)) -#define DEBUG_ONLY(f) ((void)0) -inline void AFX_CDECL AfxTrace(LPCTSTR, ...) { } -#define TRACE 1 ? (void)0 : ::AfxTrace -#define TRACE0(sz) -#define TRACE1(sz, p1) -#define TRACE2(sz, p1, p2) -#define TRACE3(sz, p1, p2, p3) - -#endif // !_DEBUG - -#endif diff --git a/stella/src/win32/main.cxx b/stella/src/win32/main.cxx deleted file mode 100644 index fa16d4e87..000000000 --- a/stella/src/win32/main.cxx +++ /dev/null @@ -1,94 +0,0 @@ -//============================================================================ -// -// SSSS tt lll lll -// SS SS tt ll ll -// SS tttttt eeee ll ll aaaa -// SSSS tt ee ee ll ll aa -// SS tt eeeeee ll ll aaaaa -- "An Atari 2600 VCS Emulator" -// SS SS tt ee ll ll aa aa -// SSSS ttt eeeee llll llll aaaaa -// -// Copyright (c) 1995-2000 by Jeff Miller -// Copyright (c) 2004 by Stephen Anthony -// -// See the file "license" for information on usage and redistribution of -// this file, and for a DISCLAIMER OF ALL WARRANTIES. -// -// $Id: main.cxx,v 1.3 2004-05-28 23:16:26 stephena Exp $ -//============================================================================ - -#include "pch.hxx" -#include "resource.h" - -#include "GlobalData.hxx" -#include "MainDlg.hxx" - -class CSingleInstance -{ - public: - CSingleInstance( LPCTSTR pszName ) - { - ::SetLastError( ERROR_SUCCESS ); - m_hMutex = ::CreateMutex( NULL, TRUE, pszName ); - m_dwError = ::GetLastError(); - } - - ~CSingleInstance() - { - if ( m_hMutex != INVALID_HANDLE_VALUE && m_dwError != ERROR_ALREADY_EXISTS ) - { - VERIFY( ::ReleaseMutex( m_hMutex ) ); - VERIFY( ::CloseHandle( m_hMutex ) ); - } - } - - BOOL AlreadyExists( void ) const - { - return ( m_dwError == ERROR_ALREADY_EXISTS ); - } - - private: - HANDLE m_hMutex; - DWORD m_dwError; - - CSingleInstance( const CSingleInstance& ); // no implementation - void operator=( const CSingleInstance& ); // no implementation -}; - -// see debug.cpp - -LPCTSTR g_ctszDebugLog = _T("stella.log"); - -int WINAPI _tWinMain( HINSTANCE hInstance, HINSTANCE hPrevInstance, - LPTSTR lpCmdLine, int nCmdShow ) -{ - UNUSED_ALWAYS( hPrevInstance ); - UNUSED_ALWAYS( lpCmdLine ); - UNUSED_ALWAYS( nCmdShow ); - - (void)::DeleteFile(g_ctszDebugLog); - - CSingleInstance mutex( _T("StellaXMutex") ); - if ( mutex.AlreadyExists() ) - { - MessageBox( hInstance, NULL, IDS_ALREADYRUNNING ); - return 1; - } - - HRESULT hrCoInit = ::CoInitialize( NULL ); - if ( FAILED(hrCoInit) ) - MessageBox( hInstance, NULL, IDS_COINIT_FAILED ); - - ::InitCommonControls(); - - CGlobalData globaldata( hInstance ); - - // show the ui - CMainDlg dlg( globaldata, hInstance ); - dlg.DoModal( NULL ); - - if ( hrCoInit == S_OK ) - ::CoUninitialize(); - - return 0; -} diff --git a/stella/src/win32/pch.cxx b/stella/src/win32/pch.cxx deleted file mode 100644 index 882b9e45f..000000000 --- a/stella/src/win32/pch.cxx +++ /dev/null @@ -1,88 +0,0 @@ -// -// StellaX -// Jeff Miller 05/01/2000 -// -#include "pch.hxx" -#include -#include - -#include "resource.h" - -// This will force in the DirectX library - -#pragma comment( lib, "dxguid" ) - -// Bring in DirectInput library (for c_dfDIMouse, etc) - -#pragma comment( lib, "dinput" ) - -// Bring in the common control library - -#pragma comment( lib, "comctl32" ) - -// Bring in multimedia timers - -#pragma comment( lib, "winmm" ) - -void MessageBox( - HINSTANCE hInstance, - HWND hwndParent, - UINT uIDText - ) -{ - const int nMaxStrLen = 1024; - TCHAR tszCaption[nMaxStrLen + 1] = { 0 }; - TCHAR tszText[nMaxStrLen + 1] = { 0 }; - - // Caption is always "StellaX" - - LoadString(hInstance, IDS_STELLA, tszCaption, nMaxStrLen); - - LoadString(hInstance, uIDText, tszText, nMaxStrLen); - - if (hwndParent == NULL) - { - hwndParent = ::GetForegroundWindow(); - } - - ::MessageBox(hwndParent, tszText, tszCaption, MB_ICONWARNING | MB_OK); -} - -void MessageBoxFromWinError( - DWORD dwError, - LPCTSTR pszCaption /* = NULL */ - ) -{ - const int nMaxStrLen = 1024; - TCHAR pszCaptionStellaX[nMaxStrLen + 1]; - - if ( pszCaption == NULL ) - { - // LoadString(hInstance, IDS_STELLA, tszCaption, nMaxStrLen); - lstrcpy( pszCaptionStellaX, _T("StellaX") ); - } - - LPTSTR pszText = NULL; - - FormatMessage( - FORMAT_MESSAGE_ALLOCATE_BUFFER | FORMAT_MESSAGE_FROM_SYSTEM, - NULL, - dwError, - MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT), - (LPTSTR)&pszText, - 0, - NULL); - - ::MessageBox(::GetForegroundWindow(), pszText, - pszCaption ? pszCaption : pszCaptionStellaX, MB_ICONWARNING | MB_OK); - - ::LocalFree( pszText ); -} - -void MessageBoxFromGetLastError( - LPCTSTR pszCaption /* = NULL */ - ) -{ - MessageBoxFromWinError( GetLastError(), pszCaption ); -} - diff --git a/stella/src/win32/pch.hxx b/stella/src/win32/pch.hxx deleted file mode 100644 index e16009fc1..000000000 --- a/stella/src/win32/pch.hxx +++ /dev/null @@ -1,139 +0,0 @@ -// -// StellaX -// Jeff Miller 05/01/2000 -// -#ifndef PCH_H -#define PCH_H -#pragma once - -#ifndef _WIN32 -#error This file can only be compiled for a Win32 platform -#endif - -#define WIN32_LEAN_AND_MEAN -#define STRICT -#define DIRECTINPUT_VERSION 5 -#include -#include -#include - -// warning C4201: nonstandard extension used : nameless struct/union - -#pragma warning ( once: 4201 ) - -#include -#include -#include - -#include -#include -#include - -#include "debug.hxx" - -// --------------------------------------------------------------------------- -// Conditional defines - -#define DOUBLE_WIDTH - -// -// Macros -// - -#ifdef _DEBUG -#define UNUSED(x) -#else -#define UNUSED(x) x -#endif -#define UNUSED_ALWAYS(x) x - -// -// Simple string class -// - -class CSimpleString -{ -public: - - CSimpleString() : - m_psz( NULL ), - m_cch( -1 ) - { - } - - ~CSimpleString() - { - delete[] m_psz; - m_psz = NULL; - - m_cch = -1; - } - - BOOL Set( LPCTSTR psz ) - { - int cch = lstrlen( psz ); - if ( cch > m_cch ) - { - delete[] m_psz; - m_psz = NULL; - m_cch = -1; - - m_psz = new TCHAR[ cch + 1 ]; - if ( m_psz == NULL ) - { - return FALSE; - } - - m_cch = cch; - } - - memcpy( m_psz, psz, ( cch + 1 ) * sizeof( TCHAR ) ); - - return TRUE; - } - - LPCTSTR Get( void ) const - { - ASSERT( m_psz != NULL ); - return m_psz; - } - - int Length( void ) const - { - return m_cch; - } - -private: - - // - // The string and its size (-1 means not initialized) - // - - LPTSTR m_psz; - int m_cch; - - CSimpleString( const CSimpleString& ); // no implementation - void operator=( const CSimpleString& ); // no implementation -}; - -// -// Utility methods -// - -void MessageBox( - HINSTANCE hInstance, - HWND hwndParent, - UINT uIDText - ); - -void MessageBoxFromWinError( - DWORD dwError, - LPCTSTR pszCaption /* = NULL */ - ); - -void MessageBoxFromGetLastError( - LPCTSTR pszCaption /* = NULL */ - ); - - -#endif diff --git a/stella/src/win32/resource.h b/stella/src/win32/resource.h deleted file mode 100644 index d6f44d6db..000000000 --- a/stella/src/win32/resource.h +++ /dev/null @@ -1,87 +0,0 @@ -//{{NO_DEPENDENCIES}} -// Microsoft Visual C++ generated include file. -// Used by stella.rc -// -#define IDB_TILE 101 -#define IDI_APP 102 -#define IDD_ABOUT 103 -#define IDD_MAIN 104 -#define IDD_ABOUT_PAGE 106 -#define IDD_DOC_PAGE 107 -#define IDD_CONFIG_PAGE 108 -#define IDS_ALREADYRUNNING 200 -#define IDS_BADARGUMENT 201 -#define IDS_BADFRAMERATE 202 -#define IDS_BADPADDLEMODE 203 -#define IDS_CANTOPEN 204 -#define IDS_CW_FAILED 208 -#define IDS_DDCP_FAILED 224 -#define IDS_DDCS_FAILED 240 -#define IDS_DDSCL_FAILED 256 -#define IDS_DDSDM_FAILED 272 -#define IDS_DSCSBFAILED 273 -#define IDS_DSSCLFAILED 274 -#define IDS_FATALERROR 275 -#define IDS_FILEFILTER 276 -#define IDS_FILENAME 277 -#define IDS_MANUFACTURER 278 -#define IDS_MIKE 279 -#define IDS_NAME 280 -#define IDS_NODIRECTDRAW 281 -#define IDS_NOGOODVIDEOMODE 282 -#define IDS_OUTOFMEMORY 283 -#define IDS_RARITY 284 -#define IDS_RC_FAILED 288 -#define IDS_STATUSTEXT 289 -#define IDS_STELLA 290 -#define IDS_UNKNOWNERROR 291 -#define IDS_DEBUGBUILD 292 -#define IDS_NODIRECTINPUT 293 -#define IDS_FATALSOUNDERROR 294 -#define IDS_CANTSTARTCONSOLE 295 -#define IDS_COINIT_FAILED 296 -#define IDS_ASS_FAILED 297 -#define IDS_PAS_FAILED 298 -#define IDS_DD_FAILED 299 -#define IDS_DD_INIT_FAILED 300 -#define IDS_DD_ENUMMODES_FAILED 301 -#define IDS_NO_VID_MODE 302 -#define IDS_DI_INIT_FAILED 303 -#define IDS_ROM_LOAD_FAILED 304 -#define IDS_NO_ITEM_SELECTED 305 -#define IDC_ABOUT 1001 -#define IDC_EMAIL_MAINTAINER 1002 -#define IDC_EMAIL_STELLA 1003 -#define IDC_EXIT 1004 -#define IDC_PLAY 1005 -#define IDC_ROMCOUNT 1006 -#define IDC_ROMLIST 1007 -#define IDC_STATIC 1008 -#define IDC_TITLE 1009 -#define IDC_WEB_MAINTAINER 1010 -#define IDC_WEB_STELLA 1011 -#define IDC_WWW_MAME 1012 -#define IDC_ROMPATH 1013 -#define IDC_ROMNOTE 1014 -#define IDC_CONFIG 1015 -#define IDC_PADDLE 1017 -#define IDC_SOUND 1018 -#define IDC_VOLUME 1019 -#define IDC_VIDEO 1020 -#define IDC_ASPECT 1021 -#define IDC_BROWSE 1022 -#define IDC_EDIT2 1027 -#define IDC_INSTRUCTIONS 2000 -#define IDC_ADOBE 2001 -#define ID_FILE_EXIT 32771 - -// Next default values for new objects -// -#ifdef APSTUDIO_INVOKED -#ifndef APSTUDIO_READONLY_SYMBOLS -#define _APS_NEXT_RESOURCE_VALUE 296 -#define _APS_NEXT_COMMAND_VALUE 32772 -#define _APS_NEXT_CONTROL_VALUE 1028 -#define _APS_NEXT_SYMED_VALUE 101 -#endif -#endif diff --git a/stella/src/win32/stella.aps b/stella/src/win32/stella.aps deleted file mode 100755 index 5136fefc96394765b0b9d65123e106bd33c934b6..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 45124 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 diff --git a/stella/src/win32/stella.ico b/stella/src/win32/stella.ico deleted file mode 100644 index f5d8e9433a6d6a772c94293d2379f1c1756db23a..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1078 zcmd5*yKcfj5S$}OX;983Rd5yY8Of*QFX-4$^QTazbeSrfnOy=LMj}#(#M-m3xjjEL z2NcZE_Z?&(GvI}>>#|-K;OPNav)2=^M8TXMFs{99Mv{zK270C#hJjIp#|?L71TVGZ z{@bdLd_)bWbXrF@nB?0!XEh&t?DuMF4zSLR#h=w`)bT*af~MxQuH&D$xBB>IH_xbn z#%%Lk0?TEwQ&5IRd;+Ued;wd*t@y9dJk4D??}(l_=$!dwGisa+H64MT>7R5i;pjwE t-g5HlNE2~b;5DUDtJ);4#8@Tut#a_YF#d+zJ2y diff --git a/stella/src/win32/stella.rc b/stella/src/win32/stella.rc deleted file mode 100755 index 43facee09..000000000 --- a/stella/src/win32/stella.rc +++ /dev/null @@ -1,346 +0,0 @@ -// Microsoft Visual C++ generated resource script. -// -#include "resource.h" - -#define APSTUDIO_READONLY_SYMBOLS -///////////////////////////////////////////////////////////////////////////// -// -// Generated from the TEXTINCLUDE 2 resource. -// -#define APSTUDIO_HIDDEN_SYMBOLS -#include "winresrc.h" -#undef APSTUDIO_HIDDEN_SYMBOLS -#include "resource.h" - -///////////////////////////////////////////////////////////////////////////// -#undef APSTUDIO_READONLY_SYMBOLS - -///////////////////////////////////////////////////////////////////////////// -// English (U.S.) resources - -#if !defined(AFX_RESOURCE_DLL) || defined(AFX_TARG_ENU) -#ifdef _WIN32 -LANGUAGE LANG_ENGLISH, SUBLANG_ENGLISH_US -#pragma code_page(1252) -#endif //_WIN32 - -#ifdef APSTUDIO_INVOKED -///////////////////////////////////////////////////////////////////////////// -// -// TEXTINCLUDE -// - -1 TEXTINCLUDE -BEGIN - "resource.h\0" -END - -2 TEXTINCLUDE -BEGIN - "#define APSTUDIO_HIDDEN_SYMBOLS\r\n" - "#include ""winresrc.h""\r\n" - "#undef APSTUDIO_HIDDEN_SYMBOLS\r\n" - "#include ""resource.h""\r\n" - "\0" -END - -3 TEXTINCLUDE -BEGIN - "\r\n" - "\0" -END - -#endif // APSTUDIO_INVOKED - - -///////////////////////////////////////////////////////////////////////////// -// -// Version -// - -VS_VERSION_INFO VERSIONINFO - FILEVERSION 1,4,0,0 - PRODUCTVERSION 1,4,0,0 - FILEFLAGSMASK 0x3fL -#ifdef _DEBUG - FILEFLAGS 0x29L -#else - FILEFLAGS 0x28L -#endif - FILEOS 0x40004L - FILETYPE 0x1L - FILESUBTYPE 0x0L -BEGIN - BLOCK "StringFileInfo" - BEGIN - BLOCK "040904b0" - BEGIN - VALUE "Comments", "This version of StellaX is released under the GPL." - VALUE "CompanyName", "Stephen Anthony (stephena@users.sourceforge.net)" - VALUE "FileDescription", "StellaX" - VALUE "FileVersion", "1, 4, 0, 0" - VALUE "InternalName", "StellaX" - VALUE "LegalCopyright", "Copyright (C) 2004 Jeff Miller, Copyright (C) 2004 Stephen Anthony" - VALUE "LegalTrademarks", "n/a" - VALUE "OriginalFilename", "StellaX.exe" - VALUE "PrivateBuild", "n/a" - VALUE "ProductName", "StellaX" - VALUE "ProductVersion", "1, 4, 0, 0" - VALUE "SpecialBuild", "n/a" - END - END - BLOCK "VarFileInfo" - BEGIN - VALUE "Translation", 0x409, 1200 - END -END - - -///////////////////////////////////////////////////////////////////////////// -// -// Dialog -// - -IDD_MAIN DIALOGEX 0, 0, 409, 249 -STYLE DS_SETFONT | DS_MODALFRAME | DS_FIXEDSYS | DS_CENTER | WS_POPUP | - WS_VISIBLE | WS_CAPTION -CAPTION "StellaX" -FONT 8, "MS Shell Dlg", 0, 0, 0x0 -BEGIN - CONTROL "&Files found in:",-1,"Static",SS_LEFTNOWORDWRAP | - WS_GROUP,7,45,44,8 - CONTROL "List1",IDC_ROMLIST,"SysListView32",LVS_REPORT | - LVS_SINGLESEL | LVS_SHOWSELALWAYS | LVS_AUTOARRANGE | - WS_BORDER | WS_TABSTOP,7,57,395,143,WS_EX_STATICEDGE - CONTROL "&Play",IDC_PLAY,"Button",BS_OWNERDRAW | WS_TABSTOP,7, - 226,200,16 - CONTROL "&Options",IDC_CONFIG,"Button",BS_OWNERDRAW | WS_TABSTOP, - 230,226,54,16 - CONTROL "&Help",IDC_ABOUT,"Button",BS_OWNERDRAW | WS_TABSTOP,289, - 226,54,16 - CONTROL "E&xit",IDC_EXIT,"Button",BS_OWNERDRAW | WS_TABSTOP,348, - 226,54,16 - CTEXT "Written by Jeff Miller (miller@zipcon.net)\nStella core by Bradford W. Mott (bwmott@acm.org)", - IDC_STATIC,175,13,227,19,SS_NOPREFIX - RTEXT "",IDC_ROMCOUNT,322,45,80,8,SS_NOPREFIX - CONTROL "",-1,"Static",SS_ETCHEDHORZ,0,39,411,1 - CONTROL "",-1,"Static",SS_ETCHEDHORZ,0,218,411,1 - CONTROL "StellaX v1.4",IDC_TITLE,"Button",BS_OWNERDRAW | - BS_CENTER | BS_TOP | WS_DISABLED | WS_TABSTOP,7,7,145,22 - CONTROL "Static",IDC_ROMPATH,"Static",SS_LEFTNOWORDWRAP | - SS_NOPREFIX | WS_GROUP,57,45,254,8 - CONTROL "",IDC_ROMNOTE,"Static",SS_LEFTNOWORDWRAP | SS_NOPREFIX | - WS_GROUP,93,205,309,8 - LTEXT "Game notes (if available):",-1,7,205,98,8 -END - -IDD_DOC_PAGE DIALOG 0, 0, 390, 196 -STYLE DS_SETFONT | WS_CHILD | WS_DISABLED | WS_CAPTION -CAPTION "Documentation" -FONT 8, "MS Shell Dlg" -BEGIN - LTEXT "To view the online documentation, you need to first install Adobe Acrobat Reader 4.0 software. Once you have done this, return to this page and you will be able to read the documentation.", - IDC_INSTRUCTIONS,7,7,376,21,NOT WS_VISIBLE - LTEXT "Click here to download the Adobe Acrobat Reader software", - IDC_ADOBE,7,35,376,10,SS_NOTIFY | NOT WS_VISIBLE -END - -IDD_ABOUT_PAGE DIALOGEX 0, 0, 298, 136 -STYLE DS_SETFONT | DS_FIXEDSYS | WS_CHILD | WS_DISABLED | WS_CAPTION -CAPTION "Information" -FONT 8, "MS Shell Dlg", 0, 0, 0x0 -BEGIN - LTEXT "You must own legal copies of all ROM images you are using. The Stella team can't tell you where to find ROM images so DON'T ASK. All requests will either be deleted or sent to the appropriate authorities. StellaX is GPL software.", - -1,7,7,283,30,SS_NOPREFIX - LTEXT "If you have a question or a problem, please try one of these contacts:", - -1,7,44,283,8,SS_NOPREFIX - LTEXT "Steve Anthony:",-1,7,58,53,8,SS_NOPREFIX - LTEXT "sa666_666@hotmail.com",IDC_EMAIL_MAINTAINER,73,58,122,8, - SS_NOPREFIX | SS_NOTIFY - LTEXT "http://minbar.org",IDC_WEB_MAINTAINER,202,58,72,8, - SS_NOPREFIX | SS_NOTIFY - LTEXT "Stella dev team:",-1,7,70,52,8,SS_NOPREFIX - LTEXT "stella-main@lists.sourceforge.net",IDC_EMAIL_STELLA,73, - 70,122,8,SS_NOPREFIX | SS_NOTIFY - LTEXT "http://stella.sf.net",IDC_WEB_STELLA,202,70,68,8, - SS_NOPREFIX | SS_NOTIFY - LTEXT "God, Suzi and Noah",-1,60,94,69,8,SS_NOPREFIX - LTEXT "Bradford Mott, Mike Balfour and Roger Onslow.",-1,60, - 107,204,8,SS_NOPREFIX - CONTROL "",-1,"Static",SS_ETCHEDHORZ,7,86,283,1 - LTEXT "Beta Tester:",-1,7,120,44,8,SS_NOPREFIX - LTEXT "John Hardy IV",IDC_WWW_MAME,60,120,46,8,SS_NOPREFIX | - SS_NOTIFY - CONTROL "",-1,"Static",SS_ETCHEDHORZ,7,37,283,1 - LTEXT "Thanks To:",-1,7,107,38,8 - LTEXT "Dedicated To:",-1,7,94,46,8 -END - -IDD_CONFIG_PAGE DIALOGEX 0, 0, 306, 199 -STYLE DS_SETFONT | DS_FIXEDSYS | WS_CHILD | WS_DISABLED | WS_CAPTION -CAPTION "Options" -FONT 8, "MS Shell Dlg", 0, 0, 0x0 -BEGIN - LTEXT "&ROM (.bin) file path:",-1,7,10,64,8 - EDITTEXT IDC_ROMPATH,82,7,152,14,ES_AUTOHSCROLL - PUSHBUTTON "&Browse...",IDC_BROWSE,241,7,50,14 - LTEXT "Set this to the path where your .bin rom files are located.", - -1,7,25,292,8 - CONTROL "",-1,"Static",SS_ETCHEDHORZ,7,39,292,1 - LTEXT "Mouse should emulate &paddle:",-1,7,49,111,8 - COMBOBOX IDC_PADDLE,122,47,48,82,CBS_DROPDOWNLIST | WS_VSCROLL | - WS_TABSTOP - LTEXT "Set this to specify which paddle the mouse should emulate. This can be any number from 0 to 3 inclusive.", - -1,7,66,198,18 - CONTROL "Disable &Sound",IDC_SOUND,"Button",BS_AUTOCHECKBOX | - WS_TABSTOP,7,164,62,10 - CONTROL "",-1,"Static",SS_ETCHEDHORZ,7,91,291,1 - LTEXT "Video Driver:",-1,7,101,67,10 - COMBOBOX IDC_VIDEO,67,99,51,35,CBS_DROPDOWN | CBS_SORT | - WS_VSCROLL | WS_TABSTOP - LTEXT "Aspect Ratio:",-1,7,120,55,10 - CONTROL "",-1,"Static",SS_ETCHEDHORZ,7,136,290,1 - EDITTEXT IDC_ASPECT,66,118,50,12,ES_AUTOHSCROLL -END - - -///////////////////////////////////////////////////////////////////////////// -// -// DESIGNINFO -// - -#ifdef APSTUDIO_INVOKED -GUIDELINES DESIGNINFO -BEGIN - IDD_MAIN, DIALOG - BEGIN - LEFTMARGIN, 7 - RIGHTMARGIN, 402 - TOPMARGIN, 7 - BOTTOMMARGIN, 242 - END - - IDD_DOC_PAGE, DIALOG - BEGIN - LEFTMARGIN, 7 - RIGHTMARGIN, 383 - TOPMARGIN, 7 - BOTTOMMARGIN, 189 - END - - IDD_ABOUT_PAGE, DIALOG - BEGIN - LEFTMARGIN, 7 - RIGHTMARGIN, 290 - TOPMARGIN, 7 - BOTTOMMARGIN, 128 - END - - IDD_CONFIG_PAGE, DIALOG - BEGIN - LEFTMARGIN, 7 - RIGHTMARGIN, 299 - TOPMARGIN, 7 - BOTTOMMARGIN, 192 - END -END -#endif // APSTUDIO_INVOKED - - -///////////////////////////////////////////////////////////////////////////// -// -// Icon -// - -// Icon with lowest ID value placed first to ensure application icon -// remains consistent on all systems. -IDI_APP ICON "STELLA.ICO" - -///////////////////////////////////////////////////////////////////////////// -// -// Bitmap -// - -IDB_TILE BITMAP "tile.bmp" - -///////////////////////////////////////////////////////////////////////////// -// -// String Table -// - -STRINGTABLE -BEGIN - IDS_STATUSTEXT "%d files found" - IDS_STELLA "StellaX" - IDS_NODIRECTINPUT "DirectInput could not be initialized. Be sure you have DirectX 5.0 or later installed." - IDS_CANTSTARTCONSOLE "Error starting console. You may have chosen an invalid ROM file." - IDS_COINIT_FAILED "Unable to initialize COM subsystem" - IDS_ASS_FAILED "Unable to initialize audio subsystem" - IDS_PAS_FAILED "Unable to create audio stream" - IDS_DD_INIT_FAILED "Unable to initialize DirectDraw object" - IDS_DD_ENUMMODES_FAILED "Unable to enumerate display modes" - IDS_NO_VID_MODE "No compatible video modes were found" - IDS_DI_INIT_FAILED "Unable to initialize DirectInput object" -END - -STRINGTABLE -BEGIN - IDS_ALREADYRUNNING "StellaX is already running!" - IDS_BADARGUMENT "Unknown argument given on command line" -END - -STRINGTABLE -BEGIN - IDS_DDSDM_FAILED "Unable to set video mode. Your video adapter might be incompatible with stella." - IDS_DSCSBFAILED "IDirectSound::CreateSoundBuffer failed" - IDS_DSSCLFAILED "IDirectSound::SetCooperativeLevel failed" - IDS_FILEFILTER "Stella Files (*.bin)|*.bin|All Files (*.*)|*.*||" - IDS_FILENAME "Filename" - IDS_MANUFACTURER "Manufacturer" - IDS_MIKE """I've heard some folks discussing the possibility of writing an 2600 emulator in a high level language - forget it, not possible."" -- Mike Livesay on rec.games.video.classic" - IDS_NAME "Name" - IDS_NODIRECTDRAW "DirectDraw does not appear to be installed on this system!" - IDS_RARITY "Rarity" -END - -STRINGTABLE -BEGIN - IDS_CW_FAILED "CreateWindow failed" -END - -STRINGTABLE -BEGIN - IDS_DDSCL_FAILED "IDirectDraw::SetCooperativeLevel failed" -END - -STRINGTABLE -BEGIN - IDS_DDCS_FAILED "IDirectDraw::CreateSurface failed" -END - -STRINGTABLE -BEGIN - IDS_DDCP_FAILED "IDirectDraw::CreatePalette failed" -END - -STRINGTABLE -BEGIN - IDS_ROM_LOAD_FAILED "Unable to load ROM image\n\nCurrent Directory: %s\nPath: %s\nError code: %d - %s" - IDS_NO_ITEM_SELECTED "Before pressing play you must first select a game from the list!" -END - -#endif // English (U.S.) resources -///////////////////////////////////////////////////////////////////////////// - - - -#ifndef APSTUDIO_INVOKED -///////////////////////////////////////////////////////////////////////////// -// -// Generated from the TEXTINCLUDE 3 resource. -// - - -///////////////////////////////////////////////////////////////////////////// -#endif // not APSTUDIO_INVOKED - diff --git a/stella/src/win32/tile.bmp b/stella/src/win32/tile.bmp deleted file mode 100644 index ec6faadf9c04d772a30d2a834cd336ec1b9cd7ba..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 27318 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 CAM#HC