From d6adf614e375c8e160d0dd5efb05334d62a09835 Mon Sep 17 00:00:00 2001 From: Wouter van Oortmerssen Date: Mon, 7 Nov 2022 16:20:14 -0800 Subject: [PATCH] Fix broken key binding Was showing incorrect binding due to https://github.com/aardappel/treesheets/commit/b538faea45d75b63bcc8d209856b4c76bcabb081 Also fixed showing double entries --- src/document.h | 23 ++++++++--------------- src/myframe.h | 6 ++---- 2 files changed, 10 insertions(+), 19 deletions(-) diff --git a/src/document.h b/src/document.h index 1522c4cd..29e139ad 100755 --- a/src/document.h +++ b/src/document.h @@ -764,14 +764,6 @@ struct Document { } } - static int CompareMenuString(const wxString &first, const wxString &second) { - auto a = first; - auto b = second; - if (a[0] == '&') a = a.Mid(1); - if (b[0] == '&') b = b.Mid(1); - return a.Cmp(b); - } - const wxChar *Key(wxDC &dc, wxChar uk, int k, bool alt, bool ctrl, bool shift, bool &unprocessed) { Cell *c = selected.GetCell(); @@ -1104,10 +1096,12 @@ struct Document { case A_CUSTKEY: { wxArrayString strs; - MyFrame::MenuString &ms = sys->frame->menustrings; - for (MyFrame::MenuStringIterator it = ms.begin(); it != ms.end(); ++it) + wxArrayString keys; + for (auto it = sys->frame->menustrings.begin(); it != sys->frame->menustrings.end(); + ++it) { strs.push_back(it->first); - strs.Sort(CompareMenuString); + keys.push_back(it->second); + } wxSingleChoiceDialog choice( sys->frame, _(L"Please pick a menu item to change the key binding for"), _(L"Key binding"), strs); @@ -1117,12 +1111,11 @@ struct Document { int sel = choice.GetSelection(); wxTextEntryDialog textentry(sys->frame, "Please enter the new key binding string", - "Key binding", ms[sel].second); + "Key binding", keys[sel]); if (textentry.ShowModal() == wxID_OK) { wxString key = textentry.GetValue(); - ms[sel].second = key; - - sys->cfg->Write(ms[sel].first, key); + sys->frame->menustrings[strs[sel]] = key; + sys->cfg->Write(strs[sel], key); return _(L"NOTE: key binding will take effect next run of TreeSheets."); } } diff --git a/src/myframe.h b/src/myframe.h index 8fe62724..3264371f 100755 --- a/src/myframe.h +++ b/src/myframe.h @@ -1,6 +1,4 @@ struct MyFrame : wxFrame { - typedef std::vector> MenuString; - typedef MenuString::iterator MenuStringIterator; wxMenu *editmenupopup; wxString exepath_; wxFileHistory filehistory; @@ -61,7 +59,7 @@ struct MyFrame : wxFrame { return wxString(relativePath.c_str()); } - MenuString menustrings; + std::map menustrings; void MyAppend(wxMenu *menu, int tag, const wxString &contents, const wchar_t *help = L"") { wxString item = contents; @@ -75,7 +73,7 @@ struct MyFrame : wxFrame { wxString newcontents = item; if (key.Length()) newcontents += "\t" + key; menu->Append(tag, newcontents, help); - menustrings.push_back(std::make_pair(item, key)); + menustrings[item] = key; } MyFrame(wxString exename, MyApp *_app)