forked from qt-creator/qt-creator
Merge remote-tracking branch 'origin/qds-1.59'
Change-Id: I8891e7490a7fd51997a3b57561961f6134be3252
This commit is contained in:
@@ -768,7 +768,8 @@ QObject *ObjectNodeInstance::createComponent(const QString &componentPath, QQmlC
|
|||||||
qWarning() << error;
|
qWarning() << error;
|
||||||
}
|
}
|
||||||
|
|
||||||
object->setProperty("__designer_url__", QUrl::fromLocalFile(componentPath));
|
if (object)
|
||||||
|
object->setProperty("__designer_url__", QUrl::fromLocalFile(componentPath));
|
||||||
|
|
||||||
return object;
|
return object;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -192,6 +192,8 @@ public:
|
|||||||
columnDefinitionString.append(defaultValue.value.toStringView());
|
columnDefinitionString.append(defaultValue.value.toStringView());
|
||||||
columnDefinitionString.append("'");
|
columnDefinitionString.append("'");
|
||||||
break;
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -33,6 +33,7 @@
|
|||||||
|
|
||||||
namespace Sqlite {
|
namespace Sqlite {
|
||||||
|
|
||||||
|
template<unsigned int TableCount = 0>
|
||||||
class LastChangedRowId
|
class LastChangedRowId
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
@@ -40,86 +41,82 @@ public:
|
|||||||
: database(database)
|
: database(database)
|
||||||
|
|
||||||
{
|
{
|
||||||
callback = [=](ChangeType, char const *, char const *, long long rowId) {
|
database.setUpdateHook(this, callbackOnlyRowId);
|
||||||
this->lastRowId = rowId;
|
|
||||||
};
|
|
||||||
|
|
||||||
database.setUpdateHook(callback);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
LastChangedRowId(DatabaseInterface &database, Utils::SmallStringView databaseName)
|
LastChangedRowId(DatabaseInterface &database, Utils::SmallStringView databaseName)
|
||||||
: database(database)
|
: database(database)
|
||||||
|
, databaseName(databaseName)
|
||||||
{
|
{
|
||||||
callback = [=](ChangeType, char const *database, char const *, long long rowId) {
|
database.setUpdateHook(this, callbackWithDatabase);
|
||||||
if (databaseName == database)
|
|
||||||
this->lastRowId = rowId;
|
|
||||||
};
|
|
||||||
|
|
||||||
database.setUpdateHook(callback);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
template<typename... Tables>
|
||||||
LastChangedRowId(DatabaseInterface &database,
|
LastChangedRowId(DatabaseInterface &database,
|
||||||
Utils::SmallStringView databaseName,
|
Utils::SmallStringView databaseName,
|
||||||
Utils::SmallStringView tableName)
|
Tables... tableNames)
|
||||||
: database(database)
|
: database(database)
|
||||||
|
, databaseName(databaseName)
|
||||||
|
, tableNames({tableNames...})
|
||||||
{
|
{
|
||||||
callback = [=](ChangeType, char const *database, char const *table, long long rowId) {
|
database.setUpdateHook(this, callbackWithTables);
|
||||||
if (databaseName == database && tableName == table)
|
|
||||||
this->lastRowId = rowId;
|
|
||||||
};
|
|
||||||
|
|
||||||
database.setUpdateHook(callback);
|
|
||||||
}
|
|
||||||
|
|
||||||
LastChangedRowId(DatabaseInterface &database,
|
|
||||||
Utils::SmallStringView databaseName,
|
|
||||||
Utils::SmallStringView tableName,
|
|
||||||
Utils::SmallStringView tableName2)
|
|
||||||
: database(database)
|
|
||||||
|
|
||||||
{
|
|
||||||
callback = [=](ChangeType, char const *database, char const *table, long long rowId) {
|
|
||||||
if (databaseName == database && (tableName == table || tableName2 == table))
|
|
||||||
this->lastRowId = rowId;
|
|
||||||
};
|
|
||||||
|
|
||||||
database.setUpdateHook(callback);
|
|
||||||
}
|
|
||||||
|
|
||||||
LastChangedRowId(DatabaseInterface &database,
|
|
||||||
Utils::SmallStringView databaseName,
|
|
||||||
Utils::SmallStringView tableName,
|
|
||||||
Utils::SmallStringView tableName2,
|
|
||||||
Utils::SmallStringView tableName3)
|
|
||||||
: database(database)
|
|
||||||
|
|
||||||
{
|
|
||||||
callback = [=](ChangeType, char const *database, char const *table, long long rowId) {
|
|
||||||
if (databaseName == database
|
|
||||||
&& (tableName == table || tableName2 == table || tableName3 == table))
|
|
||||||
this->lastRowId = rowId;
|
|
||||||
};
|
|
||||||
|
|
||||||
database.setUpdateHook(callback);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
~LastChangedRowId() { database.resetUpdateHook(); }
|
~LastChangedRowId() { database.resetUpdateHook(); }
|
||||||
|
|
||||||
long long takeLastRowId()
|
void operator()(long long rowId) { lastRowId = rowId; }
|
||||||
|
|
||||||
|
static void callbackOnlyRowId(void *object, int, char const *, char const *, long long rowId)
|
||||||
{
|
{
|
||||||
long long rowId = lastRowId;
|
(*static_cast<LastChangedRowId *>(object))(rowId);
|
||||||
lastRowId = -1;
|
|
||||||
return rowId;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool lastRowIdIsValid() { return lastRowId >= 0; }
|
bool containsTable(Utils::SmallStringView table)
|
||||||
|
{
|
||||||
|
return std::find(tableNames.begin(), tableNames.end(), table) != tableNames.end();
|
||||||
|
}
|
||||||
|
|
||||||
|
void operator()(Utils::SmallStringView database, long long rowId)
|
||||||
|
{
|
||||||
|
if (databaseName == database)
|
||||||
|
lastRowId = rowId;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void callbackWithDatabase(
|
||||||
|
void *object, int, char const *database, char const *, long long rowId)
|
||||||
|
{
|
||||||
|
(*static_cast<LastChangedRowId *>(object))(Utils::SmallStringView{database}, rowId);
|
||||||
|
}
|
||||||
|
|
||||||
|
void operator()(Utils::SmallStringView database, Utils::SmallStringView table, long long rowId)
|
||||||
|
{
|
||||||
|
if (databaseName == database && containsTable(table))
|
||||||
|
lastRowId = rowId;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void callbackWithTables(
|
||||||
|
void *object, int, char const *database, char const *table, long long rowId)
|
||||||
|
{
|
||||||
|
(*static_cast<LastChangedRowId *>(
|
||||||
|
object))(Utils::SmallStringView{database}, Utils::SmallStringView{table}, rowId);
|
||||||
|
}
|
||||||
|
|
||||||
|
long long takeLastRowId()
|
||||||
|
{
|
||||||
|
long long lastId = lastRowId;
|
||||||
|
|
||||||
|
lastRowId = -1;
|
||||||
|
|
||||||
|
return lastId;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool lastRowIdIsValid() const { return lastRowId >= 0; }
|
||||||
|
|
||||||
public:
|
public:
|
||||||
DatabaseInterface &database;
|
DatabaseInterface &database;
|
||||||
DatabaseInterface::UpdateCallback callback;
|
|
||||||
long long lastRowId = -1;
|
long long lastRowId = -1;
|
||||||
|
Utils::SmallStringView databaseName;
|
||||||
|
std::array<Utils::SmallStringView, TableCount> tableNames;
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace Sqlite
|
} // namespace Sqlite
|
||||||
|
|||||||
@@ -214,6 +214,9 @@ void BaseStatement::bind(int index, const Value &value)
|
|||||||
case ValueType::String:
|
case ValueType::String:
|
||||||
bind(index, value.toStringView());
|
bind(index, value.toStringView());
|
||||||
break;
|
break;
|
||||||
|
case ValueType::Null:
|
||||||
|
bind(index, NullValue{});
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -89,7 +89,7 @@ public:
|
|||||||
void setOpenMode(OpenMode openMode);
|
void setOpenMode(OpenMode openMode);
|
||||||
OpenMode openMode() const;
|
OpenMode openMode() const;
|
||||||
|
|
||||||
void execute(Utils::SmallStringView sqlStatement);
|
void execute(Utils::SmallStringView sqlStatement) override;
|
||||||
|
|
||||||
DatabaseBackend &backend();
|
DatabaseBackend &backend();
|
||||||
|
|
||||||
@@ -116,15 +116,20 @@ public:
|
|||||||
m_databaseBackend.walCheckpointFull();
|
m_databaseBackend.walCheckpointFull();
|
||||||
}
|
}
|
||||||
|
|
||||||
void setUpdateHook(DatabaseBackend::UpdateCallback &callback)
|
void setUpdateHook(void *object,
|
||||||
|
void (*callback)(void *object,
|
||||||
|
int,
|
||||||
|
char const *database,
|
||||||
|
char const *,
|
||||||
|
long long rowId)) override
|
||||||
{
|
{
|
||||||
m_databaseBackend.setUpdateHook(callback);
|
m_databaseBackend.setUpdateHook(object, callback);
|
||||||
}
|
}
|
||||||
|
|
||||||
void resetUpdateHook() { m_databaseBackend.resetUpdateHook(); }
|
void resetUpdateHook() override { m_databaseBackend.resetUpdateHook(); }
|
||||||
|
|
||||||
void setAttachedTables(const Utils::SmallStringVector &tables);
|
void setAttachedTables(const Utils::SmallStringVector &tables) override;
|
||||||
void applyAndUpdateSessions();
|
void applyAndUpdateSessions() override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void deferredBegin() override;
|
void deferredBegin() override;
|
||||||
|
|||||||
@@ -400,22 +400,11 @@ void DatabaseBackend::walCheckpointFull()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
namespace {
|
void DatabaseBackend::setUpdateHook(
|
||||||
void updateCallback(
|
void *object,
|
||||||
void *callback, int type, char const *database, char const *table, sqlite3_int64 row)
|
void (*callback)(void *object, int, char const *database, char const *, long long rowId))
|
||||||
{
|
{
|
||||||
auto &function = *reinterpret_cast<DatabaseBackend::UpdateCallback *>(callback);
|
sqlite3_update_hook(m_databaseHandle, callback, object);
|
||||||
|
|
||||||
function(static_cast<ChangeType>(type), database, table, row);
|
|
||||||
}
|
|
||||||
} // namespace
|
|
||||||
|
|
||||||
void DatabaseBackend::setUpdateHook(UpdateCallback &callback)
|
|
||||||
{
|
|
||||||
if (callback)
|
|
||||||
sqlite3_update_hook(m_databaseHandle, updateCallback, &callback);
|
|
||||||
else
|
|
||||||
sqlite3_update_hook(m_databaseHandle, nullptr, nullptr);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void DatabaseBackend::resetUpdateHook()
|
void DatabaseBackend::resetUpdateHook()
|
||||||
|
|||||||
@@ -41,9 +41,6 @@ class Database;
|
|||||||
class SQLITE_EXPORT DatabaseBackend
|
class SQLITE_EXPORT DatabaseBackend
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
using UpdateCallback
|
|
||||||
= std::function<void(ChangeType type, char const *, char const *, long long)>;
|
|
||||||
|
|
||||||
DatabaseBackend(Database &database);
|
DatabaseBackend(Database &database);
|
||||||
~DatabaseBackend();
|
~DatabaseBackend();
|
||||||
|
|
||||||
@@ -88,7 +85,9 @@ public:
|
|||||||
|
|
||||||
void walCheckpointFull();
|
void walCheckpointFull();
|
||||||
|
|
||||||
void setUpdateHook(UpdateCallback &callback);
|
void setUpdateHook(
|
||||||
|
void *object,
|
||||||
|
void (*callback)(void *object, int, char const *database, char const *, long long rowId));
|
||||||
void resetUpdateHook();
|
void resetUpdateHook();
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
|||||||
@@ -29,18 +29,16 @@
|
|||||||
|
|
||||||
#include "sqliteglobal.h"
|
#include "sqliteglobal.h"
|
||||||
|
|
||||||
#include <functional>
|
|
||||||
|
|
||||||
namespace Sqlite {
|
namespace Sqlite {
|
||||||
class DatabaseInterface
|
class DatabaseInterface
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
using UpdateCallback
|
|
||||||
= std::function<void(ChangeType type, char const *, char const *, long long)>;
|
|
||||||
|
|
||||||
virtual void walCheckpointFull() = 0;
|
virtual void walCheckpointFull() = 0;
|
||||||
virtual void execute(Utils::SmallStringView sqlStatement) = 0;
|
virtual void execute(Utils::SmallStringView sqlStatement) = 0;
|
||||||
virtual void setUpdateHook(UpdateCallback &callback) = 0;
|
virtual void setUpdateHook(
|
||||||
|
void *object,
|
||||||
|
void (*)(void *object, int, char const *database, char const *, long long rowId))
|
||||||
|
= 0;
|
||||||
virtual void resetUpdateHook() = 0;
|
virtual void resetUpdateHook() = 0;
|
||||||
virtual void applyAndUpdateSessions() = 0;
|
virtual void applyAndUpdateSessions() = 0;
|
||||||
virtual void setAttachedTables(const Utils::SmallStringVector &tables) = 0;
|
virtual void setAttachedTables(const Utils::SmallStringVector &tables) = 0;
|
||||||
|
|||||||
@@ -102,6 +102,8 @@ public:
|
|||||||
return QVariant(toFloat());
|
return QVariant(toFloat());
|
||||||
case ValueType::String:
|
case ValueType::String:
|
||||||
return QVariant(QString(toStringView()));
|
return QVariant(QString(toStringView()));
|
||||||
|
case ValueType::Null:
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
return {};
|
return {};
|
||||||
@@ -281,6 +283,8 @@ public:
|
|||||||
return first.toFloat() == second.toFloat();
|
return first.toFloat() == second.toFloat();
|
||||||
case ValueType::String:
|
case ValueType::String:
|
||||||
return first.toStringView() == second.toStringView();
|
return first.toStringView() == second.toStringView();
|
||||||
|
case ValueType::Null:
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
|
|||||||
@@ -36,6 +36,6 @@ add_qtc_plugin(ClangRefactoring
|
|||||||
symbol.h
|
symbol.h
|
||||||
symbolquery.h
|
symbolquery.h
|
||||||
symbolqueryinterface.h
|
symbolqueryinterface.h
|
||||||
symbolsfindfilter.cpp symbolsfindfilter.h
|
clangsymbolsfindfilter.cpp clangsymbolsfindfilter.h
|
||||||
symbolsfindfilterconfigwidget.cpp symbolsfindfilterconfigwidget.h
|
symbolsfindfilterconfigwidget.cpp symbolsfindfilterconfigwidget.h
|
||||||
)
|
)
|
||||||
|
|||||||
@@ -6,6 +6,7 @@ HEADERS += \
|
|||||||
$$PWD/clangqueryhighlighter.h \
|
$$PWD/clangqueryhighlighter.h \
|
||||||
$$PWD/clangqueryhighlightmarker.h \
|
$$PWD/clangqueryhighlightmarker.h \
|
||||||
$$PWD/clangqueryprojectsfindfilter.h \
|
$$PWD/clangqueryprojectsfindfilter.h \
|
||||||
|
$$PWD/clangsymbolsfindfilter.h \
|
||||||
$$PWD/projectpartutilities.h \
|
$$PWD/projectpartutilities.h \
|
||||||
$$PWD/refactoringclient.h \
|
$$PWD/refactoringclient.h \
|
||||||
$$PWD/refactoringconnectionclient.h \
|
$$PWD/refactoringconnectionclient.h \
|
||||||
@@ -13,7 +14,6 @@ HEADERS += \
|
|||||||
$$PWD/refactoringprojectupdater.h \
|
$$PWD/refactoringprojectupdater.h \
|
||||||
$$PWD/searchinterface.h \
|
$$PWD/searchinterface.h \
|
||||||
$$PWD/searchhandle.h \
|
$$PWD/searchhandle.h \
|
||||||
$$PWD/symbolsfindfilter.h \
|
|
||||||
$$PWD/symbolqueryinterface.h \
|
$$PWD/symbolqueryinterface.h \
|
||||||
$$PWD/symbol.h \
|
$$PWD/symbol.h \
|
||||||
$$PWD/projectpartproviderinterface.h \
|
$$PWD/projectpartproviderinterface.h \
|
||||||
@@ -24,11 +24,11 @@ SOURCES += \
|
|||||||
$$PWD/clangqueryexamplehighlighter.cpp \
|
$$PWD/clangqueryexamplehighlighter.cpp \
|
||||||
$$PWD/clangqueryhighlighter.cpp \
|
$$PWD/clangqueryhighlighter.cpp \
|
||||||
$$PWD/clangqueryprojectsfindfilter.cpp \
|
$$PWD/clangqueryprojectsfindfilter.cpp \
|
||||||
|
$$PWD/clangsymbolsfindfilter.cpp \
|
||||||
$$PWD/projectpartutilities.cpp \
|
$$PWD/projectpartutilities.cpp \
|
||||||
$$PWD/refactoringclient.cpp \
|
$$PWD/refactoringclient.cpp \
|
||||||
$$PWD/refactoringconnectionclient.cpp \
|
$$PWD/refactoringconnectionclient.cpp \
|
||||||
$$PWD/refactoringengine.cpp \
|
$$PWD/refactoringengine.cpp \
|
||||||
$$PWD/refactoringprojectupdater.cpp \
|
$$PWD/refactoringprojectupdater.cpp \
|
||||||
$$PWD/searchhandle.cpp \
|
$$PWD/searchhandle.cpp \
|
||||||
$$PWD/symbolsfindfilter.cpp \
|
|
||||||
$$PWD/locatorfilter.cpp
|
$$PWD/locatorfilter.cpp
|
||||||
|
|||||||
@@ -73,8 +73,8 @@ QtcPlugin {
|
|||||||
"symbol.h",
|
"symbol.h",
|
||||||
"symbolquery.h",
|
"symbolquery.h",
|
||||||
"symbolqueryinterface.h",
|
"symbolqueryinterface.h",
|
||||||
"symbolsfindfilter.cpp",
|
"clangsymbolsfindfilter.cpp",
|
||||||
"symbolsfindfilter.h",
|
"clangsymbolsfindfilter.h",
|
||||||
"symbolsfindfilterconfigwidget.cpp",
|
"symbolsfindfilterconfigwidget.cpp",
|
||||||
"symbolsfindfilterconfigwidget.h",
|
"symbolsfindfilterconfigwidget.h",
|
||||||
]
|
]
|
||||||
|
|||||||
@@ -23,7 +23,7 @@
|
|||||||
**
|
**
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#include "symbolsfindfilter.h"
|
#include "clangsymbolsfindfilter.h"
|
||||||
|
|
||||||
#include <cpptools/cpptoolsconstants.h>
|
#include <cpptools/cpptoolsconstants.h>
|
||||||
|
|
||||||
@@ -25,7 +25,7 @@
|
|||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include "symbolsfindfilter.h"
|
#include "clangsymbolsfindfilter.h"
|
||||||
|
|
||||||
namespace ClangRefactoring {
|
namespace ClangRefactoring {
|
||||||
|
|
||||||
|
|||||||
@@ -26,7 +26,7 @@
|
|||||||
|
|
||||||
#include "symbolsfindfilterconfigwidget.h"
|
#include "symbolsfindfilterconfigwidget.h"
|
||||||
|
|
||||||
#include "symbolsfindfilter.h"
|
#include "clangsymbolsfindfilter.h"
|
||||||
|
|
||||||
namespace ClangRefactoring {
|
namespace ClangRefactoring {
|
||||||
|
|
||||||
|
|||||||
@@ -56,6 +56,7 @@ const int flowBlockSize = 200;
|
|||||||
const int blockRadius = 18;
|
const int blockRadius = 18;
|
||||||
const int blockAdjust = 40;
|
const int blockAdjust = 40;
|
||||||
const int startItemOffset = 96;
|
const int startItemOffset = 96;
|
||||||
|
const int labelFontSize = 16;
|
||||||
|
|
||||||
void drawIcon(QPainter *painter,
|
void drawIcon(QPainter *painter,
|
||||||
int x,
|
int x,
|
||||||
@@ -670,6 +671,7 @@ void FormEditorFlowActionItem::paint(QPainter *painter, const QStyleOptionGraphi
|
|||||||
if (qmlItemNode().modelNode().hasAuxiliaryData("color"))
|
if (qmlItemNode().modelNode().hasAuxiliaryData("color"))
|
||||||
flowColor = qmlItemNode().modelNode().auxiliaryData("color").value<QColor>();
|
flowColor = qmlItemNode().modelNode().auxiliaryData("color").value<QColor>();
|
||||||
|
|
||||||
|
const qreal scaleFactor = viewportTransform().m11();
|
||||||
qreal width = 2;
|
qreal width = 2;
|
||||||
|
|
||||||
if (qmlItemNode().modelNode().hasAuxiliaryData("width"))
|
if (qmlItemNode().modelNode().hasAuxiliaryData("width"))
|
||||||
@@ -787,26 +789,28 @@ public:
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// Only assign area node if there is exactly one from (QmlFlowItemNode)
|
|
||||||
if (from.size() == 1) {
|
// Only assign area node if there is exactly one from (QmlFlowItemNode)
|
||||||
const QmlItemNode tmp = from.back();
|
if (from.size() == 1) {
|
||||||
const QmlFlowItemNode f(tmp.modelNode());
|
const QmlItemNode tmp = from.back();
|
||||||
if (f.isValid()) {
|
const QmlFlowItemNode f(tmp.modelNode());
|
||||||
for (const QmlFlowActionAreaNode &area : f.flowActionAreas()) {
|
|
||||||
ModelNode target = area.targetTransition();
|
if (f.isValid()) {
|
||||||
if (target == node.modelNode()) {
|
for (const QmlFlowActionAreaNode &area : f.flowActionAreas()) {
|
||||||
areaNode = area;
|
ModelNode target = area.targetTransition();
|
||||||
} else {
|
if (target == node.modelNode()) {
|
||||||
const ModelNode decisionNode = area.decisionNodeForTransition(node.modelNode());
|
areaNode = area;
|
||||||
if (decisionNode.isValid()) {
|
} else {
|
||||||
from.clear();
|
const ModelNode decisionNode = area.decisionNodeForTransition(node.modelNode());
|
||||||
from.append(decisionNode);
|
if (decisionNode.isValid()) {
|
||||||
areaNode = ModelNode();
|
from.clear();
|
||||||
|
from.append(decisionNode);
|
||||||
|
areaNode = ModelNode();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
if (f.modelNode().hasAuxiliaryData("joinConnection"))
|
||||||
if (f.modelNode().hasAuxiliaryData("joinConnection"))
|
joinConnection = f.modelNode().auxiliaryData("joinConnection").toBool();
|
||||||
joinConnection = f.modelNode().auxiliaryData("joinConnection").toBool();
|
|
||||||
} else {
|
} else {
|
||||||
if (f == node.rootModelNode())
|
if (f == node.rootModelNode())
|
||||||
isStartLine = true;
|
isStartLine = true;
|
||||||
@@ -852,7 +856,7 @@ public:
|
|||||||
, bezier(50)
|
, bezier(50)
|
||||||
, type(ConnectionType::Default)
|
, type(ConnectionType::Default)
|
||||||
, label()
|
, label()
|
||||||
, fontSize(16 / scaleFactor)
|
, fontSize(labelFontSize / scaleFactor)
|
||||||
, labelOffset(14 / scaleFactor)
|
, labelOffset(14 / scaleFactor)
|
||||||
, labelPosition(50.0)
|
, labelPosition(50.0)
|
||||||
, labelFlags(Qt::AlignHCenter | Qt::AlignVCenter | Qt::TextDontClip)
|
, labelFlags(Qt::AlignHCenter | Qt::AlignVCenter | Qt::TextDontClip)
|
||||||
@@ -1159,10 +1163,29 @@ public:
|
|||||||
const ConnectionConfiguration &connectionConfig)
|
const ConnectionConfiguration &connectionConfig)
|
||||||
: config(connectionConfig)
|
: config(connectionConfig)
|
||||||
{
|
{
|
||||||
if (from.isFlowDecision() || from.isFlowWildcard() || from.isFlowView())
|
if (from.isFlowDecision()) {
|
||||||
|
int size = flowBlockSize;
|
||||||
|
if (from.modelNode().hasAuxiliaryData("blockSize"))
|
||||||
|
size = from.modelNode().auxiliaryData("blockSize").toInt();
|
||||||
|
|
||||||
|
fromRect = QRectF(0, 0, size, size);
|
||||||
|
|
||||||
|
QTransform transform;
|
||||||
|
transform.translate(fromRect.center().x(), fromRect.center().y());
|
||||||
|
transform.rotate(45);
|
||||||
|
transform.translate(-fromRect.center().x(), -fromRect.center().y());
|
||||||
|
|
||||||
|
fromRect = transform.mapRect(fromRect);
|
||||||
|
} else if (from.isFlowWildcard()) {
|
||||||
|
int size = flowBlockSize;
|
||||||
|
if (from.modelNode().hasAuxiliaryData("blockSize"))
|
||||||
|
size = from.modelNode().auxiliaryData("blockSize").toInt();
|
||||||
|
fromRect = QRectF(0, 0, size, size);
|
||||||
|
} else if (from.isFlowView()) {
|
||||||
fromRect = QRectF(0, 0, flowBlockSize, flowBlockSize);
|
fromRect = QRectF(0, 0, flowBlockSize, flowBlockSize);
|
||||||
else
|
} else {
|
||||||
fromRect = from.instanceBoundingRect();
|
fromRect = from.instanceBoundingRect();
|
||||||
|
}
|
||||||
|
|
||||||
fromRect.translate(from.flowPosition());
|
fromRect.translate(from.flowPosition());
|
||||||
|
|
||||||
@@ -1172,15 +1195,27 @@ public:
|
|||||||
fromRect.translate(resolveConnection.areaNode.instancePosition());
|
fromRect.translate(resolveConnection.areaNode.instancePosition());
|
||||||
}
|
}
|
||||||
|
|
||||||
if (to.isFlowDecision())
|
if (to.isFlowDecision()) {
|
||||||
toRect = QRectF(0, 0, flowBlockSize,flowBlockSize);
|
int size = flowBlockSize;
|
||||||
else
|
if (to.modelNode().hasAuxiliaryData("blockSize"))
|
||||||
|
size = to.modelNode().auxiliaryData("blockSize").toInt();
|
||||||
|
|
||||||
|
toRect = QRectF(0, 0, size, size);
|
||||||
|
|
||||||
|
QTransform transform;
|
||||||
|
transform.translate(toRect.center().x(), toRect.center().y());
|
||||||
|
transform.rotate(45);
|
||||||
|
transform.translate(-toRect.center().x(), -toRect.center().y());
|
||||||
|
|
||||||
|
toRect = transform.mapRect(toRect);
|
||||||
|
} else {
|
||||||
toRect = to.instanceBoundingRect();
|
toRect = to.instanceBoundingRect();
|
||||||
|
}
|
||||||
|
|
||||||
toRect.translate(to.flowPosition());
|
toRect.translate(to.flowPosition());
|
||||||
|
|
||||||
if (resolveConnection.isStartLine) {
|
if (resolveConnection.isStartLine) {
|
||||||
fromRect = QRectF(0, 0, 96, 96);
|
fromRect = QRectF(0, 0, 96, 96); // TODO Use const startItemOffset
|
||||||
fromRect.translate(to.flowPosition() + QPoint(-180, toRect.height() / 2 - 96 / 2));
|
fromRect.translate(to.flowPosition() + QPoint(-180, toRect.height() / 2 - 96 / 2));
|
||||||
fromRect.translate(0, config.outOffset);
|
fromRect.translate(0, config.outOffset);
|
||||||
}
|
}
|
||||||
@@ -1623,7 +1658,76 @@ QTransform FormEditorItem::viewportTransform() const
|
|||||||
void FormEditorFlowDecisionItem::updateGeometry()
|
void FormEditorFlowDecisionItem::updateGeometry()
|
||||||
{
|
{
|
||||||
prepareGeometryChange();
|
prepareGeometryChange();
|
||||||
m_selectionBoundingRect = QRectF(0, 0, flowBlockSize, flowBlockSize);
|
|
||||||
|
int size = flowBlockSize;
|
||||||
|
if (qmlItemNode().modelNode().hasAuxiliaryData("blockSize"))
|
||||||
|
size = qmlItemNode().modelNode().auxiliaryData("blockSize").toInt();
|
||||||
|
|
||||||
|
QRectF boundingRect(0, 0, size, size);
|
||||||
|
QTransform transform;
|
||||||
|
if (qmlItemNode().isFlowDecision()) {
|
||||||
|
transform.translate(boundingRect.center().x(), boundingRect.center().y());
|
||||||
|
transform.rotate(45);
|
||||||
|
transform.translate(-boundingRect.center().x(), -boundingRect.center().y());
|
||||||
|
|
||||||
|
// If drawing the dialog title is requested we need to add it to the bounding rect.
|
||||||
|
QRectF labelBoundingRect;
|
||||||
|
int showDialogLabel = false;
|
||||||
|
if (qmlItemNode().modelNode().hasAuxiliaryData("showDialogLabel"))
|
||||||
|
showDialogLabel = qmlItemNode().modelNode().auxiliaryData("showDialogLabel").toBool();
|
||||||
|
|
||||||
|
if (showDialogLabel) {
|
||||||
|
QString dialogTitle;
|
||||||
|
if (qmlItemNode().modelNode().hasVariantProperty("dialogTitle"))
|
||||||
|
dialogTitle = qmlItemNode().modelNode().variantProperty("dialogTitle").value().toString();
|
||||||
|
|
||||||
|
if (!dialogTitle.isEmpty()) {
|
||||||
|
// Local painter is used to get the labels bounding rect by using drawText()
|
||||||
|
QPixmap pixmap(640, 480);
|
||||||
|
QPainter localPainter(&pixmap);
|
||||||
|
QFont font = localPainter.font();
|
||||||
|
font.setPixelSize(labelFontSize / viewportTransform().m11());
|
||||||
|
localPainter.setFont(font);
|
||||||
|
|
||||||
|
int margin = blockAdjust * 0.5;
|
||||||
|
const QRectF adjustedRect = boundingRect.adjusted(margin, margin, -margin, -margin);
|
||||||
|
|
||||||
|
QRectF textRect(0, 0, 100, 20);
|
||||||
|
|
||||||
|
Qt::Corner corner = Qt::TopRightCorner;
|
||||||
|
if (qmlItemNode().modelNode().hasAuxiliaryData("dialogLabelPosition"))
|
||||||
|
corner = qmlItemNode().modelNode().auxiliaryData("dialogLabelPosition").value<Qt::Corner>();
|
||||||
|
|
||||||
|
int flag = 0;
|
||||||
|
switch (corner) {
|
||||||
|
case Qt::TopLeftCorner:
|
||||||
|
flag = Qt::AlignRight;
|
||||||
|
textRect.moveBottomRight(adjustedRect.topLeft());
|
||||||
|
break;
|
||||||
|
case Qt::TopRightCorner:
|
||||||
|
flag = Qt::AlignLeft;
|
||||||
|
textRect.moveBottomLeft(adjustedRect.topRight());
|
||||||
|
break;
|
||||||
|
case Qt::BottomLeftCorner:
|
||||||
|
flag = Qt::AlignRight;
|
||||||
|
textRect.moveTopRight(adjustedRect.bottomLeft());
|
||||||
|
break;
|
||||||
|
case Qt::BottomRightCorner:
|
||||||
|
flag = Qt::AlignLeft;
|
||||||
|
textRect.moveTopLeft(adjustedRect.bottomRight());
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
localPainter.drawText(textRect, flag | Qt::TextDontClip, dialogTitle, &labelBoundingRect);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Unite the rotate item bounding rect with the label bounding rect.
|
||||||
|
boundingRect = transform.mapRect(boundingRect);
|
||||||
|
boundingRect = boundingRect.united(labelBoundingRect);
|
||||||
|
}
|
||||||
|
|
||||||
|
m_selectionBoundingRect = boundingRect;
|
||||||
m_paintedBoundingRect = m_selectionBoundingRect;
|
m_paintedBoundingRect = m_selectionBoundingRect;
|
||||||
m_boundingRect = m_paintedBoundingRect;
|
m_boundingRect = m_paintedBoundingRect;
|
||||||
setTransform(qmlItemNode().instanceTransformWithContentTransform());
|
setTransform(qmlItemNode().instanceTransformWithContentTransform());
|
||||||
@@ -1665,6 +1769,7 @@ void FormEditorFlowDecisionItem::paint(QPainter *painter, const QStyleOptionGrap
|
|||||||
if (qmlItemNode().modelNode().hasAuxiliaryData("color"))
|
if (qmlItemNode().modelNode().hasAuxiliaryData("color"))
|
||||||
flowColor = qmlItemNode().modelNode().auxiliaryData("color").value<QColor>();
|
flowColor = qmlItemNode().modelNode().auxiliaryData("color").value<QColor>();
|
||||||
|
|
||||||
|
const qreal scaleFactor = viewportTransform().m11();
|
||||||
qreal width = 2;
|
qreal width = 2;
|
||||||
|
|
||||||
if (qmlItemNode().modelNode().hasAuxiliaryData("width"))
|
if (qmlItemNode().modelNode().hasAuxiliaryData("width"))
|
||||||
@@ -1692,30 +1797,84 @@ void FormEditorFlowDecisionItem::paint(QPainter *painter, const QStyleOptionGrap
|
|||||||
|
|
||||||
painter->save();
|
painter->save();
|
||||||
|
|
||||||
if (m_iconType == DecisionIcon) {
|
|
||||||
painter->translate(boundingRect().center());
|
|
||||||
painter->rotate(45);
|
|
||||||
painter->translate(-boundingRect().center());
|
|
||||||
}
|
|
||||||
|
|
||||||
if (fillColor.alpha() > 0)
|
if (fillColor.alpha() > 0)
|
||||||
painter->setBrush(fillColor);
|
painter->setBrush(fillColor);
|
||||||
|
|
||||||
int radius = blockRadius;
|
int radius = blockRadius;
|
||||||
|
if (qmlItemNode().modelNode().hasAuxiliaryData("blockRadius"))
|
||||||
|
radius = qmlItemNode().modelNode().auxiliaryData("blockRadius").toInt();
|
||||||
|
|
||||||
const QRectF adjustedRect = boundingRect().adjusted(blockAdjust,
|
int size = flowBlockSize;
|
||||||
blockAdjust,
|
if (qmlItemNode().modelNode().hasAuxiliaryData("blockSize"))
|
||||||
-blockAdjust,
|
size = qmlItemNode().modelNode().auxiliaryData("blockSize").toInt();
|
||||||
-blockAdjust);
|
|
||||||
|
|
||||||
|
QRectF boundingRect(0, 0, size, size);
|
||||||
|
QTransform transform;
|
||||||
|
int margin = blockAdjust;
|
||||||
|
if (m_iconType == DecisionIcon) {
|
||||||
|
transform.translate(boundingRect.center().x(), boundingRect.center().y());
|
||||||
|
transform.rotate(45);
|
||||||
|
transform.translate(-boundingRect.center().x(), -boundingRect.center().y());
|
||||||
|
margin *= 0.5;
|
||||||
|
}
|
||||||
|
|
||||||
|
const QRectF adjustedRect = boundingRect.adjusted(margin, margin, -margin, -margin);
|
||||||
|
|
||||||
|
painter->setTransform(transform, true);
|
||||||
painter->drawRoundedRect(adjustedRect, radius, radius);
|
painter->drawRoundedRect(adjustedRect, radius, radius);
|
||||||
|
|
||||||
const int iconDecrement = 32;
|
const int iconDecrement = 32;
|
||||||
const int iconSize = adjustedRect.width() - iconDecrement;
|
const int iconSize = adjustedRect.width() - iconDecrement;
|
||||||
const int offset = iconDecrement / 2 + blockAdjust;
|
const int offset = iconDecrement / 2 + margin;
|
||||||
|
|
||||||
painter->restore();
|
painter->restore();
|
||||||
|
|
||||||
|
// Draw the dialog title inside the form view if requested. Decision item only.
|
||||||
|
int showDialogLabel = false;
|
||||||
|
if (qmlItemNode().modelNode().hasAuxiliaryData("showDialogLabel"))
|
||||||
|
showDialogLabel = qmlItemNode().modelNode().auxiliaryData("showDialogLabel").toBool();
|
||||||
|
|
||||||
|
if (showDialogLabel) {
|
||||||
|
QString dialogTitle;
|
||||||
|
if (qmlItemNode().modelNode().hasVariantProperty("dialogTitle"))
|
||||||
|
dialogTitle = qmlItemNode().modelNode().variantProperty("dialogTitle").value().toString();
|
||||||
|
|
||||||
|
if (!dialogTitle.isEmpty()) {
|
||||||
|
|
||||||
|
QFont font = painter->font();
|
||||||
|
font.setPixelSize(labelFontSize / scaleFactor);
|
||||||
|
painter->setFont(font);
|
||||||
|
|
||||||
|
QRectF textRect(0, 0, 100, 20);
|
||||||
|
|
||||||
|
Qt::Corner corner = Qt::TopRightCorner;
|
||||||
|
if (qmlItemNode().modelNode().hasAuxiliaryData("dialogLabelPosition"))
|
||||||
|
corner = qmlItemNode().modelNode().auxiliaryData("dialogLabelPosition").value<Qt::Corner>();
|
||||||
|
|
||||||
|
int flag = 0;
|
||||||
|
switch (corner) {
|
||||||
|
case Qt::TopLeftCorner:
|
||||||
|
flag = Qt::AlignRight;
|
||||||
|
textRect.moveBottomRight(adjustedRect.topLeft());
|
||||||
|
break;
|
||||||
|
case Qt::TopRightCorner:
|
||||||
|
flag = Qt::AlignLeft;
|
||||||
|
textRect.moveBottomLeft(adjustedRect.topRight());
|
||||||
|
break;
|
||||||
|
case Qt::BottomLeftCorner:
|
||||||
|
flag = Qt::AlignRight;
|
||||||
|
textRect.moveTopRight(adjustedRect.bottomLeft());
|
||||||
|
break;
|
||||||
|
case Qt::BottomRightCorner:
|
||||||
|
flag = Qt::AlignLeft;
|
||||||
|
textRect.moveTopLeft(adjustedRect.bottomRight());
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
painter->drawText(textRect, flag | Qt::TextDontClip, dialogTitle);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
const QString icon = (m_iconType ==
|
const QString icon = (m_iconType ==
|
||||||
WildcardIcon) ? Theme::getIconUnicode(Theme::wildcard)
|
WildcardIcon) ? Theme::getIconUnicode(Theme::wildcard)
|
||||||
: Theme::getIconUnicode(Theme::decisionNode);
|
: Theme::getIconUnicode(Theme::decisionNode);
|
||||||
|
|||||||
@@ -392,9 +392,9 @@ void FormEditorView::variantPropertiesChanged(const QList<VariantProperty> &prop
|
|||||||
Q_UNUSED(propertyChange)
|
Q_UNUSED(propertyChange)
|
||||||
for (const VariantProperty &property : propertyList) {
|
for (const VariantProperty &property : propertyList) {
|
||||||
QmlVisualNode node(property.parentModelNode());
|
QmlVisualNode node(property.parentModelNode());
|
||||||
if (node.isFlowTransition()) {
|
if (node.isFlowTransition() || node.isFlowDecision()) {
|
||||||
if (FormEditorItem *item = m_scene->itemForQmlItemNode(node.toQmlItemNode())) {
|
if (FormEditorItem *item = m_scene->itemForQmlItemNode(node.toQmlItemNode())) {
|
||||||
if (property.name() == "question")
|
if (property.name() == "question" || property.name() == "dialogTitle")
|
||||||
item->updateGeometry();
|
item->updateGeometry();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -572,7 +572,8 @@ void FormEditorView::auxiliaryDataChanged(const ModelNode &node, const PropertyN
|
|||||||
// Update the geomtry if one of the following auxiliary properties has changed
|
// Update the geomtry if one of the following auxiliary properties has changed
|
||||||
static const QStringList updateGeometryPropertyNames = {
|
static const QStringList updateGeometryPropertyNames = {
|
||||||
"breakPoint", "bezier", "transitionBezier", "type", "tranitionType", "radius",
|
"breakPoint", "bezier", "transitionBezier", "type", "tranitionType", "radius",
|
||||||
"transitionRadius", "labelPosition", "labelFlipSide", "inOffset", "outOffset"
|
"transitionRadius", "labelPosition", "labelFlipSide", "inOffset", "outOffset",
|
||||||
|
"blockSize", "blockRadius", "showDialogLabel", "dialogLabelPosition"
|
||||||
};
|
};
|
||||||
if (updateGeometryPropertyNames.contains(QString::fromUtf8(name)))
|
if (updateGeometryPropertyNames.contains(QString::fromUtf8(name)))
|
||||||
editorItem->updateGeometry();
|
editorItem->updateGeometry();
|
||||||
|
|||||||
@@ -188,6 +188,14 @@ QVariant properDefaultAuxiliaryProperties(const QmlObjectNode &qmlObjectNode,
|
|||||||
return QString();
|
return QString();
|
||||||
else if (propertyName == "joinConnection")
|
else if (propertyName == "joinConnection")
|
||||||
return false;
|
return false;
|
||||||
|
else if (propertyName == "blockSize")
|
||||||
|
return 200;
|
||||||
|
else if (propertyName == "blockRadius")
|
||||||
|
return 18;
|
||||||
|
else if (propertyName == "showDialogLabel")
|
||||||
|
return false;
|
||||||
|
else if (propertyName == "dialogLabelPosition")
|
||||||
|
return Qt::TopRightCorner;
|
||||||
|
|
||||||
return {};
|
return {};
|
||||||
}
|
}
|
||||||
@@ -259,9 +267,9 @@ void PropertyEditorQmlBackend::setupAuxiliaryProperties(const QmlObjectNode &qml
|
|||||||
} else if (itemNode.isFlowActionArea()) {
|
} else if (itemNode.isFlowActionArea()) {
|
||||||
propertyNames.append({"color", "width", "fillColor", "outOffset", "dash"});
|
propertyNames.append({"color", "width", "fillColor", "outOffset", "dash"});
|
||||||
} else if (itemNode.isFlowDecision()) {
|
} else if (itemNode.isFlowDecision()) {
|
||||||
propertyNames.append({"color", "width", "fillColor", "dash"});
|
propertyNames.append({"color", "width", "fillColor", "dash", "blockSize", "blockRadius", "showDialogLabel", "dialogLabelPosition"});
|
||||||
} else if (itemNode.isFlowWildcard()) {
|
} else if (itemNode.isFlowWildcard()) {
|
||||||
propertyNames.append({"color", "width", "fillColor", "dash"});
|
propertyNames.append({"color", "width", "fillColor", "dash", "blockSize", "blockRadius"});
|
||||||
} else if (itemNode.isFlowView()) {
|
} else if (itemNode.isFlowView()) {
|
||||||
propertyNames.append({"transitionColor", "areaColor", "areaFillColor", "blockColor", "transitionType", "transitionRadius", "transitionBezier"});
|
propertyNames.append({"transitionColor", "areaColor", "areaFillColor", "blockColor", "transitionType", "transitionRadius", "transitionBezier"});
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -62,6 +62,7 @@ add_qtc_test(unittest GTEST
|
|||||||
gtest-creator-printing.cpp gtest-creator-printing.h
|
gtest-creator-printing.cpp gtest-creator-printing.h
|
||||||
gtest-llvm-printing.h
|
gtest-llvm-printing.h
|
||||||
gtest-qt-printing.cpp gtest-qt-printing.h
|
gtest-qt-printing.cpp gtest-qt-printing.h
|
||||||
|
gtest-std-printing.h
|
||||||
headerpathfilter-test.cpp
|
headerpathfilter-test.cpp
|
||||||
highlightingresultreporter-test.cpp
|
highlightingresultreporter-test.cpp
|
||||||
lineprefixer-test.cpp
|
lineprefixer-test.cpp
|
||||||
@@ -390,7 +391,7 @@ extend_qtc_test(unittest
|
|||||||
refactoringprojectupdater.cpp refactoringprojectupdater.h
|
refactoringprojectupdater.cpp refactoringprojectupdater.h
|
||||||
searchinterface.h
|
searchinterface.h
|
||||||
searchhandle.cpp searchhandle.h
|
searchhandle.cpp searchhandle.h
|
||||||
symbolsfindfilter.cpp symbolsfindfilter.h
|
clangsymbolsfindfilter.cpp clangsymbolsfindfilter.h
|
||||||
symbolqueryinterface.h
|
symbolqueryinterface.h
|
||||||
symbol.h
|
symbol.h
|
||||||
projectpartproviderinterface.h
|
projectpartproviderinterface.h
|
||||||
|
|||||||
@@ -16,7 +16,7 @@ include($$PWD/../../../src/plugins/clangpchmanager/clangpchmanager-source.pri)
|
|||||||
include($$PWD/../../../src/plugins/cpptools/cpptoolsunittestfiles.pri)
|
include($$PWD/../../../src/plugins/cpptools/cpptoolsunittestfiles.pri)
|
||||||
include($$PWD/../../../src/plugins/debugger/debuggerunittestfiles.pri)
|
include($$PWD/../../../src/plugins/debugger/debuggerunittestfiles.pri)
|
||||||
include($$PWD/../../../src/plugins/compilationdatabaseprojectmanager/compilationdatabaseunittestfiles.pri)
|
include($$PWD/../../../src/plugins/compilationdatabaseprojectmanager/compilationdatabaseunittestfiles.pri)
|
||||||
include(cplusplus.pri)
|
!isEmpty(QTC_UNITTEST_BUILD_CPP_PARSER):include(cplusplus.pri)
|
||||||
!isEmpty(LLVM_VERSION) {
|
!isEmpty(LLVM_VERSION) {
|
||||||
include($$PWD/../../../src/plugins/clangtools/clangtoolsunittestfiles.pri)
|
include($$PWD/../../../src/plugins/clangtools/clangtoolsunittestfiles.pri)
|
||||||
include($$PWD/../../../src/shared/clang/clang_defines.pri)
|
include($$PWD/../../../src/shared/clang/clang_defines.pri)
|
||||||
|
|||||||
@@ -38,9 +38,10 @@
|
|||||||
#include "compare-operators.h"
|
#include "compare-operators.h"
|
||||||
|
|
||||||
#include "conditionally-disabled-tests.h"
|
#include "conditionally-disabled-tests.h"
|
||||||
#include "gtest-qt-printing.h"
|
|
||||||
#include "gtest-creator-printing.h"
|
#include "gtest-creator-printing.h"
|
||||||
#include "gtest-llvm-printing.h"
|
#include "gtest-llvm-printing.h"
|
||||||
|
#include "gtest-qt-printing.h"
|
||||||
|
#include "gtest-std-printing.h"
|
||||||
#ifdef CLANG_UNIT_TESTS
|
#ifdef CLANG_UNIT_TESTS
|
||||||
# include "gtest-clang-printing.h"
|
# include "gtest-clang-printing.h"
|
||||||
#endif
|
#endif
|
||||||
|
|||||||
@@ -24,6 +24,7 @@
|
|||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#include "gtest-creator-printing.h"
|
#include "gtest-creator-printing.h"
|
||||||
|
#include "gtest-std-printing.h"
|
||||||
|
|
||||||
#ifdef CLANG_UNIT_TESTS
|
#ifdef CLANG_UNIT_TESTS
|
||||||
#include <clang/Basic/SourceLocation.h>
|
#include <clang/Basic/SourceLocation.h>
|
||||||
|
|||||||
@@ -24,6 +24,7 @@
|
|||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#include "gtest-creator-printing.h"
|
#include "gtest-creator-printing.h"
|
||||||
|
#include "gtest-std-printing.h"
|
||||||
|
|
||||||
#include "gtest-qt-printing.h"
|
#include "gtest-qt-printing.h"
|
||||||
|
|
||||||
@@ -320,6 +321,9 @@ std::ostream &operator<<(std::ostream &out, const Value &value)
|
|||||||
case Sqlite::ValueType::String:
|
case Sqlite::ValueType::String:
|
||||||
out << "\"" << value.toStringView() << "\"";
|
out << "\"" << value.toStringView() << "\"";
|
||||||
break;
|
break;
|
||||||
|
case Sqlite::ValueType::Null:
|
||||||
|
out << "null";
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
return out << ")";
|
return out << ")";
|
||||||
|
|||||||
@@ -350,24 +350,4 @@ std::ostream &operator<<(std::ostream &out, const Diagnostic &diag);
|
|||||||
} // namespace Internal
|
} // namespace Internal
|
||||||
} // namespace CppTools
|
} // namespace CppTools
|
||||||
|
|
||||||
namespace std {
|
|
||||||
template<typename T>
|
|
||||||
ostream &operator<<(ostream &out, const vector<T> &vector)
|
|
||||||
{
|
|
||||||
out << "[";
|
|
||||||
|
|
||||||
for (auto current = vector.begin(); current != vector.end(); ++current) {
|
|
||||||
out << *current;
|
|
||||||
|
|
||||||
if (std::next(current) != vector.end())
|
|
||||||
out << ", ";
|
|
||||||
}
|
|
||||||
|
|
||||||
out << "]";
|
|
||||||
|
|
||||||
return out;
|
|
||||||
}
|
|
||||||
|
|
||||||
} // namespace std
|
|
||||||
|
|
||||||
void setFilePathCache(ClangBackEnd::FilePathCaching *filePathCache);
|
void setFilePathCache(ClangBackEnd::FilePathCaching *filePathCache);
|
||||||
|
|||||||
@@ -23,7 +23,8 @@
|
|||||||
**
|
**
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#include "gtest-creator-printing.h"
|
#include "gtest-llvm-printing.h"
|
||||||
|
#include "gtest-std-printing.h"
|
||||||
|
|
||||||
#include <gtest/gtest-printers.h>
|
#include <gtest/gtest-printers.h>
|
||||||
|
|
||||||
|
|||||||
41
tests/unit/unittest/gtest-std-printing.h
Normal file
41
tests/unit/unittest/gtest-std-printing.h
Normal file
@@ -0,0 +1,41 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
**
|
||||||
|
** Copyright (C) 2020 The Qt Company Ltd.
|
||||||
|
** Contact: https://www.qt.io/licensing/
|
||||||
|
**
|
||||||
|
** This file is part of Qt Creator.
|
||||||
|
**
|
||||||
|
** Commercial License Usage
|
||||||
|
** Licensees holding valid commercial Qt licenses may use this file in
|
||||||
|
** accordance with the commercial license agreement provided with the
|
||||||
|
** Software or, alternatively, in accordance with the terms contained in
|
||||||
|
** a written agreement between you and The Qt Company. For licensing terms
|
||||||
|
** and conditions see https://www.qt.io/terms-conditions. For further
|
||||||
|
** information use the contact form at https://www.qt.io/contact-us.
|
||||||
|
**
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include <ostream>
|
||||||
|
#include <vector>
|
||||||
|
|
||||||
|
namespace std {
|
||||||
|
template<typename T>
|
||||||
|
ostream &operator<<(ostream &out, const vector<T> &vector)
|
||||||
|
{
|
||||||
|
out << "[";
|
||||||
|
|
||||||
|
for (auto current = vector.begin(); current != vector.end(); ++current) {
|
||||||
|
out << *current;
|
||||||
|
|
||||||
|
if (std::next(current) != vector.end())
|
||||||
|
out << ", ";
|
||||||
|
}
|
||||||
|
|
||||||
|
out << "]";
|
||||||
|
|
||||||
|
return out;
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace std
|
||||||
@@ -35,14 +35,14 @@ class LastChangedRowId : public testing::Test
|
|||||||
{
|
{
|
||||||
protected:
|
protected:
|
||||||
NiceMock<MockSqliteDatabase> mockSqliteDatabase;
|
NiceMock<MockSqliteDatabase> mockSqliteDatabase;
|
||||||
Sqlite::LastChangedRowId lastRowId{mockSqliteDatabase, "main", "foo"};
|
Sqlite::LastChangedRowId<1> lastRowId{mockSqliteDatabase, "main", "foo"};
|
||||||
};
|
};
|
||||||
|
|
||||||
TEST_F(LastChangedRowId, SetUpdateHookInContructor)
|
TEST_F(LastChangedRowId, SetUpdateHookInContructor)
|
||||||
{
|
{
|
||||||
EXPECT_CALL(mockSqliteDatabase, setUpdateHook(_));
|
EXPECT_CALL(mockSqliteDatabase, setUpdateHook(_, _));
|
||||||
|
|
||||||
Sqlite::LastChangedRowId lastRowId{mockSqliteDatabase, "main", "foo"};
|
Sqlite::LastChangedRowId<1> lastRowId{mockSqliteDatabase, "main", "foo"};
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(LastChangedRowId, ResetUpdateHookInDestructor)
|
TEST_F(LastChangedRowId, ResetUpdateHookInDestructor)
|
||||||
@@ -57,42 +57,42 @@ TEST_F(LastChangedRowId, GetMinusOneAsRowIdIfNoCallbackWasCalled)
|
|||||||
|
|
||||||
TEST_F(LastChangedRowId, CallbackSetsLastRowId)
|
TEST_F(LastChangedRowId, CallbackSetsLastRowId)
|
||||||
{
|
{
|
||||||
lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 42);
|
lastRowId("main", "foo", 42);
|
||||||
|
|
||||||
ASSERT_THAT(lastRowId.lastRowId, 42);
|
ASSERT_THAT(lastRowId.lastRowId, 42);
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(LastChangedRowId, CallbackChecksDatabaseName)
|
TEST_F(LastChangedRowId, CallbackChecksDatabaseName)
|
||||||
{
|
{
|
||||||
lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 33);
|
lastRowId("main", "foo", 33);
|
||||||
|
|
||||||
lastRowId.callback(Sqlite::ChangeType::Update, "temp", "foo", 42);
|
lastRowId("temp", "foo", 42);
|
||||||
|
|
||||||
ASSERT_THAT(lastRowId.lastRowId, 33);
|
ASSERT_THAT(lastRowId.lastRowId, 33);
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(LastChangedRowId, CallbackChecksTableName)
|
TEST_F(LastChangedRowId, CallbackChecksTableName)
|
||||||
{
|
{
|
||||||
lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 33);
|
lastRowId("main", "foo", 33);
|
||||||
|
|
||||||
lastRowId.callback(Sqlite::ChangeType::Update, "main", "bar", 42);
|
lastRowId("main", "bar", 42);
|
||||||
|
|
||||||
ASSERT_THAT(lastRowId.lastRowId, 33);
|
ASSERT_THAT(lastRowId.lastRowId, 33);
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(LastChangedRowId, LastCallSetsRowId)
|
TEST_F(LastChangedRowId, LastCallSetsRowId)
|
||||||
{
|
{
|
||||||
lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 42);
|
lastRowId("main", "foo", 42);
|
||||||
lastRowId.callback(Sqlite::ChangeType::Insert, "main", "foo", 33);
|
lastRowId("main", "foo", 33);
|
||||||
|
|
||||||
lastRowId.callback(Sqlite::ChangeType::Delete, "main", "foo", 66);
|
lastRowId("main", "foo", 66);
|
||||||
|
|
||||||
ASSERT_THAT(lastRowId.lastRowId, 66);
|
ASSERT_THAT(lastRowId.lastRowId, 66);
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(LastChangedRowId, TakeLastRowId)
|
TEST_F(LastChangedRowId, TakeLastRowId)
|
||||||
{
|
{
|
||||||
lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 42);
|
lastRowId("main", "foo", 42);
|
||||||
|
|
||||||
auto id = lastRowId.takeLastRowId();
|
auto id = lastRowId.takeLastRowId();
|
||||||
|
|
||||||
@@ -101,7 +101,7 @@ TEST_F(LastChangedRowId, TakeLastRowId)
|
|||||||
|
|
||||||
TEST_F(LastChangedRowId, TakeLastRowIdResetsRowIdToMinusOne)
|
TEST_F(LastChangedRowId, TakeLastRowIdResetsRowIdToMinusOne)
|
||||||
{
|
{
|
||||||
lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 42);
|
lastRowId("main", "foo", 42);
|
||||||
lastRowId.takeLastRowId();
|
lastRowId.takeLastRowId();
|
||||||
|
|
||||||
auto id = lastRowId.takeLastRowId();
|
auto id = lastRowId.takeLastRowId();
|
||||||
@@ -114,14 +114,14 @@ class LastChangedRowIdWithTwoTables : public testing::Test
|
|||||||
protected:
|
protected:
|
||||||
NiceMock<MockSqliteDatabase> mockSqliteDatabase;
|
NiceMock<MockSqliteDatabase> mockSqliteDatabase;
|
||||||
|
|
||||||
Sqlite::LastChangedRowId lastRowId{mockSqliteDatabase, "main", "foo", "bar"};
|
Sqlite::LastChangedRowId<2> lastRowId{mockSqliteDatabase, "main", "foo", "bar"};
|
||||||
};
|
};
|
||||||
|
|
||||||
TEST_F(LastChangedRowIdWithTwoTables, SetUpdateHookInContructor)
|
TEST_F(LastChangedRowIdWithTwoTables, SetUpdateHookInContructor)
|
||||||
{
|
{
|
||||||
EXPECT_CALL(mockSqliteDatabase, setUpdateHook(_));
|
EXPECT_CALL(mockSqliteDatabase, setUpdateHook(_, _));
|
||||||
|
|
||||||
Sqlite::LastChangedRowId lastRowId{mockSqliteDatabase, "main", "foo"};
|
Sqlite::LastChangedRowId<2> lastRowId{mockSqliteDatabase, "main", "foo", "bar"};
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(LastChangedRowIdWithTwoTables, ResetUpdateHookInDestructor)
|
TEST_F(LastChangedRowIdWithTwoTables, ResetUpdateHookInDestructor)
|
||||||
@@ -136,48 +136,48 @@ TEST_F(LastChangedRowIdWithTwoTables, GetMinusOneAsRowIdIfNoCallbackWasCalled)
|
|||||||
|
|
||||||
TEST_F(LastChangedRowIdWithTwoTables, CallbackSetsLastRowIdFirstTable)
|
TEST_F(LastChangedRowIdWithTwoTables, CallbackSetsLastRowIdFirstTable)
|
||||||
{
|
{
|
||||||
lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 42);
|
lastRowId("main", "foo", 42);
|
||||||
|
|
||||||
ASSERT_THAT(lastRowId.lastRowId, 42);
|
ASSERT_THAT(lastRowId.lastRowId, 42);
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(LastChangedRowIdWithTwoTables, CallbackSetsLastRowIdSecondTable)
|
TEST_F(LastChangedRowIdWithTwoTables, CallbackSetsLastRowIdSecondTable)
|
||||||
{
|
{
|
||||||
lastRowId.callback(Sqlite::ChangeType::Update, "main", "bar", 66);
|
lastRowId("main", "bar", 66);
|
||||||
|
|
||||||
ASSERT_THAT(lastRowId.lastRowId, 66);
|
ASSERT_THAT(lastRowId.lastRowId, 66);
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(LastChangedRowIdWithTwoTables, CallbackChecksDatabaseName)
|
TEST_F(LastChangedRowIdWithTwoTables, CallbackChecksDatabaseName)
|
||||||
{
|
{
|
||||||
lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 33);
|
lastRowId("main", "foo", 33);
|
||||||
|
|
||||||
lastRowId.callback(Sqlite::ChangeType::Update, "temp", "foo", 42);
|
lastRowId("temp", "foo", 42);
|
||||||
|
|
||||||
ASSERT_THAT(lastRowId.lastRowId, 33);
|
ASSERT_THAT(lastRowId.lastRowId, 33);
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(LastChangedRowIdWithTwoTables, CallbackChecksTableName)
|
TEST_F(LastChangedRowIdWithTwoTables, CallbackChecksTableName)
|
||||||
{
|
{
|
||||||
lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 33);
|
lastRowId("main", "foo", 33);
|
||||||
|
|
||||||
lastRowId.callback(Sqlite::ChangeType::Update, "main", "zoo", 42);
|
lastRowId("main", "zoo", 42);
|
||||||
|
|
||||||
ASSERT_THAT(lastRowId.lastRowId, 33);
|
ASSERT_THAT(lastRowId.lastRowId, 33);
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(LastChangedRowIdWithTwoTables, LastCallSetsRowId)
|
TEST_F(LastChangedRowIdWithTwoTables, LastCallSetsRowId)
|
||||||
{
|
{
|
||||||
lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 42);
|
lastRowId("main", "foo", 42);
|
||||||
|
|
||||||
lastRowId.callback(Sqlite::ChangeType::Delete, "main", "bar", 66);
|
lastRowId("main", "bar", 66);
|
||||||
|
|
||||||
ASSERT_THAT(lastRowId.lastRowId, 66);
|
ASSERT_THAT(lastRowId.lastRowId, 66);
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(LastChangedRowIdWithTwoTables, TakeLastRowId)
|
TEST_F(LastChangedRowIdWithTwoTables, TakeLastRowId)
|
||||||
{
|
{
|
||||||
lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 42);
|
lastRowId("main", "foo", 42);
|
||||||
|
|
||||||
auto id = lastRowId.takeLastRowId();
|
auto id = lastRowId.takeLastRowId();
|
||||||
|
|
||||||
@@ -186,7 +186,7 @@ TEST_F(LastChangedRowIdWithTwoTables, TakeLastRowId)
|
|||||||
|
|
||||||
TEST_F(LastChangedRowIdWithTwoTables, TakeLastRowIdResetsRowIdToMinusOne)
|
TEST_F(LastChangedRowIdWithTwoTables, TakeLastRowIdResetsRowIdToMinusOne)
|
||||||
{
|
{
|
||||||
lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 42);
|
lastRowId("main", "foo", 42);
|
||||||
lastRowId.takeLastRowId();
|
lastRowId.takeLastRowId();
|
||||||
|
|
||||||
auto id = lastRowId.takeLastRowId();
|
auto id = lastRowId.takeLastRowId();
|
||||||
@@ -199,14 +199,14 @@ class LastChangedRowIdWithThreeTables : public testing::Test
|
|||||||
protected:
|
protected:
|
||||||
NiceMock<MockSqliteDatabase> mockSqliteDatabase;
|
NiceMock<MockSqliteDatabase> mockSqliteDatabase;
|
||||||
|
|
||||||
Sqlite::LastChangedRowId lastRowId{mockSqliteDatabase, "main", "foo", "bar", "too"};
|
Sqlite::LastChangedRowId<3> lastRowId{mockSqliteDatabase, "main", "foo", "bar", "too"};
|
||||||
};
|
};
|
||||||
|
|
||||||
TEST_F(LastChangedRowIdWithThreeTables, SetUpdateHookInContructor)
|
TEST_F(LastChangedRowIdWithThreeTables, SetUpdateHookInContructor)
|
||||||
{
|
{
|
||||||
EXPECT_CALL(mockSqliteDatabase, setUpdateHook(_));
|
EXPECT_CALL(mockSqliteDatabase, setUpdateHook(_, _));
|
||||||
|
|
||||||
Sqlite::LastChangedRowId lastRowId{mockSqliteDatabase, "main", "foo"};
|
Sqlite::LastChangedRowId<3> lastRowId{mockSqliteDatabase, "main", "foo", "bar", "too"};
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(LastChangedRowIdWithThreeTables, ResetUpdateHookInDestructor)
|
TEST_F(LastChangedRowIdWithThreeTables, ResetUpdateHookInDestructor)
|
||||||
@@ -221,56 +221,56 @@ TEST_F(LastChangedRowIdWithThreeTables, GetMinusOneAsRowIdIfNoCallbackWasCalled)
|
|||||||
|
|
||||||
TEST_F(LastChangedRowIdWithThreeTables, CallbackSetsLastRowIdFirstTable)
|
TEST_F(LastChangedRowIdWithThreeTables, CallbackSetsLastRowIdFirstTable)
|
||||||
{
|
{
|
||||||
lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 42);
|
lastRowId("main", "foo", 42);
|
||||||
|
|
||||||
ASSERT_THAT(lastRowId.lastRowId, 42);
|
ASSERT_THAT(lastRowId.lastRowId, 42);
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(LastChangedRowIdWithThreeTables, CallbackSetsLastRowIdSecondTable)
|
TEST_F(LastChangedRowIdWithThreeTables, CallbackSetsLastRowIdSecondTable)
|
||||||
{
|
{
|
||||||
lastRowId.callback(Sqlite::ChangeType::Update, "main", "bar", 42);
|
lastRowId("main", "bar", 42);
|
||||||
|
|
||||||
ASSERT_THAT(lastRowId.lastRowId, 42);
|
ASSERT_THAT(lastRowId.lastRowId, 42);
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(LastChangedRowIdWithThreeTables, CallbackSetsLastRowIdThirdTable)
|
TEST_F(LastChangedRowIdWithThreeTables, CallbackSetsLastRowIdThirdTable)
|
||||||
{
|
{
|
||||||
lastRowId.callback(Sqlite::ChangeType::Update, "main", "too", 42);
|
lastRowId("main", "too", 42);
|
||||||
|
|
||||||
ASSERT_THAT(lastRowId.lastRowId, 42);
|
ASSERT_THAT(lastRowId.lastRowId, 42);
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(LastChangedRowIdWithThreeTables, CallbackChecksDatabaseName)
|
TEST_F(LastChangedRowIdWithThreeTables, CallbackChecksDatabaseName)
|
||||||
{
|
{
|
||||||
lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 33);
|
lastRowId("main", "foo", 33);
|
||||||
|
|
||||||
lastRowId.callback(Sqlite::ChangeType::Update, "temp", "foo", 42);
|
lastRowId("temp", "foo", 42);
|
||||||
|
|
||||||
ASSERT_THAT(lastRowId.lastRowId, 33);
|
ASSERT_THAT(lastRowId.lastRowId, 33);
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(LastChangedRowIdWithThreeTables, CallbackChecksTableName)
|
TEST_F(LastChangedRowIdWithThreeTables, CallbackChecksTableName)
|
||||||
{
|
{
|
||||||
lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 33);
|
lastRowId("main", "foo", 33);
|
||||||
|
|
||||||
lastRowId.callback(Sqlite::ChangeType::Update, "main", "zoo", 42);
|
lastRowId("main", "zoo", 42);
|
||||||
|
|
||||||
ASSERT_THAT(lastRowId.lastRowId, 33);
|
ASSERT_THAT(lastRowId.lastRowId, 33);
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(LastChangedRowIdWithThreeTables, LastCallSetsRowId)
|
TEST_F(LastChangedRowIdWithThreeTables, LastCallSetsRowId)
|
||||||
{
|
{
|
||||||
lastRowId.callback(Sqlite::ChangeType::Update, "main", "bar", 42);
|
lastRowId("main", "bar", 42);
|
||||||
lastRowId.callback(Sqlite::ChangeType::Insert, "main", "too", 33);
|
lastRowId("main", "too", 33);
|
||||||
|
|
||||||
lastRowId.callback(Sqlite::ChangeType::Delete, "main", "too", 66);
|
lastRowId("main", "too", 66);
|
||||||
|
|
||||||
ASSERT_THAT(lastRowId.lastRowId, 66);
|
ASSERT_THAT(lastRowId.lastRowId, 66);
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(LastChangedRowIdWithThreeTables, TakeLastRowId)
|
TEST_F(LastChangedRowIdWithThreeTables, TakeLastRowId)
|
||||||
{
|
{
|
||||||
lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 42);
|
lastRowId("main", "foo", 42);
|
||||||
|
|
||||||
auto id = lastRowId.takeLastRowId();
|
auto id = lastRowId.takeLastRowId();
|
||||||
|
|
||||||
@@ -279,7 +279,7 @@ TEST_F(LastChangedRowIdWithThreeTables, TakeLastRowId)
|
|||||||
|
|
||||||
TEST_F(LastChangedRowIdWithThreeTables, TakeLastRowIdResetsRowIdToMinusOne)
|
TEST_F(LastChangedRowIdWithThreeTables, TakeLastRowIdResetsRowIdToMinusOne)
|
||||||
{
|
{
|
||||||
lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 42);
|
lastRowId("main", "foo", 42);
|
||||||
lastRowId.takeLastRowId();
|
lastRowId.takeLastRowId();
|
||||||
|
|
||||||
auto id = lastRowId.takeLastRowId();
|
auto id = lastRowId.takeLastRowId();
|
||||||
@@ -291,14 +291,14 @@ class LastChangedRowIdWithNoDatabaseAndTable : public testing::Test
|
|||||||
{
|
{
|
||||||
protected:
|
protected:
|
||||||
NiceMock<MockSqliteDatabase> mockSqliteDatabase;
|
NiceMock<MockSqliteDatabase> mockSqliteDatabase;
|
||||||
Sqlite::LastChangedRowId lastRowId{mockSqliteDatabase};
|
Sqlite::LastChangedRowId<> lastRowId{mockSqliteDatabase};
|
||||||
};
|
};
|
||||||
|
|
||||||
TEST_F(LastChangedRowIdWithNoDatabaseAndTable, SetUpdateHookInContructor)
|
TEST_F(LastChangedRowIdWithNoDatabaseAndTable, SetUpdateHookInContructor)
|
||||||
{
|
{
|
||||||
EXPECT_CALL(mockSqliteDatabase, setUpdateHook(_));
|
EXPECT_CALL(mockSqliteDatabase, setUpdateHook(_, _));
|
||||||
|
|
||||||
Sqlite::LastChangedRowId lastRowId{mockSqliteDatabase, "main", "foo"};
|
Sqlite::LastChangedRowId<> lastRowId{mockSqliteDatabase};
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(LastChangedRowIdWithNoDatabaseAndTable, ResetUpdateHookInDestructor)
|
TEST_F(LastChangedRowIdWithNoDatabaseAndTable, ResetUpdateHookInDestructor)
|
||||||
@@ -313,42 +313,24 @@ TEST_F(LastChangedRowIdWithNoDatabaseAndTable, GetMinusOneAsRowIdIfNoCallbackWas
|
|||||||
|
|
||||||
TEST_F(LastChangedRowIdWithNoDatabaseAndTable, CallbackSetsLastRowId)
|
TEST_F(LastChangedRowIdWithNoDatabaseAndTable, CallbackSetsLastRowId)
|
||||||
{
|
{
|
||||||
lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 42);
|
lastRowId(42);
|
||||||
|
|
||||||
ASSERT_THAT(lastRowId.lastRowId, 42);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST_F(LastChangedRowIdWithNoDatabaseAndTable, CallbackDoNotChecksDatabaseName)
|
|
||||||
{
|
|
||||||
lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 33);
|
|
||||||
|
|
||||||
lastRowId.callback(Sqlite::ChangeType::Update, "temp", "foo", 42);
|
|
||||||
|
|
||||||
ASSERT_THAT(lastRowId.lastRowId, 42);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST_F(LastChangedRowIdWithNoDatabaseAndTable, CallbackDoNotChecksTableName)
|
|
||||||
{
|
|
||||||
lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 33);
|
|
||||||
|
|
||||||
lastRowId.callback(Sqlite::ChangeType::Update, "main", "bar", 42);
|
|
||||||
|
|
||||||
ASSERT_THAT(lastRowId.lastRowId, 42);
|
ASSERT_THAT(lastRowId.lastRowId, 42);
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(LastChangedRowIdWithNoDatabaseAndTable, LastCallSetsRowId)
|
TEST_F(LastChangedRowIdWithNoDatabaseAndTable, LastCallSetsRowId)
|
||||||
{
|
{
|
||||||
lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 42);
|
lastRowId(42);
|
||||||
lastRowId.callback(Sqlite::ChangeType::Insert, "main", "foo", 33);
|
lastRowId(33);
|
||||||
|
|
||||||
lastRowId.callback(Sqlite::ChangeType::Delete, "main", "foo", 66);
|
lastRowId(66);
|
||||||
|
|
||||||
ASSERT_THAT(lastRowId.lastRowId, 66);
|
ASSERT_THAT(lastRowId.lastRowId, 66);
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(LastChangedRowIdWithNoDatabaseAndTable, TakeLastRowId)
|
TEST_F(LastChangedRowIdWithNoDatabaseAndTable, TakeLastRowId)
|
||||||
{
|
{
|
||||||
lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 42);
|
lastRowId(42);
|
||||||
|
|
||||||
auto id = lastRowId.takeLastRowId();
|
auto id = lastRowId.takeLastRowId();
|
||||||
|
|
||||||
@@ -357,7 +339,7 @@ TEST_F(LastChangedRowIdWithNoDatabaseAndTable, TakeLastRowId)
|
|||||||
|
|
||||||
TEST_F(LastChangedRowIdWithNoDatabaseAndTable, TakeLastRowIdResetsRowIdToMinusOne)
|
TEST_F(LastChangedRowIdWithNoDatabaseAndTable, TakeLastRowIdResetsRowIdToMinusOne)
|
||||||
{
|
{
|
||||||
lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 42);
|
lastRowId(42);
|
||||||
lastRowId.takeLastRowId();
|
lastRowId.takeLastRowId();
|
||||||
|
|
||||||
auto id = lastRowId.takeLastRowId();
|
auto id = lastRowId.takeLastRowId();
|
||||||
@@ -369,14 +351,14 @@ class LastChangedRowIdWithNoTable : public testing::Test
|
|||||||
{
|
{
|
||||||
protected:
|
protected:
|
||||||
NiceMock<MockSqliteDatabase> mockSqliteDatabase;
|
NiceMock<MockSqliteDatabase> mockSqliteDatabase;
|
||||||
Sqlite::LastChangedRowId lastRowId{mockSqliteDatabase, "main"};
|
Sqlite::LastChangedRowId<> lastRowId{mockSqliteDatabase, "main"};
|
||||||
};
|
};
|
||||||
|
|
||||||
TEST_F(LastChangedRowIdWithNoTable, SetUpdateHookInContructor)
|
TEST_F(LastChangedRowIdWithNoTable, SetUpdateHookInContructor)
|
||||||
{
|
{
|
||||||
EXPECT_CALL(mockSqliteDatabase, setUpdateHook(_));
|
EXPECT_CALL(mockSqliteDatabase, setUpdateHook(_, _));
|
||||||
|
|
||||||
Sqlite::LastChangedRowId lastRowId{mockSqliteDatabase, "main", "foo"};
|
Sqlite::LastChangedRowId<> lastRowId{mockSqliteDatabase, "main"};
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(LastChangedRowIdWithNoTable, ResetUpdateHookInDestructor)
|
TEST_F(LastChangedRowIdWithNoTable, ResetUpdateHookInDestructor)
|
||||||
@@ -391,42 +373,33 @@ TEST_F(LastChangedRowIdWithNoTable, GetMinusOneAsRowIdIfNoCallbackWasCalled)
|
|||||||
|
|
||||||
TEST_F(LastChangedRowIdWithNoTable, CallbackSetsLastRowId)
|
TEST_F(LastChangedRowIdWithNoTable, CallbackSetsLastRowId)
|
||||||
{
|
{
|
||||||
lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 42);
|
lastRowId("main", 42);
|
||||||
|
|
||||||
ASSERT_THAT(lastRowId.lastRowId, 42);
|
ASSERT_THAT(lastRowId.lastRowId, 42);
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(LastChangedRowIdWithNoTable, CallbackChecksDatabaseName)
|
TEST_F(LastChangedRowIdWithNoTable, CallbackChecksDatabaseName)
|
||||||
{
|
{
|
||||||
lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 33);
|
lastRowId("main", 33);
|
||||||
|
|
||||||
lastRowId.callback(Sqlite::ChangeType::Update, "temp", "foo", 42);
|
lastRowId("temp", 42);
|
||||||
|
|
||||||
ASSERT_THAT(lastRowId.lastRowId, 33);
|
ASSERT_THAT(lastRowId.lastRowId, 33);
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(LastChangedRowIdWithNoTable, CallbackDoNotChecksTableName)
|
|
||||||
{
|
|
||||||
lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 33);
|
|
||||||
|
|
||||||
lastRowId.callback(Sqlite::ChangeType::Update, "main", "bar", 42);
|
|
||||||
|
|
||||||
ASSERT_THAT(lastRowId.lastRowId, 42);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST_F(LastChangedRowIdWithNoTable, LastCallSetsRowId)
|
TEST_F(LastChangedRowIdWithNoTable, LastCallSetsRowId)
|
||||||
{
|
{
|
||||||
lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 42);
|
lastRowId("main", 42);
|
||||||
lastRowId.callback(Sqlite::ChangeType::Insert, "main", "foo", 33);
|
lastRowId("main", 33);
|
||||||
|
|
||||||
lastRowId.callback(Sqlite::ChangeType::Delete, "main", "foo", 66);
|
lastRowId("main", 66);
|
||||||
|
|
||||||
ASSERT_THAT(lastRowId.lastRowId, 66);
|
ASSERT_THAT(lastRowId.lastRowId, 66);
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(LastChangedRowIdWithNoTable, TakeLastRowId)
|
TEST_F(LastChangedRowIdWithNoTable, TakeLastRowId)
|
||||||
{
|
{
|
||||||
lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 42);
|
lastRowId("main", 42);
|
||||||
|
|
||||||
auto id = lastRowId.takeLastRowId();
|
auto id = lastRowId.takeLastRowId();
|
||||||
|
|
||||||
@@ -435,7 +408,7 @@ TEST_F(LastChangedRowIdWithNoTable, TakeLastRowId)
|
|||||||
|
|
||||||
TEST_F(LastChangedRowIdWithNoTable, TakeLastRowIdResetsRowIdToMinusOne)
|
TEST_F(LastChangedRowIdWithNoTable, TakeLastRowIdResetsRowIdToMinusOne)
|
||||||
{
|
{
|
||||||
lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 42);
|
lastRowId("main", 42);
|
||||||
lastRowId.takeLastRowId();
|
lastRowId.takeLastRowId();
|
||||||
|
|
||||||
auto id = lastRowId.takeLastRowId();
|
auto id = lastRowId.takeLastRowId();
|
||||||
@@ -452,7 +425,7 @@ TEST_F(LastChangedRowIdWithNoTable, LastRowIdIsNotValidForNegativeValues)
|
|||||||
|
|
||||||
TEST_F(LastChangedRowIdWithNoTable, LastRowIdIsValidForNull)
|
TEST_F(LastChangedRowIdWithNoTable, LastRowIdIsValidForNull)
|
||||||
{
|
{
|
||||||
lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 0);
|
lastRowId("main", 0);
|
||||||
|
|
||||||
auto isValid = lastRowId.lastRowIdIsValid();
|
auto isValid = lastRowId.lastRowIdIsValid();
|
||||||
|
|
||||||
@@ -461,7 +434,7 @@ TEST_F(LastChangedRowIdWithNoTable, LastRowIdIsValidForNull)
|
|||||||
|
|
||||||
TEST_F(LastChangedRowIdWithNoTable, LastRowIdIsValidForPositiveValues)
|
TEST_F(LastChangedRowIdWithNoTable, LastRowIdIsValidForPositiveValues)
|
||||||
{
|
{
|
||||||
lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 777);
|
lastRowId("main", 777);
|
||||||
|
|
||||||
auto isValid = lastRowId.lastRowIdIsValid();
|
auto isValid = lastRowId.lastRowIdIsValid();
|
||||||
|
|
||||||
|
|||||||
@@ -60,7 +60,9 @@ public:
|
|||||||
|
|
||||||
MOCK_METHOD0(walCheckpointFull, void());
|
MOCK_METHOD0(walCheckpointFull, void());
|
||||||
|
|
||||||
MOCK_METHOD1(setUpdateHook, void(Sqlite::DatabaseInterface::UpdateCallback &));
|
MOCK_METHOD2(setUpdateHook,
|
||||||
|
void(void *object,
|
||||||
|
void (*)(void *object, int, char const *database, char const *, long long rowId)));
|
||||||
|
|
||||||
MOCK_METHOD0(resetUpdateHook, void());
|
MOCK_METHOD0(resetUpdateHook, void());
|
||||||
|
|
||||||
|
|||||||
@@ -39,6 +39,8 @@
|
|||||||
#include <QTemporaryFile>
|
#include <QTemporaryFile>
|
||||||
#include <QVariant>
|
#include <QVariant>
|
||||||
|
|
||||||
|
#include <functional>
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
|
||||||
using testing::Contains;
|
using testing::Contains;
|
||||||
@@ -74,13 +76,23 @@ protected:
|
|||||||
return Sqlite::ReadStatement("SELECT name FROM test", database).values<Utils::SmallString>(8);
|
return Sqlite::ReadStatement("SELECT name FROM test", database).values<Utils::SmallString>(8);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void updateHookCallback(
|
||||||
|
void *object, int type, char const *database, char const *table, long long rowId)
|
||||||
|
{
|
||||||
|
static_cast<SqliteDatabase *>(object)->callback(static_cast<Sqlite::ChangeType>(type),
|
||||||
|
database,
|
||||||
|
table,
|
||||||
|
rowId);
|
||||||
|
}
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
SpyDummy spyDummy;
|
SpyDummy spyDummy;
|
||||||
QString databaseFilePath{":memory:"};
|
QString databaseFilePath{":memory:"};
|
||||||
mutable Sqlite::Database database;
|
mutable Sqlite::Database database;
|
||||||
Sqlite::TransactionInterface &transactionInterface = database;
|
Sqlite::TransactionInterface &transactionInterface = database;
|
||||||
MockFunction<void(Sqlite::ChangeType tupe, char const *, char const *, long long)> callbackMock;
|
MockFunction<void(Sqlite::ChangeType tupe, char const *, char const *, long long)> callbackMock;
|
||||||
Sqlite::Database::UpdateCallback callback = callbackMock.AsStdFunction();
|
std::function<void(Sqlite::ChangeType tupe, char const *, char const *, long long)>
|
||||||
|
callback = callbackMock.AsStdFunction();
|
||||||
};
|
};
|
||||||
|
|
||||||
TEST_F(SqliteDatabase, SetDatabaseFilePath)
|
TEST_F(SqliteDatabase, SetDatabaseFilePath)
|
||||||
@@ -232,7 +244,7 @@ TEST_F(SqliteDatabase, Rollback)
|
|||||||
|
|
||||||
TEST_F(SqliteDatabase, SetUpdateHookSet)
|
TEST_F(SqliteDatabase, SetUpdateHookSet)
|
||||||
{
|
{
|
||||||
database.setUpdateHook(callback);
|
database.setUpdateHook(this, updateHookCallback);
|
||||||
|
|
||||||
EXPECT_CALL(callbackMock, Call(_, _, _, _));
|
EXPECT_CALL(callbackMock, Call(_, _, _, _));
|
||||||
Sqlite::WriteStatement("INSERT INTO test(name) VALUES (?)", database).write(42);
|
Sqlite::WriteStatement("INSERT INTO test(name) VALUES (?)", database).write(42);
|
||||||
@@ -240,10 +252,9 @@ TEST_F(SqliteDatabase, SetUpdateHookSet)
|
|||||||
|
|
||||||
TEST_F(SqliteDatabase, SetNullUpdateHook)
|
TEST_F(SqliteDatabase, SetNullUpdateHook)
|
||||||
{
|
{
|
||||||
database.setUpdateHook(callback);
|
database.setUpdateHook(this, updateHookCallback);
|
||||||
Sqlite::Database::UpdateCallback newCallback;
|
|
||||||
|
|
||||||
database.setUpdateHook(newCallback);
|
database.setUpdateHook(nullptr, nullptr);
|
||||||
|
|
||||||
EXPECT_CALL(callbackMock, Call(_, _, _, _)).Times(0);
|
EXPECT_CALL(callbackMock, Call(_, _, _, _)).Times(0);
|
||||||
Sqlite::WriteStatement("INSERT INTO test(name) VALUES (?)", database).write(42);
|
Sqlite::WriteStatement("INSERT INTO test(name) VALUES (?)", database).write(42);
|
||||||
@@ -251,8 +262,7 @@ TEST_F(SqliteDatabase, SetNullUpdateHook)
|
|||||||
|
|
||||||
TEST_F(SqliteDatabase, ResetUpdateHook)
|
TEST_F(SqliteDatabase, ResetUpdateHook)
|
||||||
{
|
{
|
||||||
database.setUpdateHook(callback);
|
database.setUpdateHook(this, updateHookCallback);
|
||||||
Sqlite::Database::UpdateCallback newCallback;
|
|
||||||
|
|
||||||
database.resetUpdateHook();
|
database.resetUpdateHook();
|
||||||
|
|
||||||
@@ -263,7 +273,7 @@ TEST_F(SqliteDatabase, ResetUpdateHook)
|
|||||||
TEST_F(SqliteDatabase, DeleteUpdateHookCall)
|
TEST_F(SqliteDatabase, DeleteUpdateHookCall)
|
||||||
{
|
{
|
||||||
Sqlite::WriteStatement("INSERT INTO test(name) VALUES (?)", database).write(42);
|
Sqlite::WriteStatement("INSERT INTO test(name) VALUES (?)", database).write(42);
|
||||||
database.setUpdateHook(callback);
|
database.setUpdateHook(this, updateHookCallback);
|
||||||
|
|
||||||
EXPECT_CALL(callbackMock, Call(Eq(Sqlite::ChangeType::Delete), _, _, _));
|
EXPECT_CALL(callbackMock, Call(Eq(Sqlite::ChangeType::Delete), _, _, _));
|
||||||
|
|
||||||
@@ -272,7 +282,7 @@ TEST_F(SqliteDatabase, DeleteUpdateHookCall)
|
|||||||
|
|
||||||
TEST_F(SqliteDatabase, InsertUpdateHookCall)
|
TEST_F(SqliteDatabase, InsertUpdateHookCall)
|
||||||
{
|
{
|
||||||
database.setUpdateHook(callback);
|
database.setUpdateHook(this, updateHookCallback);
|
||||||
|
|
||||||
EXPECT_CALL(callbackMock, Call(Eq(Sqlite::ChangeType::Insert), _, _, _));
|
EXPECT_CALL(callbackMock, Call(Eq(Sqlite::ChangeType::Insert), _, _, _));
|
||||||
|
|
||||||
@@ -281,7 +291,7 @@ TEST_F(SqliteDatabase, InsertUpdateHookCall)
|
|||||||
|
|
||||||
TEST_F(SqliteDatabase, UpdateUpdateHookCall)
|
TEST_F(SqliteDatabase, UpdateUpdateHookCall)
|
||||||
{
|
{
|
||||||
database.setUpdateHook(callback);
|
database.setUpdateHook(this, updateHookCallback);
|
||||||
|
|
||||||
EXPECT_CALL(callbackMock, Call(Eq(Sqlite::ChangeType::Insert), _, _, _));
|
EXPECT_CALL(callbackMock, Call(Eq(Sqlite::ChangeType::Insert), _, _, _));
|
||||||
|
|
||||||
@@ -290,7 +300,7 @@ TEST_F(SqliteDatabase, UpdateUpdateHookCall)
|
|||||||
|
|
||||||
TEST_F(SqliteDatabase, RowIdUpdateHookCall)
|
TEST_F(SqliteDatabase, RowIdUpdateHookCall)
|
||||||
{
|
{
|
||||||
database.setUpdateHook(callback);
|
database.setUpdateHook(this, updateHookCallback);
|
||||||
|
|
||||||
EXPECT_CALL(callbackMock, Call(_, _, _, Eq(42)));
|
EXPECT_CALL(callbackMock, Call(_, _, _, Eq(42)));
|
||||||
|
|
||||||
@@ -299,7 +309,7 @@ TEST_F(SqliteDatabase, RowIdUpdateHookCall)
|
|||||||
|
|
||||||
TEST_F(SqliteDatabase, DatabaseUpdateHookCall)
|
TEST_F(SqliteDatabase, DatabaseUpdateHookCall)
|
||||||
{
|
{
|
||||||
database.setUpdateHook(callback);
|
database.setUpdateHook(this, updateHookCallback);
|
||||||
|
|
||||||
EXPECT_CALL(callbackMock, Call(_, StrEq("main"), _, _));
|
EXPECT_CALL(callbackMock, Call(_, StrEq("main"), _, _));
|
||||||
|
|
||||||
@@ -308,7 +318,7 @@ TEST_F(SqliteDatabase, DatabaseUpdateHookCall)
|
|||||||
|
|
||||||
TEST_F(SqliteDatabase, TableUpdateHookCall)
|
TEST_F(SqliteDatabase, TableUpdateHookCall)
|
||||||
{
|
{
|
||||||
database.setUpdateHook(callback);
|
database.setUpdateHook(this, updateHookCallback);
|
||||||
|
|
||||||
EXPECT_CALL(callbackMock, Call(_, _, StrEq("test"), _));
|
EXPECT_CALL(callbackMock, Call(_, _, StrEq("test"), _));
|
||||||
|
|
||||||
|
|||||||
@@ -388,6 +388,7 @@ TEST_F(SqliteStatement, WritePointerValues)
|
|||||||
TEST_F(SqliteStatement, WriteNullValues)
|
TEST_F(SqliteStatement, WriteNullValues)
|
||||||
{
|
{
|
||||||
WriteStatement statement("UPDATE test SET name=?, number=? WHERE rowid=?", database);
|
WriteStatement statement("UPDATE test SET name=?, number=? WHERE rowid=?", database);
|
||||||
|
statement.write(1, 1, 1);
|
||||||
|
|
||||||
statement.write(Sqlite::NullValue{}, Sqlite::Value{}, 1);
|
statement.write(Sqlite::NullValue{}, Sqlite::Value{}, 1);
|
||||||
|
|
||||||
|
|||||||
@@ -25,7 +25,7 @@
|
|||||||
|
|
||||||
#include "googletest.h"
|
#include "googletest.h"
|
||||||
|
|
||||||
#include <clangrefactoring/symbolsfindfilter.h>
|
#include <clangrefactoring/clangsymbolsfindfilter.h>
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
|
||||||
|
|||||||
@@ -1,9 +1,11 @@
|
|||||||
INCLUDEPATH += ../mockup
|
INCLUDEPATH += ../mockup
|
||||||
|
|
||||||
QT += core network testlib widgets
|
QT += core network testlib widgets
|
||||||
CONFIG += console c++14 testcase object_parallel_to_source
|
CONFIG += console c++14 testcase
|
||||||
CONFIG -= app_bundle shared
|
CONFIG -= app_bundle shared
|
||||||
|
|
||||||
|
QTC_UNITTEST_BUILD_CPP_PARSER = $$(QTC_UNITTEST_BUILD_CPP_PARSER)
|
||||||
|
|
||||||
include(gmock_dependency.pri)
|
include(gmock_dependency.pri)
|
||||||
include(clang_dependency.pri)
|
include(clang_dependency.pri)
|
||||||
include(creator_dependency.pri)
|
include(creator_dependency.pri)
|
||||||
@@ -11,8 +13,6 @@ include(benchmark_dependency.pri)
|
|||||||
|
|
||||||
requires(isEmpty(QTC_CLANG_BUILDMODE_MISMATCH))
|
requires(isEmpty(QTC_CLANG_BUILDMODE_MISMATCH))
|
||||||
|
|
||||||
OBJECTS_DIR = $$OUT_PWD/obj # workaround for qmake bug in object_parallel_to_source
|
|
||||||
|
|
||||||
!msvc:force_debug_info:QMAKE_CXXFLAGS += -fno-omit-frame-pointer
|
!msvc:force_debug_info:QMAKE_CXXFLAGS += -fno-omit-frame-pointer
|
||||||
|
|
||||||
DEFINES += \
|
DEFINES += \
|
||||||
@@ -66,7 +66,6 @@ SOURCES += \
|
|||||||
lastchangedrowid-test.cpp \
|
lastchangedrowid-test.cpp \
|
||||||
lineprefixer-test.cpp \
|
lineprefixer-test.cpp \
|
||||||
locatorfilter-test.cpp \
|
locatorfilter-test.cpp \
|
||||||
matchingtext-test.cpp \
|
|
||||||
mimedatabase-utilities.cpp \
|
mimedatabase-utilities.cpp \
|
||||||
pchmanagerclientserverinprocess-test.cpp \
|
pchmanagerclientserverinprocess-test.cpp \
|
||||||
pchmanagerclient-test.cpp \
|
pchmanagerclient-test.cpp \
|
||||||
@@ -133,6 +132,8 @@ SOURCES += \
|
|||||||
sqlstatementbuilder-test.cpp \
|
sqlstatementbuilder-test.cpp \
|
||||||
createtablesqlstatementbuilder-test.cpp
|
createtablesqlstatementbuilder-test.cpp
|
||||||
|
|
||||||
|
!isEmpty(QTC_UNITTEST_BUILD_CPP_PARSER):matchingtext-test.cpp
|
||||||
|
|
||||||
!isEmpty(LIBCLANG_LIBS) {
|
!isEmpty(LIBCLANG_LIBS) {
|
||||||
SOURCES += \
|
SOURCES += \
|
||||||
activationsequencecontextprocessor-test.cpp \
|
activationsequencecontextprocessor-test.cpp \
|
||||||
@@ -229,6 +230,7 @@ HEADERS += \
|
|||||||
gtest-creator-printing.h \
|
gtest-creator-printing.h \
|
||||||
gtest-llvm-printing.h \
|
gtest-llvm-printing.h \
|
||||||
gtest-qt-printing.h \
|
gtest-qt-printing.h \
|
||||||
|
gtest-std-printing.h \
|
||||||
mimedatabase-utilities.h \
|
mimedatabase-utilities.h \
|
||||||
mockclangcodemodelclient.h \
|
mockclangcodemodelclient.h \
|
||||||
mockclangcodemodelserver.h \
|
mockclangcodemodelserver.h \
|
||||||
|
|||||||
Reference in New Issue
Block a user