From 2a7f38b1870f90eb8ab358f8fce09a52a0088619 Mon Sep 17 00:00:00 2001 From: Jordan Sherer Date: Mon, 9 Jul 2018 15:17:53 -0400 Subject: [PATCH] Better breaking apart messages with newlines. Macros behavior --- mainwindow.cpp | 44 +++++++++++++++++++++++++++++--------------- 1 file changed, 29 insertions(+), 15 deletions(-) diff --git a/mainwindow.cpp b/mainwindow.cpp index 1e277b3..fee223b 100644 --- a/mainwindow.cpp +++ b/mainwindow.cpp @@ -5262,20 +5262,24 @@ void MainWindow::on_extFreeTextMsgEdit_currentTextChanged (QString const& text) QStringList MainWindow::buildFT8MessageFrames(QString const& text){ QStringList frames; - QString input = QString(text).replace("\n", " ").replace(" ", " "); - while(input.size() > 0){ - QString frame = parseFT8Message(input); - if(frame.isEmpty()){ - break; - } - frames.append(frame); + //QString input = QString(text); //.replace("\n", " ").replace(" ", " "); + //.split(QRegExp("\\n")) - int sz = input.size(); - input = input.remove(QRegExp("^" + QRegExp::escape(frame))).trimmed(); - if(input.size() == sz){ - break; - } + foreach(QString input, text.split(QRegExp("[\\r\\n]"), QString::SkipEmptyParts)){ + while(input.size() > 0){ + QString frame = parseFT8Message(input); + if(frame.isEmpty()){ + break; + } + frames.append(frame); + + int sz = input.size(); + input = input.remove(QRegExp("^" + QRegExp::escape(frame))).trimmed(); + if(input.size() == sz){ + break; + } + } } return frames; @@ -5284,7 +5288,7 @@ QStringList MainWindow::buildFT8MessageFrames(QString const& text){ QString MainWindow::parseFT8Message(QString input){ char message[29]; char msgsent[29]; - char volatile ft8msgbits[75]; + char volatile ft8msgbits[75 + 12]; int volatile itone[NUM_ISCAT_SYMBOLS]; QByteArray ba = input.toLocal8Bit(); @@ -6616,17 +6620,27 @@ void MainWindow::on_snrMacroButton_clicked(){ } void MainWindow::on_macrosMacroButton_clicked(){ - QMenu *menu = new QMenu(ui->macrosMacroButton); + if(m_config.macros()->stringList().isEmpty()){ + on_actionSettings_triggered(); + return; + } + + QMenu *menu = ui->macrosMacroButton->menu(); + if(!menu){ + menu = new QMenu(ui->macrosMacroButton); + } + menu->clear(); + foreach(QString macro, m_config.macros()->stringList()){ QAction *action = menu->addAction(macro); connect(action, &QAction::triggered, this, [this, macro](){ addMessageText(macro); }); } + menu->addSeparator(); auto action = new QAction(QIcon::fromTheme("edit-edit"), QString("Edit"), menu); menu->addAction(action); connect(action, &QAction::triggered, this, &MainWindow::on_actionSettings_triggered); - ui->macrosMacroButton->setMenu(menu); ui->macrosMacroButton->showMenu(); }