QByteArray: Overload toHex() with separator character
The separator character is inserted in the resulting array
after every byte and is useful for MAC address output like
01:23:45🆎cd:ef, Hash fingerprints, or low level data
debug output.
[ChangeLog][QtCore][QByteArray] Added toHex() overload to
insert a separator character between the hex bytes.
Change-Id: Ibe436094badc02f3ade7751aa8b5d690599941d4
Reviewed-by: Thiago Macieira <thiago.macieira@intel.com>
This commit is contained in:
parent
8266de089c
commit
615027129d
@ -4355,12 +4355,41 @@ QByteArray QByteArray::fromHex(const QByteArray &hexEncoded)
|
|||||||
*/
|
*/
|
||||||
QByteArray QByteArray::toHex() const
|
QByteArray QByteArray::toHex() const
|
||||||
{
|
{
|
||||||
QByteArray hex(d->size * 2, Qt::Uninitialized);
|
return toHex('\0');
|
||||||
|
}
|
||||||
|
|
||||||
|
/*! \overload
|
||||||
|
\since 5.9
|
||||||
|
|
||||||
|
Returns a hex encoded copy of the byte array. The hex encoding uses the numbers 0-9 and
|
||||||
|
the letters a-f.
|
||||||
|
|
||||||
|
If \a separator is not '\0', the separator character is inserted between the hex bytes.
|
||||||
|
|
||||||
|
Example:
|
||||||
|
\code
|
||||||
|
QByteArray macAddress = QByteArray::fromHex("123456abcdef");
|
||||||
|
macAddress.toHex(':'); // returns "12:34:56:ab:cd:ef"
|
||||||
|
macAddress.toHex(0); // returns "123456abcdef"
|
||||||
|
\endcode
|
||||||
|
|
||||||
|
\sa fromHex()
|
||||||
|
*/
|
||||||
|
QByteArray QByteArray::toHex(char separator) const
|
||||||
|
{
|
||||||
|
if (!d->size)
|
||||||
|
return QByteArray();
|
||||||
|
|
||||||
|
const int length = separator ? (d->size * 3 - 1) : (d->size * 2);
|
||||||
|
QByteArray hex(length, Qt::Uninitialized);
|
||||||
char *hexData = hex.data();
|
char *hexData = hex.data();
|
||||||
const uchar *data = (const uchar *)d->data();
|
const uchar *data = (const uchar *)d->data();
|
||||||
for (int i = 0; i < d->size; ++i) {
|
for (int i = 0, o = 0; i < d->size; ++i) {
|
||||||
hexData[i*2] = QtMiscUtils::toHexLower(data[i] >> 4);
|
hexData[o++] = QtMiscUtils::toHexLower(data[i] >> 4);
|
||||||
hexData[i*2+1] = QtMiscUtils::toHexLower(data[i] & 0xf);
|
hexData[o++] = QtMiscUtils::toHexLower(data[i] & 0xf);
|
||||||
|
|
||||||
|
if ((separator) && (o < length))
|
||||||
|
hexData[o++] = separator;
|
||||||
}
|
}
|
||||||
return hex;
|
return hex;
|
||||||
}
|
}
|
||||||
|
@ -357,6 +357,7 @@ public:
|
|||||||
QByteArray toBase64(Base64Options options) const;
|
QByteArray toBase64(Base64Options options) const;
|
||||||
QByteArray toBase64() const; // ### Qt6 merge with previous
|
QByteArray toBase64() const; // ### Qt6 merge with previous
|
||||||
QByteArray toHex() const;
|
QByteArray toHex() const;
|
||||||
|
QByteArray toHex(char separator) const; // ### Qt6 merge with previous
|
||||||
QByteArray toPercentEncoding(const QByteArray &exclude = QByteArray(),
|
QByteArray toPercentEncoding(const QByteArray &exclude = QByteArray(),
|
||||||
const QByteArray &include = QByteArray(),
|
const QByteArray &include = QByteArray(),
|
||||||
char percent = '%') const;
|
char percent = '%') const;
|
||||||
|
@ -1443,61 +1443,97 @@ void tst_QByteArray::appendAfterFromRawData()
|
|||||||
void tst_QByteArray::toFromHex_data()
|
void tst_QByteArray::toFromHex_data()
|
||||||
{
|
{
|
||||||
QTest::addColumn<QByteArray>("str");
|
QTest::addColumn<QByteArray>("str");
|
||||||
|
QTest::addColumn<char>("sep");
|
||||||
QTest::addColumn<QByteArray>("hex");
|
QTest::addColumn<QByteArray>("hex");
|
||||||
QTest::addColumn<QByteArray>("hex_alt1");
|
QTest::addColumn<QByteArray>("hex_alt1");
|
||||||
|
|
||||||
QTest::newRow("Qt is great!")
|
QTest::newRow("Qt is great! (default)")
|
||||||
<< QByteArray("Qt is great!")
|
<< QByteArray("Qt is great!")
|
||||||
|
<< '\0'
|
||||||
<< QByteArray("517420697320677265617421")
|
<< QByteArray("517420697320677265617421")
|
||||||
<< QByteArray("51 74 20 69 73 20 67 72 65 61 74 21");
|
<< QByteArray("51 74 20 69 73 20 67 72 65 61 74 21");
|
||||||
|
|
||||||
|
QTest::newRow("Qt is great! (with space)")
|
||||||
|
<< QByteArray("Qt is great!")
|
||||||
|
<< ' '
|
||||||
|
<< QByteArray("51 74 20 69 73 20 67 72 65 61 74 21")
|
||||||
|
<< QByteArray("51 74 20 69 73 20 67 72 65 61 74 21");
|
||||||
|
|
||||||
|
QTest::newRow("Qt is great! (with minus)")
|
||||||
|
<< QByteArray("Qt is great!")
|
||||||
|
<< '-'
|
||||||
|
<< QByteArray("51-74-20-69-73-20-67-72-65-61-74-21")
|
||||||
|
<< QByteArray("51-74-20-69-73-20-67-72-65-61-74-21");
|
||||||
|
|
||||||
QTest::newRow("Qt is so great!")
|
QTest::newRow("Qt is so great!")
|
||||||
<< QByteArray("Qt is so great!")
|
<< QByteArray("Qt is so great!")
|
||||||
|
<< '\0'
|
||||||
<< QByteArray("517420697320736f20677265617421")
|
<< QByteArray("517420697320736f20677265617421")
|
||||||
<< QByteArray("51 74 20 69 73 20 73 6f 20 67 72 65 61 74 21");
|
<< QByteArray("51 74 20 69 73 20 73 6f 20 67 72 65 61 74 21");
|
||||||
|
|
||||||
QTest::newRow("default-constructed")
|
QTest::newRow("default-constructed")
|
||||||
<< QByteArray()
|
<< QByteArray()
|
||||||
|
<< '\0'
|
||||||
|
<< QByteArray()
|
||||||
|
<< QByteArray();
|
||||||
|
|
||||||
|
QTest::newRow("default-constructed (with space)")
|
||||||
|
<< QByteArray()
|
||||||
|
<< ' '
|
||||||
<< QByteArray()
|
<< QByteArray()
|
||||||
<< QByteArray();
|
<< QByteArray();
|
||||||
|
|
||||||
QTest::newRow("empty")
|
QTest::newRow("empty")
|
||||||
<< QByteArray("")
|
<< QByteArray("")
|
||||||
|
<< '\0'
|
||||||
|
<< QByteArray("")
|
||||||
|
<< QByteArray("");
|
||||||
|
|
||||||
|
QTest::newRow("empty (with space)")
|
||||||
|
<< QByteArray("")
|
||||||
|
<< ' '
|
||||||
<< QByteArray("")
|
<< QByteArray("")
|
||||||
<< QByteArray("");
|
<< QByteArray("");
|
||||||
|
|
||||||
QTest::newRow("array-of-null")
|
QTest::newRow("array-of-null")
|
||||||
<< QByteArray("\0", 1)
|
<< QByteArray("\0", 1)
|
||||||
|
<< '\0'
|
||||||
<< QByteArray("00")
|
<< QByteArray("00")
|
||||||
<< QByteArray("0");
|
<< QByteArray("0");
|
||||||
|
|
||||||
QTest::newRow("no-leading-zero")
|
QTest::newRow("no-leading-zero")
|
||||||
<< QByteArray("\xf")
|
<< QByteArray("\xf")
|
||||||
|
<< '\0'
|
||||||
<< QByteArray("0f")
|
<< QByteArray("0f")
|
||||||
<< QByteArray("f");
|
<< QByteArray("f");
|
||||||
|
|
||||||
QTest::newRow("single-byte")
|
QTest::newRow("single-byte")
|
||||||
<< QByteArray("\xaf")
|
<< QByteArray("\xaf")
|
||||||
|
<< '\0'
|
||||||
<< QByteArray("af")
|
<< QByteArray("af")
|
||||||
<< QByteArray("xaf");
|
<< QByteArray("xaf");
|
||||||
|
|
||||||
QTest::newRow("no-leading-zero")
|
QTest::newRow("no-leading-zero")
|
||||||
<< QByteArray("\xd\xde\xad\xc0\xde")
|
<< QByteArray("\xd\xde\xad\xc0\xde")
|
||||||
|
<< '\0'
|
||||||
<< QByteArray("0ddeadc0de")
|
<< QByteArray("0ddeadc0de")
|
||||||
<< QByteArray("ddeadc0de");
|
<< QByteArray("ddeadc0de");
|
||||||
|
|
||||||
QTest::newRow("garbage")
|
QTest::newRow("garbage")
|
||||||
<< QByteArray("\xC\xde\xeC\xea\xee\xDe\xee\xee")
|
<< QByteArray("\xC\xde\xeC\xea\xee\xDe\xee\xee")
|
||||||
|
<< '\0'
|
||||||
<< QByteArray("0cdeeceaeedeeeee")
|
<< QByteArray("0cdeeceaeedeeeee")
|
||||||
<< QByteArray("Code less. Create more. Deploy everywhere.");
|
<< QByteArray("Code less. Create more. Deploy everywhere.");
|
||||||
|
|
||||||
QTest::newRow("under-defined-1")
|
QTest::newRow("under-defined-1")
|
||||||
<< QByteArray("\x1\x23")
|
<< QByteArray("\x1\x23")
|
||||||
|
<< '\0'
|
||||||
<< QByteArray("0123")
|
<< QByteArray("0123")
|
||||||
<< QByteArray("x123");
|
<< QByteArray("x123");
|
||||||
|
|
||||||
QTest::newRow("under-defined-2")
|
QTest::newRow("under-defined-2")
|
||||||
<< QByteArray("\x12\x34")
|
<< QByteArray("\x12\x34")
|
||||||
|
<< '\0'
|
||||||
<< QByteArray("1234")
|
<< QByteArray("1234")
|
||||||
<< QByteArray("x1234");
|
<< QByteArray("x1234");
|
||||||
}
|
}
|
||||||
@ -1505,15 +1541,22 @@ void tst_QByteArray::toFromHex_data()
|
|||||||
void tst_QByteArray::toFromHex()
|
void tst_QByteArray::toFromHex()
|
||||||
{
|
{
|
||||||
QFETCH(QByteArray, str);
|
QFETCH(QByteArray, str);
|
||||||
|
QFETCH(char, sep);
|
||||||
QFETCH(QByteArray, hex);
|
QFETCH(QByteArray, hex);
|
||||||
QFETCH(QByteArray, hex_alt1);
|
QFETCH(QByteArray, hex_alt1);
|
||||||
|
|
||||||
{
|
if (sep == 0) {
|
||||||
const QByteArray th = str.toHex();
|
const QByteArray th = str.toHex();
|
||||||
QCOMPARE(th.size(), hex.size());
|
QCOMPARE(th.size(), hex.size());
|
||||||
QCOMPARE(th, hex);
|
QCOMPARE(th, hex);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
const QByteArray th = str.toHex(sep);
|
||||||
|
QCOMPARE(th.size(), hex.size());
|
||||||
|
QCOMPARE(th, hex);
|
||||||
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
const QByteArray fh = QByteArray::fromHex(hex);
|
const QByteArray fh = QByteArray::fromHex(hex);
|
||||||
QCOMPARE(fh.size(), str.size());
|
QCOMPARE(fh.size(), str.size());
|
||||||
|
Loading…
Reference in New Issue
Block a user