sources:
BasicClass.h (1.4k)
C1_2.cpp (604 bytes)
CashOffice.cpp (3.8k)
CashOffice.h (1.8k)
Date.cpp (6.0k)
Date.h (2.9k)
Exception.cpp (2.5k)
Exception.h (1.4k)
House.cpp (6.8k)
House.h (2.5k)
Room.cpp (3.0k)
Room.h (1.6k)


binaries:
Release/C1_2.exe (140.0k)


website:
more info here
studies/bauelemente/Softwarebauelemente-CodeC1-2/Date.cpp
download file

  1 ///////////////////////////////////////////////////////////
  2 // Softwarebauelemente II, Aufgabe C1.1
  3 //
  4 // author: Stephan Brumme
  5 // last changes: July 3, 2001
  6
  7
  8 #include "Date.h"
  9
 10
 11 // we are using OS-specific date/time operations
 12 #include <time.h>
 13 #include <iomanip>
 14 #include <iostream>
 15 using namespace std;
 16
 17
 18
 19
 20 // constructor, default value is current date and time
 21 CDate::CDate()
 22 {
 23     GetToday(m_nDay, m_nMonth, m_nYear, m_nHour, m_nMinute, m_nSecond);
 24 }
 25
 26
 27 // copy constructor
 28 CDate::CDate(const CDate &date)
 29 {
 30     operator=(date);
 31 }
 32
 33
 34 // set user defined date at construction time
 35 CDate::CDate(unsigned int nDay, unsigned int nMonth, unsigned int nYear,
 36              unsigned int nHour, unsigned int nMinute, unsigned int nSecond)

 37 {
 38     // store date
 39     m_nDay    = nDay;
 40     m_nMonth  = nMonth;
 41     m_nYear   = nYear;
 42
 43     // store time
 44     m_nHour   = nHour;
 45     m_nMinute = nMinute;
 46     m_nSecond = nSecond;
 47 }
 48
 49
 50 // show attributes
 51 string CDate::Show() const {
 52     // check invariance
 53     if (!ClassInvariant())
 54         return "";
 55
 56     ostringstream strOutput;
 57
 58     strOutput << setw(2) << setfill('0') << m_nDay << "."
 59               << setw(2) << setfill('0') << m_nMonth << "."
 60               << m_nYear << " - "
 61               << setw(2) << setfill('0') << m_nHour<< ":"
 62               << setw(2) << setfill('0') << m_nMinute << ":"
 63               << setw(2) << setfill('0') << m_nSecond;
 64
 65     return strOutput.str();
 66 }
 67
 68
 69 // shows all internal attributes
 70 string CDate::ShowDebug() const {
 71     ostringstream strOutput;
 72
 73     strOutput << "DEBUG info for 'CDate'" << endl
 74               << " m_nDay = " << m_nDay    << endl
 75               << " m_nMonth = " << m_nMonth  << endl
 76               << " m_nYear = " << m_nYear   << endl
 77               << " m_nHour = " << m_nHour   << endl
 78               << " m_nMinute = " << m_nMinute << endl
 79               << " m_nSecond = " << m_nSecond << endl;
 80
 81     return strOutput.str();
 82 }
 83
 84
 85 // return current date
 86 void CDate::GetToday(unsigned int &nDay,  unsigned int &nMonth,  unsigned int &nYear,
 87                      unsigned int &nHour, unsigned int &nMinute, unsigned int &nSecond)

 88 {
 89     // the following code is basically taken from MSDN
 90
 91     // use system functions to get the current date as UTC
 92     time_t secondsSince1970;
 93     time(&secondsSince1970);
 94
 95     // convert UTC to local time zone
 96     struct tm *localTime;
 97     localTime = localtime(&secondsSince1970);
 98
 99     // store retrieved date
100     nDay    = localTime->tm_mday;
101     nMonth  = localTime->tm_mon + 1;
102     nYear   = localTime->tm_year + 1900;
103     // store time
104     nHour   = localTime->tm_hour;
105     nMinute = localTime->tm_min;
106     nSecond = localTime->tm_sec;
107 }
108
109
110 // validate a date
111 bool CDate::ClassInvariant() const {
112     // validate month
113     if (m_nMonth < JANUARY || m_nMonth > DECEMBER)
114         return false;
115
116     // days per month, february may vary, note that array starts with 0, not JANUARY
117     unsigned int nDaysPerMonth[] = {0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};
118
119     // adjust days of february
120     if (IsLeapYear(m_nYear))
121         nDaysPerMonth[FEBRUARY]++;
122
123     // validate day
124     if (m_nDay < 1 || m_nDay > nDaysPerMonth[m_nMonth])
125         return false;
126     // day and month are valid
127
128     // now check the time
129     if (m_nHour < 0 || m_nHour > 23)
130         return false;
131     if (m_nMinute < 0 || m_nMinute > 59)
132         return false;
133     if (m_nSecond < 0 || m_nSecond > 59)
134         return false;
135
136     // instance must be valid now
137     return true;
138 }
139
140
141 // determine whether it is a leap year
142 bool CDate::IsLeapYear(unsigned int nYear)
143 {
144     // used to speed up code, may be deleted
145     if (nYear % 4   != 0)
146         return false;
147
148     // algorithm taken from MSDN, just converted from VBA to C++
149     if (nYear % 400 == 0)
150         return true;
151     if (nYear % 100 == 0)
152         return false;
153     if (nYear % 4   == 0)
154         return true;
155
156     // this line won't be executed because of optimization (see above)
157     return false;
158 }
159
160
161 // copy constructor
162 CDate& CDate::operator =(const CDate &date)
163 {
164     // date
165     m_nDay    = date.m_nDay;
166     m_nMonth  = date.m_nMonth;
167     m_nYear   = date.m_nYear;
168     // time
169     m_nHour   = date.m_nHour;
170     m_nMinute = date.m_nMinute;
171     m_nSecond = date.m_nSecond;
172
173     return *this;
174 }
175
176
177 // virtual, see operator=
178 bool CDate::Copy(const CBasicClass *pClass)
179 {
180     // cast to CDate
181     const CDate *date = dynamic_cast<const CDate*>(pClass);
182
183     // invalid class (is NULL when pClass is not a CDate)
184     if (date == NULL || date == this)
185         return false;
186
187     // use non virtual reference based copy
188     // return value isn't needed
189     operator=(*date);
190
191     // we're done
192     return true;
193 }
194
195
196 // compare two dates
197 bool CDate::operator ==(const CDate &date) const {
198     // compare date and time attributes
199     return (m_nDay    == date.m_nDay    &&
200             m_nMonth  == date.m_nMonth  &&
201             m_nYear   == date.m_nYear   &&
202             m_nHour   == date.m_nHour   &&
203             m_nMinute == date.m_nMinute &&
204             m_nSecond == date.m_nSecond)
;
205 }
206
207
208 // virtual, see operator==
209 bool CDate::EqualValue(const CBasicClass *pClass) const {
210     // cast to CDate
211     const CDate *date = dynamic_cast<const CDate*>(pClass);
212
213     // invalid class (is NULL when pClass is not a CDate)
214     if (date == NULL)
215         return false;
216
217     // use non virtual reference based copy
218     return operator==(*date);
219 }
220
221
222 // set attributes, returns validility of date
223 void CDate::SetDay(unsigned int nDay)
224 {
225     m_nDay = nDay;
226 }
227 void CDate::SetMonth(unsigned int nMonth)
228 {
229     m_nMonth = nMonth;
230 }
231 void CDate::SetYear(unsigned int nYear)
232 {
233     m_nYear = nYear;
234 }
235 void CDate::SetHour(unsigned int nHour)
236 {
237     m_nHour = nHour;
238 }
239 void CDate::SetMinute(unsigned int nMinute)
240 {
241     m_nMinute = nMinute;
242 }
243 void CDate::SetSecond(unsigned int nSecond)
244 {
245     m_nSecond = nSecond;
246 }
247
248 // return attributes
249 unsigned int CDate::GetDay() const {
250     return m_nDay;
251 }
252 unsigned int CDate::GetMonth() const {
253     return m_nMonth;
254 }
255 unsigned int CDate::GetYear() const {
256     return m_nYear;
257 }
258 unsigned int CDate::GetHour() const {
259     return m_nHour;
260 }
261 unsigned int CDate::GetMinute() const {
262     return m_nMinute;
263 }
264 unsigned int CDate::GetSecond() const {
265     return m_nSecond;
266 }
267
268