9#include <QJsonDocument>
63 mode.
startsWith(u
"ac v"_s) || mode.startsWith(u
"vac"_s)) {
65 }
else if (mode.startsWith(u
"dc v"_s) || mode.startsWith(u
"vdc"_s)) {
67 }
else if (mode.startsWith(u
"ac c"_s) || mode.startsWith(u
"aac"_s)) {
69 }
else if (mode.startsWith(u
"dc c"_s) || mode.startsWith(u
"adc"_s)) {
72 errors.
append(
tr(
"Unknown DSO mode: %1").arg(parser.
value(u
"mode"_s)));
80 quint32 sensibleMinimum = 0;
101 errors.
append(
tr(
"Invalid range value: %1").arg(value));
106 if (parser.
isSet(u
"trigger-level"_s)) {
108 const QString rawValue = parser.
value(u
"trigger-level"_s);
111 for (nonSpacePos = 0; (nonSpacePos < rawValue.
length()) && (rawValue.
at(nonSpacePos) == u
' '); ++nonSpacePos);
112 if ((nonSpacePos < rawValue.
length()) && (rawValue.
at(nonSpacePos) == u
'-')) {
113 absValue = rawValue.
mid(nonSpacePos+1);
117 qCDebug(lc) <<
"Trigger level" << rawValue << absValue << nonSpacePos << sign << level;
119 errors.
append(
tr(
"Invalid trigger-level value: %1").arg(rawValue));
121 settings.triggerLevel = sign * level;
122 qCDebug(lc) <<
"Trigger level" <<
settings.triggerLevel;
126 errors.
append(
tr(
"Trigger-level %1%2 is outside range ±%3%2").arg(
133 if (parser.
isSet(u
"trigger-mode"_s)) {
137 }
else if (triggerMode.
startsWith(u
"ris"_s)) {
139 }
else if (triggerMode.
startsWith(u
"fall"_s)) {
142 errors.
append(
tr(
"Unknown trigger mode: %1").arg(parser.
value(u
"trigger-mode"_s)));
147 if (parser.
isSet(u
"trigger-level"_s) != parser.
isSet(u
"trigger-mode"_s)) {
148 errors.
append(
tr(
"If either option is provided, then both must be: trigger-level, trigger-mode"));
152 if (parser.
isSet(u
"interval"_s)) {
156 errors.
append(
tr(
"Invalid interval value: %1").arg(value));
163 if (parser.
isSet(u
"samples"_s)) {
167 errors.
append(
tr(
"Invalid samples value: %1").arg(value));
168 }
else if (samples > std::numeric_limits<quint16>::max()) {
169 errors.
append(
tr(
"Samples value (%1) must be no greater than %2")
170 .arg(value).arg(std::numeric_limits<quint16>::max()));
172 if (samples > 8192) {
173 qCWarning(lc).noquote() <<
tr(
"Pokit devices do not officially support great than 8192 samples");
175 settings.numberOfSamples = (quint16)samples;
211 range.
at(range.
size()-1));
212 qCInfo(lc).noquote() <<
tr(
"Sampling %1, with range %2, %Ln sample/s over %L3us%4.",
nullptr,
settings.numberOfSamples)
238 qCDebug(lc).noquote() <<
tr(
"Settings written; DSO has started.");
241 service->enableMetadataNotifications();
242 service->enableReadingNotifications();
250 qCDebug(lc) <<
"status:" << (int)(data.
status);
251 qCDebug(lc) <<
"scale:" << data.
scale;
256 qCDebug(lc) <<
"samplingRate:" << data.
samplingRate <<
"Hz";
273 qCDebug(lc).noquote() <<
tr(R
"(No known unit for mode %1 "%2".)").arg((int)
metadata.mode)
278 for (
const qint16 &sample: samples) {
279 static int sampleNumber = 0; ++sampleNumber;
280 const float value = sample *
metadata.scale;
284 std::cout << qUtf8Printable(
tr(
"sample_number,value,unit,range\n"));
287 .arg(sampleNumber).arg(value).arg(unit, range));
291 { u
"value"_s, value },
293 { u
"range"_s, range },
295 }).toJson().toStdString();
298 std::cout << qUtf8Printable(
tr(
"%1 %2 %3\n").arg(sampleNumber).arg(value).arg(unit));
304 qCInfo(lc).noquote() <<
tr(
"Finished fetching %Ln sample/s (with %L2 to remaining).",
virtual QStringList supportedOptions(const QCommandLineParser &parser) const
Returns a list of CLI option names supported by this command.
static QString appendSiPrefix(const double value, int precision=6)
Returns a human-readable version of value, with up-to precision decimal digits, and SI unit prefix wh...
static T parseNumber(const QString &value, const QString &unit, const T sensibleMinimum=0)
Returns value as an integer multiple of the ratio R, as number of type T.
OutputFormat format
Selected output format.
@ Text
Plain unstructured text.
@ Csv
RFC 4180 compliant CSV text.
@ Json
RFC 8259 compliant JSON text.
virtual QStringList processOptions(const QCommandLineParser &parser)
Processes the relevant options from the command line parser.
virtual QStringList requiredOptions(const QCommandLineParser &parser) const
Returns a list of CLI option names required by this command.
The AbstractPokitService class provides a common base for Pokit services classes.
PokitDevice * device
Pokit Bluetooth device (if any) this command interacts with.
DeviceCommand(QObject *const parent=nullptr)
Construct a new DeviceCommand object with parent.
virtual void serviceDetailsDiscovered()
Handles service detail discovery events.
static quint8 minVoltageRange(const PokitProduct product, const quint32 maxValue)
Returns the product's lowest voltage range that can measure at least up to maxValue (mV),...
static quint8 minCurrentRange(const PokitProduct product, const quint32 maxValue)
Returns the product's lowest current range that can measure at least up to maxValue (μA),...
void disconnect(int exitCode=EXIT_SUCCESS)
Disconnects the underlying Pokit device, and sets exitCode to be return to the OS once the disconnect...
DsoService::Settings settings
Settings for the Pokit device's DSO mode.
quint8(* minRangeFunc)(const PokitProduct product, const quint32 maxValue)
Pointer to function for converting rangeOptionValue to a Pokit device's range enumerator.
qint32 samplesToGo
Number of samples we're expecting in the current window.
bool showCsvHeader
Whether or not to show a header as the first line of CSV output.
void serviceDetailsDiscovered() override
Handles service detail discovery events.
void outputSamples(const DsoService::Samples &samples)
Outputs DSO samples in the selected output format.
QStringList supportedOptions(const QCommandLineParser &parser) const override
Returns a list of CLI option names supported by this command.
DsoCommand(QObject *const parent=nullptr)
Construct a new DsoCommand object with parent.
DsoService * service
Bluetooth service this command interacts with.
QStringList processOptions(const QCommandLineParser &parser) override
Processes the relevant options from the command line parser.
void settingsWritten()
Invoked when the DSO settings have been written.
quint32 rangeOptionValue
The parsed value of range option.
QStringList requiredOptions(const QCommandLineParser &parser) const override
Returns a list of CLI option names required by this command.
AbstractPokitService * getService() override
Returns a Pokit service object for the derived command class.
DsoService::Metadata metadata
Most recent DSO metadata.
void metadataRead(const DsoService::Metadata &data)
Invoked when metadata has been received from the DSO.
void metadataRead(const DsoService::Metadata &meta)
This signal is emitted when the Metadata characteristic has been read successfully.
QVector< qint16 > Samples
Raw samples from the Reading characteristic.
void settingsWritten()
This signal is emitted when the Settings characteristic has been written successfully.
static QString toString(const Command &command)
Returns command as a user-friendly string.
@ DcVoltage
Measure DC voltage.
@ AcCurrent
Measure AC current.
@ AcVoltage
Measure AC voltage.
@ DcCurrent
Measure DC current.
@ FreeRunning
Run free, without waiting for edge triggers.
@ RisingEdgeTrigger
Trigger on a rising edge.
@ FallingEdgeTrigger
Trigger on a falling edge.
void samplesRead(const DsoService::Samples &samples)
This signal is emitted when the Reading characteristic has been notified.
Declares the PokitDevice class.
bool isSet(const QString &name) const const
QString value(const QString &optionName) const const
void append(const T &value)
bool isEmpty() const const
QMetaObject::Connection connect(const QObject *sender, const char *signal, const QObject *receiver, const char *method, Qt::ConnectionType type)
QObject * parent() const const
QString tr(const char *sourceText, const char *disambiguation, int n)
QString arg(qlonglong a, int fieldWidth, int base, QChar fillChar) const const
const QChar at(int position) const const
QString fromLatin1(const char *str, int size)
bool isEmpty() const const
bool isNull() const const
QString mid(int position, int n) const const
bool startsWith(const QString &s, Qt::CaseSensitivity cs) const const
QString toLower() const const
QString trimmed() const const
Declares the DOKIT_USE_STRINGLITERALS macro, and related functions.
#define DOKIT_STRING_INDEX_TYPE
Internal macro for matching the index type used by QString methods.
#define DOKIT_USE_STRINGLITERALS
Internal macro for using either official Qt string literals (added in Qt 6.4), or our own equivalent ...