aboutsummaryrefslogtreecommitdiff
path: root/src/base_tab/BaseGameTab.cpp
diff options
context:
space:
mode:
authorLoic Guegan <manzerbredes@mailbox.org>2022-12-26 12:51:48 +0100
committerLoic Guegan <manzerbredes@mailbox.org>2022-12-26 12:51:48 +0100
commit1d78e106adf4cc5894f299d597c02a9b7e508173 (patch)
tree04e722a73340082f6c2b06d9901bb705f762eead /src/base_tab/BaseGameTab.cpp
parent2bd85f53bcaeb12090b9ac2d4cf7c781b280e678 (diff)
Debug database tab
Diffstat (limited to 'src/base_tab/BaseGameTab.cpp')
-rw-r--r--src/base_tab/BaseGameTab.cpp129
1 files changed, 65 insertions, 64 deletions
diff --git a/src/base_tab/BaseGameTab.cpp b/src/base_tab/BaseGameTab.cpp
index 29729c4..4d16562 100644
--- a/src/base_tab/BaseGameTab.cpp
+++ b/src/base_tab/BaseGameTab.cpp
@@ -5,23 +5,19 @@
wxDEFINE_EVENT(OPEN_GAME_EVENT, wxCommandEvent);
-BaseGameTab::BaseGameTab(wxFrame *parent, std::string base_file, TabInfos *main_tab)
- : TabBase_TabGames(parent), base_file(base_file),
- base(NULL),main_tab(main_tab) {
+BaseGameTab::BaseGameTab(wxFrame *parent, std::shared_ptr<GameBase> base, TabInfos *main_tab)
+ : TabBase_TabGames(parent), main_tab(main_tab),base(base) {
+
+ glm=std::make_shared<GameListManager>(game_list);
+ Reset(base);
- glm=new GameListManager(game_list);
this->Bind(wxEVT_BUTTON, &BaseGameTab::OnDelete, this, ID_DELETE_BUTTON);
- this->Bind(wxEVT_BUTTON, &BaseGameTab::OnSave, this, ID_SAVE_BUTTON);
- this->Bind(wxEVT_BUTTON, &BaseGameTab::OnExport, this, ID_EXPORT_BUTTON);
this->Bind(wxEVT_LIST_ITEM_ACTIVATED, &BaseGameTab::OnOpenGame, this, wxID_ANY);
- this->Bind(wxEVT_BUTTON, &BaseGameTab::OnImport, this, ID_IMPORT_BUTTON);
this->Bind(wxEVT_BUTTON, &BaseGameTab::OnApplyFilter, this, ID_APPLY_FILTER_BUTTON);
this->Bind(wxEVT_TEXT_ENTER, &BaseGameTab::OnApplyFilter, this, ID_SEARCH_TERMS);
- current_base->SetLabel(base_file);
search_terms->SetHint("e.g: Paul Morphy");
- LoadFile();
}
void BaseGameTab::OnApplyFilter(wxCommandEvent &event){
@@ -34,12 +30,12 @@ void BaseGameTab::OnApplyFilter(wxCommandEvent &event){
}
void BaseGameTab::OnImport(wxCommandEvent &event) {
- AppendGameDialog *dia = new AppendGameDialog(this, base);
- dia->ShowModal();
- glm->Clear();
- deleted.clear();
- edited.clear();
- LoadFile();
+ // AppendGameDialog *dia = new AppendGameDialog(this, base);
+ // dia->ShowModal();
+ // glm->Clear();
+ // deleted.clear();
+ // edited.clear();
+ // LoadFile();
}
void BaseGameTab::OnDelete(wxCommandEvent &event) {
@@ -50,35 +46,37 @@ void BaseGameTab::OnDelete(wxCommandEvent &event) {
}
void BaseGameTab::OnSave(wxCommandEvent &event) {
- std::vector<std::shared_ptr<GameBase>> new_games_bases;
-
- // Build edited games vector
- std::vector<std::shared_ptr<Game>> edited_games;
- for (auto itr = edited.begin(); itr != edited.end(); itr++) {
- edited_games.push_back(itr->second);
- }
-
- // Combine new_games and edited games
- std::vector<std::shared_ptr<Game>> new_games;
- new_games.insert(
- new_games.end(), edited_games.begin(),
- edited_games.end()); // Add edited game (since they are also deleted)
- base->Save(deleted, new_games_bases, new_games);
+ // std::vector<std::shared_ptr<GameBase>> new_games_bases;
+
+ // // Build edited games vector
+ // std::vector<std::shared_ptr<Game>> edited_games;
+ // for (auto itr = edited.begin(); itr != edited.end(); itr++) {
+ // edited_games.push_back(itr->second);
+ // }
+
+ // // Combine new_games and edited games
+ // std::vector<std::shared_ptr<Game>> new_games;
+ // new_games.insert(
+ // new_games.end(), edited_games.begin(),
+ // edited_games.end()); // Add edited game (since they are also deleted)
+ // base->Save(deleted, new_games_bases, new_games);
- // Close all opened games in this database
- wxCommandEvent closeLinkedTabEvent(CLOSE_LINKED_TAB, GetId());
- closeLinkedTabEvent.SetClientData(main_tab);
- ProcessEvent(closeLinkedTabEvent);
-
- glm->Clear();
- edited.clear();
- deleted.clear();
- LoadFile();
+ // // Close all opened games in this database
+ // wxCommandEvent closeLinkedTabEvent(CLOSE_LINKED_TAB, GetId());
+ // closeLinkedTabEvent.SetClientData(main_tab);
+ // ProcessEvent(closeLinkedTabEvent);
+
+ // glm->Clear();
+ // edited.clear();
+ // deleted.clear();
+ // LoadFile();
}
void BaseGameTab::OnOpenGame(wxListEvent &event) {
long id = std::stoi(event.GetItem().GetText().ToStdString());
std::shared_ptr<Game> *g = new std::shared_ptr<Game>(base->GetGame(id));
+ wxLogDebug("kjkj");
+
if (g != NULL) {
if(edited.find(id) != edited.end()){
// TODO: Focus on the game tab and if close reopen it
@@ -97,33 +95,21 @@ void BaseGameTab::OnOpenGame(wxListEvent &event) {
}
}
-void BaseGameTab::ApplyPreferences() {}
-
-void BaseGameTab::OnExport(wxCommandEvent &event) {
- wxFileDialog openFileDialog(this, _("Export database"), "", "",
- "Database files (*.pgn)|*.pgn",
- wxFD_SAVE | wxFD_OVERWRITE_PROMPT);
- if (openFileDialog.ShowModal() != wxID_CANCEL) {
- std::string path = openFileDialog.GetPath().ToStdString();
- wxFileName file(base_file);
- wxString ext = file.GetExt().Lower();
- GameBase *base;
- if (ext == "pgn") {
- base = new PGNGameBase(path);
- base->Export(this->base);
- delete base;
- }
+std::vector<std::shared_ptr<Game>> BaseGameTab::GetEditedGames(){
+ std::vector<std::shared_ptr<Game>> games;
+ for(auto it = edited.begin(); it != edited.end(); it++){
+ games.push_back(it->second);
}
+ return(games);
}
-void BaseGameTab::LoadFile() {
- wxFileName file(base_file);
- wxString ext = file.GetExt().Lower();
- if (ext == "pgn") {
- base = std::shared_ptr<GameBase>(new PGNGameBase(base_file));
- SetLabel(file.GetName() + "(PGN)");
- }
+void BaseGameTab::Reset(std::shared_ptr<GameBase> base){
+ glm->Clear();
+ edited.clear();
+ deleted.clear();
+ // Load all games (for now :)
+ this->base=base;
if (base != NULL) {
while (base->NextGame()) {
glm->AddGame(
@@ -135,8 +121,23 @@ void BaseGameTab::LoadFile() {
base->GetTag("ECO"));
}
}
+}
- wxCommandEvent event(REFRESH_TAB_TITLE, GetId());
- event.SetEventObject(this);
- ProcessEvent(event);
+void BaseGameTab::OnExport(wxCommandEvent &event) {
+ // wxFileDialog openFileDialog(this, _("Export database"), "", "",
+ // "Database files (*.pgn)|*.pgn",
+ // wxFD_SAVE | wxFD_OVERWRITE_PROMPT);
+ // if (openFileDialog.ShowModal() != wxID_CANCEL) {
+ // std::string path = openFileDialog.GetPath().ToStdString();
+ // wxFileName file(base_file);
+ // wxString ext = file.GetExt().Lower();
+ // GameBase *base;
+ // if (ext == "pgn") {
+ // base = new PGNGameBase(path);
+ // base->Export(this->base);
+ // delete base;
+ // }
+ // }
}
+
+