mirror of https://github.com/linuxdeepin/dtkcore
chore: format code
Add .clang-format. Format code that has been modified by commite6423c5
. Log: format code Influence:e6423c5
This commit is contained in:
parent
c3b81cb348
commit
724696bdf6
|
@ -0,0 +1,196 @@
|
|||
---
|
||||
# 语言: None, Cpp, Java, JavaScript, ObjC, Proto, TableGen, TextProto
|
||||
Language: Cpp
|
||||
# BasedOnStyle: LLVM
|
||||
# 访问说明符(public、private等)的偏移
|
||||
AccessModifierOffset: -4
|
||||
# 开括号(开圆括号、开尖括号、开方括号)后的对齐: Align, DontAlign, AlwaysBreak(总是在开括号后换行)
|
||||
AlignAfterOpenBracket: Align
|
||||
# 连续赋值时,对齐所有等号
|
||||
AlignConsecutiveAssignments: None
|
||||
# 连续声明时,对齐所有声明的变量名
|
||||
AlignConsecutiveDeclarations: None
|
||||
|
||||
AlignEscapedNewlines: Right
|
||||
|
||||
# 左对齐逃脱换行(使用反斜杠换行)的反斜杠
|
||||
#AlignEscapedNewlinesLeft: true
|
||||
# 水平对齐二元和三元表达式的操作数
|
||||
AlignOperands: true
|
||||
# 对齐连续的尾随的注释
|
||||
AlignTrailingComments: true
|
||||
|
||||
# 允许函数声明的所有参数在放在下一行
|
||||
AllowAllParametersOfDeclarationOnNextLine: true
|
||||
# 允许短的块放在同一行
|
||||
AllowShortBlocksOnASingleLine: Empty
|
||||
# 允许短的case标签放在同一行
|
||||
AllowShortCaseLabelsOnASingleLine: false
|
||||
# 允许短的函数放在同一行: None, InlineOnly(定义在类中), Empty(空函数), Inline(定义在类中,空函数), All
|
||||
AllowShortFunctionsOnASingleLine: Inline
|
||||
# 允许短的if语句保持在同一行
|
||||
AllowShortIfStatementsOnASingleLine: false
|
||||
# 允许短的循环保持在同一行
|
||||
AllowShortLoopsOnASingleLine: false
|
||||
|
||||
# 总是在定义返回类型后换行(deprecated)
|
||||
AlwaysBreakAfterDefinitionReturnType: None
|
||||
# 总是在返回类型后换行: None, All, TopLevel(顶级函数,不包括在类中的函数),
|
||||
# AllDefinitions(所有的定义,不包括声明), TopLevelDefinitions(所有的顶级函数的定义)
|
||||
AlwaysBreakAfterReturnType: None
|
||||
# 总是在多行string字面量前换行
|
||||
AlwaysBreakBeforeMultilineStrings: false
|
||||
# 总是在template声明后换行
|
||||
AlwaysBreakTemplateDeclarations: Yes
|
||||
# false表示函数实参要么都在同一行,要么都各自一行
|
||||
BinPackArguments: false
|
||||
# false表示所有形参要么都在同一行,要么都各自一行
|
||||
BinPackParameters: false
|
||||
# 大括号换行,只有当BreakBeforeBraces设置为Custom时才有效
|
||||
BraceWrapping:
|
||||
# class定义后面
|
||||
AfterClass: true
|
||||
# 控制语句后面
|
||||
AfterControlStatement: Never
|
||||
# enum定义后面
|
||||
AfterEnum: false
|
||||
# 函数定义后面
|
||||
AfterFunction: true
|
||||
# 命名空间定义后面
|
||||
AfterNamespace: false
|
||||
# ObjC定义后面
|
||||
AfterObjCDeclaration: false
|
||||
# struct定义后面
|
||||
AfterStruct: true
|
||||
# union定义后面
|
||||
AfterUnion: true
|
||||
|
||||
AfterExternBlock: false
|
||||
# catch之前
|
||||
BeforeCatch: false
|
||||
# else之前
|
||||
BeforeElse: false
|
||||
# 缩进大括号
|
||||
IndentBraces: false
|
||||
SplitEmptyFunction: true
|
||||
SplitEmptyRecord: true
|
||||
SplitEmptyNamespace: true
|
||||
|
||||
# 在二元运算符前换行: None(在操作符后换行), NonAssignment(在非赋值的操作符前换行), All(在操作符前换行)
|
||||
BreakBeforeBinaryOperators: None
|
||||
# 在大括号前换行: Attach(始终将大括号附加到周围的上下文), Linux(除函数、命名空间和类定义,与Attach类似),
|
||||
# Mozilla(除枚举、函数、记录定义,与Attach类似), Stroustrup(除函数定义、catch、else,与Attach类似),
|
||||
# Allman(总是在大括号前换行), GNU(总是在大括号前换行,并对于控制语句的大括号增加额外的缩进), WebKit(在函数前换行), Custom
|
||||
# 注:这里认为语句块也属于函数
|
||||
BreakBeforeBraces: Custom
|
||||
# 在三元运算符前换行
|
||||
BreakBeforeTernaryOperators: false
|
||||
|
||||
# 在构造函数的初始化列表的逗号前换行
|
||||
BreakConstructorInitializersBeforeComma: true
|
||||
BreakConstructorInitializers: BeforeColon
|
||||
# 每行字符的限制,0表示没有限制
|
||||
ColumnLimit: 130
|
||||
# 描述具有特殊意义的注释的正则表达式,它不应该被分割为多行或以其它方式改变
|
||||
CommentPragmas: '^ IWYU pragma:'
|
||||
CompactNamespaces: false
|
||||
# 构造函数的初始化列表要么都在同一行,要么都各自一行
|
||||
ConstructorInitializerAllOnOneLineOrOnePerLine: false
|
||||
# 构造函数的初始化列表的缩进宽度
|
||||
ConstructorInitializerIndentWidth: 4
|
||||
# 延续的行的缩进宽度
|
||||
ContinuationIndentWidth: 4
|
||||
# 去除C++11的列表初始化的大括号{后和}前的空格
|
||||
Cpp11BracedListStyle: true
|
||||
# 继承最常用的指针和引用的对齐方式
|
||||
DerivePointerAlignment: false
|
||||
# 关闭格式化
|
||||
DisableFormat: false
|
||||
# 自动检测函数的调用和定义是否被格式为每行一个参数(Experimental)
|
||||
ExperimentalAutoDetectBinPacking: false
|
||||
# 需要被解读为foreach循环而不是函数调用的宏
|
||||
ForEachMacros: [ foreach, Q_FOREACH, BOOST_FOREACH ]
|
||||
# 对#include进行排序,匹配了某正则表达式的#include拥有对应的优先级,匹配不到的则默认优先级为INT_MAX(优先级越小排序越靠前),
|
||||
# 可以定义负数优先级从而保证某些#include永远在最前面
|
||||
IncludeCategories:
|
||||
- Regex: '^"(llvm|llvm-c|clang|clang-c)/'
|
||||
Priority: 2
|
||||
- Regex: '^(<|"(gtest|isl|json)/)'
|
||||
Priority: 3
|
||||
- Regex: '.*'
|
||||
Priority: 1
|
||||
# 缩进case标签
|
||||
IndentCaseLabels: true
|
||||
|
||||
#IndentPPDirectives: AfterHash
|
||||
# 缩进宽度
|
||||
IndentWidth: 4
|
||||
# 函数返回类型换行时,缩进函数声明或函数定义的函数名
|
||||
IndentWrappedFunctionNames: false
|
||||
# 保留在块开始处的空行
|
||||
KeepEmptyLinesAtTheStartOfBlocks: false
|
||||
# 开始一个块的宏的正则表达式
|
||||
MacroBlockBegin: ''
|
||||
# 结束一个块的宏的正则表达式
|
||||
MacroBlockEnd: ''
|
||||
# 连续空行的最大数量
|
||||
MaxEmptyLinesToKeep: 1
|
||||
# 命名空间的缩进: None, Inner(缩进嵌套的命名空间中的内容), All
|
||||
NamespaceIndentation: Inner
|
||||
# 使用ObjC块时缩进宽度
|
||||
ObjCBlockIndentWidth: 4
|
||||
# 在ObjC的@property后添加一个空格
|
||||
ObjCSpaceAfterProperty: false
|
||||
# 在ObjC的protocol列表前添加一个空格
|
||||
ObjCSpaceBeforeProtocolList: true
|
||||
|
||||
|
||||
# 在call(后对函数调用换行的penalty
|
||||
PenaltyBreakBeforeFirstCallParameter: 19
|
||||
# 在一个注释中引入换行的penalty
|
||||
PenaltyBreakComment: 300
|
||||
# 第一次在<<前换行的penalty
|
||||
PenaltyBreakFirstLessLess: 120
|
||||
# 在一个字符串字面量中引入换行的penalty
|
||||
PenaltyBreakString: 1000
|
||||
# 对于每个在行字符数限制之外的字符的penalty
|
||||
PenaltyExcessCharacter: 1000000
|
||||
# 将函数的返回类型放到它自己的行的penalty
|
||||
PenaltyReturnTypeOnItsOwnLine: 60
|
||||
|
||||
# 指针和引用的对齐: Left, Right, Middle
|
||||
PointerAlignment: Right
|
||||
# 允许重新排版注释
|
||||
ReflowComments: true
|
||||
# 允许排序#include
|
||||
SortIncludes: Never
|
||||
|
||||
# 在C风格类型转换后添加空格
|
||||
SpaceAfterCStyleCast: false
|
||||
|
||||
SpaceAfterTemplateKeyword: true
|
||||
|
||||
# 在赋值运算符之前添加空格
|
||||
SpaceBeforeAssignmentOperators: true
|
||||
# 开圆括号之前添加一个空格: Never, ControlStatements, Always
|
||||
SpaceBeforeParens: ControlStatements
|
||||
# 在空的圆括号中添加空格
|
||||
SpaceInEmptyParentheses: false
|
||||
# 在尾随的评论前添加的空格数(只适用于//)
|
||||
SpacesBeforeTrailingComments: 2
|
||||
# 在尖括号的<后和>前添加空格
|
||||
SpacesInAngles: false
|
||||
# 在容器(ObjC和JavaScript的数组和字典等)字面量中添加空格
|
||||
SpacesInContainerLiterals: false
|
||||
# 在C风格类型转换的括号中添加空格
|
||||
SpacesInCStyleCastParentheses: false
|
||||
# 在圆括号的(后和)前添加空格
|
||||
SpacesInParentheses: false
|
||||
# 在方括号的[后和]前添加空格,lamda表达式和未指明大小的数组的声明不受影响
|
||||
SpacesInSquareBrackets: false
|
||||
# 标准: Cpp03, Cpp11, Auto
|
||||
Standard: Auto
|
||||
# tab宽度
|
||||
TabWidth: 4
|
||||
# 使用tab字符: Never, ForIndentation, ForContinuationAndIndentation, Always
|
||||
UseTab: Never
|
|
@ -20,7 +20,7 @@ Copyright: None
|
|||
License: CC0-1.0
|
||||
|
||||
# config
|
||||
Files: *.toml *.conf *.json
|
||||
Files: *.toml *.conf *.json .clang-format
|
||||
Copyright: None
|
||||
License: CC0-1.0
|
||||
|
||||
|
|
|
@ -13,8 +13,8 @@ DCORE_BEGIN_NAMESPACE
|
|||
|
||||
class DDBusExtendedPendingCallWatcher;
|
||||
|
||||
class LIBDTKCORESHARED_EXPORT DDBusExtendedAbstractInterface
|
||||
: public QDBusAbstractInterface {
|
||||
class LIBDTKCORESHARED_EXPORT DDBusExtendedAbstractInterface : public QDBusAbstractInterface
|
||||
{
|
||||
Q_OBJECT
|
||||
|
||||
public:
|
||||
|
@ -36,16 +36,13 @@ public Q_SLOTS:
|
|||
void startServiceProcess();
|
||||
|
||||
protected:
|
||||
DDBusExtendedAbstractInterface(const QString &service, const QString &path,
|
||||
const char *interface,
|
||||
const QDBusConnection &connection,
|
||||
QObject *parent);
|
||||
DDBusExtendedAbstractInterface(
|
||||
const QString &service, const QString &path, const char *interface, const QDBusConnection &connection, QObject *parent);
|
||||
|
||||
void connectNotify(const QMetaMethod &signal);
|
||||
void disconnectNotify(const QMetaMethod &signal);
|
||||
QVariant internalPropGet(const char *propname, void *propertyPtr);
|
||||
void internalPropSet(const char *propname, const QVariant &value,
|
||||
void *propertyPtr);
|
||||
void internalPropSet(const char *propname, const QVariant &value, void *propertyPtr);
|
||||
|
||||
Q_SIGNALS:
|
||||
void serviceValidChanged(const bool valid) const;
|
||||
|
@ -60,8 +57,7 @@ private Q_SLOTS:
|
|||
void onPropertiesChanged(const QString &interfaceName,
|
||||
const QVariantMap &changedProperties,
|
||||
const QStringList &invalidatedProperties);
|
||||
void onDBusNameOwnerChanged(const QString &name, const QString &oldOwner,
|
||||
const QString &newOwner);
|
||||
void onDBusNameOwnerChanged(const QString &name, const QString &oldOwner, const QString &newOwner);
|
||||
void onAsyncPropertyFinished(QDBusPendingCallWatcher *w);
|
||||
void onAsyncSetPropertyFinished(QDBusPendingCallWatcher *w);
|
||||
void onAsyncGetAllPropertiesFinished(QDBusPendingCallWatcher *watcher);
|
||||
|
@ -70,9 +66,8 @@ private Q_SLOTS:
|
|||
private:
|
||||
QVariant asyncProperty(const QString &propertyName);
|
||||
void asyncSetProperty(const QString &propertyName, const QVariant &value);
|
||||
static QVariant demarshall(const QString &interface,
|
||||
const QMetaProperty &metaProperty,
|
||||
const QVariant &value, QDBusError *error);
|
||||
static QVariant
|
||||
demarshall(const QString &interface, const QMetaProperty &metaProperty, const QVariant &value, QDBusError *error);
|
||||
|
||||
bool m_sync;
|
||||
bool m_useCache;
|
||||
|
|
|
@ -18,31 +18,34 @@
|
|||
DCORE_BEGIN_NAMESPACE
|
||||
|
||||
Q_GLOBAL_STATIC_WITH_ARGS(QByteArray, dBusInterface, ("org.freedesktop.DBus"))
|
||||
Q_GLOBAL_STATIC_WITH_ARGS(QByteArray, dBusPropertiesInterface,
|
||||
("org.freedesktop.DBus.Properties"))
|
||||
Q_GLOBAL_STATIC_WITH_ARGS(QByteArray, dBusPropertiesChangedSignal,
|
||||
("PropertiesChanged"))
|
||||
Q_GLOBAL_STATIC_WITH_ARGS(QByteArray, propertyChangedSignature,
|
||||
("propertyChanged(QString,QVariant)"))
|
||||
Q_GLOBAL_STATIC_WITH_ARGS(QByteArray, propertyInvalidatedSignature,
|
||||
("propertyInvalidated(QString)"))
|
||||
Q_GLOBAL_STATIC_WITH_ARGS(QByteArray, dBusPropertiesInterface, ("org.freedesktop.DBus.Properties"))
|
||||
Q_GLOBAL_STATIC_WITH_ARGS(QByteArray, dBusPropertiesChangedSignal, ("PropertiesChanged"))
|
||||
Q_GLOBAL_STATIC_WITH_ARGS(QByteArray, propertyChangedSignature, ("propertyChanged(QString,QVariant)"))
|
||||
Q_GLOBAL_STATIC_WITH_ARGS(QByteArray, propertyInvalidatedSignature, ("propertyInvalidated(QString)"))
|
||||
|
||||
DDBusExtendedAbstractInterface::DDBusExtendedAbstractInterface(
|
||||
const QString &service, const QString &path, const char *interface,
|
||||
const QDBusConnection &connection, QObject *parent)
|
||||
: QDBusAbstractInterface(service, path, interface, connection, parent),
|
||||
m_sync(true), m_useCache(false), m_getAllPendingCallWatcher(0),
|
||||
m_propertiesChangedConnected(false) {
|
||||
const QString &service, const QString &path, const char *interface, const QDBusConnection &connection, QObject *parent)
|
||||
: QDBusAbstractInterface(service, path, interface, connection, parent)
|
||||
, m_sync(true)
|
||||
, m_useCache(false)
|
||||
, m_getAllPendingCallWatcher(0)
|
||||
, m_propertiesChangedConnected(false)
|
||||
{
|
||||
const_cast<QDBusConnection &>(connection)
|
||||
.connect(QString("org.freedesktop.DBus"),
|
||||
QString("/org/freedesktop/DBus"),
|
||||
QString("org.freedesktop.DBus"), QString("NameOwnerChanged"),
|
||||
this, SLOT(onDBusNameOwnerChanged(QString, QString, QString)));
|
||||
QString("org.freedesktop.DBus"),
|
||||
QString("NameOwnerChanged"),
|
||||
this,
|
||||
SLOT(onDBusNameOwnerChanged(QString, QString, QString)));
|
||||
}
|
||||
|
||||
DDBusExtendedAbstractInterface::~DDBusExtendedAbstractInterface() {}
|
||||
|
||||
void DDBusExtendedAbstractInterface::setSync(bool sync) { setSync(sync, true); }
|
||||
void DDBusExtendedAbstractInterface::setSync(bool sync)
|
||||
{
|
||||
setSync(sync, true);
|
||||
}
|
||||
|
||||
/*
|
||||
* @~english
|
||||
|
@ -51,7 +54,8 @@ void DDBusExtendedAbstractInterface::setSync(bool sync) { setSync(sync, true); }
|
|||
* through the changed signal when you get an property, and it's also a good
|
||||
* idea to save a cache yourself.
|
||||
*/
|
||||
void DDBusExtendedAbstractInterface::setSync(bool sync, bool autoStart) {
|
||||
void DDBusExtendedAbstractInterface::setSync(bool sync, bool autoStart)
|
||||
{
|
||||
m_sync = sync;
|
||||
|
||||
// init all properties
|
||||
|
@ -59,14 +63,13 @@ void DDBusExtendedAbstractInterface::setSync(bool sync, bool autoStart) {
|
|||
startServiceProcess();
|
||||
}
|
||||
|
||||
void DDBusExtendedAbstractInterface::getAllProperties() {
|
||||
void DDBusExtendedAbstractInterface::getAllProperties()
|
||||
{
|
||||
m_lastExtendedError = QDBusError();
|
||||
|
||||
if (!isValid()) {
|
||||
QString errorMessage =
|
||||
QStringLiteral("This Extended DBus interface is not valid yet.");
|
||||
m_lastExtendedError =
|
||||
QDBusMessage::createError(QDBusError::Failed, errorMessage);
|
||||
QString errorMessage = QStringLiteral("This Extended DBus interface is not valid yet.");
|
||||
m_lastExtendedError = QDBusMessage::createError(QDBusError::Failed, errorMessage);
|
||||
qDebug() << Q_FUNC_INFO << errorMessage;
|
||||
return;
|
||||
}
|
||||
|
@ -76,8 +79,7 @@ void DDBusExtendedAbstractInterface::getAllProperties() {
|
|||
return;
|
||||
}
|
||||
|
||||
QDBusMessage msg = QDBusMessage::createMethodCall(
|
||||
service(), path(), *dBusPropertiesInterface(), QStringLiteral("GetAll"));
|
||||
QDBusMessage msg = QDBusMessage::createMethodCall(service(), path(), *dBusPropertiesInterface(), QStringLiteral("GetAll"));
|
||||
msg << interface();
|
||||
|
||||
if (m_sync) {
|
||||
|
@ -90,12 +92,10 @@ void DDBusExtendedAbstractInterface::getAllProperties() {
|
|||
}
|
||||
|
||||
if (reply.signature() != QLatin1String("a{sv}")) {
|
||||
QString errorMessage =
|
||||
QStringLiteral("Invalid signature \"%1\" in return from call to %2")
|
||||
QString errorMessage = QStringLiteral("Invalid signature \"%1\" in return from call to %2")
|
||||
.arg(reply.signature(), QString(*dBusPropertiesInterface()));
|
||||
qWarning() << Q_FUNC_INFO << errorMessage;
|
||||
m_lastExtendedError =
|
||||
QDBusError(QDBusError::InvalidSignature, errorMessage);
|
||||
m_lastExtendedError = QDBusError(QDBusError::InvalidSignature, errorMessage);
|
||||
return;
|
||||
}
|
||||
|
||||
|
@ -106,22 +106,27 @@ void DDBusExtendedAbstractInterface::getAllProperties() {
|
|||
m_getAllPendingCallWatcher = new QDBusPendingCallWatcher(async, this);
|
||||
|
||||
connect(m_getAllPendingCallWatcher,
|
||||
SIGNAL(finished(QDBusPendingCallWatcher *)), this,
|
||||
SIGNAL(finished(QDBusPendingCallWatcher *)),
|
||||
this,
|
||||
SLOT(onAsyncGetAllPropertiesFinished(QDBusPendingCallWatcher *)));
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
void DDBusExtendedAbstractInterface::connectNotify(const QMetaMethod &signal) {
|
||||
if (signal.methodType() == QMetaMethod::Signal &&
|
||||
(signal.methodSignature() == *propertyChangedSignature() ||
|
||||
void DDBusExtendedAbstractInterface::connectNotify(const QMetaMethod &signal)
|
||||
{
|
||||
if (signal.methodType() == QMetaMethod::Signal && (signal.methodSignature() == *propertyChangedSignature() ||
|
||||
signal.methodSignature() == *propertyInvalidatedSignature())) {
|
||||
if (!m_propertiesChangedConnected) {
|
||||
QStringList argumentMatch;
|
||||
argumentMatch << interface();
|
||||
connection().connect(
|
||||
service(), path(), *dBusPropertiesInterface(),
|
||||
*dBusPropertiesChangedSignal(), argumentMatch, QString(), this,
|
||||
connection().connect(service(),
|
||||
path(),
|
||||
*dBusPropertiesInterface(),
|
||||
*dBusPropertiesChangedSignal(),
|
||||
argumentMatch,
|
||||
QString(),
|
||||
this,
|
||||
SLOT(onPropertiesChanged(QString, QVariantMap, QStringList)));
|
||||
|
||||
m_propertiesChangedConnected = true;
|
||||
|
@ -132,19 +137,21 @@ void DDBusExtendedAbstractInterface::connectNotify(const QMetaMethod &signal) {
|
|||
}
|
||||
}
|
||||
|
||||
void DDBusExtendedAbstractInterface::disconnectNotify(
|
||||
const QMetaMethod &signal) {
|
||||
if (signal.methodType() == QMetaMethod::Signal &&
|
||||
(signal.methodSignature() == *propertyChangedSignature() ||
|
||||
void DDBusExtendedAbstractInterface::disconnectNotify(const QMetaMethod &signal)
|
||||
{
|
||||
if (signal.methodType() == QMetaMethod::Signal && (signal.methodSignature() == *propertyChangedSignature() ||
|
||||
signal.methodSignature() == *propertyInvalidatedSignature())) {
|
||||
if (m_propertiesChangedConnected &&
|
||||
0 == receivers(propertyChangedSignature()->constData()) &&
|
||||
if (m_propertiesChangedConnected && 0 == receivers(propertyChangedSignature()->constData()) &&
|
||||
0 == receivers(propertyInvalidatedSignature()->constData())) {
|
||||
QStringList argumentMatch;
|
||||
argumentMatch << interface();
|
||||
connection().disconnect(
|
||||
service(), path(), *dBusPropertiesInterface(),
|
||||
*dBusPropertiesChangedSignal(), argumentMatch, QString(), this,
|
||||
connection().disconnect(service(),
|
||||
path(),
|
||||
*dBusPropertiesInterface(),
|
||||
*dBusPropertiesChangedSignal(),
|
||||
argumentMatch,
|
||||
QString(),
|
||||
this,
|
||||
SLOT(onPropertiesChanged(QString, QVariantMap, QStringList)));
|
||||
|
||||
m_propertiesChangedConnected = false;
|
||||
|
@ -155,8 +162,8 @@ void DDBusExtendedAbstractInterface::disconnectNotify(
|
|||
}
|
||||
}
|
||||
|
||||
QVariant DDBusExtendedAbstractInterface::internalPropGet(const char *propname,
|
||||
void *propertyPtr) {
|
||||
QVariant DDBusExtendedAbstractInterface::internalPropGet(const char *propname, void *propertyPtr)
|
||||
{
|
||||
m_lastExtendedError = QDBusError();
|
||||
|
||||
if (m_useCache) {
|
||||
|
@ -173,10 +180,8 @@ QVariant DDBusExtendedAbstractInterface::internalPropGet(const char *propname,
|
|||
return ret;
|
||||
} else {
|
||||
if (!isValid()) {
|
||||
QString errorMessage =
|
||||
QStringLiteral("This Extended DBus interface is not valid yet.");
|
||||
m_lastExtendedError =
|
||||
QDBusMessage::createError(QDBusError::Failed, errorMessage);
|
||||
QString errorMessage = QStringLiteral("This Extended DBus interface is not valid yet.");
|
||||
m_lastExtendedError = QDBusMessage::createError(QDBusError::Failed, errorMessage);
|
||||
qDebug() << Q_FUNC_INFO << errorMessage;
|
||||
return QVariant();
|
||||
}
|
||||
|
@ -184,11 +189,8 @@ QVariant DDBusExtendedAbstractInterface::internalPropGet(const char *propname,
|
|||
int propertyIndex = metaObject()->indexOfProperty(propname);
|
||||
|
||||
if (-1 == propertyIndex) {
|
||||
QString errorMessage =
|
||||
QStringLiteral("Got unknown property \"%1\" to read")
|
||||
.arg(QString::fromLatin1(propname));
|
||||
m_lastExtendedError =
|
||||
QDBusMessage::createError(QDBusError::Failed, errorMessage);
|
||||
QString errorMessage = QStringLiteral("Got unknown property \"%1\" to read").arg(QString::fromLatin1(propname));
|
||||
m_lastExtendedError = QDBusMessage::createError(QDBusError::Failed, errorMessage);
|
||||
qWarning() << Q_FUNC_INFO << errorMessage;
|
||||
return QVariant();
|
||||
}
|
||||
|
@ -196,10 +198,8 @@ QVariant DDBusExtendedAbstractInterface::internalPropGet(const char *propname,
|
|||
QMetaProperty metaProperty = metaObject()->property(propertyIndex);
|
||||
|
||||
if (!metaProperty.isReadable()) {
|
||||
QString errorMessage = QStringLiteral("Property \"%1\" is NOT readable")
|
||||
.arg(QString::fromLatin1(propname));
|
||||
m_lastExtendedError =
|
||||
QDBusMessage::createError(QDBusError::Failed, errorMessage);
|
||||
QString errorMessage = QStringLiteral("Property \"%1\" is NOT readable").arg(QString::fromLatin1(propname));
|
||||
m_lastExtendedError = QDBusMessage::createError(QDBusError::Failed, errorMessage);
|
||||
qWarning() << Q_FUNC_INFO << errorMessage;
|
||||
return QVariant();
|
||||
}
|
||||
|
@ -207,16 +207,13 @@ QVariant DDBusExtendedAbstractInterface::internalPropGet(const char *propname,
|
|||
// is this metatype registered?
|
||||
const char *expectedSignature = "";
|
||||
if (int(metaProperty.type()) != QMetaType::QVariant) {
|
||||
expectedSignature =
|
||||
QDBusMetaType::typeToSignature(metaProperty.userType());
|
||||
expectedSignature = QDBusMetaType::typeToSignature(metaProperty.userType());
|
||||
if (0 == expectedSignature) {
|
||||
QString errorMessage =
|
||||
QStringLiteral("Type %1 must be registered with Qt D-Bus "
|
||||
QString errorMessage = QStringLiteral("Type %1 must be registered with Qt D-Bus "
|
||||
"before it can be used to read property "
|
||||
"%2.%3")
|
||||
.arg(metaProperty.typeName(), interface(), propname);
|
||||
m_lastExtendedError =
|
||||
QDBusMessage::createError(QDBusError::Failed, errorMessage);
|
||||
m_lastExtendedError = QDBusMessage::createError(QDBusError::Failed, errorMessage);
|
||||
qWarning() << Q_FUNC_INFO << errorMessage;
|
||||
return QVariant();
|
||||
}
|
||||
|
@ -227,9 +224,8 @@ QVariant DDBusExtendedAbstractInterface::internalPropGet(const char *propname,
|
|||
}
|
||||
}
|
||||
|
||||
void DDBusExtendedAbstractInterface::internalPropSet(const char *propname,
|
||||
const QVariant &value,
|
||||
void *propertyPtr) {
|
||||
void DDBusExtendedAbstractInterface::internalPropSet(const char *propname, const QVariant &value, void *propertyPtr)
|
||||
{
|
||||
m_lastExtendedError = QDBusError();
|
||||
|
||||
if (m_sync) {
|
||||
|
@ -237,8 +233,7 @@ void DDBusExtendedAbstractInterface::internalPropSet(const char *propname,
|
|||
} else {
|
||||
if (!isValid()) {
|
||||
QString errorMessage = QStringLiteral("This interface is not yet valid");
|
||||
m_lastExtendedError =
|
||||
QDBusMessage::createError(QDBusError::Failed, errorMessage);
|
||||
m_lastExtendedError = QDBusMessage::createError(QDBusError::Failed, errorMessage);
|
||||
qDebug() << Q_FUNC_INFO << errorMessage;
|
||||
return;
|
||||
}
|
||||
|
@ -246,11 +241,8 @@ void DDBusExtendedAbstractInterface::internalPropSet(const char *propname,
|
|||
int propertyIndex = metaObject()->indexOfProperty(propname);
|
||||
|
||||
if (-1 == propertyIndex) {
|
||||
QString errorMessage =
|
||||
QStringLiteral("Got unknown property \"%1\" to write")
|
||||
.arg(QString::fromLatin1(propname));
|
||||
m_lastExtendedError =
|
||||
QDBusMessage::createError(QDBusError::Failed, errorMessage);
|
||||
QString errorMessage = QStringLiteral("Got unknown property \"%1\" to write").arg(QString::fromLatin1(propname));
|
||||
m_lastExtendedError = QDBusMessage::createError(QDBusError::Failed, errorMessage);
|
||||
qWarning() << Q_FUNC_INFO << errorMessage;
|
||||
return;
|
||||
}
|
||||
|
@ -258,10 +250,8 @@ void DDBusExtendedAbstractInterface::internalPropSet(const char *propname,
|
|||
QMetaProperty metaProperty = metaObject()->property(propertyIndex);
|
||||
|
||||
if (!metaProperty.isWritable()) {
|
||||
QString errorMessage = QStringLiteral("Property \"%1\" is NOT writable")
|
||||
.arg(QString::fromLatin1(propname));
|
||||
m_lastExtendedError =
|
||||
QDBusMessage::createError(QDBusError::Failed, errorMessage);
|
||||
QString errorMessage = QStringLiteral("Property \"%1\" is NOT writable").arg(QString::fromLatin1(propname));
|
||||
m_lastExtendedError = QDBusMessage::createError(QDBusError::Failed, errorMessage);
|
||||
qWarning() << Q_FUNC_INFO << errorMessage;
|
||||
return;
|
||||
}
|
||||
|
@ -273,38 +263,32 @@ void DDBusExtendedAbstractInterface::internalPropSet(const char *propname,
|
|||
}
|
||||
}
|
||||
|
||||
QVariant
|
||||
DDBusExtendedAbstractInterface::asyncProperty(const QString &propertyName) {
|
||||
QDBusMessage msg = QDBusMessage::createMethodCall(
|
||||
service(), path(), *dBusPropertiesInterface(), QStringLiteral("Get"));
|
||||
QVariant DDBusExtendedAbstractInterface::asyncProperty(const QString &propertyName)
|
||||
{
|
||||
QDBusMessage msg = QDBusMessage::createMethodCall(service(), path(), *dBusPropertiesInterface(), QStringLiteral("Get"));
|
||||
msg << interface() << propertyName;
|
||||
QDBusPendingReply<QVariant> async = connection().asyncCall(msg);
|
||||
DDBusExtendedPendingCallWatcher *watcher =
|
||||
new DDBusExtendedPendingCallWatcher(async, propertyName, QVariant(),
|
||||
this);
|
||||
DDBusExtendedPendingCallWatcher *watcher = new DDBusExtendedPendingCallWatcher(async, propertyName, QVariant(), this);
|
||||
|
||||
connect(watcher, SIGNAL(finished(QDBusPendingCallWatcher *)), this,
|
||||
SLOT(onAsyncPropertyFinished(QDBusPendingCallWatcher *)));
|
||||
connect(watcher, SIGNAL(finished(QDBusPendingCallWatcher *)), this, SLOT(onAsyncPropertyFinished(QDBusPendingCallWatcher *)));
|
||||
|
||||
return QVariant();
|
||||
}
|
||||
|
||||
void DDBusExtendedAbstractInterface::asyncSetProperty(
|
||||
const QString &propertyName, const QVariant &value) {
|
||||
QDBusMessage msg = QDBusMessage::createMethodCall(
|
||||
service(), path(), *dBusPropertiesInterface(), QStringLiteral("Set"));
|
||||
void DDBusExtendedAbstractInterface::asyncSetProperty(const QString &propertyName, const QVariant &value)
|
||||
{
|
||||
QDBusMessage msg = QDBusMessage::createMethodCall(service(), path(), *dBusPropertiesInterface(), QStringLiteral("Set"));
|
||||
|
||||
msg << interface() << propertyName
|
||||
<< QVariant::fromValue(QDBusVariant(value));
|
||||
msg << interface() << propertyName << QVariant::fromValue(QDBusVariant(value));
|
||||
QDBusPendingReply<> async = connection().asyncCall(msg);
|
||||
DDBusExtendedPendingCallWatcher *watcher =
|
||||
new DDBusExtendedPendingCallWatcher(async, propertyName, value, this);
|
||||
DDBusExtendedPendingCallWatcher *watcher = new DDBusExtendedPendingCallWatcher(async, propertyName, value, this);
|
||||
|
||||
connect(watcher, SIGNAL(finished(QDBusPendingCallWatcher *)), this,
|
||||
SLOT(onAsyncSetPropertyFinished(QDBusPendingCallWatcher *)));
|
||||
connect(
|
||||
watcher, SIGNAL(finished(QDBusPendingCallWatcher *)), this, SLOT(onAsyncSetPropertyFinished(QDBusPendingCallWatcher *)));
|
||||
}
|
||||
|
||||
void DDBusExtendedAbstractInterface::startServiceProcess() {
|
||||
void DDBusExtendedAbstractInterface::startServiceProcess()
|
||||
{
|
||||
const QString &servName = service();
|
||||
|
||||
if (isValid()) {
|
||||
|
@ -312,19 +296,17 @@ void DDBusExtendedAbstractInterface::startServiceProcess() {
|
|||
return;
|
||||
}
|
||||
|
||||
QDBusMessage msg = QDBusMessage::createMethodCall(
|
||||
"org.freedesktop.DBus", "/", *dBusInterface(),
|
||||
QStringLiteral("StartServiceByName"));
|
||||
QDBusMessage msg =
|
||||
QDBusMessage::createMethodCall("org.freedesktop.DBus", "/", *dBusInterface(), QStringLiteral("StartServiceByName"));
|
||||
msg << servName << quint32(0);
|
||||
QDBusPendingReply<quint32> async = connection().asyncCall(msg);
|
||||
QDBusPendingCallWatcher *watcher = new QDBusPendingCallWatcher(async, this);
|
||||
|
||||
connect(watcher, &QDBusPendingCallWatcher::finished, this,
|
||||
&DDBusExtendedAbstractInterface::onStartServiceProcessFinished);
|
||||
connect(watcher, &QDBusPendingCallWatcher::finished, this, &DDBusExtendedAbstractInterface::onStartServiceProcessFinished);
|
||||
}
|
||||
|
||||
void DDBusExtendedAbstractInterface::onStartServiceProcessFinished(
|
||||
QDBusPendingCallWatcher *w) {
|
||||
void DDBusExtendedAbstractInterface::onStartServiceProcessFinished(QDBusPendingCallWatcher *w)
|
||||
{
|
||||
if (w->isError()) {
|
||||
m_lastExtendedError = w->error();
|
||||
} else {
|
||||
|
@ -338,10 +320,9 @@ void DDBusExtendedAbstractInterface::onStartServiceProcessFinished(
|
|||
w->deleteLater();
|
||||
}
|
||||
|
||||
void DDBusExtendedAbstractInterface::onAsyncPropertyFinished(
|
||||
QDBusPendingCallWatcher *w) {
|
||||
DDBusExtendedPendingCallWatcher *watcher =
|
||||
qobject_cast<DDBusExtendedPendingCallWatcher *>(w);
|
||||
void DDBusExtendedAbstractInterface::onAsyncPropertyFinished(QDBusPendingCallWatcher *w)
|
||||
{
|
||||
DDBusExtendedPendingCallWatcher *watcher = qobject_cast<DDBusExtendedPendingCallWatcher *>(w);
|
||||
Q_ASSERT(watcher);
|
||||
|
||||
QDBusPendingReply<QVariant> reply = *watcher;
|
||||
|
@ -349,11 +330,8 @@ void DDBusExtendedAbstractInterface::onAsyncPropertyFinished(
|
|||
if (reply.isError()) {
|
||||
m_lastExtendedError = reply.error();
|
||||
} else {
|
||||
int propertyIndex = metaObject()->indexOfProperty(
|
||||
watcher->asyncProperty().toLatin1().constData());
|
||||
QVariant value =
|
||||
demarshall(interface(), metaObject()->property(propertyIndex),
|
||||
reply.value(), &m_lastExtendedError);
|
||||
int propertyIndex = metaObject()->indexOfProperty(watcher->asyncProperty().toLatin1().constData());
|
||||
QVariant value = demarshall(interface(), metaObject()->property(propertyIndex), reply.value(), &m_lastExtendedError);
|
||||
|
||||
if (m_lastExtendedError.isValid()) {
|
||||
Q_EMIT propertyInvalidated(watcher->asyncProperty());
|
||||
|
@ -366,10 +344,9 @@ void DDBusExtendedAbstractInterface::onAsyncPropertyFinished(
|
|||
watcher->deleteLater();
|
||||
}
|
||||
|
||||
void DDBusExtendedAbstractInterface::onAsyncSetPropertyFinished(
|
||||
QDBusPendingCallWatcher *w) {
|
||||
DDBusExtendedPendingCallWatcher *watcher =
|
||||
qobject_cast<DDBusExtendedPendingCallWatcher *>(w);
|
||||
void DDBusExtendedAbstractInterface::onAsyncSetPropertyFinished(QDBusPendingCallWatcher *w)
|
||||
{
|
||||
DDBusExtendedPendingCallWatcher *watcher = qobject_cast<DDBusExtendedPendingCallWatcher *>(w);
|
||||
Q_ASSERT(watcher);
|
||||
|
||||
QDBusPendingReply<> reply = *watcher;
|
||||
|
@ -392,8 +369,8 @@ void DDBusExtendedAbstractInterface::onAsyncSetPropertyFinished(
|
|||
watcher->deleteLater();
|
||||
}
|
||||
|
||||
void DDBusExtendedAbstractInterface::onAsyncGetAllPropertiesFinished(
|
||||
QDBusPendingCallWatcher *watcher) {
|
||||
void DDBusExtendedAbstractInterface::onAsyncGetAllPropertiesFinished(QDBusPendingCallWatcher *watcher)
|
||||
{
|
||||
m_getAllPendingCallWatcher = 0;
|
||||
|
||||
QDBusPendingReply<QVariantMap> reply = *watcher;
|
||||
|
@ -413,21 +390,19 @@ void DDBusExtendedAbstractInterface::onAsyncGetAllPropertiesFinished(
|
|||
watcher->deleteLater();
|
||||
}
|
||||
|
||||
void DDBusExtendedAbstractInterface::onPropertiesChanged(
|
||||
const QString &interfaceName, const QVariantMap &changedProperties,
|
||||
const QStringList &invalidatedProperties) {
|
||||
void DDBusExtendedAbstractInterface::onPropertiesChanged(const QString &interfaceName,
|
||||
const QVariantMap &changedProperties,
|
||||
const QStringList &invalidatedProperties)
|
||||
{
|
||||
if (interfaceName == interface()) {
|
||||
QVariantMap::const_iterator i = changedProperties.constBegin();
|
||||
while (i != changedProperties.constEnd()) {
|
||||
int propertyIndex =
|
||||
metaObject()->indexOfProperty(i.key().toLatin1().constData());
|
||||
int propertyIndex = metaObject()->indexOfProperty(i.key().toLatin1().constData());
|
||||
|
||||
if (-1 == propertyIndex) {
|
||||
qDebug() << Q_FUNC_INFO << "Got unknown changed property" << i.key();
|
||||
} else {
|
||||
QVariant value =
|
||||
demarshall(interface(), metaObject()->property(propertyIndex),
|
||||
i.value(), &m_lastExtendedError);
|
||||
QVariant value = demarshall(interface(), metaObject()->property(propertyIndex), i.value(), &m_lastExtendedError);
|
||||
|
||||
if (m_lastExtendedError.isValid()) {
|
||||
Q_EMIT propertyInvalidated(i.key());
|
||||
|
@ -453,8 +428,8 @@ void DDBusExtendedAbstractInterface::onPropertiesChanged(
|
|||
}
|
||||
}
|
||||
|
||||
void DDBusExtendedAbstractInterface::onDBusNameOwnerChanged(
|
||||
const QString &name, const QString &oldOwner, const QString &newOwner) {
|
||||
void DDBusExtendedAbstractInterface::onDBusNameOwnerChanged(const QString &name, const QString &oldOwner, const QString &newOwner)
|
||||
{
|
||||
if (name == service() && oldOwner.isEmpty()) {
|
||||
m_dbusOwner = newOwner;
|
||||
Q_EMIT serviceValidChanged(true);
|
||||
|
@ -464,9 +439,11 @@ void DDBusExtendedAbstractInterface::onDBusNameOwnerChanged(
|
|||
}
|
||||
}
|
||||
|
||||
QVariant DDBusExtendedAbstractInterface::demarshall(
|
||||
const QString &interface, const QMetaProperty &metaProperty,
|
||||
const QVariant &value, QDBusError *error) {
|
||||
QVariant DDBusExtendedAbstractInterface::demarshall(const QString &interface,
|
||||
const QMetaProperty &metaProperty,
|
||||
const QVariant &value,
|
||||
QDBusError *error)
|
||||
{
|
||||
Q_ASSERT(metaProperty.isValid());
|
||||
Q_ASSERT(error != 0);
|
||||
|
||||
|
@ -478,45 +455,42 @@ QVariant DDBusExtendedAbstractInterface::demarshall(
|
|||
|
||||
QVariant result = QVariant(metaProperty.userType(), (void *)0);
|
||||
QString errorMessage;
|
||||
const char *expectedSignature =
|
||||
QDBusMetaType::typeToSignature(metaProperty.userType());
|
||||
const char *expectedSignature = QDBusMetaType::typeToSignature(metaProperty.userType());
|
||||
|
||||
if (value.userType() == qMetaTypeId<QDBusArgument>()) {
|
||||
// demarshalling a DBus argument ...
|
||||
QDBusArgument dbusArg = value.value<QDBusArgument>();
|
||||
|
||||
if (expectedSignature == dbusArg.currentSignature().toLatin1()) {
|
||||
QDBusMetaType::demarshall(dbusArg, metaProperty.userType(),
|
||||
result.data());
|
||||
QDBusMetaType::demarshall(dbusArg, metaProperty.userType(), result.data());
|
||||
if (!result.isValid()) {
|
||||
errorMessage =
|
||||
QStringLiteral("Unexpected failure demarshalling "
|
||||
errorMessage = QStringLiteral("Unexpected failure demarshalling "
|
||||
"upon PropertiesChanged signal arrival "
|
||||
"for property `%3.%4' (expected type `%5' (%6))")
|
||||
.arg(interface, QString::fromLatin1(metaProperty.name()),
|
||||
.arg(interface,
|
||||
QString::fromLatin1(metaProperty.name()),
|
||||
QString::fromLatin1(metaProperty.typeName()),
|
||||
expectedSignature);
|
||||
}
|
||||
} else {
|
||||
errorMessage =
|
||||
QStringLiteral("Unexpected `user type' (%2) "
|
||||
errorMessage = QStringLiteral("Unexpected `user type' (%2) "
|
||||
"upon PropertiesChanged signal arrival "
|
||||
"for property `%3.%4' (expected type `%5' (%6))")
|
||||
.arg(dbusArg.currentSignature(), interface,
|
||||
.arg(dbusArg.currentSignature(),
|
||||
interface,
|
||||
QString::fromLatin1(metaProperty.name()),
|
||||
QString::fromLatin1(metaProperty.typeName()),
|
||||
QString::fromLatin1(expectedSignature));
|
||||
}
|
||||
} else {
|
||||
const char *actualSignature =
|
||||
QDBusMetaType::typeToSignature(value.userType());
|
||||
const char *actualSignature = QDBusMetaType::typeToSignature(value.userType());
|
||||
|
||||
errorMessage =
|
||||
QStringLiteral("Unexpected `%1' (%2) "
|
||||
errorMessage = QStringLiteral("Unexpected `%1' (%2) "
|
||||
"upon PropertiesChanged signal arrival "
|
||||
"for property `%3.%4' (expected type `%5' (%6))")
|
||||
.arg(QString::fromLatin1(value.typeName()),
|
||||
QString::fromLatin1(actualSignature), interface,
|
||||
QString::fromLatin1(actualSignature),
|
||||
interface,
|
||||
QString::fromLatin1(metaProperty.name()),
|
||||
QString::fromLatin1(metaProperty.typeName()),
|
||||
QString::fromLatin1(expectedSignature));
|
||||
|
@ -525,8 +499,7 @@ QVariant DDBusExtendedAbstractInterface::demarshall(
|
|||
if (errorMessage.isEmpty()) {
|
||||
*error = QDBusError();
|
||||
} else {
|
||||
*error =
|
||||
QDBusMessage::createError(QDBusError::InvalidSignature, errorMessage);
|
||||
*error = QDBusMessage::createError(QDBusError::InvalidSignature, errorMessage);
|
||||
qDebug() << Q_FUNC_INFO << errorMessage;
|
||||
}
|
||||
|
||||
|
|
|
@ -5,11 +5,15 @@
|
|||
#include "ddbusextendedpendingcallwatcher_p.h"
|
||||
|
||||
DCORE_BEGIN_NAMESPACE
|
||||
DDBusExtendedPendingCallWatcher::DDBusExtendedPendingCallWatcher(
|
||||
const QDBusPendingCall &call, const QString &asyncProperty,
|
||||
const QVariant &previousValue, QObject *parent)
|
||||
: QDBusPendingCallWatcher(call, parent), m_asyncProperty(asyncProperty),
|
||||
m_previousValue(previousValue) {}
|
||||
DDBusExtendedPendingCallWatcher::DDBusExtendedPendingCallWatcher(const QDBusPendingCall &call,
|
||||
const QString &asyncProperty,
|
||||
const QVariant &previousValue,
|
||||
QObject *parent)
|
||||
: QDBusPendingCallWatcher(call, parent)
|
||||
, m_asyncProperty(asyncProperty)
|
||||
, m_previousValue(previousValue)
|
||||
{
|
||||
}
|
||||
|
||||
DDBusExtendedPendingCallWatcher::~DDBusExtendedPendingCallWatcher() {}
|
||||
DCORE_END_NAMESPACE
|
||||
|
|
|
@ -21,7 +21,8 @@
|
|||
#include <QDBusPendingCallWatcher>
|
||||
|
||||
DCORE_BEGIN_NAMESPACE
|
||||
class DDBusExtendedPendingCallWatcher : public QDBusPendingCallWatcher {
|
||||
class DDBusExtendedPendingCallWatcher : public QDBusPendingCallWatcher
|
||||
{
|
||||
Q_OBJECT
|
||||
|
||||
public:
|
||||
|
|
Loading…
Reference in New Issue