mirror of
https://gitlab.com/pholy/OSCAR-code.git
synced 2025-04-05 18:50:44 +00:00
Implemented abort on multiple machine day records of the same type.
Also, Session data was not being freed.
This commit is contained in:
parent
19c229c7b1
commit
3fdd240428
10
GUIFrame.cpp
10
GUIFrame.cpp
@ -184,8 +184,8 @@ SummaryPanel::SummaryPanel( wxWindow* parent, wxWindowID id, const wxPoint& pos,
|
||||
ScrolledWindow->Layout();
|
||||
fgSizer->Fit( ScrolledWindow );
|
||||
m_panel1 = new wxPanel( this, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxTAB_TRAVERSAL );
|
||||
m_panel1->SetMaxSize( wxSize( -1,40 ) );
|
||||
m_mgr.AddPane( m_panel1, wxAuiPaneInfo() .Bottom() .Caption( wxT("Date Range") ).CloseButton( false ).MaximizeButton( false ).MinimizeButton( false ).PinButton( true ).Dock().Resizable().FloatingSize( wxSize( -1,-1 ) ).DockFixed( false ).Row( 0 ).Position( 1 ).BestSize( wxSize( 570,42 ) ).MinSize( wxSize( 570,42 ) ).MaxSize( wxSize( -1,42 ) ) );
|
||||
m_panel1->SetMaxSize( wxSize( -1,42 ) );
|
||||
m_mgr.AddPane( m_panel1, wxAuiPaneInfo() .Bottom() .Caption( wxT("Date Range") ).CloseButton( false ).MaximizeButton( false ).MinimizeButton( false ).PinButton( true ).Dock().Resizable().FloatingSize( wxSize( -1,-1 ) ).DockFixed( false ).LeftDockable( false ).RightDockable( false ).Row( 0 ).Position( 1 ).BestSize( wxSize( 570,42 ) ).MinSize( wxSize( 570,42 ) ).MaxSize( wxSize( -1,42 ) ) );
|
||||
|
||||
wxBoxSizer* bSizer1;
|
||||
bSizer1 = new wxBoxSizer( wxHORIZONTAL );
|
||||
@ -197,10 +197,10 @@ SummaryPanel::SummaryPanel( wxWindow* parent, wxWindowID id, const wxPoint& pos,
|
||||
bSizer1->Add( rbLastWeek, 0, wxALIGN_CENTER_VERTICAL|wxLEFT, 5 );
|
||||
|
||||
rbLastMonth = new wxRadioButton( m_panel1, wxID_ANY, _("Last Month"), wxDefaultPosition, wxDefaultSize, 0 );
|
||||
bSizer1->Add( rbLastMonth, 0, wxALIGN_CENTER_VERTICAL|wxALL, 0 );
|
||||
bSizer1->Add( rbLastMonth, 0, wxALIGN_CENTER_VERTICAL|wxLEFT, 5 );
|
||||
|
||||
rbCustomDate = new wxRadioButton( m_panel1, wxID_ANY, _("Custom"), wxDefaultPosition, wxDefaultSize, 0 );
|
||||
bSizer1->Add( rbCustomDate, 0, wxALIGN_CENTER_VERTICAL|wxALL, 0 );
|
||||
bSizer1->Add( rbCustomDate, 0, wxALIGN_CENTER_VERTICAL|wxLEFT|wxRIGHT, 5 );
|
||||
|
||||
sdLabel = new wxStaticText( m_panel1, wxID_ANY, _("Start"), wxDefaultPosition, wxDefaultSize, 0 );
|
||||
sdLabel->Wrap( -1 );
|
||||
@ -208,7 +208,7 @@ SummaryPanel::SummaryPanel( wxWindow* parent, wxWindowID id, const wxPoint& pos,
|
||||
|
||||
bSizer1->Add( sdLabel, 0, wxALIGN_CENTER_VERTICAL|wxLEFT|wxRIGHT, 5 );
|
||||
|
||||
StartDatePicker = new wxDatePickerCtrl( m_panel1, wxID_ANY, wxDefaultDateTime, wxDefaultPosition, wxDefaultSize, wxDP_SHOWCENTURY|wxDP_SPIN );
|
||||
StartDatePicker = new wxDatePickerCtrl( m_panel1, wxID_ANY, wxDefaultDateTime, wxDefaultPosition, wxDefaultSize, wxDP_SPIN );
|
||||
StartDatePicker->Enable( false );
|
||||
|
||||
bSizer1->Add( StartDatePicker, 0, wxALIGN_CENTER_VERTICAL|wxALL, 0 );
|
||||
|
@ -7785,7 +7785,7 @@
|
||||
"wx/progdlg.h"
|
||||
"wx/dialog.h"
|
||||
|
||||
1306753008 source:/home/mark/projects/git/sleepyhead/GUIFrame.cpp
|
||||
1306758595 source:/home/mark/projects/git/sleepyhead/GUIFrame.cpp
|
||||
"wx/wxprec.h"
|
||||
<wx/wx.h>
|
||||
"GUIFrame.h"
|
||||
@ -7837,7 +7837,7 @@
|
||||
"sleeplib/machine.h"
|
||||
"graphs/graph.h"
|
||||
|
||||
1306726896 /home/mark/projects/git/sleepyhead/libs/sleeplib/machine.h
|
||||
1306759276 /home/mark/projects/git/sleepyhead/libs/sleeplib/machine.h
|
||||
<wx/string.h>
|
||||
<wx/variant.h>
|
||||
<wx/dir.h>
|
||||
@ -7875,7 +7875,7 @@
|
||||
<sleeplib/machine.h>
|
||||
<list>
|
||||
|
||||
1306756665 /home/mark/projects/git/sleepyhead/version.h
|
||||
1306761075 /home/mark/projects/git/sleepyhead/version.h
|
||||
|
||||
1306724655 /home/mark/projects/git/sleepyhead/libs/sleeplib/prs1_loader.h
|
||||
"machine.h"
|
||||
@ -7885,14 +7885,14 @@
|
||||
1306415040 /home/mark/projects/git/sleepyhead/libs/sleeplib/machine_loader.h
|
||||
"profiles.h"
|
||||
|
||||
1306754109 /home/mark/projects/git/sleepyhead/libs/sleeplib/profiles.h
|
||||
1306759480 /home/mark/projects/git/sleepyhead/libs/sleeplib/profiles.h
|
||||
<wx/string.h>
|
||||
<map>
|
||||
"machine.h"
|
||||
"preferences.h"
|
||||
"tinyxml/tinyxml.h"
|
||||
|
||||
1306756567 source:/home/mark/projects/git/sleepyhead/SleepyHeadMain.cpp
|
||||
1306758522 source:/home/mark/projects/git/sleepyhead/SleepyHeadMain.cpp
|
||||
"wx_pch.h"
|
||||
"version.h"
|
||||
<wx/app.h>
|
||||
@ -7923,7 +7923,7 @@
|
||||
<wx/ffile.h>
|
||||
<wx/utils.h>
|
||||
|
||||
1306753649 source:/home/mark/projects/git/sleepyhead/libs/sleeplib/machine.cpp
|
||||
1306760870 source:/home/mark/projects/git/sleepyhead/libs/sleeplib/machine.cpp
|
||||
<tr1/random>
|
||||
<wx/colour.h>
|
||||
<wx/log.h>
|
||||
@ -7944,7 +7944,7 @@
|
||||
<wx/stdpaths.h>
|
||||
"preferences.h"
|
||||
|
||||
1306755802 source:/home/mark/projects/git/sleepyhead/libs/sleeplib/profiles.cpp
|
||||
1306759549 source:/home/mark/projects/git/sleepyhead/libs/sleeplib/profiles.cpp
|
||||
<wx/filefn.h>
|
||||
<wx/filename.h>
|
||||
<wx/utils.h>
|
||||
@ -7956,7 +7956,7 @@
|
||||
"machine_loader.h"
|
||||
"tinyxml/tinyxml.h"
|
||||
|
||||
1306724998 source:/home/mark/projects/git/sleepyhead/libs/sleeplib/prs1_loader.cpp
|
||||
1306760452 source:/home/mark/projects/git/sleepyhead/libs/sleeplib/prs1_loader.cpp
|
||||
<wx/dir.h>
|
||||
<wx/filename.h>
|
||||
<wx/ffile.h>
|
||||
@ -7965,6 +7965,7 @@
|
||||
<wx/datetime.h>
|
||||
<wx/log.h>
|
||||
<wx/progdlg.h>
|
||||
<wx/msgdlg.h>
|
||||
<initializer_list>
|
||||
"prs1_loader.h"
|
||||
|
||||
|
@ -355,7 +355,7 @@ Summary::Summary(wxWindow *win,Profile *_profile)
|
||||
}
|
||||
Summary::~Summary()
|
||||
{
|
||||
wxMemoryFSHandler::RemoveFile(_T("test.png"));
|
||||
// wxMemoryFSHandler::RemoveFile(_T("test.png"));
|
||||
}
|
||||
void Summary::ResetProfile(Profile *p)
|
||||
{
|
||||
@ -582,7 +582,7 @@ void Daily::ResetDate()
|
||||
// RefreshData();
|
||||
wxDateTime date;
|
||||
if (profile->LastDay().IsValid()) {
|
||||
date=profile->LastDay();
|
||||
date=profile->LastDay()+wxTimeSpan::Day();
|
||||
Calendar->SetDate(date);
|
||||
} else {
|
||||
Calendar->SetDate(wxDateTime::Today());
|
||||
|
@ -1157,8 +1157,8 @@
|
||||
</object>
|
||||
<object class="wxPanel" expanded="1">
|
||||
<property name="BottomDockable">1</property>
|
||||
<property name="LeftDockable">1</property>
|
||||
<property name="RightDockable">1</property>
|
||||
<property name="LeftDockable">0</property>
|
||||
<property name="RightDockable">0</property>
|
||||
<property name="TopDockable">1</property>
|
||||
<property name="aui_name"></property>
|
||||
<property name="best_size">570,42</property>
|
||||
@ -1183,7 +1183,7 @@
|
||||
<property name="layer"></property>
|
||||
<property name="max_size">-1,42</property>
|
||||
<property name="maximize_button">0</property>
|
||||
<property name="maximum_size">-1,40</property>
|
||||
<property name="maximum_size">-1,42</property>
|
||||
<property name="min_size">570,42</property>
|
||||
<property name="minimize_button">0</property>
|
||||
<property name="minimum_size"></property>
|
||||
@ -1415,8 +1415,8 @@
|
||||
</object>
|
||||
</object>
|
||||
<object class="sizeritem" expanded="1">
|
||||
<property name="border">0</property>
|
||||
<property name="flag">wxALIGN_CENTER_VERTICAL|wxALL</property>
|
||||
<property name="border">5</property>
|
||||
<property name="flag">wxALIGN_CENTER_VERTICAL|wxLEFT</property>
|
||||
<property name="proportion">0</property>
|
||||
<object class="wxRadioButton" expanded="1">
|
||||
<property name="BottomDockable">1</property>
|
||||
@ -1503,8 +1503,8 @@
|
||||
</object>
|
||||
</object>
|
||||
<object class="sizeritem" expanded="1">
|
||||
<property name="border">0</property>
|
||||
<property name="flag">wxALIGN_CENTER_VERTICAL|wxALL</property>
|
||||
<property name="border">5</property>
|
||||
<property name="flag">wxALIGN_CENTER_VERTICAL|wxLEFT|wxRIGHT</property>
|
||||
<property name="proportion">0</property>
|
||||
<object class="wxRadioButton" expanded="1">
|
||||
<property name="BottomDockable">1</property>
|
||||
@ -1726,7 +1726,7 @@
|
||||
<property name="row"></property>
|
||||
<property name="show">1</property>
|
||||
<property name="size"></property>
|
||||
<property name="style">wxDP_SHOWCENTURY|wxDP_SPIN</property>
|
||||
<property name="style">wxDP_SPIN</property>
|
||||
<property name="subclass"></property>
|
||||
<property name="toolbar_pane">0</property>
|
||||
<property name="tooltip"></property>
|
||||
|
@ -182,7 +182,7 @@ Day *Machine::AddSession(Session *s,Profile *p)
|
||||
}
|
||||
if (day.find(date)==day.end()) {
|
||||
day[date]=new Day(this);
|
||||
p->AddDay(date,day[date]);
|
||||
p->AddDay(date,day[date],m_type);
|
||||
}
|
||||
|
||||
day[date]->AddSession(s);
|
||||
@ -259,6 +259,9 @@ Day::Day(Machine *m)
|
||||
}
|
||||
Day::~Day()
|
||||
{
|
||||
for (auto s=sessions.begin();s!=sessions.end();s++) {
|
||||
delete (*s);
|
||||
}
|
||||
|
||||
}
|
||||
MachineType Day::machine_type()
|
||||
|
@ -83,6 +83,10 @@ class Session;
|
||||
class Profile;
|
||||
class Machine;
|
||||
|
||||
class OneTypePerDay
|
||||
{
|
||||
};
|
||||
|
||||
class Day
|
||||
{
|
||||
public:
|
||||
|
@ -98,6 +98,10 @@ void Profile::AddMachine(Machine *m) {
|
||||
assert(m!=NULL);
|
||||
machlist[m->id()]=m;
|
||||
};
|
||||
void Profile::DelMachine(Machine *m) {
|
||||
assert(m!=NULL);
|
||||
machlist.erase(m->id());
|
||||
};
|
||||
|
||||
TiXmlElement * Profile::ExtraSave()
|
||||
{
|
||||
@ -123,7 +127,7 @@ TiXmlElement * Profile::ExtraSave()
|
||||
|
||||
}
|
||||
|
||||
void Profile::AddDay(wxDateTime date,Day *day) {
|
||||
void Profile::AddDay(wxDateTime date,Day *day,MachineType mt) {
|
||||
//date+=wxTimeSpan::Day();
|
||||
if (is_first_day) {
|
||||
m_first=m_last=date;
|
||||
@ -131,6 +135,15 @@ void Profile::AddDay(wxDateTime date,Day *day) {
|
||||
}
|
||||
if (m_first>date) m_first=date;
|
||||
if (m_last<date) m_last=date;
|
||||
|
||||
// Check for any other machines of same type.. Throw an exception if one already exists.
|
||||
vector<Day *> & dl=daylist[date];
|
||||
for (auto a=dl.begin();a!=dl.end();a++) {
|
||||
if ((*a)->machine->GetType()==mt) {
|
||||
throw OneTypePerDay();
|
||||
}
|
||||
}
|
||||
|
||||
daylist[date].push_back(day);
|
||||
}
|
||||
|
||||
|
@ -34,10 +34,11 @@ public:
|
||||
bool is_first_day;
|
||||
map<MachineID,Machine *> machlist;
|
||||
void AddMachine(Machine *m);
|
||||
void DelMachine(Machine *m);
|
||||
void LoadMachineData();
|
||||
void Import(wxString path);
|
||||
|
||||
void AddDay(wxDateTime date,Day *day);
|
||||
void AddDay(wxDateTime date,Day *day,MachineType mt);
|
||||
|
||||
vector<Machine *> GetMachines(MachineType t);
|
||||
Machine * GetMachine(MachineType t,wxDateTime date);
|
||||
|
@ -14,7 +14,7 @@ License: GPL
|
||||
#include <wx/datetime.h>
|
||||
#include <wx/log.h>
|
||||
#include <wx/progdlg.h>
|
||||
|
||||
#include <wx/msgdlg.h>
|
||||
#include <initializer_list>
|
||||
|
||||
#include "prs1_loader.h"
|
||||
@ -126,13 +126,19 @@ bool PRS1Loader::Open(wxString & path,Profile *profile)
|
||||
for (sn=SerialNumbers.begin(); sn!=SerialNumbers.end(); sn++) {
|
||||
wxString s=*sn;
|
||||
m=CreateMachine(s,profile);
|
||||
|
||||
try {
|
||||
if (m) OpenMachine(m,newpath+wxFileName::GetPathSeparator()+(*sn),profile);
|
||||
} catch(OneTypePerDay e) {
|
||||
profile->DelMachine(m);
|
||||
PRS1List.erase(s);
|
||||
wxMessageBox(_("This Machine Record cannot be imported in this profile.\nThe Day records overlap with already existing content."),_("Import Error"),wxOK|wxCENTER);
|
||||
delete m;
|
||||
}
|
||||
}
|
||||
|
||||
return PRS1List.size();
|
||||
|
||||
return c;
|
||||
// return c;
|
||||
}
|
||||
bool PRS1Loader::ParseProperties(Machine *m,wxString filename)
|
||||
{
|
||||
|
12
version.h
12
version.h
@ -16,14 +16,14 @@ namespace AutoVersion{
|
||||
//Standard Version Type
|
||||
static const long MAJOR = 0;
|
||||
static const long MINOR = 7;
|
||||
static const long BUILD = 2233;
|
||||
static const long REVISION = 6877;
|
||||
static const long BUILD = 2249;
|
||||
static const long REVISION = 6961;
|
||||
|
||||
//Miscellaneous Version Types
|
||||
static const long BUILDS_COUNT = 7025;
|
||||
#define RC_FILEVERSION 0,7,2233,6877
|
||||
#define RC_FILEVERSION_STRING "0, 7, 2233, 6877\0"
|
||||
static const char FULLVERSION_STRING[] = "0.7.2233.6877";
|
||||
static const long BUILDS_COUNT = 7077;
|
||||
#define RC_FILEVERSION 0,7,2249,6961
|
||||
#define RC_FILEVERSION_STRING "0, 7, 2249, 6961\0"
|
||||
static const char FULLVERSION_STRING[] = "0.7.2249.6961";
|
||||
|
||||
//These values are to keep track of your versioning state, don't modify them.
|
||||
static const long BUILD_HISTORY = 62;
|
||||
|
Loading…
Reference in New Issue
Block a user