- Code/Resource
- Windows Develop
- Linux-Unix program
- Internet-Socket-Network
- Web Server
- Browser Client
- Ftp Server
- Ftp Client
- Browser Plugins
- Proxy Server
- Email Server
- Email Client
- WEB Mail
- Firewall-Security
- Telnet Server
- Telnet Client
- ICQ-IM-Chat
- Search Engine
- Sniffer Package capture
- Remote Control
- xml-soap-webservice
- P2P
- WEB(ASP,PHP,...)
- TCP/IP Stack
- SNMP
- Grid Computing
- SilverLight
- DNS
- Cluster Service
- Network Security
- Communication-Mobile
- Game Program
- Editor
- Multimedia program
- Graph program
- Compiler program
- Compress-Decompress algrithms
- Crypt_Decrypt algrithms
- Mathimatics-Numerical algorithms
- MultiLanguage
- Disk/Storage
- Java Develop
- assembly language
- Applications
- Other systems
- Database system
- Embeded-SCM Develop
- FlashMX/Flex
- source in ebook
- Delphi VCL
- OS Develop
- MiddleWare
- MPI
- MacOS develop
- LabView
- ELanguage
- Software/Tools
- E-Books
- Artical/Document
CRSFORM.CPP
Package: MSDN_VC98.zip [view]
Upload User: bangxh
Upload Date: 2007-01-31
Package Size: 42235k
Code Size: 4k
Category:
Windows Develop
Development Platform:
Visual C++
- // crsform.cpp : implementation file
- //
- #include "stdafx.h"
- #include "enroll.h"
- #include "coursset.h"
- #include "addform.h"
- #include "crsform.h"
- #include "sectset.h"
- #include "enroldoc.h"
- #include "mainfrm.h"
- #include "resource.h"
- #ifdef _DEBUG
- #undef THIS_FILE
- static char BASED_CODE THIS_FILE[] = __FILE__;
- #endif
- /////////////////////////////////////////////////////////////////////////////
- // CCourseForm
- IMPLEMENT_DYNCREATE(CCourseForm, CAddForm)
- CCourseForm::CCourseForm()
- : CAddForm(CCourseForm::IDD)
- {
- //{{AFX_DATA_INIT(CCourseForm)
- m_pSet = NULL;
- //}}AFX_DATA_INIT
- }
- CCourseForm::~CCourseForm()
- {
- }
- void CCourseForm::DoDataExchange(CDataExchange* pDX)
- {
- CRecordView::DoDataExchange(pDX);
- //{{AFX_DATA_MAP(CCourseForm)
- DDX_Control(pDX, IDC_COURSEID, m_ctlCourseID);
- DDX_FieldText(pDX, IDC_COURSEID, m_pSet->m_CourseID, m_pSet);
- DDX_FieldText(pDX, IDC_HOURS, m_pSet->m_Hours, m_pSet);
- DDX_FieldText(pDX, IDC_TITLE, m_pSet->m_CourseTitle, m_pSet);
- //}}AFX_DATA_MAP
- }
- BOOL CCourseForm::OnMove(UINT nIDMoveCommand)
- {
- BOOL bWasAddMode = FALSE;
- CString strCourseID;
- if (m_bAddMode == TRUE)
- {
- m_ctlCourseID.GetWindowText(strCourseID);
- bWasAddMode = TRUE;
- }
- if (CAddForm::OnMove(nIDMoveCommand))
- {
- m_ctlCourseID.SetReadOnly(TRUE);
- if (bWasAddMode == TRUE)
- {
- CUpdateHint hint;
- hint.m_strCourse = strCourseID;
- GetDocument()->UpdateAllViews(this, HINT_ADD_COURSE, &hint);
- }
- return TRUE;
- }
- return FALSE;
- }
- BEGIN_MESSAGE_MAP(CCourseForm, CAddForm)
- //{{AFX_MSG_MAP(CCourseForm)
- ON_COMMAND(ID_RECORD_ADD, OnRecordAdd)
- ON_COMMAND(ID_RECORD_DELETE, OnRecordDelete)
- ON_COMMAND(ID_RECORD_REFRESH, OnRecordRefresh)
- //}}AFX_MSG_MAP
- END_MESSAGE_MAP()
- /////////////////////////////////////////////////////////////////////////////
- // CCourseForm message handlers
- CRecordset* CCourseForm::OnGetRecordset()
- {
- return m_pSet;
- }
- void CCourseForm::OnInitialUpdate()
- {
- CEnrollDoc* pDoc = (CEnrollDoc*)GetDocument();
- CDatabase* pDatabase = pDoc->GetDatabase();
- if (!pDatabase->IsOpen())
- return;
- m_pSet = &pDoc->m_courseSetForForm;
- m_pSet->m_strSort = "CourseID";
- m_pSet->m_pDatabase = pDatabase;
- CRecordView::OnInitialUpdate();
- }
- void CCourseForm::OnRecordAdd()
- {
- CAddForm::RecordAdd();
- m_ctlCourseID.SetReadOnly(FALSE);
- }
- void CCourseForm::OnRecordDelete()
- {
- // The STDREG.MDB Student Registration database in Access Format
- // does not require a programmatic validation to
- // assure that a course is not deleted if any sections exist.
- // That is because the STDREG.MDB database has been pre-built with
- // such an referential integrity rule. If the user tries to
- // delete a course that has a section, a CDBException will be
- // thrown, and ENROLL will display the SQL error message
- // informing the user that the course cannot be deleted.
- //
- // A Student Registration database initialized by the STDREG
- // tool will not have any such built-in referential integrity
- // rules. For such databases, the following code assumes the
- // burden of assuring that the course is not deleted if a section
- // exists. The reason that STDREG does not add referential
- // integrity checks to the Student Registration database is that
- // some databases such as SQL Server do not offer SQL, via ODBC,
- // for creating referential integrity rules such as "FOREIGN KEY".
- //
- // The deletion of a course is not the only place ENROLL
- // needs a programmatic referential integrity check. Another example
- // is a check that a duplicate course or seciton is not added.
- // For simplicity, ENROLL does not make these other checks.
- CEnrollDoc* pDoc = (CEnrollDoc*)GetDocument();
- CSectionSet sectionSet;
- sectionSet.m_pDatabase = pDoc->GetDatabase();
- sectionSet.m_strFilter = "CourseID = ?";
- sectionSet.m_strCourseIDParam = m_pSet->m_CourseID;
- BOOL b = sectionSet.Open();
- if (!sectionSet.IsEOF())
- {
- AfxMessageBox(IDS_CANNOT_DELETE_COURSE_WITH_SECTION);
- return;
- }
- CUpdateHint hint;
- hint.m_strCourse = m_pSet->m_CourseID;
- if (CAddForm::RecordDelete())
- GetDocument()->UpdateAllViews(this, HINT_DELETE_COURSE, &hint);
- }
- void CCourseForm::OnRecordRefresh()
- {
- if (m_bAddMode == TRUE)
- m_ctlCourseID.SetReadOnly(TRUE);
- CAddForm::RecordRefresh();
- }