Skip to content

Commit

Permalink
Add tool Copy N0183 to NMEA Debug Window as discussed in OpenCPN#4243
Browse files Browse the repository at this point in the history
  • Loading branch information
Hakansv committed Jan 1, 2025
1 parent 6676184 commit 1067084
Show file tree
Hide file tree
Showing 4 changed files with 30 additions and 8 deletions.
2 changes: 1 addition & 1 deletion gui/include/gui/TTYScroll.h
Original file line number Diff line number Diff line change
Expand Up @@ -37,7 +37,7 @@ class TTYScroll : public wxScrolledWindow {
virtual void Add(const wxString &line);
void OnSize(wxSizeEvent &event);
void Pause(bool pause) { bpause = pause; }
void Copy();
void Copy(bool);

protected:
wxCoord m_hLine; // the height of one line on screen
Expand Down
2 changes: 2 additions & 0 deletions gui/include/gui/TTYWindow.h
Original file line number Diff line number Diff line change
Expand Up @@ -47,13 +47,15 @@ class TTYWindow : public wxFrame {
void Close();
void OnPauseClick(wxCommandEvent &event);
void OnCopyClick(wxCommandEvent &event);
void OnCopyN0183Click(wxCommandEvent &event);

protected:
void CreateLegendBitmap();
WindowDestroyListener *m_window_destroy_listener;
TTYScroll *m_tty_scroll;
wxButton *m_btn_pause;
wxButton *m_btn_copy;
wxButton *m_btn_copy_N0183;
bool m_is_paused;
wxBitmap m_bm_legend;
wxTextCtrl *m_filter;
Expand Down
16 changes: 13 additions & 3 deletions gui/src/TTYScroll.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -99,11 +99,21 @@ void TTYScroll::OnDraw(wxDC &dc) {
}
}

void TTYScroll::Copy() {
void TTYScroll::Copy(bool n0183) {
wxString theText;
for (unsigned int i = 0; i < m_plineArray->GetCount(); i++) {
theText.append(m_plineArray->Item(i));
theText.append("\n");
wxString s = m_plineArray->Item(i);
if (n0183) {
int pos = 0;
if ((pos = s.Find("$")) != wxNOT_FOUND) {
theText.append(s.Mid(pos) + "\n");
} else if ((pos = s.Find("!")) != wxNOT_FOUND) {
theText.append(s.Mid(pos) + "\n");
}
} else {
theText.append(s);
theText.append("\n");
}
}
// Write scrolled text to the clipboard
if (wxTheClipboard->Open()) {
Expand Down
18 changes: 14 additions & 4 deletions gui/src/TTYWindow.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -76,22 +76,30 @@ TTYWindow::TTYWindow(wxWindow* parent, int n_lines,
wxBitmapButton* bb = new wxBitmapButton(this, wxID_ANY, m_bm_legend);
sbSizer1->Add(bb, 1, wxALL | wxEXPAND, 5);

wxStaticBox* buttonBox = new wxStaticBox(this, wxID_ANY, wxEmptyString);
wxStaticBox* buttonBox = new wxStaticBox(this, wxID_ANY, "Tools");
wxStaticBoxSizer* bbSizer1 = new wxStaticBoxSizer(buttonBox, wxVERTICAL);

m_btn_pause = new wxButton(this, wxID_ANY, _("Pause"), wxDefaultPosition,
wxDefaultSize, 0);
m_btn_copy = new wxButton(this, wxID_ANY, _("Copy"), wxDefaultPosition,
m_btn_copy = new wxButton(this, wxID_ANY, _("Copy all"), wxDefaultPosition,
wxDefaultSize, 0);
m_btn_copy->SetToolTip(_("Copy NMEA Debug window to clipboard."));
m_btn_copy->SetToolTip(_("Copy all NMEA Debug window to clipboard."));
m_btn_copy_N0183 = new wxButton(this, wxID_ANY, _("Copy NMEA 0183"),
wxDefaultPosition, wxDefaultSize, 0);
m_btn_copy_N0183->SetToolTip(
_("Copy only pure NMEA 0183 sentences to clipboard."));

bbSizer1->Add(m_btn_pause, 0, wxALL, 5);
bbSizer1->Add(m_btn_copy, 0, wxALL, 5);
bbSizer1->Add(m_btn_copy_N0183, 0, wxALL, 5);
bSizerBottomContainer->Add(bbSizer1, 1, wxALL | wxEXPAND, 5);

m_btn_copy->Connect(wxEVT_COMMAND_BUTTON_CLICKED,
wxCommandEventHandler(TTYWindow::OnCopyClick), NULL,
this);
m_btn_copy_N0183->Connect(wxEVT_COMMAND_BUTTON_CLICKED,
wxCommandEventHandler(TTYWindow::OnCopyN0183Click),
NULL, this);
m_btn_pause->Connect(wxEVT_COMMAND_BUTTON_CLICKED,
wxCommandEventHandler(TTYWindow::OnPauseClick), NULL,
this);
Expand Down Expand Up @@ -181,7 +189,9 @@ void TTYWindow::OnPauseClick(wxCommandEvent&) {
}
}

void TTYWindow::OnCopyClick(wxCommandEvent&) { m_tty_scroll->Copy(); }
void TTYWindow::OnCopyClick(wxCommandEvent&) { m_tty_scroll->Copy(false); }

void TTYWindow::OnCopyN0183Click(wxCommandEvent&) { m_tty_scroll->Copy(true); }

void TTYWindow::OnCloseWindow(wxCloseEvent&) {
if (m_window_destroy_listener) {
Expand Down

0 comments on commit 1067084

Please sign in to comment.