diff --git a/snapcraft.yaml b/snapcraft.yaml index d3d417b..73e65b3 100644 --- a/snapcraft.yaml +++ b/snapcraft.yaml @@ -1,8 +1,8 @@ name: kochmorse -#version: git -#grade: devel -version: 3.5.0 -grade: stable +version: git +grade: devel +#version: 3.5.0 +#grade: stable summary: A simple Morse tutor. description: | Kochmorse is a simple to use morse-code tutor using the so called Koch mehtod. It can not only @@ -41,7 +41,7 @@ parts: - qt5dxcb-plugin source: https://github.com/hmatuschek/kochmorse.git source-type: git - source-tag: "v$SNAPCRAFT_PROJECT_VERSION" + #source-tag: "v$SNAPCRAFT_PROJECT_VERSION" configflags: - "-DCMAKE_INSTALL_PREFIX=/usr" - "-DCMAKE_BUILD_TYPE=Release" diff --git a/src/tutor.cc b/src/tutor.cc index 8f75f05..bf9dc40 100644 --- a/src/tutor.cc +++ b/src/tutor.cc @@ -81,7 +81,7 @@ KochTutor::KochTutor(MorseEncoder *encoder, int lesson, bool prefLastChars, bool _repeatLastChar(repeatLastChar), _minGroupSize(std::min(minGroupSize, maxGroupSize)), _maxGroupSize(std::max(minGroupSize, maxGroupSize)), _lines(lines), _linecount(0), _showSummary(showSummary), _verify(verify), _hideOutput(hideOutput), - _threshold(successThreshold), _text(), _chars_send(0), _words_send(0), _lines_send(0) + _threshold(successThreshold), _text(), _chars_sent(0), _words_sent(0), _lines_sent(0) { // Init random number generator srand(time(nullptr)); @@ -153,15 +153,15 @@ QString KochTutor::summary() const { if (! _showSummary) return ""; - int threshold = int(_chars_send*(100-_threshold))/100; + int threshold = int(_chars_sent*(100-_threshold))/100; if (_lesson < (_lessons.size()-1)) return tr("\n\nSent %1 chars in %2 words and %3 lines. " "If you have less than %4 mistakes, you can proceed to lesson %5.") - .arg(_chars_send).arg(_words_send).arg(_lines_send).arg(threshold).arg(_lesson+1); + .arg(_chars_sent).arg(_words_sent).arg(_lines_sent).arg(threshold).arg(_lesson+1); else return tr("\n\nSent %1 chars in %2 words and %3 lines. " "If you have less than %4 mistakes, you completed the course!") - .arg(_chars_send).arg(_words_send).arg(_lines_send).arg(threshold); + .arg(_chars_sent).arg(_words_sent).arg(_lines_sent).arg(threshold); } void @@ -199,10 +199,10 @@ KochTutor::reset() } _text.push_back('\n'); } - _sendText.clear(); - _chars_send = 0; - _words_send = 0; - _lines_send = 0; + _sentText.clear(); + _chars_sent = 0; + _words_sent = 0; + _lines_sent = 0; // sample a line of text. _nextline(); } @@ -225,17 +225,17 @@ KochTutor::isOutputHidden() const { int KochTutor::verify(const QString &text, QString &summary) { QVector mistakes; - int err = textCompare(_sendText.toLower(), text.toLower(), mistakes); + int err = textCompare(_sentText.toLower(), text.toLower(), mistakes); // Format Send text QString tx, rx; QTextStream buffer(&tx); - for (int i=0; i<_sendText.size(); i++) { - if ('\n' == _sendText.at(i)) + for (int i=0; i<_sentText.size(); i++) { + if ('\n' == _sentText.at(i)) buffer << "
"; else if (mistakes.contains(i)) - buffer << "" << _sendText.at(i) << ""; + buffer << "" << _sentText.at(i) << ""; else - buffer << _sendText.at(i); + buffer << _sentText.at(i); } buffer.setString(&rx); for (int i=0; i

Text send:

%1

" + int correct = 100*double(_chars_sent-err)/_chars_sent; + summary = tr("

Text sent:

%1

" "

Text entered:

%2

" - "

Summary:

Characters/Words/Lines send: %3/%4/%5
" + "

Summary:

Characters/Words/Lines sent: %3/%4/%5
" "Mistakes: %6
" - "Accuracy: %7%

").arg(tx).arg(rx).arg(_chars_send) - .arg(_words_send).arg(_lines_send).arg(err).arg(correct); + "Accuracy: %7%

").arg(tx).arg(rx).arg(_chars_sent) + .arg(_words_sent).arg(_lines_sent).arg(err).arg(correct); if (correct >= _threshold) { summary.append(tr("

You achieved an accuracy of %1% >= %2%. " "You may advance to the next lesson!

").arg(correct).arg(_threshold)); @@ -294,21 +294,21 @@ KochTutor::_nextline() { idx = _lesson*double(rand())/RAND_MAX; } _text.push_back(_lessons[idx]); - _sendText.push_back(_lessons[idx]); - _chars_send++; + _sentText.push_back(_lessons[idx]); + _chars_sent++; } i += n; _text.push_back(' '); - _sendText.push_back(' '); - _words_send++; + _sentText.push_back(' '); + _words_sent++; } _text.push_back('='); _text.push_back(' '); _text.push_back(' '); _text.push_back('\n'); - _sendText.push_back('\n'); + _sentText.push_back('\n'); _linecount++; - _lines_send++; + _lines_sent++; } const QVector & @@ -323,7 +323,7 @@ KochTutor::lessons() { RandomTutor::RandomTutor(MorseEncoder *encoder, size_t minGroupSize, size_t maxGroupSize, int lines, bool showSummary, bool verify, bool hideOutput, QObject *parent) : Tutor(encoder, parent), _minGroupSize(minGroupSize), _maxGroupSize(maxGroupSize), _lines(lines), _linecount(0), _showSummary(showSummary), _verify(verify), - _hideOutput(hideOutput), _text(), _chars(), _chars_send(0), _words_send(0), _lines_send(0) + _hideOutput(hideOutput), _text(), _chars(), _chars_sent(0), _words_sent(0), _lines_sent(0) { // Init random number generator srand(time(nullptr)); @@ -349,7 +349,7 @@ RandomTutor::RandomTutor(MorseEncoder *encoder, const QSet &chars, size_t bool hideOutput, QObject *parent) : Tutor(encoder, parent), _minGroupSize(minGroupSize), _maxGroupSize(maxGroupSize), _lines(lines), _showSummary(showSummary), _verify(verify), _hideOutput(hideOutput), _text(), _chars(), - _chars_send(0), _words_send(0), _lines_send(0) + _chars_sent(0), _words_sent(0), _lines_sent(0) { // Init random number generator srand(time(nullptr)); @@ -369,9 +369,9 @@ QString RandomTutor::summary() const { if (! _showSummary) return ""; - int chars_send = _chars_send; - int words_send = _words_send; - int lines_send = _lines_send; + int chars_send = _chars_sent; + int words_send = _words_sent; + int lines_send = _lines_sent; return tr("\n\nSent %1 chars in %2 words and %3 lines.") .arg(chars_send).arg(words_send).arg(lines_send); } @@ -414,13 +414,13 @@ RandomTutor::reset() { // Empty current session _text.clear(); - _sendText.clear(); + _sentText.clear(); // If empty char set -> done. if (0 == _chars.size()) { return; } // Reset linecount _linecount = 0; // reset char, word & line count - _chars_send = _words_send = _lines_send = 0; + _chars_sent = _words_sent = _lines_sent = 0; // Insert "vvv\n" _text.push_back('v'); _text.push_back('v'); _text.push_back('v'); _text.push_back('\n'); // sample a line @@ -453,17 +453,17 @@ RandomTutor::isOutputHidden() const { int RandomTutor::verify(const QString &text, QString &summary) { QVector mistakes; - int err = textCompare(_sendText.toLower(), text.toLower(), mistakes); - // Format Send text + int err = textCompare(_sentText.toLower(), text.toLower(), mistakes); + // Format Sent text QString tx, rx; QTextStream buffer(&tx); - for (int i=0; i<_sendText.size(); i++) { - if ('\n' == _sendText.at(i)) + for (int i=0; i<_sentText.size(); i++) { + if ('\n' == _sentText.at(i)) buffer << "
"; else if (mistakes.contains(i)) - buffer << "" << _sendText.at(i) << ""; + buffer << "" << _sentText.at(i) << ""; else - buffer << _sendText.at(i); + buffer << _sentText.at(i); } buffer.setString(&rx); for (int i=0; i

Text send:

%1

" + int correct = 100*double(_chars_sent-err)/_chars_sent; + summary = tr("

Text sent:

%1

" "

Text entered:

%2

" - "

Summary:

Characters/Words/Lines send: %3/%4/%5
" + "

Summary:

Characters/Words/Lines sent: %3/%4/%5
" "Mistakes: %6
" - "Accuracy: %7%

").arg(tx).arg(rx).arg(_chars_send) - .arg(_words_send).arg(_lines_send).arg(err).arg(correct); + "Accuracy: %7%

").arg(tx).arg(rx).arg(_chars_sent) + .arg(_words_sent).arg(_lines_sent).arg(err).arg(correct); emit sessionVerified("rand", _chars.size(), correct); return err; @@ -493,20 +493,20 @@ RandomTutor::_nextline() { // Sample char from chars size_t idx = _chars.size()*double(rand())/RAND_MAX; _text.push_back(_chars[idx]); - _sendText.push_back(_chars[idx]); - _chars_send++; + _sentText.push_back(_chars[idx]); + _chars_sent++; } i += n; _text.push_back(' '); - _sendText.push_back(' '); - _words_send++; + _sentText.push_back(' '); + _words_sent++; } _text.push_back('='); _text.push_back(' '); _text.push_back('\n'); - _sendText.push_back('\n'); + _sentText.push_back('\n'); _linecount++; - _lines_send++; + _lines_sent++; } QSet @@ -564,7 +564,7 @@ WordsworthTutor::WordsworthTutor( : Tutor(encoder, parent), _lesson(lesson), _prefLastWords(prefLastWords), _repeatLastWord(repeatLastWord), _lines(lines), _linecount(0), _showSummary(showSummary), _verify(verify), _hideOutput(hideOutput), - _threshold(successThreshold), _text(), _chars_send(0), _words_send(0), _lines_send(0) + _threshold(successThreshold), _text(), _chars_sent(0), _words_sent(0), _lines_sent(0) { // Init random number generator srand(time(nullptr)); @@ -636,15 +636,15 @@ QString WordsworthTutor::summary() const { if (! _showSummary) return ""; - int threshold = int(_chars_send*(100-_threshold))/100; + int threshold = int(_chars_sent*(100-_threshold))/100; if (_lesson < (_lessons.size()-1)) return tr("\n\nSent %1 chars in %2 words and %3 lines. " "If you have less than %4 mistakes, you can proceed to lesson %5.") - .arg(_chars_send).arg(_words_send).arg(_lines_send).arg(threshold).arg(_lesson+1); + .arg(_chars_sent).arg(_words_sent).arg(_lines_sent).arg(threshold).arg(_lesson+1); else return tr("\n\nSent %1 chars in %2 words and %3 lines. " "If you have less than %4 mistakes, you completed the course!") - .arg(_chars_send).arg(_words_send).arg(_lines_send).arg(threshold); + .arg(_chars_sent).arg(_words_sent).arg(_lines_sent).arg(threshold); } void @@ -684,10 +684,10 @@ WordsworthTutor::reset() } _text.push_back('\n'); } - _sendText.clear(); - _chars_send = 0; - _words_send = 0; - _lines_send = 0; + _sentText.clear(); + _chars_sent = 0; + _words_sent = 0; + _lines_sent = 0; // sample a line of text. _nextline(); } @@ -710,17 +710,17 @@ WordsworthTutor::isOutputHidden() const { int WordsworthTutor::verify(const QString &text, QString &summary) { QVector mistakes; - int err = textCompare(_sendText.toLower(), text.toLower(), mistakes); - // Format Send text + int err = textCompare(_sentText.toLower(), text.toLower(), mistakes); + // Format text QString tx, rx; QTextStream buffer(&tx); - for (int i=0; i<_sendText.size(); i++) { - if ('\n' == _sendText.at(i)) + for (int i=0; i<_sentText.size(); i++) { + if ('\n' == _sentText.at(i)) buffer << "
"; else if (mistakes.contains(i)) - buffer << "" << _sendText.at(i) << ""; + buffer << "" << _sentText.at(i) << ""; else - buffer << _sendText.at(i); + buffer << _sentText.at(i); } buffer.setString(&rx); for (int i=0; i

Text send:

%1

" + int correct = 100*double(_chars_sent-err)/_chars_sent; + summary = tr("

Text sent:

%1

" "

Text entered:

%2

" - "

Summary:

Characters/Words/Lines send: %3/%4/%5
" + "

Summary:

Characters/Words/Lines sent: %3/%4/%5
" "Mistakes: %6
" - "Accuracy: %7%

").arg(tx).arg(rx).arg(_chars_send) - .arg(_words_send).arg(_lines_send).arg(err).arg(correct); + "Accuracy: %7%

").arg(tx).arg(rx).arg(_chars_sent) + .arg(_words_sent).arg(_lines_sent).arg(err).arg(correct); if (correct >= _threshold) { summary.append(tr("

You achieved an accuracy of %1% >= %2%. " "You may advance to the next lesson!

").arg(correct).arg(_threshold)); @@ -776,19 +776,19 @@ WordsworthTutor::_nextline() { } for (int j=0; j<_lessons[idx].size(); j++) _text.push_back(_lessons[idx][j]); - _sendText.push_back(_lessons[idx]); - _chars_send += _lessons[idx].size(); + _sentText.push_back(_lessons[idx]); + _chars_sent += _lessons[idx].size(); _text.push_back(' '); - _sendText.push_back(' '); - _words_send++; + _sentText.push_back(' '); + _words_sent++; } _text.push_back('='); _text.push_back(' '); _text.push_back(' '); _text.push_back('\n'); - _sendText.push_back('\n'); + _sentText.push_back('\n'); _linecount++; - _lines_send++; + _lines_sent++; } const QVector & diff --git a/src/tutor.hh b/src/tutor.hh index 5be3983..5336a31 100644 --- a/src/tutor.hh +++ b/src/tutor.hh @@ -148,10 +148,10 @@ protected: QList _text; /** The vector of symbols for each lesson. */ static QVector _lessons; - size_t _chars_send; - size_t _words_send; - size_t _lines_send; - QString _sendText; + size_t _chars_sent; + size_t _words_sent; + size_t _lines_sent; + QString _sentText; }; @@ -225,10 +225,10 @@ protected: QList _text; /** Vector of chars to choose from. */ QVector _chars; - QString _sendText; - size_t _chars_send; - size_t _words_send; - size_t _lines_send; + QString _sentText; + size_t _chars_sent; + size_t _words_sent; + size_t _lines_sent; }; @@ -308,9 +308,9 @@ protected: bool _prefLastWords; /** The "repeat last word" flag. */ bool _repeatLastWord; - /** The number of lines to send, if negative send an infinite number of lines. */ + /** The number of lines to send. If negative, send an infinite number of lines. */ int _lines; - /** The number of lines send. */ + /** The number of lines sent. */ int _linecount; bool _showSummary; bool _verify; @@ -320,10 +320,10 @@ protected: QList _text; /** The vector of words for each lesson. */ static QVector _lessons; - size_t _chars_send; - size_t _words_send; - size_t _lines_send; - QString _sendText; + size_t _chars_sent; + size_t _words_sent; + size_t _lines_sent; + QString _sentText; };