| Line | Source Code | Coverage | 
|---|
| 1 |  | - | 
| 2 |  | - | 
| 3 |  | - | 
| 4 |  | - | 
| 5 |  | - | 
| 6 |  | - | 
| 7 |  | - | 
| 8 |  | - | 
| 9 |  | - | 
| 10 | static int DIRECT_CONNECTION_ONLY = 0; | - | 
| 11 |  | - | 
| 12 | struct QSlotObjectBaseDeleter { | - | 
| 13 | static void cleanup(QtPrivate::QSlotObjectBase *slot) { | - | 
| 14 | if (slot) slot->destroyIfLastRef(); executed:  slot->destroyIfLastRef();Execution Count:372partially evaluated:  slot| yes Evaluation Count:372 | no Evaluation Count:0 | 
 | 0-372 | 
| 15 | } executed:  }Execution Count:372 | 372 | 
| 16 | }; | - | 
| 17 | static int *queuedConnectionTypes(const QList<QByteArray> &typeNames) | - | 
| 18 | { | - | 
| 19 | int *types = new int [typeNames.count() + 1]; | - | 
| 20 | do { if (!(types)) qBadAlloc(); } while (0); never executed: qBadAlloc();executed:  }Execution Count:1780partially evaluated:  !(types)| no Evaluation Count:0 | yes Evaluation Count:1780 | 
partially evaluated:  0| no Evaluation Count:0 | yes Evaluation Count:1780 | 
 | 0-1780 | 
| 21 | for (int i = 0; i < typeNames.count(); ++i) { evaluated:  i < typeNames.count()| yes Evaluation Count:1384 | yes Evaluation Count:1780 | 
 | 1384-1780 | 
| 22 | const QByteArray typeName = typeNames.at(i); | - | 
| 23 | if (typeName.endsWith('*')) partially evaluated:  typeName.endsWith('*')| no Evaluation Count:0 | yes Evaluation Count:1384 | 
 | 0-1384 | 
| 24 | types[i] = QMetaType::VoidStar; never executed: types[i] = QMetaType::VoidStar; | 0 | 
| 25 | else | - | 
| 26 | types[i] = QMetaType::type(typeName); executed:  types[i] = QMetaType::type(typeName);Execution Count:1384 | 1384 | 
| 27 |  | - | 
| 28 | if (!types[i]) { partially evaluated:  !types[i]| no Evaluation Count:0 | yes Evaluation Count:1384 | 
 | 0-1384 | 
| 29 | QMessageLogger("kernel/qobject.cpp", 92, __PRETTY_FUNCTION__).warning("QObject::connect: Cannot queue arguments of type '%s'\n" | - | 
| 30 | "(Make sure '%s' is registered using qRegisterMetaType().)", | - | 
| 31 | typeName.constData(), typeName.constData()); | - | 
| 32 | delete [] types; | - | 
| 33 | return 0; never executed: return 0; | 0 | 
| 34 | } | - | 
| 35 | } executed:  }Execution Count:1384 | 1384 | 
| 36 | types[typeNames.count()] = 0; | - | 
| 37 |  | - | 
| 38 | return types; executed:  return types;Execution Count:1780 | 1780 | 
| 39 | } | - | 
| 40 |  | - | 
| 41 | static int *queuedConnectionTypes(const QArgumentType *argumentTypes, int argc) | - | 
| 42 | { | - | 
| 43 | QScopedArrayPointer<int> types(new int [argc + 1]); | - | 
| 44 | for (int i = 0; i < argc; ++i) { evaluated:  i < argc| yes Evaluation Count:34165 | yes Evaluation Count:21073 | 
 | 21073-34165 | 
| 45 | const QArgumentType &type = argumentTypes[i]; | - | 
| 46 | if (type.type()) evaluated:  type.type()| yes Evaluation Count:34164 | yes Evaluation Count:1 | 
 | 1-34164 | 
| 47 | types[i] = type.type(); executed:  types[i] = type.type();Execution Count:34164 | 34164 | 
| 48 | else if (type.name().endsWith('*')) partially evaluated:  type.name().endsWith('*')| yes Evaluation Count:1 | no Evaluation Count:0 | 
 | 0-1 | 
| 49 | types[i] = QMetaType::VoidStar; executed:  types[i] = QMetaType::VoidStar;Execution Count:1 | 1 | 
| 50 | else | - | 
| 51 | types[i] = QMetaType::type(type.name()); never executed: types[i] = QMetaType::type(type.name()); | 0 | 
| 52 |  | - | 
| 53 | if (!types[i]) { partially evaluated:  !types[i]| no Evaluation Count:0 | yes Evaluation Count:34165 | 
 | 0-34165 | 
| 54 | QMessageLogger("kernel/qobject.cpp", 117, __PRETTY_FUNCTION__).warning("QObject::connect: Cannot queue arguments of type '%s'\n" | - | 
| 55 | "(Make sure '%s' is registered using qRegisterMetaType().)", | - | 
| 56 | type.name().constData(), type.name().constData()); | - | 
| 57 | return 0; never executed: return 0; | 0 | 
| 58 | } | - | 
| 59 | } executed:  }Execution Count:34165 | 34165 | 
| 60 | types[argc] = 0; | - | 
| 61 |  | - | 
| 62 | return types.take(); executed:  return types.take();Execution Count:21073 | 21073 | 
| 63 | } | - | 
| 64 |  | - | 
| 65 | static QBasicMutex _q_ObjectMutexPool[131]; | - | 
| 66 |  | - | 
| 67 |  | - | 
| 68 |  | - | 
| 69 |  | - | 
| 70 |  | - | 
| 71 | static inline QMutex *signalSlotLock(const QObject *o) | - | 
| 72 | { | - | 
| 73 | return static_cast<QMutex *>(&_q_ObjectMutexPool[ | 9395226 | 
| 74 | uint(quintptr(o)) % sizeof(_q_ObjectMutexPool)/sizeof(QBasicMutex)]); executed:  return static_cast<QMutex *>(&_q_ObjectMutexPool[ uint(quintptr(o)) % sizeof(_q_ObjectMutexPool)/sizeof(QBasicMutex)]);Execution Count:9395226 | 9395226 | 
| 75 | } | - | 
| 76 |  | - | 
| 77 | extern "C" __attribute__((visibility("default"))) void qt_addObject(QObject *) | - | 
| 78 | {} | - | 
| 79 |  | - | 
| 80 | extern "C" __attribute__((visibility("default"))) void qt_removeObject(QObject *) | - | 
| 81 | {} | - | 
| 82 |  | - | 
| 83 | struct QConnectionSenderSwitcher { | - | 
| 84 | QObject *receiver; | - | 
| 85 | QObjectPrivate::Sender *previousSender; | - | 
| 86 | QObjectPrivate::Sender currentSender; | - | 
| 87 | bool switched; | - | 
| 88 |  | - | 
| 89 | inline QConnectionSenderSwitcher() : switched(false) {} executed:  }Execution Count:8326818 | 8326818 | 
| 90 |  | - | 
| 91 | inline QConnectionSenderSwitcher(QObject *receiver, QObject *sender, int signal_absolute_id) | - | 
| 92 | { | - | 
| 93 | switchSender(receiver, sender, signal_absolute_id); | - | 
| 94 | } executed:  }Execution Count:91586 | 91586 | 
| 95 |  | - | 
| 96 | inline void switchSender(QObject *receiver, QObject *sender, int signal_absolute_id) | - | 
| 97 | { | - | 
| 98 | this->receiver = receiver; | - | 
| 99 | currentSender.sender = sender; | - | 
| 100 | currentSender.signal = signal_absolute_id; | - | 
| 101 | currentSender.ref = 1; | - | 
| 102 | previousSender = QObjectPrivate::setCurrentSender(receiver, ¤tSender); | - | 
| 103 | switched = true; | - | 
| 104 | } executed:  }Execution Count:8418280 | 8418280 | 
| 105 |  | - | 
| 106 | inline ~QConnectionSenderSwitcher() | - | 
| 107 | { | - | 
| 108 | if (switched) evaluated:  switched| yes Evaluation Count:8418322 | yes Evaluation Count:105 | 
 | 105-8418322 | 
| 109 | QObjectPrivate::resetCurrentSender(receiver, ¤tSender, previousSender); executed:  QObjectPrivate::resetCurrentSender(receiver, ¤tSender, previousSender);Execution Count:8418322 | 8418322 | 
| 110 | } executed:  }Execution Count:8418426 | 8418426 | 
| 111 | private: | - | 
| 112 | QConnectionSenderSwitcher(const QConnectionSenderSwitcher &) = delete; QConnectionSenderSwitcher &operator=(const QConnectionSenderSwitcher &) = delete; | - | 
| 113 | }; | - | 
| 114 |  | - | 
| 115 |  | - | 
| 116 | void (*QAbstractDeclarativeData::destroyed)(QAbstractDeclarativeData *, QObject *) = 0; | - | 
| 117 | void (*QAbstractDeclarativeData::parentChanged)(QAbstractDeclarativeData *, QObject *, QObject *) = 0; | - | 
| 118 | void (*QAbstractDeclarativeData::signalEmitted)(QAbstractDeclarativeData *, QObject *, int, void **) = 0; | - | 
| 119 | int (*QAbstractDeclarativeData::receivers)(QAbstractDeclarativeData *, const QObject *, int) = 0; | - | 
| 120 | bool (*QAbstractDeclarativeData::isSignalConnected)(QAbstractDeclarativeData *, const QObject *, int) = 0; | - | 
| 121 |  | - | 
| 122 | QObjectData::~QObjectData() {} | - | 
| 123 |  | - | 
| 124 | QMetaObject *QObjectData::dynamicMetaObject() const | - | 
| 125 | { | - | 
| 126 | return metaObject->toDynamicMetaObject(q_ptr); never executed: return metaObject->toDynamicMetaObject(q_ptr); | 0 | 
| 127 | } | - | 
| 128 |  | - | 
| 129 | QObjectPrivate::QObjectPrivate(int version) | - | 
| 130 | : threadData(0), connectionLists(0), senders(0), currentSender(0), currentChildBeingDeleted(0) | - | 
| 131 | { | - | 
| 132 | if (version != QObjectPrivateVersion) partially evaluated:  version != QObjectPrivateVersion| no Evaluation Count:0 | yes Evaluation Count:3600974 | 
 | 0-3600974 | 
| 133 | QMessageLogger("kernel/qobject.cpp", 196, __PRETTY_FUNCTION__).fatal("Cannot mix incompatible Qt library (version 0x%x) with this library (version 0x%x)", | 0 | 
| 134 | version, QObjectPrivateVersion); never executed: QMessageLogger("kernel/qobject.cpp", 196, __PRETTY_FUNCTION__).fatal("Cannot mix incompatible Qt library (version 0x%x) with this library (version 0x%x)", version, QObjectPrivateVersion); | 0 | 
| 135 |  | - | 
| 136 |  | - | 
| 137 | q_ptr = 0; | - | 
| 138 | parent = 0; | - | 
| 139 | isWidget = false; | - | 
| 140 | blockSig = false; | - | 
| 141 | wasDeleted = false; | - | 
| 142 | isDeletingChildren = false; | - | 
| 143 | sendChildEvents = true; | - | 
| 144 | receiveChildEvents = true; | - | 
| 145 | postedEvents = 0; | - | 
| 146 | extraData = 0; | - | 
| 147 | connectedSignals[0] = connectedSignals[1] = 0; | - | 
| 148 | metaObject = 0; | - | 
| 149 | isWindow = false; | - | 
| 150 | } executed:  }Execution Count:3600979 | 3600979 | 
| 151 |  | - | 
| 152 | QObjectPrivate::~QObjectPrivate() | - | 
| 153 | { | - | 
| 154 | if (extraData && !extraData->runningTimers.isEmpty()) { evaluated:  extraData| yes Evaluation Count:56772 | yes Evaluation Count:3541668 | 
evaluated:  !extraData->runningTimers.isEmpty()| yes Evaluation Count:1245 | yes Evaluation Count:55527 | 
 | 1245-3541668 | 
| 155 |  | - | 
| 156 | if (threadData->eventDispatcher) evaluated:  threadData->eventDispatcher| yes Evaluation Count:1177 | yes Evaluation Count:68 | 
 | 68-1177 | 
| 157 | threadData->eventDispatcher->unregisterTimers(q_ptr); executed:  threadData->eventDispatcher->unregisterTimers(q_ptr);Execution Count:1177 | 1177 | 
| 158 |  | - | 
| 159 |  | - | 
| 160 | for (int i = 0; i < extraData->runningTimers.size(); ++i) evaluated:  i < extraData->runningTimers.size()| yes Evaluation Count:1294 | yes Evaluation Count:1245 | 
 | 1245-1294 | 
| 161 | QAbstractEventDispatcherPrivate::releaseTimerId(extraData->runningTimers.at(i)); executed:  QAbstractEventDispatcherPrivate::releaseTimerId(extraData->runningTimers.at(i));Execution Count:1294 | 1294 | 
| 162 | } executed:  }Execution Count:1245 | 1245 | 
| 163 |  | - | 
| 164 | if (postedEvents) evaluated:  postedEvents| yes Evaluation Count:7312 | yes Evaluation Count:3591124 | 
 | 7312-3591124 | 
| 165 | QCoreApplication::removePostedEvents(q_ptr, 0); executed:  QCoreApplication::removePostedEvents(q_ptr, 0);Execution Count:7312 | 7312 | 
| 166 |  | - | 
| 167 | threadData->deref(); | - | 
| 168 |  | - | 
| 169 | if (metaObject) metaObject->objectDestroyed(q_ptr); never executed: metaObject->objectDestroyed(q_ptr);partially evaluated:  metaObject| no Evaluation Count:0 | yes Evaluation Count:3598488 | 
 | 0-3598488 | 
| 170 |  | - | 
| 171 |  | - | 
| 172 | if (extraData) evaluated:  extraData| yes Evaluation Count:56772 | yes Evaluation Count:3541742 | 
 | 56772-3541742 | 
| 173 | qDeleteAll(extraData->userData); executed:  qDeleteAll(extraData->userData);Execution Count:56772 | 56772 | 
| 174 |  | - | 
| 175 | delete extraData; | - | 
| 176 | } executed:  }Execution Count:3598481 | 3598481 | 
| 177 |  | - | 
| 178 |  | - | 
| 179 |  | - | 
| 180 |  | - | 
| 181 |  | - | 
| 182 | static void computeOffsets(const QMetaObject *metaobject, int *signalOffset, int *methodOffset) | - | 
| 183 | { | - | 
| 184 | *signalOffset = *methodOffset = 0; | - | 
| 185 | const QMetaObject *m = metaobject->d.superdata; | - | 
| 186 | while (m) { evaluated:  m| yes Evaluation Count:10003 | yes Evaluation Count:207552 | 
 | 10003-207552 | 
| 187 | const QMetaObjectPrivate *d = QMetaObjectPrivate::get(m); | - | 
| 188 | *methodOffset += d->methodCount; | - | 
| 189 | qt_noop(); | - | 
| 190 | *signalOffset += d->signalCount; | - | 
| 191 | m = m->d.superdata; | - | 
| 192 | } executed:  }Execution Count:10003 | 10003 | 
| 193 | } executed:  }Execution Count:207552 | 207552 | 
| 194 | class QObjectConnectionListVector : public QVector<QObjectPrivate::ConnectionList> | - | 
| 195 | { | - | 
| 196 | public: | - | 
| 197 | bool orphaned; | - | 
| 198 | bool dirty; | - | 
| 199 | int inUse; | - | 
| 200 | QObjectPrivate::ConnectionList allsignals; | - | 
| 201 |  | - | 
| 202 | QObjectConnectionListVector() | - | 
| 203 | : QVector<QObjectPrivate::ConnectionList>(), orphaned(false), dirty(false), inUse(0) | - | 
| 204 | { } executed:  }Execution Count:78776 | 78776 | 
| 205 |  | - | 
| 206 | QObjectPrivate::ConnectionList &operator[](int at) | - | 
| 207 | { | - | 
| 208 | if (at < 0) evaluated:  at < 0| yes Evaluation Count:185723 | yes Evaluation Count:1584227 | 
 | 185723-1584227 | 
| 209 | return allsignals; executed:  return allsignals;Execution Count:185723 | 185723 | 
| 210 | return QVector<QObjectPrivate::ConnectionList>::operator[](at); executed:  return QVector<QObjectPrivate::ConnectionList>::operator[](at);Execution Count:1584227 | 1584227 | 
| 211 | } | - | 
| 212 | }; | - | 
| 213 |  | - | 
| 214 |  | - | 
| 215 | bool QObjectPrivate::isSender(const QObject *receiver, const char *signal) const | - | 
| 216 | { | - | 
| 217 | const QObject * const q = q_func(); | - | 
| 218 | int signal_index = signalIndex(signal); | - | 
| 219 | if (signal_index < 0) never evaluated: signal_index < 0 | 0 | 
| 220 | return false; never executed: return false; | 0 | 
| 221 | QMutexLocker locker(signalSlotLock(q)); | - | 
| 222 | if (connectionLists) { never evaluated: connectionLists | 0 | 
| 223 | if (signal_index < connectionLists->count()) { never evaluated: signal_index < connectionLists->count() | 0 | 
| 224 | const QObjectPrivate::Connection *c = | - | 
| 225 | connectionLists->at(signal_index).first; | - | 
| 226 |  | - | 
| 227 | while (c) { | 0 | 
| 228 | if (c->receiver == receiver) never evaluated: c->receiver == receiver | 0 | 
| 229 | return true; never executed: return true; | 0 | 
| 230 | c = c->nextConnectionList; | - | 
| 231 | } | 0 | 
| 232 | } | 0 | 
| 233 | } | 0 | 
| 234 | return false; never executed: return false; | 0 | 
| 235 | } | - | 
| 236 |  | - | 
| 237 |  | - | 
| 238 | QObjectList QObjectPrivate::receiverList(const char *signal) const | - | 
| 239 | { | - | 
| 240 | const QObject * const q = q_func(); | - | 
| 241 | QObjectList returnValue; | - | 
| 242 | int signal_index = signalIndex(signal); | - | 
| 243 | if (signal_index < 0) partially evaluated:  signal_index < 0| no Evaluation Count:0 | yes Evaluation Count:1 | 
 | 0-1 | 
| 244 | return returnValue; never executed: return returnValue; | 0 | 
| 245 | QMutexLocker locker(signalSlotLock(q)); | - | 
| 246 | if (connectionLists) { partially evaluated:  connectionLists| no Evaluation Count:0 | yes Evaluation Count:1 | 
 | 0-1 | 
| 247 | if (signal_index < connectionLists->count()) { never evaluated: signal_index < connectionLists->count() | 0 | 
| 248 | const QObjectPrivate::Connection *c = connectionLists->at(signal_index).first; | - | 
| 249 |  | - | 
| 250 | while (c) { | 0 | 
| 251 | if (c->receiver) never evaluated: c->receiver | 0 | 
| 252 | returnValue << c->receiver; never executed: returnValue << c->receiver; | 0 | 
| 253 | c = c->nextConnectionList; | - | 
| 254 | } | 0 | 
| 255 | } | 0 | 
| 256 | } | 0 | 
| 257 | return returnValue; executed:  return returnValue;Execution Count:1 | 1 | 
| 258 | } | - | 
| 259 |  | - | 
| 260 |  | - | 
| 261 | QObjectList QObjectPrivate::senderList() const | - | 
| 262 | { | - | 
| 263 | QObjectList returnValue; | - | 
| 264 | QMutexLocker locker(signalSlotLock(q_func())); | - | 
| 265 | for (Connection *c = senders; c; c = c->next) | 0 | 
| 266 | returnValue << c->sender; never executed: returnValue << c->sender; | 0 | 
| 267 | return returnValue; never executed: return returnValue; | 0 | 
| 268 | } | - | 
| 269 | void QObjectPrivate::addConnection(int signal, Connection *c) | - | 
| 270 | { | - | 
| 271 | qt_noop(); | - | 
| 272 | if (!connectionLists) evaluated:  !connectionLists| yes Evaluation Count:78776 | yes Evaluation Count:411538 | 
 | 78776-411538 | 
| 273 | connectionLists = new QObjectConnectionListVector(); executed:  connectionLists = new QObjectConnectionListVector();Execution Count:78776 | 78776 | 
| 274 | if (signal >= connectionLists->count()) evaluated:  signal >= connectionLists->count()| yes Evaluation Count:160428 | yes Evaluation Count:329886 | 
 | 160428-329886 | 
| 275 | connectionLists->resize(signal + 1); executed:  connectionLists->resize(signal + 1);Execution Count:160429 | 160429 | 
| 276 |  | - | 
| 277 | ConnectionList &connectionList = (*connectionLists)[signal]; | - | 
| 278 | if (connectionList.last) { evaluated:  connectionList.last| yes Evaluation Count:263399 | yes Evaluation Count:226915 | 
 | 226915-263399 | 
| 279 | connectionList.last->nextConnectionList = c; | - | 
| 280 | } else { executed:  }Execution Count:263399 | 263399 | 
| 281 | connectionList.first = c; | - | 
| 282 | } executed:  }Execution Count:226913 | 226913 | 
| 283 | connectionList.last = c; | - | 
| 284 |  | - | 
| 285 | cleanConnectionLists(); | - | 
| 286 |  | - | 
| 287 | c->prev = &(QObjectPrivate::get(c->receiver)->senders); | - | 
| 288 | c->next = *c->prev; | - | 
| 289 | *c->prev = c; | - | 
| 290 | if (c->next) evaluated:  c->next| yes Evaluation Count:311936 | yes Evaluation Count:178370 | 
 | 178370-311936 | 
| 291 | c->next->prev = &c->next; executed:  c->next->prev = &c->next;Execution Count:311936 | 311936 | 
| 292 |  | - | 
| 293 | if (signal < 0) { evaluated:  signal < 0| yes Evaluation Count:133 | yes Evaluation Count:490170 | 
 | 133-490170 | 
| 294 | connectedSignals[0] = connectedSignals[1] = ~0; | - | 
| 295 | } else if (signal < (int)sizeof(connectedSignals) * 8) { evaluated:  signal < (int)sizeof(connectedSignals) * 8| yes Evaluation Count:490168 | yes Evaluation Count:2 | 
executed:  }Execution Count:133 | 2-490168 | 
| 296 | connectedSignals[signal >> 5] |= (1 << (signal & 0x1f)); | - | 
| 297 | } executed:  }Execution Count:490166 | 490166 | 
| 298 | } | - | 
| 299 |  | - | 
| 300 | void QObjectPrivate::cleanConnectionLists() | - | 
| 301 | { | - | 
| 302 | if (connectionLists->dirty && !connectionLists->inUse) { evaluated:  connectionLists->dirty| yes Evaluation Count:107265 | yes Evaluation Count:383042 | 
evaluated:  !connectionLists->inUse| yes Evaluation Count:107068 | yes Evaluation Count:197 | 
 | 197-383042 | 
| 303 |  | - | 
| 304 | for (int signal = -1; signal < connectionLists->count(); ++signal) { evaluated:  signal < connectionLists->count()| yes Evaluation Count:466611 | yes Evaluation Count:107068 | 
 | 107068-466611 | 
| 305 | QObjectPrivate::ConnectionList &connectionList = | - | 
| 306 | (*connectionLists)[signal]; | - | 
| 307 |  | - | 
| 308 |  | - | 
| 309 |  | - | 
| 310 |  | - | 
| 311 | QObjectPrivate::Connection *last = 0; | - | 
| 312 |  | - | 
| 313 | QObjectPrivate::Connection **prev = &connectionList.first; | - | 
| 314 | QObjectPrivate::Connection *c = *prev; | - | 
| 315 | while (c) { evaluated:  c| yes Evaluation Count:315870 | yes Evaluation Count:466611 | 
 | 315870-466611 | 
| 316 | if (c->receiver) { evaluated:  c->receiver| yes Evaluation Count:180581 | yes Evaluation Count:135289 | 
 | 135289-180581 | 
| 317 | last = c; | - | 
| 318 | prev = &c->nextConnectionList; | - | 
| 319 | c = *prev; | - | 
| 320 | } else { executed:  }Execution Count:180581 | 180581 | 
| 321 | QObjectPrivate::Connection *next = c->nextConnectionList; | - | 
| 322 | *prev = next; | - | 
| 323 | c->deref(); | - | 
| 324 | c = next; | - | 
| 325 | } executed:  }Execution Count:135289 | 135289 | 
| 326 | } | - | 
| 327 |  | - | 
| 328 |  | - | 
| 329 |  | - | 
| 330 | connectionList.last = last; | - | 
| 331 | } executed:  }Execution Count:466611 | 466611 | 
| 332 | connectionLists->dirty = false; | - | 
| 333 | } executed:  }Execution Count:107068 | 107068 | 
| 334 | } executed:  }Execution Count:490305 | 490305 | 
| 335 |  | - | 
| 336 |  | - | 
| 337 |  | - | 
| 338 |  | - | 
| 339 | QMetaCallEvent::QMetaCallEvent(ushort method_offset, ushort method_relative, QObjectPrivate::StaticMetaCallFunction callFunction, | - | 
| 340 | const QObject *sender, int signalId, | - | 
| 341 | int nargs, int *types, void **args, QSemaphore *semaphore) | - | 
| 342 | : QEvent(MetaCall), slotObj_(0), sender_(sender), signalId_(signalId), | - | 
| 343 | nargs_(nargs), types_(types), args_(args), semaphore_(semaphore), | - | 
| 344 | callFunction_(callFunction), method_offset_(method_offset), method_relative_(method_relative) | - | 
| 345 | { } executed:  }Execution Count:99311 | 99311 | 
| 346 |  | - | 
| 347 |  | - | 
| 348 |  | - | 
| 349 |  | - | 
| 350 | QMetaCallEvent::QMetaCallEvent(QtPrivate::QSlotObjectBase *slotO, const QObject *sender, int signalId, | - | 
| 351 | int nargs, int *types, void **args, QSemaphore *semaphore) | - | 
| 352 | : QEvent(MetaCall), slotObj_(slotO), sender_(sender), signalId_(signalId), | - | 
| 353 | nargs_(nargs), types_(types), args_(args), semaphore_(semaphore), | - | 
| 354 | callFunction_(0), method_offset_(0), method_relative_(ushort(-1)) | - | 
| 355 | { | - | 
| 356 | if (slotObj_) partially evaluated:  slotObj_| yes Evaluation Count:67 | no Evaluation Count:0 | 
 | 0-67 | 
| 357 | slotObj_->ref(); executed:  slotObj_->ref();Execution Count:67 | 67 | 
| 358 | } executed:  }Execution Count:67 | 67 | 
| 359 |  | - | 
| 360 |  | - | 
| 361 |  | - | 
| 362 |  | - | 
| 363 | QMetaCallEvent::~QMetaCallEvent() | - | 
| 364 | { | - | 
| 365 | if (types_) { evaluated:  types_| yes Evaluation Count:98804 | yes Evaluation Count:750 | 
 | 750-98804 | 
| 366 | for (int i = 0; i < nargs_; ++i) { evaluated:  i < nargs_| yes Evaluation Count:155681 | yes Evaluation Count:98802 | 
 | 98802-155681 | 
| 367 | if (types_[i] && args_[i]) evaluated:  types_[i]| yes Evaluation Count:56895 | yes Evaluation Count:98803 | 
partially evaluated:  args_[i]| yes Evaluation Count:56897 | no Evaluation Count:0 | 
 | 0-98803 | 
| 368 | QMetaType::destroy(types_[i], args_[i]); executed:  QMetaType::destroy(types_[i], args_[i]);Execution Count:56897 | 56897 | 
| 369 | } executed:  }Execution Count:155693 | 155693 | 
| 370 | free(types_); | - | 
| 371 | free(args_); | - | 
| 372 | } executed:  }Execution Count:98818 | 98818 | 
| 373 |  | - | 
| 374 | if (semaphore_) evaluated:  semaphore_| yes Evaluation Count:587 | yes Evaluation Count:98979 | 
 | 587-98979 | 
| 375 | semaphore_->release(); executed:  semaphore_->release();Execution Count:587 | 587 | 
| 376 |  | - | 
| 377 | if (slotObj_) evaluated:  slotObj_| yes Evaluation Count:67 | yes Evaluation Count:99499 | 
 | 67-99499 | 
| 378 | slotObj_->destroyIfLastRef(); executed:  slotObj_->destroyIfLastRef();Execution Count:67 | 67 | 
| 379 | } executed:  }Execution Count:99565 | 99565 | 
| 380 |  | - | 
| 381 |  | - | 
| 382 |  | - | 
| 383 |  | - | 
| 384 | void QMetaCallEvent::placeMetaCall(QObject *object) | - | 
| 385 | { | - | 
| 386 | if (slotObj_) { evaluated:  slotObj_| yes Evaluation Count:67 | yes Evaluation Count:91342 | 
 | 67-91342 | 
| 387 | slotObj_->call(object, args_); | - | 
| 388 | } else if (callFunction_ && method_offset_ <= object->metaObject()->methodOffset()) { executed:  }Execution Count:67evaluated:  callFunction_| yes Evaluation Count:91341 | yes Evaluation Count:7 | 
evaluated:  method_offset_ <= object->metaObject()->methodOffset()| yes Evaluation Count:91316 | yes Evaluation Count:1 | 
 | 1-91341 | 
| 389 | callFunction_(object, QMetaObject::InvokeMetaMethod, method_relative_, args_); | - | 
| 390 | } else { executed:  }Execution Count:91384 | 91384 | 
| 391 | QMetaObject::metacall(object, QMetaObject::InvokeMetaMethod, method_offset_ + method_relative_, args_); | - | 
| 392 | } executed:  }Execution Count:8 | 8 | 
| 393 | } | - | 
| 394 | void *qt_find_obj_child(QObject *parent, const char *type, const QString &name) | - | 
| 395 | { | - | 
| 396 | QObjectList list = parent->children(); | - | 
| 397 | if (list.size() == 0) return 0; never evaluated: list.size() == 0never executed: return 0; | 0 | 
| 398 | for (int i = 0; i < list.size(); ++i) { never evaluated: i < list.size() | 0 | 
| 399 | QObject *obj = list.at(i); | - | 
| 400 | if (name == obj->objectName() && obj->inherits(type)) never evaluated: name == obj->objectName()never evaluated: obj->inherits(type) | 0 | 
| 401 | return obj; never executed: return obj; | 0 | 
| 402 | } | 0 | 
| 403 | return 0; never executed: return 0; | 0 | 
| 404 | } | - | 
| 405 |  | - | 
| 406 |  | - | 
| 407 |  | - | 
| 408 |  | - | 
| 409 |  | - | 
| 410 |  | - | 
| 411 |  | - | 
| 412 | static bool check_parent_thread(QObject *parent, | - | 
| 413 | QThreadData *parentThreadData, | - | 
| 414 | QThreadData *currentThreadData) | - | 
| 415 | { | - | 
| 416 | if (parent && parentThreadData != currentThreadData) { partially evaluated:  parent| yes Evaluation Count:54435 | no Evaluation Count:0 | 
partially evaluated:  parentThreadData != currentThreadData| no Evaluation Count:0 | yes Evaluation Count:54435 | 
 | 0-54435 | 
| 417 | QThread *parentThread = parentThreadData->thread; | - | 
| 418 | QThread *currentThread = currentThreadData->thread; | - | 
| 419 | QMessageLogger("kernel/qobject.cpp", 647, __PRETTY_FUNCTION__).warning("QObject: Cannot create children for a parent that is in a different thread.\n" | - | 
| 420 | "(Parent is %s(%p), parent's thread is %s(%p), current thread is %s(%p)", | - | 
| 421 | parent->metaObject()->className(), | - | 
| 422 | parent, | - | 
| 423 | parentThread ? parentThread->metaObject()->className() : "QThread", | - | 
| 424 | parentThread, | - | 
| 425 | currentThread ? currentThread->metaObject()->className() : "QThread", | - | 
| 426 | currentThread); | - | 
| 427 | return false; never executed: return false; | 0 | 
| 428 | } | - | 
| 429 | return true; executed:  return true;Execution Count:54435 | 54435 | 
| 430 | } | - | 
| 431 | QObject::QObject(QObject *parent) | - | 
| 432 | : d_ptr(new QObjectPrivate) | - | 
| 433 | { | - | 
| 434 | QObjectPrivate * const d = d_func(); | - | 
| 435 | d_ptr->q_ptr = this; | - | 
| 436 | d->threadData = (parent && !parent->thread()) ? parent->d_func()->threadData : QThreadData::current(); evaluated:  parent| yes Evaluation Count:5257 | yes Evaluation Count:77079 | 
evaluated:  !parent->thread()| yes Evaluation Count:1 | yes Evaluation Count:5256 | 
 | 1-77079 | 
| 437 | d->threadData->ref(); | - | 
| 438 | if (parent) { evaluated:  parent| yes Evaluation Count:5257 | yes Evaluation Count:77081 | 
 | 5257-77081 | 
| 439 | try { | - | 
| 440 | if (!check_parent_thread(parent, parent ? parent->d_func()->threadData : 0, d->threadData)) partially evaluated:  !check_parent_thread(parent, parent ? parent->d_func()->threadData : 0, d->threadData)| no Evaluation Count:0 | yes Evaluation Count:5257 | 
 | 0-5257 | 
| 441 | parent = 0; never executed: parent = 0; | 0 | 
| 442 | setParent(parent); | - | 
| 443 | } catch (...) { executed:  }Execution Count:5257 | 5257 | 
| 444 | d->threadData->deref(); | - | 
| 445 | throw; | 0 | 
| 446 | } | - | 
| 447 | } executed:  }Execution Count:5257 | 5257 | 
| 448 | qt_addObject(this); | - | 
| 449 | } executed:  }Execution Count:82339 | 82339 | 
| 450 |  | - | 
| 451 |  | - | 
| 452 |  | - | 
| 453 |  | - | 
| 454 | QObject::QObject(QObjectPrivate &dd, QObject *parent) | - | 
| 455 | : d_ptr(&dd) | - | 
| 456 | { | - | 
| 457 | QObjectPrivate * const d = d_func(); | - | 
| 458 | d_ptr->q_ptr = this; | - | 
| 459 | d->threadData = (parent && !parent->thread()) ? parent->d_func()->threadData : QThreadData::current(); evaluated:  parent| yes Evaluation Count:49176 | yes Evaluation Count:3469456 | 
partially evaluated:  !parent->thread()| no Evaluation Count:0 | yes Evaluation Count:49177 | 
 | 0-3469456 | 
| 460 | d->threadData->ref(); | - | 
| 461 | if (parent) { evaluated:  parent| yes Evaluation Count:49178 | yes Evaluation Count:3469461 | 
 | 49178-3469461 | 
| 462 | try { | - | 
| 463 | if (!check_parent_thread(parent, parent ? parent->d_func()->threadData : 0, d->threadData)) partially evaluated:  !check_parent_thread(parent, parent ? parent->d_func()->threadData : 0, d->threadData)| no Evaluation Count:0 | yes Evaluation Count:49178 | 
 | 0-49178 | 
| 464 | parent = 0; never executed: parent = 0; | 0 | 
| 465 | if (d->isWidget) { partially evaluated:  d->isWidget| no Evaluation Count:0 | yes Evaluation Count:49178 | 
 | 0-49178 | 
| 466 | if (parent) { | 0 | 
| 467 | d->parent = parent; | - | 
| 468 | d->parent->d_func()->children.append(this); | - | 
| 469 | } | 0 | 
| 470 |  | - | 
| 471 | } else { | 0 | 
| 472 | setParent(parent); | - | 
| 473 | } executed:  }Execution Count:49177 | 49177 | 
| 474 | } catch (...) { | - | 
| 475 | d->threadData->deref(); | - | 
| 476 | throw; | 0 | 
| 477 | } | - | 
| 478 | } executed:  }Execution Count:49177 | 49177 | 
| 479 | qt_addObject(this); | - | 
| 480 | } executed:  }Execution Count:3518615 | 3518615 | 
| 481 | QObject::~QObject() | - | 
| 482 | { | - | 
| 483 | QObjectPrivate * const d = d_func(); | - | 
| 484 | d->wasDeleted = true; | - | 
| 485 | d->blockSig = 0; | - | 
| 486 |  | - | 
| 487 | QtSharedPointer::ExternalRefCountData *sharedRefcount = d->sharedRefcount.load(); | - | 
| 488 | if (sharedRefcount) { evaluated:  sharedRefcount| yes Evaluation Count:38488 | yes Evaluation Count:3560078 | 
 | 38488-3560078 | 
| 489 | if (sharedRefcount->strongref.load() > 0) { partially evaluated:  sharedRefcount->strongref.load() > 0| no Evaluation Count:0 | yes Evaluation Count:38489 | 
 | 0-38489 | 
| 490 | QMessageLogger("kernel/qobject.cpp", 759, __PRETTY_FUNCTION__).warning("QObject: shared QObject was deleted directly. The program is malformed and may crash."); | - | 
| 491 |  | - | 
| 492 | } | 0 | 
| 493 |  | - | 
| 494 |  | - | 
| 495 | sharedRefcount->strongref.store(0); | - | 
| 496 | if (!sharedRefcount->weakref.deref()) evaluated:  !sharedRefcount->weakref.deref()| yes Evaluation Count:16944 | yes Evaluation Count:21546 | 
 | 16944-21546 | 
| 497 | delete sharedRefcount; executed:  delete sharedRefcount;Execution Count:16944 | 16944 | 
| 498 | } executed:  }Execution Count:38489 | 38489 | 
| 499 |  | - | 
| 500 | if (!d->isWidget && d->isSignalConnected(0)) { evaluated:  !d->isWidget| yes Evaluation Count:3555579 | yes Evaluation Count:42959 | 
evaluated:  d->isSignalConnected(0)| yes Evaluation Count:4392 | yes Evaluation Count:3551228 | 
 | 4392-3555579 | 
| 501 | try { | - | 
| 502 | destroyed(this); | - | 
| 503 | } catch (...) { executed:  }Execution Count:4392 | 4392 | 
| 504 |  | - | 
| 505 |  | - | 
| 506 | QMessageLogger("kernel/qobject.cpp", 775, __PRETTY_FUNCTION__).warning("Detected an unexpected exception in ~QObject while emitting destroyed()."); | - | 
| 507 | throw; | 0 | 
| 508 | } | - | 
| 509 | } executed:  }Execution Count:4392 | 4392 | 
| 510 |  | - | 
| 511 | if (d->declarativeData) partially evaluated:  d->declarativeData| no Evaluation Count:0 | yes Evaluation Count:3598572 | 
 | 0-3598572 | 
| 512 | QAbstractDeclarativeData::destroyed(d->declarativeData, this); never executed: QAbstractDeclarativeData::destroyed(d->declarativeData, this); | 0 | 
| 513 |  | - | 
| 514 |  | - | 
| 515 | if (d->currentSender != 0) evaluated:  d->currentSender != 0| yes Evaluation Count:30 | yes Evaluation Count:3598521 | 
 | 30-3598521 | 
| 516 | d->currentSender->ref = 0; executed:  d->currentSender->ref = 0;Execution Count:30 | 30 | 
| 517 | d->currentSender = 0; | - | 
| 518 |  | - | 
| 519 | if (d->connectionLists || d->senders) { evaluated:  d->connectionLists| yes Evaluation Count:76806 | yes Evaluation Count:3521743 | 
evaluated:  d->senders| yes Evaluation Count:54148 | yes Evaluation Count:3467625 | 
 | 54148-3521743 | 
| 520 | QMutex *signalSlotMutex = signalSlotLock(this); | - | 
| 521 | QMutexLocker locker(signalSlotMutex); | - | 
| 522 |  | - | 
| 523 |  | - | 
| 524 | if (d->connectionLists) { evaluated:  d->connectionLists| yes Evaluation Count:76806 | yes Evaluation Count:54148 | 
 | 54148-76806 | 
| 525 | ++d->connectionLists->inUse; | - | 
| 526 | int connectionListsCount = d->connectionLists->count(); | - | 
| 527 | for (int signal = -1; signal < connectionListsCount; ++signal) { evaluated:  signal < connectionListsCount| yes Evaluation Count:674595 | yes Evaluation Count:76808 | 
 | 76808-674595 | 
| 528 | QObjectPrivate::ConnectionList &connectionList = | - | 
| 529 | (*d->connectionLists)[signal]; | - | 
| 530 |  | - | 
| 531 | while (QObjectPrivate::Connection *c = connectionList.first) { evaluated:  QObjectPrivate::Connection *c = connectionList.first| yes Evaluation Count:340979 | yes Evaluation Count:674607 | 
 | 340979-674607 | 
| 532 | if (!c->receiver) { evaluated:  !c->receiver| yes Evaluation Count:121519 | yes Evaluation Count:219464 | 
 | 121519-219464 | 
| 533 | connectionList.first = c->nextConnectionList; | - | 
| 534 | c->deref(); | - | 
| 535 | continue; executed:  continue;Execution Count:121520 | 121520 | 
| 536 | } | - | 
| 537 |  | - | 
| 538 | QMutex *m = signalSlotLock(c->receiver); | - | 
| 539 | bool needToUnlock = QOrderedMutexLocker::relock(signalSlotMutex, m); | - | 
| 540 |  | - | 
| 541 | if (c->receiver) { evaluated:  c->receiver| yes Evaluation Count:219422 | yes Evaluation Count:50 | 
 | 50-219422 | 
| 542 | *c->prev = c->next; | - | 
| 543 | if (c->next) c->next->prev = c->prev; executed:  c->next->prev = c->prev;Execution Count:129502evaluated:  c->next| yes Evaluation Count:129502 | yes Evaluation Count:89920 | 
 | 89920-129502 | 
| 544 | } executed:  }Execution Count:219422 | 219422 | 
| 545 | c->receiver = 0; | - | 
| 546 | if (needToUnlock) evaluated:  needToUnlock| yes Evaluation Count:210921 | yes Evaluation Count:8551 | 
 | 8551-210921 | 
| 547 | m->unlock(); executed:  m->unlock();Execution Count:210920 | 210920 | 
| 548 |  | - | 
| 549 | connectionList.first = c->nextConnectionList; | - | 
| 550 | c->deref(); | - | 
| 551 | } executed:  }Execution Count:219470 | 219470 | 
| 552 | } executed:  }Execution Count:674607 | 674607 | 
| 553 |  | - | 
| 554 | if (!--d->connectionLists->inUse) { evaluated:  !--d->connectionLists->inUse| yes Evaluation Count:76734 | yes Evaluation Count:74 | 
 | 74-76734 | 
| 555 | delete d->connectionLists; | - | 
| 556 | } else { executed:  }Execution Count:76734 | 76734 | 
| 557 | d->connectionLists->orphaned = true; | - | 
| 558 | } executed:  }Execution Count:74 | 74 | 
| 559 | d->connectionLists = 0; | - | 
| 560 | } executed:  }Execution Count:76808 | 76808 | 
| 561 |  | - | 
| 562 |  | - | 
| 563 | QObjectPrivate::Connection *node = d->senders; | - | 
| 564 | while (node) { evaluated:  node| yes Evaluation Count:139795 | yes Evaluation Count:130955 | 
 | 130955-139795 | 
| 565 | QObject *sender = node->sender; | - | 
| 566 | QMutex *m = signalSlotLock(sender); | - | 
| 567 | node->prev = &node; | - | 
| 568 | bool needToUnlock = QOrderedMutexLocker::relock(signalSlotMutex, m); | - | 
| 569 |  | - | 
| 570 | if (!node || node->sender != sender) { evaluated:  !node| yes Evaluation Count:12 | yes Evaluation Count:139783 | 
evaluated:  node->sender != sender| yes Evaluation Count:3 | yes Evaluation Count:139780 | 
 | 3-139783 | 
| 571 | m->unlock(); | - | 
| 572 | continue; executed:  continue;Execution Count:15 | 15 | 
| 573 | } | - | 
| 574 | node->receiver = 0; | - | 
| 575 | QObjectConnectionListVector *senderLists = sender->d_func()->connectionLists; | - | 
| 576 | if (senderLists) partially evaluated:  senderLists| yes Evaluation Count:139780 | no Evaluation Count:0 | 
 | 0-139780 | 
| 577 | senderLists->dirty = true; executed:  senderLists->dirty = true;Execution Count:139780 | 139780 | 
| 578 |  | - | 
| 579 | int signal_index = node->signal_index; | - | 
| 580 | node = node->next; | - | 
| 581 | if (needToUnlock) evaluated:  needToUnlock| yes Evaluation Count:138723 | yes Evaluation Count:1057 | 
 | 1057-138723 | 
| 582 | m->unlock(); executed:  m->unlock();Execution Count:138723 | 138723 | 
| 583 | sender->disconnectNotify(QMetaObjectPrivate::signal(sender->metaObject(), signal_index)); | - | 
| 584 | } executed:  }Execution Count:139780 | 139780 | 
| 585 | } executed:  }Execution Count:130955 | 130955 | 
| 586 |  | - | 
| 587 | if (!d->children.isEmpty()) evaluated:  !d->children.isEmpty()| yes Evaluation Count:9602 | yes Evaluation Count:3588931 | 
 | 9602-3588931 | 
| 588 | d->deleteChildren(); executed:  d->deleteChildren();Execution Count:9602 | 9602 | 
| 589 |  | - | 
| 590 | qt_removeObject(this); | - | 
| 591 |  | - | 
| 592 | if (d->parent) evaluated:  d->parent| yes Evaluation Count:111769 | yes Evaluation Count:3486749 | 
 | 111769-3486749 | 
| 593 | d->setParent_helper(0); executed:  d->setParent_helper(0);Execution Count:111769 | 111769 | 
| 594 | } executed:  }Execution Count:3598592 | 3598592 | 
| 595 |  | - | 
| 596 | QObjectPrivate::Connection::~Connection() | - | 
| 597 | { | - | 
| 598 | if (ownArgumentTypes) { evaluated:  ownArgumentTypes| yes Evaluation Count:476247 | yes Evaluation Count:35 | 
 | 35-476247 | 
| 599 | const int *v = argumentTypes.load(); | - | 
| 600 | if (v != &DIRECT_CONNECTION_ONLY) partially evaluated:  v != &DIRECT_CONNECTION_ONLY| yes Evaluation Count:476247 | no Evaluation Count:0 | 
 | 0-476247 | 
| 601 | delete [] v; executed:  delete [] v;Execution Count:476247 | 476247 | 
| 602 | } executed:  }Execution Count:476246 | 476246 | 
| 603 | if (isSlotObject) evaluated:  isSlotObject| yes Evaluation Count:3940 | yes Evaluation Count:472341 | 
 | 3940-472341 | 
| 604 | slotObj->destroyIfLastRef(); executed:  slotObj->destroyIfLastRef();Execution Count:3940 | 3940 | 
| 605 | } executed:  }Execution Count:476281 | 476281 | 
| 606 | QString QObject::objectName() const | - | 
| 607 | { | - | 
| 608 | const QObjectPrivate * const d = d_func(); | - | 
| 609 | return d->extraData ? d->extraData->objectName : QString(); executed:  return d->extraData ? d->extraData->objectName : QString();Execution Count:1726345 | 1726345 | 
| 610 | } | - | 
| 611 |  | - | 
| 612 |  | - | 
| 613 |  | - | 
| 614 |  | - | 
| 615 | void QObject::setObjectName(const QString &name) | - | 
| 616 | { | - | 
| 617 | QObjectPrivate * const d = d_func(); | - | 
| 618 | if (!d->extraData) evaluated:  !d->extraData| yes Evaluation Count:38079 | yes Evaluation Count:411 | 
 | 411-38079 | 
| 619 | d->extraData = new QObjectPrivate::ExtraData; executed:  d->extraData = new QObjectPrivate::ExtraData;Execution Count:38079 | 38079 | 
| 620 |  | - | 
| 621 | if (d->extraData->objectName != name) { evaluated:  d->extraData->objectName != name| yes Evaluation Count:38473 | yes Evaluation Count:17 | 
 | 17-38473 | 
| 622 | d->extraData->objectName = name; | - | 
| 623 | objectNameChanged(d->extraData->objectName, QPrivateSignal()); | - | 
| 624 | } executed:  }Execution Count:38473 | 38473 | 
| 625 | } executed:  }Execution Count:38490 | 38490 | 
| 626 | bool QObject::event(QEvent *e) | - | 
| 627 | { | - | 
| 628 | switch (e->type()) { | - | 
| 629 | case QEvent::Timer: | - | 
| 630 | timerEvent((QTimerEvent*)e); | - | 
| 631 | break; executed:  break;Execution Count:42115 | 42115 | 
| 632 |  | - | 
| 633 | case QEvent::ChildAdded: | - | 
| 634 | case QEvent::ChildPolished: | - | 
| 635 | case QEvent::ChildRemoved: | - | 
| 636 | childEvent((QChildEvent*)e); | - | 
| 637 | break; executed:  break;Execution Count:201906 | 201906 | 
| 638 |  | - | 
| 639 | case QEvent::DeferredDelete: | - | 
| 640 | qDeleteInEventHandler(this); | - | 
| 641 | break; executed:  break;Execution Count:2768 | 2768 | 
| 642 |  | - | 
| 643 | case QEvent::MetaCall: | - | 
| 644 | { | - | 
| 645 | QMetaCallEvent *mce = static_cast<QMetaCallEvent*>(e); | - | 
| 646 |  | - | 
| 647 | QConnectionSenderSwitcher sw(this, const_cast<QObject*>(mce->sender()), mce->signalId()); | - | 
| 648 |  | - | 
| 649 | mce->placeMetaCall(this); | - | 
| 650 | break; executed:  break;Execution Count:91620 | 91620 | 
| 651 | } | - | 
| 652 |  | - | 
| 653 | case QEvent::ThreadChange: { | - | 
| 654 | QObjectPrivate * const d = d_func(); | - | 
| 655 | QThreadData *threadData = d->threadData; | - | 
| 656 | QAbstractEventDispatcher *eventDispatcher = threadData->eventDispatcher; | - | 
| 657 | if (eventDispatcher) { evaluated:  eventDispatcher| yes Evaluation Count:23328 | yes Evaluation Count:7 | 
 | 7-23328 | 
| 658 | QList<QAbstractEventDispatcher::TimerInfo> timers = eventDispatcher->registeredTimers(this); | - | 
| 659 | if (!timers.isEmpty()) { evaluated:  !timers.isEmpty()| yes Evaluation Count:3 | yes Evaluation Count:23301 | 
 | 3-23301 | 
| 660 |  | - | 
| 661 | eventDispatcher->unregisterTimers(this); | - | 
| 662 | QMetaObject::invokeMethod(this, "_q_reregisterTimers", Qt::QueuedConnection, | - | 
| 663 | QArgument<void* >("void*", (new QList<QAbstractEventDispatcher::TimerInfo>(timers)))); | - | 
| 664 | } executed:  }Execution Count:3 | 3 | 
| 665 | } executed:  }Execution Count:23301 | 23301 | 
| 666 | break; executed:  break;Execution Count:23316 | 23316 | 
| 667 | } | - | 
| 668 |  | - | 
| 669 | default: | - | 
| 670 | if (e->type() >= QEvent::User) { evaluated:  e->type() >= QEvent::User| yes Evaluation Count:268767 | yes Evaluation Count:199507 | 
 | 199507-268767 | 
| 671 | customEvent(e); | - | 
| 672 | break; executed:  break;Execution Count:268723 | 268723 | 
| 673 | } | - | 
| 674 | return false; executed:  return false;Execution Count:199507 | 199507 | 
| 675 | } | - | 
| 676 | return true; executed:  return true;Execution Count:630313 | 630313 | 
| 677 | } | - | 
| 678 | void QObject::timerEvent(QTimerEvent *) | - | 
| 679 | { | - | 
| 680 | } | - | 
| 681 | void QObject::childEvent(QChildEvent * ) | - | 
| 682 | { | - | 
| 683 | } | - | 
| 684 | void QObject::customEvent(QEvent * ) | - | 
| 685 | { | - | 
| 686 | } | - | 
| 687 | bool QObject::eventFilter(QObject * , QEvent * ) | - | 
| 688 | { | - | 
| 689 | return false; executed:  return false;Execution Count:205230 | 205230 | 
| 690 | } | - | 
| 691 | bool QObject::blockSignals(bool block) | - | 
| 692 | { | - | 
| 693 | QObjectPrivate * const d = d_func(); | - | 
| 694 | bool previous = d->blockSig; | - | 
| 695 | d->blockSig = block; | - | 
| 696 | return previous; executed:  return previous;Execution Count:26864 | 26864 | 
| 697 | } | - | 
| 698 |  | - | 
| 699 |  | - | 
| 700 |  | - | 
| 701 |  | - | 
| 702 |  | - | 
| 703 |  | - | 
| 704 | QThread *QObject::thread() const | - | 
| 705 | { | - | 
| 706 | return d_func()->threadData->thread; executed:  return d_func()->threadData->thread;Execution Count:2174759 | 2174759 | 
| 707 | } | - | 
| 708 | void QObject::moveToThread(QThread *targetThread) | - | 
| 709 | { | - | 
| 710 | QObjectPrivate * const d = d_func(); | - | 
| 711 |  | - | 
| 712 | if (d->threadData->thread == targetThread) { evaluated:  d->threadData->thread == targetThread| yes Evaluation Count:8922 | yes Evaluation Count:23167 | 
 | 8922-23167 | 
| 713 |  | - | 
| 714 | return; executed:  return;Execution Count:8922 | 8922 | 
| 715 | } | - | 
| 716 |  | - | 
| 717 | if (d->parent != 0) { partially evaluated:  d->parent != 0| no Evaluation Count:0 | yes Evaluation Count:23168 | 
 | 0-23168 | 
| 718 | QMessageLogger("kernel/qobject.cpp", 1284, __PRETTY_FUNCTION__).warning("QObject::moveToThread: Cannot move objects with a parent"); | - | 
| 719 | return; | 0 | 
| 720 | } | - | 
| 721 | if (d->isWidget) { partially evaluated:  d->isWidget| no Evaluation Count:0 | yes Evaluation Count:23165 | 
 | 0-23165 | 
| 722 | QMessageLogger("kernel/qobject.cpp", 1288, __PRETTY_FUNCTION__).warning("QObject::moveToThread: Widgets cannot be moved to a new thread"); | - | 
| 723 | return; | 0 | 
| 724 | } | - | 
| 725 |  | - | 
| 726 | QThreadData *currentData = QThreadData::current(); | - | 
| 727 | QThreadData *targetData = targetThread ? QThreadData::get2(targetThread) : new QThreadData(0); evaluated:  targetThread| yes Evaluation Count:23156 | yes Evaluation Count:5 | 
 | 5-23156 | 
| 728 | if (d->threadData->thread == 0 && currentData == targetData) { evaluated:  d->threadData->thread == 0| yes Evaluation Count:3 | yes Evaluation Count:23168 | 
partially evaluated:  currentData == targetData| yes Evaluation Count:3 | no Evaluation Count:0 | 
 | 0-23168 | 
| 729 |  | - | 
| 730 | currentData = d->threadData; | - | 
| 731 | } else if (d->threadData != currentData) { executed:  }Execution Count:3partially evaluated:  d->threadData != currentData| no Evaluation Count:0 | yes Evaluation Count:23168 | 
 | 0-23168 | 
| 732 | QMessageLogger("kernel/qobject.cpp", 1298, __PRETTY_FUNCTION__).warning("QObject::moveToThread: Current thread (%p) is not the object's thread (%p).\n" | - | 
| 733 | "Cannot move to target thread (%p)\n", | - | 
| 734 | currentData->thread, d->threadData->thread, targetData->thread); | - | 
| 735 |  | - | 
| 736 |  | - | 
| 737 |  | - | 
| 738 |  | - | 
| 739 |  | - | 
| 740 |  | - | 
| 741 |  | - | 
| 742 | return; | 0 | 
| 743 | } | - | 
| 744 |  | - | 
| 745 |  | - | 
| 746 | d->moveToThread_helper(); | - | 
| 747 |  | - | 
| 748 | QOrderedMutexLocker locker(¤tData->postEventList.mutex, | - | 
| 749 | &targetData->postEventList.mutex); | - | 
| 750 |  | - | 
| 751 |  | - | 
| 752 | currentData->ref(); | - | 
| 753 |  | - | 
| 754 |  | - | 
| 755 | d_func()->setThreadData_helper(currentData, targetData); | - | 
| 756 |  | - | 
| 757 | locker.unlock(); | - | 
| 758 |  | - | 
| 759 |  | - | 
| 760 | currentData->deref(); | - | 
| 761 | } executed:  }Execution Count:23188 | 23188 | 
| 762 |  | - | 
| 763 | void QObjectPrivate::moveToThread_helper() | - | 
| 764 | { | - | 
| 765 | QObject * const q = q_func(); | - | 
| 766 | QEvent e(QEvent::ThreadChange); | - | 
| 767 | QCoreApplication::sendEvent(q, &e); | - | 
| 768 | for (int i = 0; i < children.size(); ++i) { evaluated:  i < children.size()| yes Evaluation Count:166 | yes Evaluation Count:23293 | 
 | 166-23293 | 
| 769 | QObject *child = children.at(i); | - | 
| 770 | child->d_func()->moveToThread_helper(); | - | 
| 771 | } executed:  }Execution Count:166 | 166 | 
| 772 | } executed:  }Execution Count:23290 | 23290 | 
| 773 |  | - | 
| 774 | void QObjectPrivate::setThreadData_helper(QThreadData *currentData, QThreadData *targetData) | - | 
| 775 | { | - | 
| 776 | QObject * const q = q_func(); | - | 
| 777 |  | - | 
| 778 |  | - | 
| 779 | int eventsMoved = 0; | - | 
| 780 | for (int i = 0; i < currentData->postEventList.size(); ++i) { evaluated:  i < currentData->postEventList.size()| yes Evaluation Count:3295088 | yes Evaluation Count:23357 | 
 | 23357-3295088 | 
| 781 | const QPostEvent &pe = currentData->postEventList.at(i); | - | 
| 782 | if (!pe.event) evaluated:  !pe.event| yes Evaluation Count:1119223 | yes Evaluation Count:2175865 | 
 | 1119223-2175865 | 
| 783 | continue; executed:  continue;Execution Count:1119223 | 1119223 | 
| 784 | if (pe.receiver == q) { evaluated:  pe.receiver == q| yes Evaluation Count:408838 | yes Evaluation Count:1767027 | 
 | 408838-1767027 | 
| 785 |  | - | 
| 786 | targetData->postEventList.addEvent(pe); | - | 
| 787 | const_cast<QPostEvent &>(pe).event = 0; | - | 
| 788 | ++eventsMoved; | - | 
| 789 | } executed:  }Execution Count:408838 | 408838 | 
| 790 | } executed:  }Execution Count:2175865 | 2175865 | 
| 791 | if (eventsMoved > 0 && targetData->eventDispatcher) { evaluated:  eventsMoved > 0| yes Evaluation Count:20505 | yes Evaluation Count:2852 | 
evaluated:  targetData->eventDispatcher| yes Evaluation Count:20501 | yes Evaluation Count:4 | 
 | 4-20505 | 
| 792 | targetData->canWait = false; | - | 
| 793 | targetData->eventDispatcher->wakeUp(); | - | 
| 794 | } executed:  }Execution Count:20501 | 20501 | 
| 795 |  | - | 
| 796 |  | - | 
| 797 | if (currentSender) evaluated:  currentSender| yes Evaluation Count:21001 | yes Evaluation Count:2356 | 
 | 2356-21001 | 
| 798 | currentSender->ref = 0; executed:  currentSender->ref = 0;Execution Count:21001 | 21001 | 
| 799 | currentSender = 0; | - | 
| 800 |  | - | 
| 801 |  | - | 
| 802 | targetData->ref(); | - | 
| 803 | threadData->deref(); | - | 
| 804 | threadData = targetData; | - | 
| 805 |  | - | 
| 806 | for (int i = 0; i < children.size(); ++i) { evaluated:  i < children.size()| yes Evaluation Count:166 | yes Evaluation Count:23357 | 
 | 166-23357 | 
| 807 | QObject *child = children.at(i); | - | 
| 808 | child->d_func()->setThreadData_helper(currentData, targetData); | - | 
| 809 | } executed:  }Execution Count:166 | 166 | 
| 810 | } executed:  }Execution Count:23357 | 23357 | 
| 811 |  | - | 
| 812 | void QObjectPrivate::_q_reregisterTimers(void *pointer) | - | 
| 813 | { | - | 
| 814 | QObject * const q = q_func(); | - | 
| 815 | QList<QAbstractEventDispatcher::TimerInfo> *timerList = reinterpret_cast<QList<QAbstractEventDispatcher::TimerInfo> *>(pointer); | - | 
| 816 | QAbstractEventDispatcher *eventDispatcher = threadData->eventDispatcher; | - | 
| 817 | for (int i = 0; i < timerList->size(); ++i) { evaluated:  i < timerList->size()| yes Evaluation Count:3 | yes Evaluation Count:3 | 
 | 3 | 
| 818 | const QAbstractEventDispatcher::TimerInfo &ti = timerList->at(i); | - | 
| 819 | eventDispatcher->registerTimer(ti.timerId, ti.interval, ti.timerType, q); | - | 
| 820 | } executed:  }Execution Count:3 | 3 | 
| 821 | delete timerList; | - | 
| 822 | } executed:  }Execution Count:3 | 3 | 
| 823 | int QObject::startTimer(int interval, Qt::TimerType timerType) | - | 
| 824 | { | - | 
| 825 | QObjectPrivate * const d = d_func(); | - | 
| 826 |  | - | 
| 827 | if (interval < 0) { partially evaluated:  interval < 0| no Evaluation Count:0 | yes Evaluation Count:12025 | 
 | 0-12025 | 
| 828 | QMessageLogger("kernel/qobject.cpp", 1437, __PRETTY_FUNCTION__).warning("QObject::startTimer: QTimer cannot have a negative interval"); | - | 
| 829 | return 0; never executed: return 0; | 0 | 
| 830 | } | - | 
| 831 |  | - | 
| 832 | if (!d->threadData->eventDispatcher) { partially evaluated:  !d->threadData->eventDispatcher| no Evaluation Count:0 | yes Evaluation Count:12025 | 
 | 0-12025 | 
| 833 | QMessageLogger("kernel/qobject.cpp", 1442, __PRETTY_FUNCTION__).warning("QObject::startTimer: QTimer can only be used with threads started with QThread"); | - | 
| 834 | return 0; never executed: return 0; | 0 | 
| 835 | } | - | 
| 836 | int timerId = d->threadData->eventDispatcher->registerTimer(interval, timerType, this); | - | 
| 837 | if (!d->extraData) evaluated:  !d->extraData| yes Evaluation Count:5281 | yes Evaluation Count:6744 | 
 | 5281-6744 | 
| 838 | d->extraData = new QObjectPrivate::ExtraData; executed:  d->extraData = new QObjectPrivate::ExtraData;Execution Count:5281 | 5281 | 
| 839 | d->extraData->runningTimers.append(timerId); | - | 
| 840 | return timerId; executed:  return timerId;Execution Count:12025 | 12025 | 
| 841 | } | - | 
| 842 | void QObject::killTimer(int id) | - | 
| 843 | { | - | 
| 844 | QObjectPrivate * const d = d_func(); | - | 
| 845 | if (id) { partially evaluated:  id| yes Evaluation Count:10725 | no Evaluation Count:0 | 
 | 0-10725 | 
| 846 | int at = d->extraData ? d->extraData->runningTimers.indexOf(id) : -1; partially evaluated:  d->extraData| yes Evaluation Count:10725 | no Evaluation Count:0 | 
 | 0-10725 | 
| 847 | if (at == -1) { partially evaluated:  at == -1| no Evaluation Count:0 | yes Evaluation Count:10725 | 
 | 0-10725 | 
| 848 |  | - | 
| 849 | QMessageLogger("kernel/qobject.cpp", 1468, __PRETTY_FUNCTION__).warning("QObject::killTimer(): Error: timer id %d is not valid for object %p (%s), timer has not been killed", | - | 
| 850 | id, | - | 
| 851 | this, | - | 
| 852 | QString(objectName()).toLocal8Bit().constData()); | - | 
| 853 | return; | 0 | 
| 854 | } | - | 
| 855 |  | - | 
| 856 | if (d->threadData->eventDispatcher) evaluated:  d->threadData->eventDispatcher| yes Evaluation Count:10614 | yes Evaluation Count:111 | 
 | 111-10614 | 
| 857 | d->threadData->eventDispatcher->unregisterTimer(id); executed:  d->threadData->eventDispatcher->unregisterTimer(id);Execution Count:10614 | 10614 | 
| 858 |  | - | 
| 859 | d->extraData->runningTimers.remove(at); | - | 
| 860 | QAbstractEventDispatcherPrivate::releaseTimerId(id); | - | 
| 861 | } executed:  }Execution Count:10725 | 10725 | 
| 862 | } executed:  }Execution Count:10725 | 10725 | 
| 863 | void qt_qFindChildren_helper(const QObject *parent, const QString &name, | - | 
| 864 | const QMetaObject &mo, QList<void*> *list, Qt::FindChildOptions options) | - | 
| 865 | { | - | 
| 866 | if (!parent || !list) evaluated:  !parent| yes Evaluation Count:12 | yes Evaluation Count:41086 | 
partially evaluated:  !list| no Evaluation Count:0 | yes Evaluation Count:41086 | 
 | 0-41086 | 
| 867 | return; executed:  return;Execution Count:12 | 12 | 
| 868 | const QObjectList &children = parent->children(); | - | 
| 869 | QObject *obj; | - | 
| 870 | for (int i = 0; i < children.size(); ++i) { evaluated:  i < children.size()| yes Evaluation Count:39094 | yes Evaluation Count:41086 | 
 | 39094-41086 | 
| 871 | obj = children.at(i); | - | 
| 872 | if (mo.cast(obj)) { evaluated:  mo.cast(obj)| yes Evaluation Count:16640 | yes Evaluation Count:22454 | 
 | 16640-22454 | 
| 873 | if (name.isNull() || obj->objectName() == name) evaluated:  name.isNull()| yes Evaluation Count:16351 | yes Evaluation Count:289 | 
evaluated:  obj->objectName() == name| yes Evaluation Count:34 | yes Evaluation Count:255 | 
 | 34-16351 | 
| 874 | list->append(obj); executed:  list->append(obj);Execution Count:16385 | 16385 | 
| 875 | } executed:  }Execution Count:16640 | 16640 | 
| 876 | if (options & Qt::FindChildrenRecursively) evaluated:  options & Qt::FindChildrenRecursively| yes Evaluation Count:39009 | yes Evaluation Count:85 | 
 | 85-39009 | 
| 877 | qt_qFindChildren_helper(obj, name, mo, list, options); executed:  qt_qFindChildren_helper(obj, name, mo, list, options);Execution Count:39009 | 39009 | 
| 878 | } executed:  }Execution Count:39094 | 39094 | 
| 879 | } executed:  }Execution Count:41086 | 41086 | 
| 880 |  | - | 
| 881 |  | - | 
| 882 |  | - | 
| 883 |  | - | 
| 884 |  | - | 
| 885 | void qt_qFindChildren_helper(const QObject *parent, const QRegExp &re, | - | 
| 886 | const QMetaObject &mo, QList<void*> *list, Qt::FindChildOptions options) | - | 
| 887 | { | - | 
| 888 | if (!parent || !list) partially evaluated:  !parent| no Evaluation Count:0 | yes Evaluation Count:55 | 
partially evaluated:  !list| no Evaluation Count:0 | yes Evaluation Count:55 | 
 | 0-55 | 
| 889 | return; | 0 | 
| 890 | const QObjectList &children = parent->children(); | - | 
| 891 | QRegExp reCopy = re; | - | 
| 892 | QObject *obj; | - | 
| 893 | for (int i = 0; i < children.size(); ++i) { evaluated:  i < children.size()| yes Evaluation Count:70 | yes Evaluation Count:55 | 
 | 55-70 | 
| 894 | obj = children.at(i); | - | 
| 895 | if (mo.cast(obj) && reCopy.indexIn(obj->objectName()) != -1) evaluated:  mo.cast(obj)| yes Evaluation Count:52 | yes Evaluation Count:18 | 
evaluated:  reCopy.indexIn(obj->objectName()) != -1| yes Evaluation Count:15 | yes Evaluation Count:37 | 
 | 15-52 | 
| 896 | list->append(obj); executed:  list->append(obj);Execution Count:15 | 15 | 
| 897 |  | - | 
| 898 | if (options & Qt::FindChildrenRecursively) evaluated:  options & Qt::FindChildrenRecursively| yes Evaluation Count:45 | yes Evaluation Count:25 | 
 | 25-45 | 
| 899 | qt_qFindChildren_helper(obj, re, mo, list, options); executed:  qt_qFindChildren_helper(obj, re, mo, list, options);Execution Count:45 | 45 | 
| 900 | } executed:  }Execution Count:70 | 70 | 
| 901 | } executed:  }Execution Count:55 | 55 | 
| 902 |  | - | 
| 903 |  | - | 
| 904 |  | - | 
| 905 |  | - | 
| 906 |  | - | 
| 907 |  | - | 
| 908 | void qt_qFindChildren_helper(const QObject *parent, const QRegularExpression &re, | - | 
| 909 | const QMetaObject &mo, QList<void*> *list, Qt::FindChildOptions options) | - | 
| 910 | { | - | 
| 911 | if (!parent || !list) partially evaluated:  !parent| no Evaluation Count:0 | yes Evaluation Count:50 | 
partially evaluated:  !list| no Evaluation Count:0 | yes Evaluation Count:50 | 
 | 0-50 | 
| 912 | return; | 0 | 
| 913 | const QObjectList &children = parent->children(); | - | 
| 914 | QObject *obj; | - | 
| 915 | for (int i = 0; i < children.size(); ++i) { evaluated:  i < children.size()| yes Evaluation Count:45 | yes Evaluation Count:50 | 
 | 45-50 | 
| 916 | obj = children.at(i); | - | 
| 917 | if (mo.cast(obj)) { evaluated:  mo.cast(obj)| yes Evaluation Count:33 | yes Evaluation Count:12 | 
 | 12-33 | 
| 918 | QRegularExpressionMatch m = re.match(obj->objectName()); | - | 
| 919 | if (m.hasMatch()) evaluated:  m.hasMatch()| yes Evaluation Count:10 | yes Evaluation Count:23 | 
 | 10-23 | 
| 920 | list->append(obj); executed:  list->append(obj);Execution Count:10 | 10 | 
| 921 | } executed:  }Execution Count:33 | 33 | 
| 922 | if (options & Qt::FindChildrenRecursively) partially evaluated:  options & Qt::FindChildrenRecursively| yes Evaluation Count:45 | no Evaluation Count:0 | 
 | 0-45 | 
| 923 | qt_qFindChildren_helper(obj, re, mo, list, options); executed:  qt_qFindChildren_helper(obj, re, mo, list, options);Execution Count:45 | 45 | 
| 924 | } executed:  }Execution Count:45 | 45 | 
| 925 | } executed:  }Execution Count:50 | 50 | 
| 926 |  | - | 
| 927 |  | - | 
| 928 |  | - | 
| 929 |  | - | 
| 930 |  | - | 
| 931 | QObject *qt_qFindChild_helper(const QObject *parent, const QString &name, const QMetaObject &mo, Qt::FindChildOptions options) | - | 
| 932 | { | - | 
| 933 | if (!parent) partially evaluated:  !parent| no Evaluation Count:0 | yes Evaluation Count:4898 | 
 | 0-4898 | 
| 934 | return 0; never executed: return 0; | 0 | 
| 935 | const QObjectList &children = parent->children(); | - | 
| 936 | QObject *obj; | - | 
| 937 | int i; | - | 
| 938 | for (i = 0; i < children.size(); ++i) { evaluated:  i < children.size()| yes Evaluation Count:6252 | yes Evaluation Count:4534 | 
 | 4534-6252 | 
| 939 | obj = children.at(i); | - | 
| 940 | if (mo.cast(obj) && (name.isNull() || obj->objectName() == name)) evaluated:  mo.cast(obj)| yes Evaluation Count:526 | yes Evaluation Count:5726 | 
evaluated:  name.isNull()| yes Evaluation Count:220 | yes Evaluation Count:306 | 
evaluated:  obj->objectName() == name| yes Evaluation Count:144 | yes Evaluation Count:162 | 
 | 144-5726 | 
| 941 | return obj; executed:  return obj;Execution Count:364 | 364 | 
| 942 | } executed:  }Execution Count:5888 | 5888 | 
| 943 | if (options & Qt::FindChildrenRecursively) { evaluated:  options & Qt::FindChildrenRecursively| yes Evaluation Count:4525 | yes Evaluation Count:9 | 
 | 9-4525 | 
| 944 | for (i = 0; i < children.size(); ++i) { evaluated:  i < children.size()| yes Evaluation Count:4099 | yes Evaluation Count:4363 | 
 | 4099-4363 | 
| 945 | obj = qt_qFindChild_helper(children.at(i), name, mo, options); | - | 
| 946 | if (obj) evaluated:  obj| yes Evaluation Count:162 | yes Evaluation Count:3937 | 
 | 162-3937 | 
| 947 | return obj; executed:  return obj;Execution Count:162 | 162 | 
| 948 | } executed:  }Execution Count:3937 | 3937 | 
| 949 | } executed:  }Execution Count:4363 | 4363 | 
| 950 | return 0; executed:  return 0;Execution Count:4372 | 4372 | 
| 951 | } | - | 
| 952 |  | - | 
| 953 |  | - | 
| 954 |  | - | 
| 955 |  | - | 
| 956 |  | - | 
| 957 |  | - | 
| 958 | void QObject::setParent(QObject *parent) | - | 
| 959 | { | - | 
| 960 | QObjectPrivate * const d = d_func(); | - | 
| 961 | qt_noop(); | - | 
| 962 | d->setParent_helper(parent); | - | 
| 963 | } executed:  }Execution Count:77519 | 77519 | 
| 964 |  | - | 
| 965 | void QObjectPrivate::deleteChildren() | - | 
| 966 | { | - | 
| 967 | qt_noop(); | - | 
| 968 | isDeletingChildren = true; | - | 
| 969 |  | - | 
| 970 |  | - | 
| 971 |  | - | 
| 972 | for (int i = 0; i < children.count(); ++i) { evaluated:  i < children.count()| yes Evaluation Count:63369 | yes Evaluation Count:29164 | 
 | 29164-63369 | 
| 973 | currentChildBeingDeleted = children.at(i); | - | 
| 974 | children[i] = 0; | - | 
| 975 | delete currentChildBeingDeleted; | - | 
| 976 | } executed:  }Execution Count:63369 | 63369 | 
| 977 | children.clear(); | - | 
| 978 | currentChildBeingDeleted = 0; | - | 
| 979 | isDeletingChildren = false; | - | 
| 980 | } executed:  }Execution Count:29164 | 29164 | 
| 981 |  | - | 
| 982 | void QObjectPrivate::setParent_helper(QObject *o) | - | 
| 983 | { | - | 
| 984 | QObject * const q = q_func(); | - | 
| 985 | if (o == parent) evaluated:  o == parent| yes Evaluation Count:1646 | yes Evaluation Count:229801 | 
 | 1646-229801 | 
| 986 | return; executed:  return;Execution Count:1646 | 1646 | 
| 987 | if (parent) { evaluated:  parent| yes Evaluation Count:113156 | yes Evaluation Count:116646 | 
 | 113156-116646 | 
| 988 | QObjectPrivate *parentD = parent->d_func(); | - | 
| 989 | if (parentD->isDeletingChildren && wasDeleted evaluated:  parentD->isDeletingChildren| yes Evaluation Count:63369 | yes Evaluation Count:49787 | 
partially evaluated:  wasDeleted| yes Evaluation Count:63369 | no Evaluation Count:0 | 
 | 0-63369 | 
| 990 | && parentD->currentChildBeingDeleted == q) { evaluated:  parentD->currentChildBeingDeleted == q| yes Evaluation Count:63367 | yes Evaluation Count:2 | 
 | 2-63367 | 
| 991 |  | - | 
| 992 |  | - | 
| 993 | } else { executed:  }Execution Count:63367 | 63367 | 
| 994 | const int index = parentD->children.indexOf(q); | - | 
| 995 | if (parentD->isDeletingChildren) { evaluated:  parentD->isDeletingChildren| yes Evaluation Count:2 | yes Evaluation Count:49787 | 
 | 2-49787 | 
| 996 | parentD->children[index] = 0; | - | 
| 997 | } else { executed:  }Execution Count:2 | 2 | 
| 998 | parentD->children.removeAt(index); | - | 
| 999 | if (sendChildEvents && parentD->receiveChildEvents) { evaluated:  sendChildEvents| yes Evaluation Count:49786 | yes Evaluation Count:1 | 
partially evaluated:  parentD->receiveChildEvents| yes Evaluation Count:49786 | no Evaluation Count:0 | 
 | 0-49786 | 
| 1000 | QChildEvent e(QEvent::ChildRemoved, q); | - | 
| 1001 | QCoreApplication::sendEvent(parent, &e); | - | 
| 1002 | } executed:  }Execution Count:49786 | 49786 | 
| 1003 | } executed:  }Execution Count:49786 | 49786 | 
| 1004 | } | - | 
| 1005 | } | - | 
| 1006 | parent = o; | - | 
| 1007 | if (parent) { evaluated:  parent| yes Evaluation Count:117438 | yes Evaluation Count:112364 | 
 | 112364-117438 | 
| 1008 |  | - | 
| 1009 | if (threadData != parent->d_func()->threadData) { partially evaluated:  threadData != parent->d_func()->threadData| no Evaluation Count:0 | yes Evaluation Count:117439 | 
 | 0-117439 | 
| 1010 | QMessageLogger("kernel/qobject.cpp", 1799, __PRETTY_FUNCTION__).warning("QObject::setParent: Cannot set parent, new parent is in a different thread"); | - | 
| 1011 | parent = 0; | - | 
| 1012 | return; | 0 | 
| 1013 | } | - | 
| 1014 | parent->d_func()->children.append(q); | - | 
| 1015 | if(sendChildEvents && parent->d_func()->receiveChildEvents) { evaluated:  sendChildEvents| yes Evaluation Count:117437 | yes Evaluation Count:1 | 
partially evaluated:  parent->d_func()->receiveChildEvents| yes Evaluation Count:117437 | no Evaluation Count:0 | 
 | 0-117437 | 
| 1016 | if (!isWidget) { evaluated:  !isWidget| yes Evaluation Count:75428 | yes Evaluation Count:42009 | 
 | 42009-75428 | 
| 1017 | QChildEvent e(QEvent::ChildAdded, q); | - | 
| 1018 | QCoreApplication::sendEvent(parent, &e); | - | 
| 1019 | } executed:  }Execution Count:75426 | 75426 | 
| 1020 | } executed:  }Execution Count:117435 | 117435 | 
| 1021 | } executed:  }Execution Count:117436 | 117436 | 
| 1022 | if (!isDeletingChildren && declarativeData) partially evaluated:  !isDeletingChildren| yes Evaluation Count:229800 | no Evaluation Count:0 | 
partially evaluated:  declarativeData| no Evaluation Count:0 | yes Evaluation Count:229800 | 
 | 0-229800 | 
| 1023 | QAbstractDeclarativeData::parentChanged(declarativeData, q, o); never executed: QAbstractDeclarativeData::parentChanged(declarativeData, q, o); | 0 | 
| 1024 | } executed:  }Execution Count:229801 | 229801 | 
| 1025 | void QObject::installEventFilter(QObject *obj) | - | 
| 1026 | { | - | 
| 1027 | QObjectPrivate * const d = d_func(); | - | 
| 1028 | if (!obj) partially evaluated:  !obj| no Evaluation Count:0 | yes Evaluation Count:19282 | 
 | 0-19282 | 
| 1029 | return; | 0 | 
| 1030 | if (d->threadData != obj->d_func()->threadData) { evaluated:  d->threadData != obj->d_func()->threadData| yes Evaluation Count:1 | yes Evaluation Count:19281 | 
 | 1-19281 | 
| 1031 | QMessageLogger("kernel/qobject.cpp", 1863, __PRETTY_FUNCTION__).warning("QObject::installEventFilter(): Cannot filter events for objects in a different thread."); | - | 
| 1032 | return; executed:  return;Execution Count:1 | 1 | 
| 1033 | } | - | 
| 1034 |  | - | 
| 1035 | if (!d->extraData) evaluated:  !d->extraData| yes Evaluation Count:12891 | yes Evaluation Count:6390 | 
 | 6390-12891 | 
| 1036 | d->extraData = new QObjectPrivate::ExtraData; executed:  d->extraData = new QObjectPrivate::ExtraData;Execution Count:12891 | 12891 | 
| 1037 |  | - | 
| 1038 |  | - | 
| 1039 | d->extraData->eventFilters.removeAll((QObject*)0); | - | 
| 1040 | d->extraData->eventFilters.removeAll(obj); | - | 
| 1041 | d->extraData->eventFilters.prepend(obj); | - | 
| 1042 | } executed:  }Execution Count:19281 | 19281 | 
| 1043 | void QObject::removeEventFilter(QObject *obj) | - | 
| 1044 | { | - | 
| 1045 | QObjectPrivate * const d = d_func(); | - | 
| 1046 | if (d->extraData) { evaluated:  d->extraData| yes Evaluation Count:1092 | yes Evaluation Count:921 | 
 | 921-1092 | 
| 1047 | for (int i = 0; i < d->extraData->eventFilters.count(); ++i) { evaluated:  i < d->extraData->eventFilters.count()| yes Evaluation Count:1315 | yes Evaluation Count:1092 | 
 | 1092-1315 | 
| 1048 | if (d->extraData->eventFilters.at(i) == obj) evaluated:  d->extraData->eventFilters.at(i) == obj| yes Evaluation Count:668 | yes Evaluation Count:647 | 
 | 647-668 | 
| 1049 | d->extraData->eventFilters[i] = 0; executed:  d->extraData->eventFilters[i] = 0;Execution Count:668 | 668 | 
| 1050 | } executed:  }Execution Count:1315 | 1315 | 
| 1051 | } executed:  }Execution Count:1092 | 1092 | 
| 1052 | } executed:  }Execution Count:2013 | 2013 | 
| 1053 | void QObject::deleteLater() | - | 
| 1054 | { | - | 
| 1055 | QCoreApplication::postEvent(this, new QDeferredDeleteEvent()); | - | 
| 1056 | } executed:  }Execution Count:8432 | 8432 | 
| 1057 | const int flagged_locations_count = 2; | - | 
| 1058 | static const char* flagged_locations[flagged_locations_count] = {0}; | - | 
| 1059 |  | - | 
| 1060 | const char *qFlagLocation(const char *method) | - | 
| 1061 | { | - | 
| 1062 | static int idx = 0; | - | 
| 1063 | flagged_locations[idx] = method; | - | 
| 1064 | idx = (idx+1) % flagged_locations_count; | - | 
| 1065 | return method; never executed: return method; | 0 | 
| 1066 | } | - | 
| 1067 |  | - | 
| 1068 | static int extract_code(const char *member) | - | 
| 1069 | { | - | 
| 1070 |  | - | 
| 1071 | return (((int)(*member) - '0') & 0x3); executed:  return (((int)(*member) - '0') & 0x3);Execution Count:810355 | 810355 | 
| 1072 | } | - | 
| 1073 |  | - | 
| 1074 | static const char * extract_location(const char *member) | - | 
| 1075 | { | - | 
| 1076 | for (int i = 0; i < flagged_locations_count; ++i) { never evaluated: i < flagged_locations_count | 0 | 
| 1077 | if (member == flagged_locations[i]) { never evaluated: member == flagged_locations[i] | 0 | 
| 1078 |  | - | 
| 1079 | const char *location = member + qstrlen(member) + 1; | - | 
| 1080 | if (*location != '\0') never evaluated: *location != '\0' | 0 | 
| 1081 | return location; never executed: return location; | 0 | 
| 1082 | return 0; never executed: return 0; | 0 | 
| 1083 | } | - | 
| 1084 | } | 0 | 
| 1085 | return 0; never executed: return 0; | 0 | 
| 1086 | } | - | 
| 1087 |  | - | 
| 1088 | static bool check_signal_macro(const QObject *sender, const char *signal, | - | 
| 1089 | const char *func, const char *op) | - | 
| 1090 | { | - | 
| 1091 | int sigcode = extract_code(signal); | - | 
| 1092 | if (sigcode != 2) { partially evaluated:  sigcode != 2| no Evaluation Count:0 | yes Evaluation Count:406885 | 
 | 0-406885 | 
| 1093 | if (sigcode == 1) never evaluated: sigcode == 1 | 0 | 
| 1094 | QMessageLogger("kernel/qobject.cpp", 2047, __PRETTY_FUNCTION__).warning("QObject::%s: Attempt to %s non-signal %s::%s", | 0 | 
| 1095 | func, op, sender->metaObject()->className(), signal+1); never executed: QMessageLogger("kernel/qobject.cpp", 2047, __PRETTY_FUNCTION__).warning("QObject::%s: Attempt to %s non-signal %s::%s", func, op, sender->metaObject()->className(), signal+1); | 0 | 
| 1096 | else | - | 
| 1097 | QMessageLogger("kernel/qobject.cpp", 2050, __PRETTY_FUNCTION__).warning("QObject::%s: Use the SIGNAL macro to %s %s::%s", | 0 | 
| 1098 | func, op, sender->metaObject()->className(), signal); never executed: QMessageLogger("kernel/qobject.cpp", 2050, __PRETTY_FUNCTION__).warning("QObject::%s: Use the SIGNAL macro to %s %s::%s", func, op, sender->metaObject()->className(), signal); | 0 | 
| 1099 | return false; never executed: return false; | 0 | 
| 1100 | } | - | 
| 1101 | return true; executed:  return true;Execution Count:406886 | 406886 | 
| 1102 | } | - | 
| 1103 |  | - | 
| 1104 | static bool check_method_code(int code, const QObject *object, | - | 
| 1105 | const char *method, const char *func) | - | 
| 1106 | { | - | 
| 1107 | if (code != 1 && code != 2) { evaluated:  code != 1| yes Evaluation Count:12239 | yes Evaluation Count:391250 | 
partially evaluated:  code != 2| no Evaluation Count:0 | yes Evaluation Count:12239 | 
 | 0-391250 | 
| 1108 | QMessageLogger("kernel/qobject.cpp", 2061, __PRETTY_FUNCTION__).warning("QObject::%s: Use the SLOT or SIGNAL macro to " | - | 
| 1109 | "%s %s::%s", func, func, object->metaObject()->className(), method); | - | 
| 1110 | return false; never executed: return false; | 0 | 
| 1111 | } | - | 
| 1112 | return true; executed:  return true;Execution Count:403483 | 403483 | 
| 1113 | } | - | 
| 1114 |  | - | 
| 1115 | static void err_method_notfound(const QObject *object, | - | 
| 1116 | const char *method, const char *func) | - | 
| 1117 | { | - | 
| 1118 | const char *type = "method"; | - | 
| 1119 | switch (extract_code(method)) { | - | 
| 1120 | case 1: type = "slot"; break; | 0 | 
| 1121 | case 2: type = "signal"; break; | 0 | 
| 1122 | } | - | 
| 1123 | const char *loc = extract_location(method); | - | 
| 1124 | if (strchr(method,')') == 0) never evaluated: strchr(method,')') == 0 | 0 | 
| 1125 | QMessageLogger("kernel/qobject.cpp", 2078, __PRETTY_FUNCTION__).warning("QObject::%s: Parentheses expected, %s %s::%s%s%s", | 0 | 
| 1126 | func, type, object->metaObject()->className(), method+1, | 0 | 
| 1127 | loc ? " in ": "", loc ? loc : ""); never executed: QMessageLogger("kernel/qobject.cpp", 2078, __PRETTY_FUNCTION__).warning("QObject::%s: Parentheses expected, %s %s::%s%s%s", func, type, object->metaObject()->className(), method+1, loc ? " in ": "", loc ? loc : ""); | 0 | 
| 1128 | else | - | 
| 1129 | QMessageLogger("kernel/qobject.cpp", 2082, __PRETTY_FUNCTION__).warning("QObject::%s: No such %s %s::%s%s%s", | 0 | 
| 1130 | func, type, object->metaObject()->className(), method+1, | 0 | 
| 1131 | loc ? " in ": "", loc ? loc : ""); never executed: QMessageLogger("kernel/qobject.cpp", 2082, __PRETTY_FUNCTION__).warning("QObject::%s: No such %s %s::%s%s%s", func, type, object->metaObject()->className(), method+1, loc ? " in ": "", loc ? loc : ""); | 0 | 
| 1132 |  | - | 
| 1133 | } | - | 
| 1134 |  | - | 
| 1135 |  | - | 
| 1136 | static void err_info_about_objects(const char * func, | - | 
| 1137 | const QObject * sender, | - | 
| 1138 | const QObject * receiver) | - | 
| 1139 | { | - | 
| 1140 | QString a = sender ? sender->objectName() : QString(); | 0 | 
| 1141 | QString b = receiver ? receiver->objectName() : QString(); never evaluated: receiver | 0 | 
| 1142 | if (!a.isEmpty()) never evaluated: !a.isEmpty() | 0 | 
| 1143 | QMessageLogger("kernel/qobject.cpp", 2096, __PRETTY_FUNCTION__).warning("QObject::%s:  (sender name:   '%s')", func, a.toLocal8Bit().data()); never executed: QMessageLogger("kernel/qobject.cpp", 2096, __PRETTY_FUNCTION__).warning("QObject::%s: (sender name: '%s')", func, a.toLocal8Bit().data()); | 0 | 
| 1144 | if (!b.isEmpty()) never evaluated: !b.isEmpty() | 0 | 
| 1145 | QMessageLogger("kernel/qobject.cpp", 2098, __PRETTY_FUNCTION__).warning("QObject::%s:  (receiver name: '%s')", func, b.toLocal8Bit().data()); never executed: QMessageLogger("kernel/qobject.cpp", 2098, __PRETTY_FUNCTION__).warning("QObject::%s: (receiver name: '%s')", func, b.toLocal8Bit().data()); | 0 | 
| 1146 | } | 0 | 
| 1147 | QObject *QObject::sender() const | - | 
| 1148 | { | - | 
| 1149 | const QObjectPrivate * const d = d_func(); | - | 
| 1150 |  | - | 
| 1151 | QMutexLocker locker(signalSlotLock(this)); | - | 
| 1152 | if (!d->currentSender) evaluated:  !d->currentSender| yes Evaluation Count:35 | yes Evaluation Count:6693 | 
 | 35-6693 | 
| 1153 | return 0; executed:  return 0;Execution Count:35 | 35 | 
| 1154 |  | - | 
| 1155 | for (QObjectPrivate::Connection *c = d->senders; c; c = c->next) { evaluated:  c| yes Evaluation Count:32039 | yes Evaluation Count:3 | 
 | 3-32039 | 
| 1156 | if (c->sender == d->currentSender->sender) evaluated:  c->sender == d->currentSender->sender| yes Evaluation Count:6690 | yes Evaluation Count:25349 | 
 | 6690-25349 | 
| 1157 | return d->currentSender->sender; executed:  return d->currentSender->sender;Execution Count:6690 | 6690 | 
| 1158 | } executed:  }Execution Count:25349 | 25349 | 
| 1159 |  | - | 
| 1160 | return 0; executed:  return 0;Execution Count:3 | 3 | 
| 1161 | } | - | 
| 1162 | int QObject::senderSignalIndex() const | - | 
| 1163 | { | - | 
| 1164 | const QObjectPrivate * const d = d_func(); | - | 
| 1165 | int signal_index = d->senderSignalIndex(); | - | 
| 1166 | if (signal_index < 0) evaluated:  signal_index < 0| yes Evaluation Count:7 | yes Evaluation Count:226 | 
 | 7-226 | 
| 1167 | return signal_index; executed:  return signal_index;Execution Count:7 | 7 | 
| 1168 |  | - | 
| 1169 | return QMetaObjectPrivate::signal(sender()->metaObject(), signal_index).methodIndex(); executed:  return QMetaObjectPrivate::signal(sender()->metaObject(), signal_index).methodIndex();Execution Count:226 | 226 | 
| 1170 | } | - | 
| 1171 | int QObject::receivers(const char *signal) const | - | 
| 1172 | { | - | 
| 1173 | const QObjectPrivate * const d = d_func(); | - | 
| 1174 | int receivers = 0; | - | 
| 1175 | if (signal) { partially evaluated:  signal| yes Evaluation Count:36 | no Evaluation Count:0 | 
 | 0-36 | 
| 1176 | QByteArray signal_name = QMetaObject::normalizedSignature(signal); | - | 
| 1177 | signal = signal_name; | - | 
| 1178 |  | - | 
| 1179 |  | - | 
| 1180 |  | - | 
| 1181 |  | - | 
| 1182 | signal++; | - | 
| 1183 | int signal_index = d->signalIndex(signal); | - | 
| 1184 | if (signal_index < 0) { partially evaluated:  signal_index < 0| no Evaluation Count:0 | yes Evaluation Count:36 | 
 | 0-36 | 
| 1185 |  | - | 
| 1186 |  | - | 
| 1187 |  | - | 
| 1188 | return 0; never executed: return 0; | 0 | 
| 1189 | } | - | 
| 1190 |  | - | 
| 1191 | if (!d->isSignalConnected(signal_index)) evaluated:  !d->isSignalConnected(signal_index)| yes Evaluation Count:25 | yes Evaluation Count:11 | 
 | 11-25 | 
| 1192 | return receivers; executed:  return receivers;Execution Count:25 | 25 | 
| 1193 |  | - | 
| 1194 | if (d->declarativeData && QAbstractDeclarativeData::receivers) { partially evaluated:  d->declarativeData| no Evaluation Count:0 | yes Evaluation Count:11 | 
never evaluated: QAbstractDeclarativeData::receivers | 0-11 | 
| 1195 | receivers += QAbstractDeclarativeData::receivers(d->declarativeData, this, | - | 
| 1196 | signal_index); | - | 
| 1197 | } | 0 | 
| 1198 |  | - | 
| 1199 | QMutexLocker locker(signalSlotLock(this)); | - | 
| 1200 | if (d->connectionLists) { partially evaluated:  d->connectionLists| yes Evaluation Count:11 | no Evaluation Count:0 | 
 | 0-11 | 
| 1201 | if (signal_index < d->connectionLists->count()) { partially evaluated:  signal_index < d->connectionLists->count()| yes Evaluation Count:11 | no Evaluation Count:0 | 
 | 0-11 | 
| 1202 | const QObjectPrivate::Connection *c = | - | 
| 1203 | d->connectionLists->at(signal_index).first; | - | 
| 1204 | while (c) { evaluated:  c| yes Evaluation Count:13 | yes Evaluation Count:11 | 
 | 11-13 | 
| 1205 | receivers += c->receiver ? 1 : 0; evaluated:  c->receiver| yes Evaluation Count:7 | yes Evaluation Count:6 | 
 | 6-7 | 
| 1206 | c = c->nextConnectionList; | - | 
| 1207 | } executed:  }Execution Count:13 | 13 | 
| 1208 | } executed:  }Execution Count:11 | 11 | 
| 1209 | } executed:  }Execution Count:11 | 11 | 
| 1210 | } executed:  }Execution Count:11 | 11 | 
| 1211 | return receivers; executed:  return receivers;Execution Count:11 | 11 | 
| 1212 | } | - | 
| 1213 | bool QObject::isSignalConnected(const QMetaMethod &signal) const | - | 
| 1214 | { | - | 
| 1215 | const QObjectPrivate * const d = d_func(); | - | 
| 1216 | if (!signal.mobj) evaluated:  !signal.mobj| yes Evaluation Count:1 | yes Evaluation Count:24 | 
 | 1-24 | 
| 1217 | return false; executed:  return false;Execution Count:1 | 1 | 
| 1218 |  | - | 
| 1219 | qt_noop(); | - | 
| 1220 |  | - | 
| 1221 | uint signalIndex = (signal.handle - QMetaObjectPrivate::get(signal.mobj)->methodData)/5; | - | 
| 1222 |  | - | 
| 1223 | if (signal.mobj->d.data[signal.handle + 4] & MethodCloned) evaluated:  signal.mobj->d.data[signal.handle + 4] & MethodCloned| yes Evaluation Count:3 | yes Evaluation Count:21 | 
 | 3-21 | 
| 1224 | signalIndex = QMetaObjectPrivate::originalClone(signal.mobj, signalIndex); executed:  signalIndex = QMetaObjectPrivate::originalClone(signal.mobj, signalIndex);Execution Count:3 | 3 | 
| 1225 |  | - | 
| 1226 | signalIndex += QMetaObjectPrivate::signalOffset(signal.mobj); | - | 
| 1227 |  | - | 
| 1228 | if (signalIndex < sizeof(d->connectedSignals) * 8) evaluated:  signalIndex < sizeof(d->connectedSignals) * 8| yes Evaluation Count:20 | yes Evaluation Count:4 | 
 | 4-20 | 
| 1229 | return d->isSignalConnected(signalIndex); executed:  return d->isSignalConnected(signalIndex);Execution Count:20 | 20 | 
| 1230 |  | - | 
| 1231 | QMutexLocker locker(signalSlotLock(this)); | - | 
| 1232 | if (d->connectionLists) { evaluated:  d->connectionLists| yes Evaluation Count:3 | yes Evaluation Count:1 | 
 | 1-3 | 
| 1233 | if (signalIndex < uint(d->connectionLists->count())) { partially evaluated:  signalIndex < uint(d->connectionLists->count())| yes Evaluation Count:3 | no Evaluation Count:0 | 
 | 0-3 | 
| 1234 | const QObjectPrivate::Connection *c = | - | 
| 1235 | d->connectionLists->at(signalIndex).first; | - | 
| 1236 | while (c) { partially evaluated:  c| yes Evaluation Count:3 | no Evaluation Count:0 | 
 | 0-3 | 
| 1237 | if (c->receiver) partially evaluated:  c->receiver| yes Evaluation Count:3 | no Evaluation Count:0 | 
 | 0-3 | 
| 1238 | return true; executed:  return true;Execution Count:3 | 3 | 
| 1239 | c = c->nextConnectionList; | - | 
| 1240 | } | 0 | 
| 1241 | } | 0 | 
| 1242 | } | 0 | 
| 1243 | return false; executed:  return false;Execution Count:1 | 1 | 
| 1244 | } | - | 
| 1245 | void QMetaObjectPrivate::memberIndexes(const QObject *obj, | - | 
| 1246 | const QMetaMethod &member, | - | 
| 1247 | int *signalIndex, int *methodIndex) | - | 
| 1248 | { | - | 
| 1249 | *signalIndex = -1; | - | 
| 1250 | *methodIndex = -1; | - | 
| 1251 | if (!obj || !member.mobj) evaluated:  !obj| yes Evaluation Count:8 | yes Evaluation Count:80 | 
evaluated:  !member.mobj| yes Evaluation Count:9 | yes Evaluation Count:71 | 
 | 8-80 | 
| 1252 | return; executed:  return;Execution Count:17 | 17 | 
| 1253 | const QMetaObject *m = obj->metaObject(); | - | 
| 1254 |  | - | 
| 1255 | while (m != 0 && m != member.mobj) partially evaluated:  m != 0| yes Evaluation Count:73 | no Evaluation Count:0 | 
evaluated:  m != member.mobj| yes Evaluation Count:2 | yes Evaluation Count:71 | 
 | 0-73 | 
| 1256 | m = m->d.superdata; executed:  m = m->d.superdata;Execution Count:2 | 2 | 
| 1257 | if (!m) partially evaluated:  !m| no Evaluation Count:0 | yes Evaluation Count:71 | 
 | 0-71 | 
| 1258 | return; | 0 | 
| 1259 | *signalIndex = *methodIndex = (member.handle - get(member.mobj)->methodData)/5; | - | 
| 1260 |  | - | 
| 1261 | int signalOffset; | - | 
| 1262 | int methodOffset; | - | 
| 1263 | computeOffsets(m, &signalOffset, &methodOffset); | - | 
| 1264 |  | - | 
| 1265 | *methodIndex += methodOffset; | - | 
| 1266 | if (member.methodType() == QMetaMethod::Signal) { evaluated:  member.methodType() == QMetaMethod::Signal| yes Evaluation Count:36 | yes Evaluation Count:35 | 
 | 35-36 | 
| 1267 | *signalIndex = originalClone(m, *signalIndex); | - | 
| 1268 | *signalIndex += signalOffset; | - | 
| 1269 | } else { executed:  }Execution Count:36 | 36 | 
| 1270 | *signalIndex = -1; | - | 
| 1271 | } executed:  }Execution Count:35 | 35 | 
| 1272 | } | - | 
| 1273 |  | - | 
| 1274 | static inline void check_and_warn_compat(const QMetaObject *sender, const QMetaMethod &signal, | - | 
| 1275 | const QMetaObject *receiver, const QMetaMethod &method) | - | 
| 1276 | { | - | 
| 1277 | if (signal.attributes() & QMetaMethod::Compatibility) { never evaluated: signal.attributes() & QMetaMethod::Compatibility | 0 | 
| 1278 | if (!(method.attributes() & QMetaMethod::Compatibility)) never evaluated: !(method.attributes() & QMetaMethod::Compatibility) | 0 | 
| 1279 | QMessageLogger("kernel/qobject.cpp", 2346, __PRETTY_FUNCTION__).warning("QObject::connect: Connecting from COMPAT signal (%s::%s)", | 0 | 
| 1280 | sender->className(), signal.methodSignature().constData()); never executed: QMessageLogger("kernel/qobject.cpp", 2346, __PRETTY_FUNCTION__).warning("QObject::connect: Connecting from COMPAT signal (%s::%s)", sender->className(), signal.methodSignature().constData()); | 0 | 
| 1281 | } else if ((method.attributes() & QMetaMethod::Compatibility) && never evaluated: (method.attributes() & QMetaMethod::Compatibility) | 0 | 
| 1282 | method.methodType() == QMetaMethod::Signal) { never evaluated: method.methodType() == QMetaMethod::Signal | 0 | 
| 1283 | QMessageLogger("kernel/qobject.cpp", 2350, __PRETTY_FUNCTION__).warning("QObject::connect: Connecting from %s::%s to COMPAT slot (%s::%s)", | - | 
| 1284 | sender->className(), signal.methodSignature().constData(), | - | 
| 1285 | receiver->className(), method.methodSignature().constData()); | - | 
| 1286 | } | 0 | 
| 1287 | } | - | 
| 1288 | QMetaObject::Connection QObject::connect(const QObject *sender, const char *signal, | - | 
| 1289 | const QObject *receiver, const char *method, | - | 
| 1290 | Qt::ConnectionType type) | - | 
| 1291 | { | - | 
| 1292 | if (sender == 0 || receiver == 0 || signal == 0 || method == 0) { partially evaluated:  sender == 0| no Evaluation Count:0 | yes Evaluation Count:380481 | 
partially evaluated:  receiver == 0| no Evaluation Count:0 | yes Evaluation Count:380480 | 
partially evaluated:  signal == 0| no Evaluation Count:0 | yes Evaluation Count:380481 | 
partially evaluated:  method == 0| no Evaluation Count:0 | yes Evaluation Count:380483 | 
 | 0-380483 | 
| 1293 | QMessageLogger("kernel/qobject.cpp", 2428, __PRETTY_FUNCTION__).warning("QObject::connect: Cannot connect %s::%s to %s::%s", | - | 
| 1294 | sender ? sender->metaObject()->className() : "(null)", | - | 
| 1295 | (signal && *signal) ? signal+1 : "(null)", | - | 
| 1296 | receiver ? receiver->metaObject()->className() : "(null)", | - | 
| 1297 | (method && *method) ? method+1 : "(null)"); | - | 
| 1298 | return QMetaObject::Connection(0); never executed: return QMetaObject::Connection(0); | 0 | 
| 1299 | } | - | 
| 1300 | QByteArray tmp_signal_name; | - | 
| 1301 |  | - | 
| 1302 | if (!check_signal_macro(sender, signal, "connect", "bind")) partially evaluated:  !check_signal_macro(sender, signal, "connect", "bind")| no Evaluation Count:0 | yes Evaluation Count:380480 | 
 | 0-380480 | 
| 1303 | return QMetaObject::Connection(0); never executed: return QMetaObject::Connection(0); | 0 | 
| 1304 | const QMetaObject *smeta = sender->metaObject(); | - | 
| 1305 | const char *signal_arg = signal; | - | 
| 1306 | ++signal; | - | 
| 1307 | QArgumentTypeArray signalTypes; | - | 
| 1308 | qt_noop(); | - | 
| 1309 | QByteArray signalName = QMetaObjectPrivate::decodeMethodSignature(signal, signalTypes); | - | 
| 1310 | int signal_index = QMetaObjectPrivate::indexOfSignalRelative( | - | 
| 1311 | &smeta, signalName, signalTypes.size(), signalTypes.constData()); | - | 
| 1312 | if (signal_index < 0) { evaluated:  signal_index < 0| yes Evaluation Count:111 | yes Evaluation Count:380366 | 
 | 111-380366 | 
| 1313 |  | - | 
| 1314 | tmp_signal_name = QMetaObject::normalizedSignature(signal - 1); | - | 
| 1315 | signal = tmp_signal_name.constData() + 1; | - | 
| 1316 |  | - | 
| 1317 | signalTypes.clear(); | - | 
| 1318 | signalName = QMetaObjectPrivate::decodeMethodSignature(signal, signalTypes); | - | 
| 1319 | smeta = sender->metaObject(); | - | 
| 1320 | signal_index = QMetaObjectPrivate::indexOfSignalRelative( | - | 
| 1321 | &smeta, signalName, signalTypes.size(), signalTypes.constData()); | - | 
| 1322 | } executed:  }Execution Count:111 | 111 | 
| 1323 | if (signal_index < 0) { partially evaluated:  signal_index < 0| no Evaluation Count:0 | yes Evaluation Count:380477 | 
 | 0-380477 | 
| 1324 | err_method_notfound(sender, signal_arg, "connect"); | - | 
| 1325 | err_info_about_objects("connect", sender, receiver); | - | 
| 1326 | return QMetaObject::Connection(0); never executed: return QMetaObject::Connection(0); | 0 | 
| 1327 | } | - | 
| 1328 | signal_index = QMetaObjectPrivate::originalClone(smeta, signal_index); | - | 
| 1329 | signal_index += QMetaObjectPrivate::signalOffset(smeta); | - | 
| 1330 |  | - | 
| 1331 | QByteArray tmp_method_name; | - | 
| 1332 | int membcode = extract_code(method); | - | 
| 1333 |  | - | 
| 1334 | if (!check_method_code(membcode, receiver, method, "connect")) partially evaluated:  !check_method_code(membcode, receiver, method, "connect")| no Evaluation Count:0 | yes Evaluation Count:380469 | 
 | 0-380469 | 
| 1335 | return QMetaObject::Connection(0); never executed: return QMetaObject::Connection(0); | 0 | 
| 1336 | const char *method_arg = method; | - | 
| 1337 | ++method; | - | 
| 1338 |  | - | 
| 1339 | QByteArray methodName; | - | 
| 1340 | QArgumentTypeArray methodTypes; | - | 
| 1341 | const QMetaObject *rmeta = receiver->metaObject(); | - | 
| 1342 | int method_index_relative = -1; | - | 
| 1343 | qt_noop(); | - | 
| 1344 | switch (membcode) { | - | 
| 1345 | case 1: | - | 
| 1346 | method_index_relative = QMetaObjectPrivate::indexOfSlotRelative( | - | 
| 1347 | &rmeta, methodName, methodTypes.size(), methodTypes.constData()); | - | 
| 1348 | break; executed:  break;Execution Count:368271 | 368271 | 
| 1349 | case 2: | - | 
| 1350 | method_index_relative = QMetaObjectPrivate::indexOfSignalRelative( | - | 
| 1351 | &rmeta, methodName, methodTypes.size(), methodTypes.constData()); | - | 
| 1352 | break; executed:  break;Execution Count:12199 | 12199 | 
| 1353 | } | - | 
| 1354 | if (method_index_relative < 0) { partially evaluated:  method_index_relative < 0| yes Evaluation Count:380465 | no Evaluation Count:0 | 
 | 0-380465 | 
| 1355 |  | - | 
| 1356 | tmp_method_name = QMetaObject::normalizedSignature(method); | - | 
| 1357 | method = tmp_method_name.constData(); | - | 
| 1358 |  | - | 
| 1359 | methodTypes.clear(); | - | 
| 1360 | methodName = QMetaObjectPrivate::decodeMethodSignature(method, methodTypes); | - | 
| 1361 |  | - | 
| 1362 | rmeta = receiver->metaObject(); | - | 
| 1363 | switch (membcode) { | - | 
| 1364 | case 1: | - | 
| 1365 | method_index_relative = QMetaObjectPrivate::indexOfSlotRelative( | - | 
| 1366 | &rmeta, methodName, methodTypes.size(), methodTypes.constData()); | - | 
| 1367 | break; executed:  break;Execution Count:368279 | 368279 | 
| 1368 | case 2: | - | 
| 1369 | method_index_relative = QMetaObjectPrivate::indexOfSignalRelative( | - | 
| 1370 | &rmeta, methodName, methodTypes.size(), methodTypes.constData()); | - | 
| 1371 | break; executed:  break;Execution Count:12196 | 12196 | 
| 1372 | } | - | 
| 1373 | } executed:  }Execution Count:380473 | 380473 | 
| 1374 |  | - | 
| 1375 | if (method_index_relative < 0) { partially evaluated:  method_index_relative < 0| no Evaluation Count:0 | yes Evaluation Count:380473 | 
 | 0-380473 | 
| 1376 | err_method_notfound(receiver, method_arg, "connect"); | - | 
| 1377 | err_info_about_objects("connect", sender, receiver); | - | 
| 1378 | return QMetaObject::Connection(0); never executed: return QMetaObject::Connection(0); | 0 | 
| 1379 | } | - | 
| 1380 |  | - | 
| 1381 | if (!QMetaObjectPrivate::checkConnectArgs(signalTypes.size(), signalTypes.constData(), | 1-380473 | 
| 1382 | methodTypes.size(), methodTypes.constData())) { evaluated:  !QMetaObjectPrivate::checkConnectArgs(signalTypes.size(), signalTypes.constData(), methodTypes.size(), methodTypes.constData())| yes Evaluation Count:1 | yes Evaluation Count:380473 | 
 | 1-380473 | 
| 1383 | QMessageLogger("kernel/qobject.cpp", 2518, __PRETTY_FUNCTION__).warning("QObject::connect: Incompatible sender/receiver arguments" | - | 
| 1384 | "\n        %s::%s --> %s::%s", | - | 
| 1385 | sender->metaObject()->className(), signal, | - | 
| 1386 | receiver->metaObject()->className(), method); | - | 
| 1387 | return QMetaObject::Connection(0); executed:  return QMetaObject::Connection(0);Execution Count:1 | 1 | 
| 1388 | } | - | 
| 1389 |  | - | 
| 1390 | int *types = 0; | - | 
| 1391 | if ((type == Qt::QueuedConnection) evaluated:  (type == Qt::QueuedConnection)| yes Evaluation Count:21073 | yes Evaluation Count:359397 | 
 | 21073-359397 | 
| 1392 | && !(types = queuedConnectionTypes(signalTypes.constData(), signalTypes.size()))) { partially evaluated:  !(types = queuedConnectionTypes(signalTypes.constData(), signalTypes.size()))| no Evaluation Count:0 | yes Evaluation Count:21073 | 
 | 0-21073 | 
| 1393 | return QMetaObject::Connection(0); never executed: return QMetaObject::Connection(0); | 0 | 
| 1394 | } | - | 
| 1395 |  | - | 
| 1396 |  | - | 
| 1397 |  | - | 
| 1398 |  | - | 
| 1399 |  | - | 
| 1400 |  | - | 
| 1401 | QMetaObject::Connection handle = QMetaObject::Connection(QMetaObjectPrivate::connect( | - | 
| 1402 | sender, signal_index, smeta, receiver, method_index_relative, rmeta ,type, types)); | - | 
| 1403 | return handle; executed:  return handle;Execution Count:380475 | 380475 | 
| 1404 | } | - | 
| 1405 | QMetaObject::Connection QObject::connect(const QObject *sender, const QMetaMethod &signal, | - | 
| 1406 | const QObject *receiver, const QMetaMethod &method, | - | 
| 1407 | Qt::ConnectionType type) | - | 
| 1408 | { | - | 
| 1409 | if (sender == 0 partially evaluated:  sender == 0| no Evaluation Count:0 | yes Evaluation Count:27 | 
 | 0-27 | 
| 1410 | || receiver == 0 partially evaluated:  receiver == 0| no Evaluation Count:0 | yes Evaluation Count:27 | 
 | 0-27 | 
| 1411 | || signal.methodType() != QMetaMethod::Signal evaluated:  signal.methodType() != QMetaMethod::Signal| yes Evaluation Count:3 | yes Evaluation Count:24 | 
 | 3-24 | 
| 1412 | || method.methodType() == QMetaMethod::Constructor) { evaluated:  method.methodType() == QMetaMethod::Constructor| yes Evaluation Count:1 | yes Evaluation Count:23 | 
 | 1-23 | 
| 1413 | QMessageLogger("kernel/qobject.cpp", 2571, __PRETTY_FUNCTION__).warning("QObject::connect: Cannot connect %s::%s to %s::%s", | - | 
| 1414 | sender ? sender->metaObject()->className() : "(null)", | - | 
| 1415 | signal.methodSignature().constData(), | - | 
| 1416 | receiver ? receiver->metaObject()->className() : "(null)", | - | 
| 1417 | method.methodSignature().constData() ); | - | 
| 1418 | return QMetaObject::Connection(0); executed:  return QMetaObject::Connection(0);Execution Count:4 | 4 | 
| 1419 | } | - | 
| 1420 |  | - | 
| 1421 | int signal_index; | - | 
| 1422 | int method_index; | - | 
| 1423 | { | - | 
| 1424 | int dummy; | - | 
| 1425 | QMetaObjectPrivate::memberIndexes(sender, signal, &signal_index, &dummy); | - | 
| 1426 | QMetaObjectPrivate::memberIndexes(receiver, method, &dummy, &method_index); | - | 
| 1427 | } | - | 
| 1428 |  | - | 
| 1429 | const QMetaObject *smeta = sender->metaObject(); | - | 
| 1430 | const QMetaObject *rmeta = receiver->metaObject(); | - | 
| 1431 | if (signal_index == -1) { partially evaluated:  signal_index == -1| no Evaluation Count:0 | yes Evaluation Count:23 | 
 | 0-23 | 
| 1432 | QMessageLogger("kernel/qobject.cpp", 2590, __PRETTY_FUNCTION__).warning("QObject::connect: Can't find signal %s on instance of class %s", | - | 
| 1433 | signal.methodSignature().constData(), smeta->className()); | - | 
| 1434 | return QMetaObject::Connection(0); never executed: return QMetaObject::Connection(0); | 0 | 
| 1435 | } | - | 
| 1436 | if (method_index == -1) { partially evaluated:  method_index == -1| no Evaluation Count:0 | yes Evaluation Count:23 | 
 | 0-23 | 
| 1437 | QMessageLogger("kernel/qobject.cpp", 2595, __PRETTY_FUNCTION__).warning("QObject::connect: Can't find method %s on instance of class %s", | - | 
| 1438 | method.methodSignature().constData(), rmeta->className()); | - | 
| 1439 | return QMetaObject::Connection(0); never executed: return QMetaObject::Connection(0); | 0 | 
| 1440 | } | - | 
| 1441 |  | - | 
| 1442 | if (!QMetaObject::checkConnectArgs(signal.methodSignature().constData(), method.methodSignature().constData())) { partially evaluated:  !QMetaObject::checkConnectArgs(signal.methodSignature().constData(), method.methodSignature().constData())| no Evaluation Count:0 | yes Evaluation Count:23 | 
 | 0-23 | 
| 1443 | QMessageLogger("kernel/qobject.cpp", 2601, __PRETTY_FUNCTION__).warning("QObject::connect: Incompatible sender/receiver arguments" | - | 
| 1444 | "\n        %s::%s --> %s::%s", | - | 
| 1445 | smeta->className(), signal.methodSignature().constData(), | - | 
| 1446 | rmeta->className(), method.methodSignature().constData()); | - | 
| 1447 | return QMetaObject::Connection(0); never executed: return QMetaObject::Connection(0); | 0 | 
| 1448 | } | - | 
| 1449 |  | - | 
| 1450 | int *types = 0; | - | 
| 1451 | if ((type == Qt::QueuedConnection) partially evaluated:  (type == Qt::QueuedConnection)| no Evaluation Count:0 | yes Evaluation Count:23 | 
 | 0-23 | 
| 1452 | && !(types = queuedConnectionTypes(signal.parameterTypes()))) never evaluated: !(types = queuedConnectionTypes(signal.parameterTypes())) | 0 | 
| 1453 | return QMetaObject::Connection(0); never executed: return QMetaObject::Connection(0); | 0 | 
| 1454 |  | - | 
| 1455 |  | - | 
| 1456 |  | - | 
| 1457 |  | - | 
| 1458 | QMetaObject::Connection handle = QMetaObject::Connection(QMetaObjectPrivate::connect( | - | 
| 1459 | sender, signal_index, signal.enclosingMetaObject(), receiver, method_index, 0, type, types)); | - | 
| 1460 | return handle; executed:  return handle;Execution Count:23 | 23 | 
| 1461 | } | - | 
| 1462 | bool QObject::disconnect(const QObject *sender, const char *signal, | - | 
| 1463 | const QObject *receiver, const char *method) | - | 
| 1464 | { | - | 
| 1465 | if (sender == 0 || (receiver == 0 && method != 0)) { partially evaluated:  sender == 0| no Evaluation Count:0 | yes Evaluation Count:34757 | 
evaluated:  receiver == 0| yes Evaluation Count:9998 | yes Evaluation Count:24759 | 
partially evaluated:  method != 0| no Evaluation Count:0 | yes Evaluation Count:9998 | 
 | 0-34757 | 
| 1466 | QMessageLogger("kernel/qobject.cpp", 2701, __PRETTY_FUNCTION__).warning("QObject::disconnect: Unexpected null parameter"); | - | 
| 1467 | return false; never executed: return false; | 0 | 
| 1468 | } | - | 
| 1469 |  | - | 
| 1470 | const char *signal_arg = signal; | - | 
| 1471 | QByteArray signal_name; | - | 
| 1472 | bool signal_found = false; | - | 
| 1473 | if (signal) { evaluated:  signal| yes Evaluation Count:26406 | yes Evaluation Count:8351 | 
 | 8351-26406 | 
| 1474 | try { | - | 
| 1475 | signal_name = QMetaObject::normalizedSignature(signal); | - | 
| 1476 | signal = signal_name.constData(); | - | 
| 1477 | } catch (const std::bad_alloc &) { executed:  }Execution Count:26406 | 26406 | 
| 1478 |  | - | 
| 1479 | if (sender->metaObject()->indexOfSignal(signal + 1) == -1) never evaluated: sender->metaObject()->indexOfSignal(signal + 1) == -1 | 0 | 
| 1480 | throw; | 0 | 
| 1481 | } | 0 | 
| 1482 |  | - | 
| 1483 | if (!check_signal_macro(sender, signal, "disconnect", "unbind")) partially evaluated:  !check_signal_macro(sender, signal, "disconnect", "unbind")| no Evaluation Count:0 | yes Evaluation Count:26406 | 
 | 0-26406 | 
| 1484 | return false; never executed: return false; | 0 | 
| 1485 | signal++; | - | 
| 1486 | } executed:  }Execution Count:26406 | 26406 | 
| 1487 |  | - | 
| 1488 | QByteArray method_name; | - | 
| 1489 | const char *method_arg = method; | - | 
| 1490 | int membcode = -1; | - | 
| 1491 | bool method_found = false; | - | 
| 1492 | if (method) { evaluated:  method| yes Evaluation Count:23014 | yes Evaluation Count:11743 | 
 | 11743-23014 | 
| 1493 | try { | - | 
| 1494 | method_name = QMetaObject::normalizedSignature(method); | - | 
| 1495 | method = method_name.constData(); | - | 
| 1496 | } catch (const std::bad_alloc &) { executed:  }Execution Count:23014 | 23014 | 
| 1497 |  | - | 
| 1498 | if (receiver->metaObject()->indexOfMethod(method + 1) == -1) never evaluated: receiver->metaObject()->indexOfMethod(method + 1) == -1 | 0 | 
| 1499 | throw; | 0 | 
| 1500 | } | 0 | 
| 1501 |  | - | 
| 1502 | membcode = extract_code(method); | - | 
| 1503 | if (!check_method_code(membcode, receiver, method, "disconnect")) partially evaluated:  !check_method_code(membcode, receiver, method, "disconnect")| no Evaluation Count:0 | yes Evaluation Count:23014 | 
 | 0-23014 | 
| 1504 | return false; never executed: return false; | 0 | 
| 1505 | method++; | - | 
| 1506 | } executed:  }Execution Count:23014 | 23014 | 
| 1507 |  | - | 
| 1508 |  | - | 
| 1509 |  | - | 
| 1510 |  | - | 
| 1511 |  | - | 
| 1512 | bool res = false; | - | 
| 1513 | const QMetaObject *smeta = sender->metaObject(); | - | 
| 1514 | QByteArray signalName; | - | 
| 1515 | QArgumentTypeArray signalTypes; | - | 
| 1516 | qt_noop(); | - | 
| 1517 | if (signal) evaluated:  signal| yes Evaluation Count:26406 | yes Evaluation Count:8351 | 
 | 8351-26406 | 
| 1518 | signalName = QMetaObjectPrivate::decodeMethodSignature(signal, signalTypes); executed:  signalName = QMetaObjectPrivate::decodeMethodSignature(signal, signalTypes);Execution Count:26406 | 26406 | 
| 1519 | QByteArray methodName; | - | 
| 1520 | QArgumentTypeArray methodTypes; | - | 
| 1521 | qt_noop(); | - | 
| 1522 | if (method) evaluated:  method| yes Evaluation Count:23014 | yes Evaluation Count:11741 | 
 | 11741-23014 | 
| 1523 | methodName = QMetaObjectPrivate::decodeMethodSignature(method, methodTypes); executed:  methodName = QMetaObjectPrivate::decodeMethodSignature(method, methodTypes);Execution Count:23014 | 23014 | 
| 1524 | do { | - | 
| 1525 | int signal_index = -1; | - | 
| 1526 | if (signal) { evaluated:  signal| yes Evaluation Count:50740 | yes Evaluation Count:8349 | 
 | 8349-50740 | 
| 1527 | signal_index = QMetaObjectPrivate::indexOfSignalRelative( | - | 
| 1528 | &smeta, signalName, signalTypes.size(), signalTypes.constData()); | - | 
| 1529 | if (signal_index < 0) evaluated:  signal_index < 0| yes Evaluation Count:24333 | yes Evaluation Count:26407 | 
 | 24333-26407 | 
| 1530 | break; executed:  break;Execution Count:24333 | 24333 | 
| 1531 | signal_index = QMetaObjectPrivate::originalClone(smeta, signal_index); | - | 
| 1532 | signal_index += QMetaObjectPrivate::signalOffset(smeta); | - | 
| 1533 | signal_found = true; | - | 
| 1534 | } executed:  }Execution Count:26407 | 26407 | 
| 1535 |  | - | 
| 1536 | if (!method) { evaluated:  !method| yes Evaluation Count:11741 | yes Evaluation Count:23015 | 
 | 11741-23015 | 
| 1537 | res |= QMetaObjectPrivate::disconnect(sender, signal_index, smeta, receiver, -1, 0); | - | 
| 1538 | } else { executed:  }Execution Count:11743 | 11743 | 
| 1539 | const QMetaObject *rmeta = receiver->metaObject(); | - | 
| 1540 | do { | - | 
| 1541 | int method_index = QMetaObjectPrivate::indexOfMethod( | - | 
| 1542 | rmeta, methodName, methodTypes.size(), methodTypes.constData()); | - | 
| 1543 | if (method_index >= 0) evaluated:  method_index >= 0| yes Evaluation Count:23440 | yes Evaluation Count:23008 | 
 | 23008-23440 | 
| 1544 | while (method_index < rmeta->methodOffset()) evaluated:  method_index < rmeta->methodOffset()| yes Evaluation Count:12340 | yes Evaluation Count:23440 | 
 | 12340-23440 | 
| 1545 | rmeta = rmeta->superClass(); executed:  rmeta = rmeta->superClass();Execution Count:12340 | 12340 | 
| 1546 | if (method_index < 0) evaluated:  method_index < 0| yes Evaluation Count:23008 | yes Evaluation Count:23440 | 
 | 23008-23440 | 
| 1547 | break; executed:  break;Execution Count:23008 | 23008 | 
| 1548 | res |= QMetaObjectPrivate::disconnect(sender, signal_index, smeta, receiver, method_index, 0); | - | 
| 1549 | method_found = true; | - | 
| 1550 | } while ((rmeta = rmeta->superClass())); executed:  }Execution Count:23440evaluated:  (rmeta = rmeta->superClass())| yes Evaluation Count:23433 | yes Evaluation Count:7 | 
 | 7-23440 | 
| 1551 | } executed:  }Execution Count:23015 | 23015 | 
| 1552 | } while (signal && (smeta = smeta->superClass())); evaluated:  signal| yes Evaluation Count:26407 | yes Evaluation Count:8351 | 
evaluated:  (smeta = smeta->superClass())| yes Evaluation Count:24334 | yes Evaluation Count:2073 | 
 | 2073-26407 | 
| 1553 |  | - | 
| 1554 | if (signal && !signal_found) { evaluated:  signal| yes Evaluation Count:26406 | yes Evaluation Count:8351 | 
partially evaluated:  !signal_found| no Evaluation Count:0 | yes Evaluation Count:26406 | 
 | 0-26406 | 
| 1555 | err_method_notfound(sender, signal_arg, "disconnect"); | - | 
| 1556 | err_info_about_objects("disconnect", sender, receiver); | - | 
| 1557 | } else if (method && !method_found) { evaluated:  method| yes Evaluation Count:23014 | yes Evaluation Count:11743 | 
partially evaluated:  !method_found| no Evaluation Count:0 | yes Evaluation Count:23014 | 
 | 0-23014 | 
| 1558 | err_method_notfound(receiver, method_arg, "disconnect"); | - | 
| 1559 | err_info_about_objects("disconnect", sender, receiver); | - | 
| 1560 | } | 0 | 
| 1561 | if (res) { evaluated:  res| yes Evaluation Count:17917 | yes Evaluation Count:16840 | 
 | 16840-17917 | 
| 1562 | if (!signal) evaluated:  !signal| yes Evaluation Count:1670 | yes Evaluation Count:16247 | 
 | 1670-16247 | 
| 1563 | const_cast<QObject*>(sender)->disconnectNotify(QMetaMethod()); executed:  const_cast<QObject*>(sender)->disconnectNotify(QMetaMethod());Execution Count:1670 | 1670 | 
| 1564 | } executed:  }Execution Count:17917 | 17917 | 
| 1565 | return res; executed:  return res;Execution Count:34755 | 34755 | 
| 1566 | } | - | 
| 1567 | bool QObject::disconnect(const QObject *sender, const QMetaMethod &signal, | - | 
| 1568 | const QObject *receiver, const QMetaMethod &method) | - | 
| 1569 | { | - | 
| 1570 | if (sender == 0 || (receiver == 0 && method.mobj != 0)) { partially evaluated:  sender == 0| no Evaluation Count:0 | yes Evaluation Count:22 | 
evaluated:  receiver == 0| yes Evaluation Count:8 | yes Evaluation Count:14 | 
partially evaluated:  method.mobj != 0| no Evaluation Count:0 | yes Evaluation Count:8 | 
 | 0-22 | 
| 1571 | QMessageLogger("kernel/qobject.cpp", 2836, __PRETTY_FUNCTION__).warning("QObject::disconnect: Unexpected null parameter"); | - | 
| 1572 | return false; never executed: return false; | 0 | 
| 1573 | } | - | 
| 1574 | if (signal.mobj) { evaluated:  signal.mobj| yes Evaluation Count:14 | yes Evaluation Count:8 | 
 | 8-14 | 
| 1575 | if(signal.methodType() != QMetaMethod::Signal) { evaluated:  signal.methodType() != QMetaMethod::Signal| yes Evaluation Count:1 | yes Evaluation Count:13 | 
 | 1-13 | 
| 1576 | QMessageLogger("kernel/qobject.cpp", 2841, __PRETTY_FUNCTION__).warning("QObject::%s: Attempt to %s non-signal %s::%s", | - | 
| 1577 | "disconnect","unbind", | - | 
| 1578 | sender->metaObject()->className(), signal.methodSignature().constData()); | - | 
| 1579 | return false; executed:  return false;Execution Count:1 | 1 | 
| 1580 | } | - | 
| 1581 | } executed:  }Execution Count:13 | 13 | 
| 1582 | if (method.mobj) { evaluated:  method.mobj| yes Evaluation Count:12 | yes Evaluation Count:9 | 
 | 9-12 | 
| 1583 | if(method.methodType() == QMetaMethod::Constructor) { partially evaluated:  method.methodType() == QMetaMethod::Constructor| no Evaluation Count:0 | yes Evaluation Count:12 | 
 | 0-12 | 
| 1584 | QMessageLogger("kernel/qobject.cpp", 2849, __PRETTY_FUNCTION__).warning("QObject::disconect: cannot use constructor as argument %s::%s", | - | 
| 1585 | receiver->metaObject()->className(), method.methodSignature().constData()); | - | 
| 1586 | return false; never executed: return false; | 0 | 
| 1587 | } | - | 
| 1588 | } executed:  }Execution Count:12 | 12 | 
| 1589 |  | - | 
| 1590 |  | - | 
| 1591 | QByteArray signalSignature; | - | 
| 1592 | if (signal.mobj) { evaluated:  signal.mobj| yes Evaluation Count:13 | yes Evaluation Count:8 | 
 | 8-13 | 
| 1593 | signalSignature.reserve(signal.methodSignature().size()+1); | - | 
| 1594 | signalSignature.append((char)(2 + '0')); | - | 
| 1595 | signalSignature.append(signal.methodSignature()); | - | 
| 1596 | } executed:  }Execution Count:13 | 13 | 
| 1597 |  | - | 
| 1598 | int signal_index; | - | 
| 1599 | int method_index; | - | 
| 1600 | { | - | 
| 1601 | int dummy; | - | 
| 1602 | QMetaObjectPrivate::memberIndexes(sender, signal, &signal_index, &dummy); | - | 
| 1603 | QMetaObjectPrivate::memberIndexes(receiver, method, &dummy, &method_index); | - | 
| 1604 | } | - | 
| 1605 |  | - | 
| 1606 |  | - | 
| 1607 | if (signal.mobj && signal_index == -1) { evaluated:  signal.mobj| yes Evaluation Count:13 | yes Evaluation Count:8 | 
partially evaluated:  signal_index == -1| no Evaluation Count:0 | yes Evaluation Count:13 | 
 | 0-13 | 
| 1608 | QMessageLogger("kernel/qobject.cpp", 2873, __PRETTY_FUNCTION__).warning("QObject::disconect: signal %s not found on class %s", | - | 
| 1609 | signal.methodSignature().constData(), sender->metaObject()->className()); | - | 
| 1610 | return false; never executed: return false; | 0 | 
| 1611 | } | - | 
| 1612 |  | - | 
| 1613 | if (receiver && method.mobj && method_index == -1) { evaluated:  receiver| yes Evaluation Count:13 | yes Evaluation Count:8 | 
evaluated:  method.mobj| yes Evaluation Count:12 | yes Evaluation Count:1 | 
partially evaluated:  method_index == -1| no Evaluation Count:0 | yes Evaluation Count:12 | 
 | 0-13 | 
| 1614 | QMessageLogger("kernel/qobject.cpp", 2879, __PRETTY_FUNCTION__).warning("QObject::disconect: method %s not found on class %s", | - | 
| 1615 | method.methodSignature().constData(), receiver->metaObject()->className()); | - | 
| 1616 | return false; never executed: return false; | 0 | 
| 1617 | } | - | 
| 1618 |  | - | 
| 1619 | if (!QMetaObjectPrivate::disconnect(sender, signal_index, signal.mobj, receiver, method_index, 0)) evaluated:  !QMetaObjectPrivate::disconnect(sender, signal_index, signal.mobj, receiver, method_index, 0)| yes Evaluation Count:1 | yes Evaluation Count:20 | 
 | 1-20 | 
| 1620 | return false; executed:  return false;Execution Count:1 | 1 | 
| 1621 |  | - | 
| 1622 | if (!signal.isValid()) { evaluated:  !signal.isValid()| yes Evaluation Count:8 | yes Evaluation Count:12 | 
 | 8-12 | 
| 1623 |  | - | 
| 1624 |  | - | 
| 1625 |  | - | 
| 1626 |  | - | 
| 1627 | const_cast<QObject*>(sender)->disconnectNotify(signal); | - | 
| 1628 | } executed:  }Execution Count:8 | 8 | 
| 1629 | return true; executed:  return true;Execution Count:20 | 20 | 
| 1630 | } | - | 
| 1631 | void QObject::connectNotify(const QMetaMethod &signal) | - | 
| 1632 | { | - | 
| 1633 | (void)signal;; | - | 
| 1634 | } executed:  }Execution Count:488525 | 488525 | 
| 1635 | void QObject::disconnectNotify(const QMetaMethod &signal) | - | 
| 1636 | { | - | 
| 1637 | (void)signal;; | - | 
| 1638 | } executed:  }Execution Count:257189 | 257189 | 
| 1639 |  | - | 
| 1640 |  | - | 
| 1641 |  | - | 
| 1642 |  | - | 
| 1643 |  | - | 
| 1644 | static int methodIndexToSignalIndex(const QMetaObject **base, int signal_index) | - | 
| 1645 | { | - | 
| 1646 | if (signal_index < 0) evaluated:  signal_index < 0| yes Evaluation Count:156 | yes Evaluation Count:207481 | 
 | 156-207481 | 
| 1647 | return signal_index; executed:  return signal_index;Execution Count:156 | 156 | 
| 1648 | const QMetaObject *metaObject = *base; | - | 
| 1649 | while (metaObject && metaObject->methodOffset() > signal_index) partially evaluated:  metaObject| yes Evaluation Count:415082 | no Evaluation Count:0 | 
evaluated:  metaObject->methodOffset() > signal_index| yes Evaluation Count:207601 | yes Evaluation Count:207481 | 
 | 0-415082 | 
| 1650 | metaObject = metaObject->superClass(); executed:  metaObject = metaObject->superClass();Execution Count:207601 | 207601 | 
| 1651 |  | - | 
| 1652 | if (metaObject) { partially evaluated:  metaObject| yes Evaluation Count:207481 | no Evaluation Count:0 | 
 | 0-207481 | 
| 1653 | int signalOffset, methodOffset; | - | 
| 1654 | computeOffsets(metaObject, &signalOffset, &methodOffset); | - | 
| 1655 | if (signal_index < metaObject->methodCount()) evaluated:  signal_index < metaObject->methodCount()| yes Evaluation Count:207479 | yes Evaluation Count:2 | 
 | 2-207479 | 
| 1656 | signal_index = QMetaObjectPrivate::originalClone(metaObject, signal_index - methodOffset) + signalOffset; executed:  signal_index = QMetaObjectPrivate::originalClone(metaObject, signal_index - methodOffset) + signalOffset;Execution Count:207479 | 207479 | 
| 1657 | else | - | 
| 1658 | signal_index = signal_index - methodOffset + signalOffset; executed:  signal_index = signal_index - methodOffset + signalOffset;Execution Count:2 | 2 | 
| 1659 | *base = metaObject; | - | 
| 1660 | } executed:  }Execution Count:207481 | 207481 | 
| 1661 | return signal_index; executed:  return signal_index;Execution Count:207481 | 207481 | 
| 1662 | } | - | 
| 1663 | QMetaObject::Connection QMetaObject::connect(const QObject *sender, int signal_index, | - | 
| 1664 | const QObject *receiver, int method_index, int type, int *types) | - | 
| 1665 | { | - | 
| 1666 | const QMetaObject *smeta = sender->metaObject(); | - | 
| 1667 | signal_index = methodIndexToSignalIndex(&smeta, signal_index); | - | 
| 1668 | return Connection(QMetaObjectPrivate::connect(sender, signal_index, smeta, | 106898 | 
| 1669 | receiver, method_index, | 106898 | 
| 1670 | 0, | 106898 | 
| 1671 | type, types)); executed:  return Connection(QMetaObjectPrivate::connect(sender, signal_index, smeta, receiver, method_index, 0, type, types));Execution Count:106898 | 106898 | 
| 1672 | } | - | 
| 1673 | QObjectPrivate::Connection *QMetaObjectPrivate::connect(const QObject *sender, | - | 
| 1674 | int signal_index, const QMetaObject *smeta, | - | 
| 1675 | const QObject *receiver, int method_index, | - | 
| 1676 | const QMetaObject *rmeta, int type, int *types) | - | 
| 1677 | { | - | 
| 1678 | QObject *s = const_cast<QObject *>(sender); | - | 
| 1679 | QObject *r = const_cast<QObject *>(receiver); | - | 
| 1680 |  | - | 
| 1681 | int method_offset = rmeta ? rmeta->methodOffset() : 0; evaluated:  rmeta| yes Evaluation Count:380472 | yes Evaluation Count:106937 | 
 | 106937-380472 | 
| 1682 | qt_noop(); | - | 
| 1683 | QObjectPrivate::StaticMetaCallFunction callFunction = | - | 
| 1684 | rmeta ? rmeta->d.static_metacall : 0; evaluated:  rmeta| yes Evaluation Count:380473 | yes Evaluation Count:106937 | 
 | 106937-380473 | 
| 1685 |  | - | 
| 1686 | QOrderedMutexLocker locker(signalSlotLock(sender), | - | 
| 1687 | signalSlotLock(receiver)); | - | 
| 1688 |  | - | 
| 1689 | if (type & Qt::UniqueConnection) { evaluated:  type & Qt::UniqueConnection| yes Evaluation Count:4424 | yes Evaluation Count:482996 | 
 | 4424-482996 | 
| 1690 | QObjectConnectionListVector *connectionLists = QObjectPrivate::get(s)->connectionLists; | - | 
| 1691 | if (connectionLists && connectionLists->count() > signal_index) { evaluated:  connectionLists| yes Evaluation Count:2464 | yes Evaluation Count:1960 | 
evaluated:  connectionLists->count() > signal_index| yes Evaluation Count:2127 | yes Evaluation Count:337 | 
 | 337-2464 | 
| 1692 | const QObjectPrivate::Connection *c2 = | - | 
| 1693 | (*connectionLists)[signal_index].first; | - | 
| 1694 |  | - | 
| 1695 | int method_index_absolute = method_index + method_offset; | - | 
| 1696 |  | - | 
| 1697 | while (c2) { evaluated:  c2| yes Evaluation Count:1303 | yes Evaluation Count:1017 | 
 | 1017-1303 | 
| 1698 | if (c2->receiver == receiver && c2->method() == method_index_absolute) evaluated:  c2->receiver == receiver| yes Evaluation Count:1112 | yes Evaluation Count:191 | 
evaluated:  c2->method() == method_index_absolute| yes Evaluation Count:1110 | yes Evaluation Count:2 | 
 | 2-1112 | 
| 1699 | return 0; executed:  return 0;Execution Count:1110 | 1110 | 
| 1700 | c2 = c2->nextConnectionList; | - | 
| 1701 | } executed:  }Execution Count:193 | 193 | 
| 1702 | } executed:  }Execution Count:1017 | 1017 | 
| 1703 | type &= Qt::UniqueConnection - 1; | - | 
| 1704 | } executed:  }Execution Count:3314 | 3314 | 
| 1705 |  | - | 
| 1706 | QScopedPointer<QObjectPrivate::Connection> c(new QObjectPrivate::Connection); | - | 
| 1707 | c->sender = s; | - | 
| 1708 | c->signal_index = signal_index; | - | 
| 1709 | c->receiver = r; | - | 
| 1710 | c->method_relative = method_index; | - | 
| 1711 | c->method_offset = method_offset; | - | 
| 1712 | c->connectionType = type; | - | 
| 1713 | c->isSlotObject = false; | - | 
| 1714 | c->argumentTypes.store(types); | - | 
| 1715 | c->nextConnectionList = 0; | - | 
| 1716 | c->callFunction = callFunction; | - | 
| 1717 |  | - | 
| 1718 | QObjectPrivate::get(s)->addConnection(signal_index, c.data()); | - | 
| 1719 |  | - | 
| 1720 | locker.unlock(); | - | 
| 1721 | QMetaMethod smethod = QMetaObjectPrivate::signal(smeta, signal_index); | - | 
| 1722 | if (smethod.isValid()) evaluated:  smethod.isValid()| yes Evaluation Count:486165 | yes Evaluation Count:135 | 
 | 135-486165 | 
| 1723 | s->connectNotify(smethod); executed:  s->connectNotify(smethod);Execution Count:486166 | 486166 | 
| 1724 |  | - | 
| 1725 | return c.take(); executed:  return c.take();Execution Count:486299 | 486299 | 
| 1726 | } | - | 
| 1727 |  | - | 
| 1728 |  | - | 
| 1729 |  | - | 
| 1730 |  | - | 
| 1731 | bool QMetaObject::disconnect(const QObject *sender, int signal_index, | - | 
| 1732 | const QObject *receiver, int method_index) | - | 
| 1733 | { | - | 
| 1734 | const QMetaObject *smeta = sender->metaObject(); | - | 
| 1735 | signal_index = methodIndexToSignalIndex(&smeta, signal_index); | - | 
| 1736 | return QMetaObjectPrivate::disconnect(sender, signal_index, smeta, | 100733 | 
| 1737 | receiver, method_index, 0); executed:  return QMetaObjectPrivate::disconnect(sender, signal_index, smeta, receiver, method_index, 0);Execution Count:100733 | 100733 | 
| 1738 | } | - | 
| 1739 | bool QMetaObject::disconnectOne(const QObject *sender, int signal_index, | - | 
| 1740 | const QObject *receiver, int method_index) | - | 
| 1741 | { | - | 
| 1742 | const QMetaObject *smeta = sender->metaObject(); | - | 
| 1743 | signal_index = methodIndexToSignalIndex(&smeta, signal_index); | - | 
| 1744 | return QMetaObjectPrivate::disconnect(sender, signal_index, smeta, | 6 | 
| 1745 | receiver, method_index, 0, | 6 | 
| 1746 | QMetaObjectPrivate::DisconnectOne); executed:  return QMetaObjectPrivate::disconnect(sender, signal_index, smeta, receiver, method_index, 0, QMetaObjectPrivate::DisconnectOne);Execution Count:6 | 6 | 
| 1747 | } | - | 
| 1748 |  | - | 
| 1749 |  | - | 
| 1750 |  | - | 
| 1751 |  | - | 
| 1752 |  | - | 
| 1753 | bool QMetaObjectPrivate::disconnectHelper(QObjectPrivate::Connection *c, | - | 
| 1754 | const QObject *receiver, int method_index, void **slot, | - | 
| 1755 | QMutex *senderMutex, DisconnectType disconnectType) | - | 
| 1756 | { | - | 
| 1757 | bool success = false; | - | 
| 1758 | while (c) { evaluated:  c| yes Evaluation Count:148305 | yes Evaluation Count:136283 | 
 | 136283-148305 | 
| 1759 | if (c->receiver evaluated:  c->receiver| yes Evaluation Count:143183 | yes Evaluation Count:5122 | 
 | 5122-143183 | 
| 1760 | && (receiver == 0 || (c->receiver == receiver evaluated:  receiver == 0| yes Evaluation Count:67 | yes Evaluation Count:143116 | 
evaluated:  c->receiver == receiver| yes Evaluation Count:122827 | yes Evaluation Count:20289 | 
 | 67-143116 | 
| 1761 | && (method_index < 0 || c->method() == method_index) evaluated:  method_index < 0| yes Evaluation Count:4663 | yes Evaluation Count:118164 | 
evaluated:  c->method() == method_index| yes Evaluation Count:116498 | yes Evaluation Count:1666 | 
 | 1666-118164 | 
| 1762 | && (slot == 0 || (c->isSlotObject && c->slotObj->compare(slot)))))) { evaluated:  slot == 0| yes Evaluation Count:121157 | yes Evaluation Count:4 | 
partially evaluated:  c->isSlotObject| yes Evaluation Count:4 | no Evaluation Count:0 | 
partially evaluated:  c->slotObj->compare(slot)| yes Evaluation Count:4 | no Evaluation Count:0 | 
 | 0-121157 | 
| 1763 | bool needToUnlock = false; | - | 
| 1764 | QMutex *receiverMutex = 0; | - | 
| 1765 | if (!receiver) { evaluated:  !receiver| yes Evaluation Count:67 | yes Evaluation Count:121161 | 
 | 67-121161 | 
| 1766 | receiverMutex = signalSlotLock(c->receiver); | - | 
| 1767 |  | - | 
| 1768 | needToUnlock = QOrderedMutexLocker::relock(senderMutex, receiverMutex); | - | 
| 1769 | } executed:  }Execution Count:67 | 67 | 
| 1770 | if (c->receiver) { partially evaluated:  c->receiver| yes Evaluation Count:121228 | no Evaluation Count:0 | 
 | 0-121228 | 
| 1771 | *c->prev = c->next; | - | 
| 1772 | if (c->next) evaluated:  c->next| yes Evaluation Count:22812 | yes Evaluation Count:98416 | 
 | 22812-98416 | 
| 1773 | c->next->prev = c->prev; executed:  c->next->prev = c->prev;Execution Count:22812 | 22812 | 
| 1774 | } executed:  }Execution Count:121228 | 121228 | 
| 1775 |  | - | 
| 1776 | if (needToUnlock) evaluated:  needToUnlock| yes Evaluation Count:50 | yes Evaluation Count:121178 | 
 | 50-121178 | 
| 1777 | receiverMutex->unlock(); executed:  receiverMutex->unlock();Execution Count:50 | 50 | 
| 1778 |  | - | 
| 1779 | c->receiver = 0; | - | 
| 1780 |  | - | 
| 1781 | success = true; | - | 
| 1782 |  | - | 
| 1783 | if (disconnectType == DisconnectOne) evaluated:  disconnectType == DisconnectOne| yes Evaluation Count:4 | yes Evaluation Count:121224 | 
 | 4-121224 | 
| 1784 | return success; executed:  return success;Execution Count:4 | 4 | 
| 1785 | } executed:  }Execution Count:121224 | 121224 | 
| 1786 | c = c->nextConnectionList; | - | 
| 1787 | } executed:  }Execution Count:148301 | 148301 | 
| 1788 | return success; executed:  return success;Execution Count:136283 | 136283 | 
| 1789 | } | - | 
| 1790 |  | - | 
| 1791 |  | - | 
| 1792 |  | - | 
| 1793 |  | - | 
| 1794 |  | - | 
| 1795 | bool QMetaObjectPrivate::disconnect(const QObject *sender, | - | 
| 1796 | int signal_index, const QMetaObject *smeta, | - | 
| 1797 | const QObject *receiver, int method_index, void **slot, | - | 
| 1798 | DisconnectType disconnectType) | - | 
| 1799 | { | - | 
| 1800 | if (!sender) partially evaluated:  !sender| no Evaluation Count:0 | yes Evaluation Count:135950 | 
 | 0-135950 | 
| 1801 | return false; never executed: return false; | 0 | 
| 1802 |  | - | 
| 1803 | QObject *s = const_cast<QObject *>(sender); | - | 
| 1804 |  | - | 
| 1805 | QMutex *senderMutex = signalSlotLock(sender); | - | 
| 1806 | QMutex *receiverMutex = receiver ? signalSlotLock(receiver) : 0; evaluated:  receiver| yes Evaluation Count:125945 | yes Evaluation Count:10005 | 
 | 10005-125945 | 
| 1807 | QOrderedMutexLocker locker(senderMutex, receiverMutex); | - | 
| 1808 |  | - | 
| 1809 | QObjectConnectionListVector *connectionLists = QObjectPrivate::get(s)->connectionLists; | - | 
| 1810 | if (!connectionLists) evaluated:  !connectionLists| yes Evaluation Count:6751 | yes Evaluation Count:129201 | 
 | 6751-129201 | 
| 1811 | return false; executed:  return false;Execution Count:6751 | 6751 | 
| 1812 |  | - | 
| 1813 |  | - | 
| 1814 | ++connectionLists->inUse; | - | 
| 1815 |  | - | 
| 1816 | bool success = false; | - | 
| 1817 | if (signal_index < 0) { evaluated:  signal_index < 0| yes Evaluation Count:1717 | yes Evaluation Count:127484 | 
 | 1717-127484 | 
| 1818 |  | - | 
| 1819 | for (int sig_index = -1; sig_index < connectionLists->count(); ++sig_index) { evaluated:  sig_index < connectionLists->count()| yes Evaluation Count:14550 | yes Evaluation Count:1717 | 
 | 1717-14550 | 
| 1820 | QObjectPrivate::Connection *c = | - | 
| 1821 | (*connectionLists)[sig_index].first; | - | 
| 1822 | if (disconnectHelper(c, receiver, method_index, slot, senderMutex, disconnectType)) { evaluated:  disconnectHelper(c, receiver, method_index, slot, senderMutex, disconnectType)| yes Evaluation Count:4280 | yes Evaluation Count:10270 | 
 | 4280-10270 | 
| 1823 | success = true; | - | 
| 1824 | connectionLists->dirty = true; | - | 
| 1825 | } executed:  }Execution Count:4280 | 4280 | 
| 1826 | } executed:  }Execution Count:14550 | 14550 | 
| 1827 | } else if (signal_index < connectionLists->count()) { executed:  }Execution Count:1717evaluated:  signal_index < connectionLists->count()| yes Evaluation Count:121737 | yes Evaluation Count:5747 | 
 | 1717-121737 | 
| 1828 | QObjectPrivate::Connection *c = | - | 
| 1829 | (*connectionLists)[signal_index].first; | - | 
| 1830 | if (disconnectHelper(c, receiver, method_index, slot, senderMutex, disconnectType)) { evaluated:  disconnectHelper(c, receiver, method_index, slot, senderMutex, disconnectType)| yes Evaluation Count:116593 | yes Evaluation Count:5144 | 
 | 5144-116593 | 
| 1831 | success = true; | - | 
| 1832 | connectionLists->dirty = true; | - | 
| 1833 | } executed:  }Execution Count:116593 | 116593 | 
| 1834 | } executed:  }Execution Count:121737 | 121737 | 
| 1835 |  | - | 
| 1836 | --connectionLists->inUse; | - | 
| 1837 | qt_noop(); | - | 
| 1838 | if (connectionLists->orphaned && !connectionLists->inUse) partially evaluated:  connectionLists->orphaned| no Evaluation Count:0 | yes Evaluation Count:129201 | 
never evaluated: !connectionLists->inUse | 0-129201 | 
| 1839 | delete connectionLists; never executed: delete connectionLists; | 0 | 
| 1840 |  | - | 
| 1841 | locker.unlock(); | - | 
| 1842 | if (success) { evaluated:  success| yes Evaluation Count:118274 | yes Evaluation Count:10927 | 
 | 10927-118274 | 
| 1843 | QMetaMethod smethod = QMetaObjectPrivate::signal(smeta, signal_index); | - | 
| 1844 | if (smethod.isValid()) evaluated:  smethod.isValid()| yes Evaluation Count:116593 | yes Evaluation Count:1681 | 
 | 1681-116593 | 
| 1845 | s->disconnectNotify(smethod); executed:  s->disconnectNotify(smethod);Execution Count:116593 | 116593 | 
| 1846 | } executed:  }Execution Count:118274 | 118274 | 
| 1847 |  | - | 
| 1848 | return success; executed:  return success;Execution Count:129201 | 129201 | 
| 1849 | } | - | 
| 1850 | void QMetaObject::connectSlotsByName(QObject *o) | - | 
| 1851 | { | - | 
| 1852 | if (!o) partially evaluated:  !o| no Evaluation Count:0 | yes Evaluation Count:203 | 
 | 0-203 | 
| 1853 | return; | 0 | 
| 1854 | const QMetaObject *mo = o->metaObject(); | - | 
| 1855 | qt_noop(); | - | 
| 1856 | const QObjectList list = o->findChildren<QObject *>(QString()); | - | 
| 1857 | for (int i = 0; i < mo->methodCount(); ++i) { evaluated:  i < mo->methodCount()| yes Evaluation Count:12945 | yes Evaluation Count:203 | 
 | 203-12945 | 
| 1858 | QByteArray slotSignature = mo->method(i).methodSignature(); | - | 
| 1859 | const char *slot = slotSignature.constData(); | - | 
| 1860 | qt_noop(); | - | 
| 1861 | if (slot[0] != 'o' || slot[1] != 'n' || slot[2] != '_') evaluated:  slot[0] != 'o'| yes Evaluation Count:12527 | yes Evaluation Count:418 | 
evaluated:  slot[1] != 'n'| yes Evaluation Count:394 | yes Evaluation Count:24 | 
evaluated:  slot[2] != '_'| yes Evaluation Count:1 | yes Evaluation Count:23 | 
 | 1-12527 | 
| 1862 | continue; executed:  continue;Execution Count:12922 | 12922 | 
| 1863 | bool foundIt = false; | - | 
| 1864 | for(int j = 0; j < list.count(); ++j) { evaluated:  j < list.count()| yes Evaluation Count:26 | yes Evaluation Count:7 | 
 | 7-26 | 
| 1865 | const QObject *co = list.at(j); | - | 
| 1866 | QByteArray objName = co->objectName().toLatin1(); | - | 
| 1867 | int len = objName.length(); | - | 
| 1868 | if (!len || qstrncmp(slot + 3, objName.data(), len) || slot[len+3] != '_') partially evaluated:  !len| no Evaluation Count:0 | yes Evaluation Count:26 | 
evaluated:  qstrncmp(slot + 3, objName.data(), len)| yes Evaluation Count:10 | yes Evaluation Count:16 | 
partially evaluated:  slot[len+3] != '_'| no Evaluation Count:0 | yes Evaluation Count:16 | 
 | 0-26 | 
| 1869 | continue; executed:  continue;Execution Count:10 | 10 | 
| 1870 | const QMetaObject *smeta; | - | 
| 1871 | int sigIndex = co->d_func()->signalIndex(slot + len + 4, &smeta); | - | 
| 1872 | if (sigIndex < 0) { evaluated:  sigIndex < 0| yes Evaluation Count:1 | yes Evaluation Count:15 | 
 | 1-15 | 
| 1873 | const QMetaObject *smo = co->metaObject(); | - | 
| 1874 | int slotlen = qstrlen(slot + len + 4) - 1; | - | 
| 1875 | for (int k = 0; k < QMetaObjectPrivate::absoluteSignalCount(smo); ++k) { partially evaluated:  k < QMetaObjectPrivate::absoluteSignalCount(smo)| yes Evaluation Count:7 | no Evaluation Count:0 | 
 | 0-7 | 
| 1876 | QMetaMethod method = QMetaObjectPrivate::signal(smo, k); | - | 
| 1877 | if (!qstrncmp(method.methodSignature().constData(), slot + len + 4, slotlen)) { evaluated:  !qstrncmp(method.methodSignature().constData(), slot + len + 4, slotlen)| yes Evaluation Count:1 | yes Evaluation Count:6 | 
 | 1-6 | 
| 1878 | smeta = method.enclosingMetaObject(); | - | 
| 1879 | sigIndex = k; | - | 
| 1880 | break; executed:  break;Execution Count:1 | 1 | 
| 1881 | } | - | 
| 1882 | } executed:  }Execution Count:6 | 6 | 
| 1883 | } executed:  }Execution Count:1 | 1 | 
| 1884 | if (sigIndex < 0) partially evaluated:  sigIndex < 0| no Evaluation Count:0 | yes Evaluation Count:16 | 
 | 0-16 | 
| 1885 | continue; never executed: continue; | 0 | 
| 1886 |  | - | 
| 1887 | if (Connection(QMetaObjectPrivate::connect(co, sigIndex, smeta, o, i))) { partially evaluated:  Connection(QMetaObjectPrivate::connect(co, sigIndex, smeta, o, i))| yes Evaluation Count:16 | no Evaluation Count:0 | 
 | 0-16 | 
| 1888 | foundIt = true; | - | 
| 1889 | break; executed:  break;Execution Count:16 | 16 | 
| 1890 | } | - | 
| 1891 | } | 0 | 
| 1892 | if (foundIt) { evaluated:  foundIt| yes Evaluation Count:16 | yes Evaluation Count:7 | 
 | 7-16 | 
| 1893 |  | - | 
| 1894 | while (mo->method(i + 1).attributes() & QMetaMethod::Cloned) evaluated:  mo->method(i + 1).attributes() & QMetaMethod::Cloned| yes Evaluation Count:3 | yes Evaluation Count:16 | 
 | 3-16 | 
| 1895 | ++i; executed:  ++i;Execution Count:3 | 3 | 
| 1896 | } else if (!(mo->method(i).attributes() & QMetaMethod::Cloned)) { executed:  }Execution Count:16evaluated:  !(mo->method(i).attributes() & QMetaMethod::Cloned)| yes Evaluation Count:5 | yes Evaluation Count:2 | 
 | 2-16 | 
| 1897 | QMessageLogger("kernel/qobject.cpp", 3271, __PRETTY_FUNCTION__).warning("QMetaObject::connectSlotsByName: No matching signal for %s", slot); | - | 
| 1898 | } executed:  }Execution Count:5 | 5 | 
| 1899 | } | - | 
| 1900 | } executed:  }Execution Count:203 | 203 | 
| 1901 |  | - | 
| 1902 |  | - | 
| 1903 |  | - | 
| 1904 |  | - | 
| 1905 |  | - | 
| 1906 |  | - | 
| 1907 | static void queued_activate(QObject *sender, int signal, QObjectPrivate::Connection *c, void **argv) | - | 
| 1908 | { | - | 
| 1909 | const int *argumentTypes = c->argumentTypes.load(); | - | 
| 1910 | if (!argumentTypes && argumentTypes != &DIRECT_CONNECTION_ONLY) { evaluated:  !argumentTypes| yes Evaluation Count:1780 | yes Evaluation Count:23174 | 
partially evaluated:  argumentTypes != &DIRECT_CONNECTION_ONLY| yes Evaluation Count:1780 | no Evaluation Count:0 | 
 | 0-23174 | 
| 1911 | QMetaMethod m = QMetaObjectPrivate::signal(sender->metaObject(), signal); | - | 
| 1912 | argumentTypes = queuedConnectionTypes(m.parameterTypes()); | - | 
| 1913 | if (!argumentTypes) partially evaluated:  !argumentTypes| no Evaluation Count:0 | yes Evaluation Count:1780 | 
 | 0-1780 | 
| 1914 | argumentTypes = &DIRECT_CONNECTION_ONLY; never executed: argumentTypes = &DIRECT_CONNECTION_ONLY; | 0 | 
| 1915 | if (!c->argumentTypes.testAndSetOrdered(0, argumentTypes)) { partially evaluated:  !c->argumentTypes.testAndSetOrdered(0, argumentTypes)| no Evaluation Count:0 | yes Evaluation Count:1780 | 
 | 0-1780 | 
| 1916 | if (argumentTypes != &DIRECT_CONNECTION_ONLY) never evaluated: argumentTypes != &DIRECT_CONNECTION_ONLY | 0 | 
| 1917 | delete [] argumentTypes; never executed: delete [] argumentTypes; | 0 | 
| 1918 | argumentTypes = c->argumentTypes.load(); | - | 
| 1919 | } | 0 | 
| 1920 | } executed:  }Execution Count:1780 | 1780 | 
| 1921 | if (argumentTypes == &DIRECT_CONNECTION_ONLY) partially evaluated:  argumentTypes == &DIRECT_CONNECTION_ONLY| no Evaluation Count:0 | yes Evaluation Count:24954 | 
 | 0-24954 | 
| 1922 | return; | 0 | 
| 1923 | int nargs = 1; | - | 
| 1924 | while (argumentTypes[nargs-1]) evaluated:  argumentTypes[nargs-1]| yes Evaluation Count:35745 | yes Evaluation Count:24954 | 
 | 24954-35745 | 
| 1925 | ++nargs; executed:  ++nargs;Execution Count:35745 | 35745 | 
| 1926 | int *types = (int *) malloc(nargs*sizeof(int)); | - | 
| 1927 | do { if (!(types)) qBadAlloc(); } while (0); never executed: qBadAlloc();executed:  }Execution Count:24954partially evaluated:  !(types)| no Evaluation Count:0 | yes Evaluation Count:24954 | 
partially evaluated:  0| no Evaluation Count:0 | yes Evaluation Count:24954 | 
 | 0-24954 | 
| 1928 | void **args = (void **) malloc(nargs*sizeof(void *)); | - | 
| 1929 | do { if (!(args)) qBadAlloc(); } while (0); never executed: qBadAlloc();executed:  }Execution Count:24954partially evaluated:  !(args)| no Evaluation Count:0 | yes Evaluation Count:24954 | 
partially evaluated:  0| no Evaluation Count:0 | yes Evaluation Count:24954 | 
 | 0-24954 | 
| 1930 | types[0] = 0; | - | 
| 1931 | args[0] = 0; | - | 
| 1932 | for (int n = 1; n < nargs; ++n) evaluated:  n < nargs| yes Evaluation Count:35745 | yes Evaluation Count:24954 | 
 | 24954-35745 | 
| 1933 | args[n] = QMetaType::create((types[n] = argumentTypes[n-1]), argv[n]); executed:  args[n] = QMetaType::create((types[n] = argumentTypes[n-1]), argv[n]);Execution Count:35745 | 35745 | 
| 1934 | QMetaCallEvent *ev = c->isSlotObject ? evaluated:  c->isSlotObject| yes Evaluation Count:15 | yes Evaluation Count:24939 | 
 | 15-24939 | 
| 1935 | new QMetaCallEvent(c->slotObj, sender, signal, nargs, types, args) : | - | 
| 1936 | new QMetaCallEvent(c->method_offset, c->method_relative, c->callFunction, sender, signal, nargs, types, args); | - | 
| 1937 | QCoreApplication::postEvent(c->receiver, ev); | - | 
| 1938 | } executed:  }Execution Count:24954 | 24954 | 
| 1939 |  | - | 
| 1940 |  | - | 
| 1941 |  | - | 
| 1942 |  | - | 
| 1943 | void QMetaObject::activate(QObject *sender, const QMetaObject *m, int local_signal_index, | - | 
| 1944 | void **argv) | - | 
| 1945 | { | - | 
| 1946 | activate(sender, QMetaObjectPrivate::signalOffset(m), local_signal_index, argv); | - | 
| 1947 | } executed:  }Execution Count:20609033 | 20609033 | 
| 1948 |  | - | 
| 1949 |  | - | 
| 1950 |  | - | 
| 1951 |  | - | 
| 1952 | void QMetaObject::activate(QObject *sender, int signalOffset, int local_signal_index, void **argv) | - | 
| 1953 | { | - | 
| 1954 | int signal_index = signalOffset + local_signal_index; | - | 
| 1955 |  | - | 
| 1956 | if (!sender->d_func()->isSignalConnected(signal_index)) evaluated:  !sender->d_func()->isSignalConnected(signal_index)| yes Evaluation Count:12917625 | yes Evaluation Count:7691301 | 
 | 7691301-12917625 | 
| 1957 | return; executed:  return;Execution Count:12917631 | 12917631 | 
| 1958 |  | - | 
| 1959 | if (sender->d_func()->blockSig) evaluated:  sender->d_func()->blockSig| yes Evaluation Count:38011 | yes Evaluation Count:7653290 | 
 | 38011-7653290 | 
| 1960 | return; executed:  return;Execution Count:38011 | 38011 | 
| 1961 |  | - | 
| 1962 | if (sender->d_func()->declarativeData && QAbstractDeclarativeData::signalEmitted) partially evaluated:  sender->d_func()->declarativeData| no Evaluation Count:0 | yes Evaluation Count:7653288 | 
never evaluated: QAbstractDeclarativeData::signalEmitted | 0-7653288 | 
| 1963 | QAbstractDeclarativeData::signalEmitted(sender->d_func()->declarativeData, sender, | 0 | 
| 1964 | signal_index, argv); never executed: QAbstractDeclarativeData::signalEmitted(sender->d_func()->declarativeData, sender, signal_index, argv); | 0 | 
| 1965 |  | - | 
| 1966 | void *empty_argv[] = { 0 }; | - | 
| 1967 | if (qt_signal_spy_callback_set.signal_begin_callback != 0) { partially evaluated:  qt_signal_spy_callback_set.signal_begin_callback != 0| no Evaluation Count:0 | yes Evaluation Count:7653287 | 
 | 0-7653287 | 
| 1968 | qt_signal_spy_callback_set.signal_begin_callback(sender, signal_index, | - | 
| 1969 | argv ? argv : empty_argv); | - | 
| 1970 | } | 0 | 
| 1971 |  | - | 
| 1972 | Qt::HANDLE currentThreadId = QThread::currentThreadId(); | - | 
| 1973 |  | - | 
| 1974 | { | - | 
| 1975 | QMutexLocker locker(signalSlotLock(sender)); | - | 
| 1976 | struct ConnectionListsRef { | - | 
| 1977 | QObjectConnectionListVector *connectionLists; | - | 
| 1978 | ConnectionListsRef(QObjectConnectionListVector *connectionLists) : connectionLists(connectionLists) | - | 
| 1979 | { | - | 
| 1980 | if (connectionLists) evaluated:  connectionLists| yes Evaluation Count:7652687 | yes Evaluation Count:619 | 
 | 619-7652687 | 
| 1981 | ++connectionLists->inUse; executed:  ++connectionLists->inUse;Execution Count:7652685 | 7652685 | 
| 1982 | } executed:  }Execution Count:7653300 | 7653300 | 
| 1983 | ~ConnectionListsRef() | - | 
| 1984 | { | - | 
| 1985 | if (!connectionLists) evaluated:  !connectionLists| yes Evaluation Count:619 | yes Evaluation Count:7652632 | 
 | 619-7652632 | 
| 1986 | return; executed:  return;Execution Count:619 | 619 | 
| 1987 |  | - | 
| 1988 | --connectionLists->inUse; | - | 
| 1989 | qt_noop(); | - | 
| 1990 | if (connectionLists->orphaned) { evaluated:  connectionLists->orphaned| yes Evaluation Count:75 | yes Evaluation Count:7652557 | 
 | 75-7652557 | 
| 1991 | if (!connectionLists->inUse) evaluated:  !connectionLists->inUse| yes Evaluation Count:74 | yes Evaluation Count:1 | 
 | 1-74 | 
| 1992 | delete connectionLists; executed:  delete connectionLists;Execution Count:74 | 74 | 
| 1993 | } executed:  }Execution Count:75 | 75 | 
| 1994 | } executed:  }Execution Count:7652635 | 7652635 | 
| 1995 |  | - | 
| 1996 | QObjectConnectionListVector *operator->() const { return connectionLists; } executed:  return connectionLists;Execution Count:54241509 | 54241509 | 
| 1997 | }; | - | 
| 1998 | ConnectionListsRef connectionLists = sender->d_func()->connectionLists; | - | 
| 1999 | if (!connectionLists.connectionLists) { evaluated:  !connectionLists.connectionLists| yes Evaluation Count:619 | yes Evaluation Count:7652682 | 
 | 619-7652682 | 
| 2000 | locker.unlock(); | - | 
| 2001 | if (qt_signal_spy_callback_set.signal_end_callback != 0) partially evaluated:  qt_signal_spy_callback_set.signal_end_callback != 0| no Evaluation Count:0 | yes Evaluation Count:619 | 
 | 0-619 | 
| 2002 | qt_signal_spy_callback_set.signal_end_callback(sender, signal_index); never executed: qt_signal_spy_callback_set.signal_end_callback(sender, signal_index); | 0 | 
| 2003 | return; executed:  return;Execution Count:619 | 619 | 
| 2004 | } | - | 
| 2005 |  | - | 
| 2006 | const QObjectPrivate::ConnectionList *list; | - | 
| 2007 | if (signal_index < connectionLists->count()) evaluated:  signal_index < connectionLists->count()| yes Evaluation Count:7652448 | yes Evaluation Count:206 | 
 | 206-7652448 | 
| 2008 | list = &connectionLists->at(signal_index); executed:  list = &connectionLists->at(signal_index);Execution Count:7652452 | 7652452 | 
| 2009 | else | - | 
| 2010 | list = &connectionLists->allsignals; executed:  list = &connectionLists->allsignals;Execution Count:206 | 206 | 
| 2011 |  | - | 
| 2012 | do { | - | 
| 2013 | QObjectPrivate::Connection *c = list->first; | - | 
| 2014 | if (!c) continue; executed:  continue;Execution Count:7652418evaluated:  !c| yes Evaluation Count:7652421 | yes Evaluation Count:7652579 | 
 | 7652418-7652579 | 
| 2015 |  | - | 
| 2016 |  | - | 
| 2017 | QObjectPrivate::Connection *last = list->last; | - | 
| 2018 |  | - | 
| 2019 | do { | - | 
| 2020 | if (!c->receiver) evaluated:  !c->receiver| yes Evaluation Count:38874 | yes Evaluation Count:8352307 | 
 | 38874-8352307 | 
| 2021 | continue; executed:  continue;Execution Count:38874 | 38874 | 
| 2022 |  | - | 
| 2023 | QObject * const receiver = c->receiver; | - | 
| 2024 | const bool receiverInSameThread = currentThreadId == receiver->d_func()->threadData->threadId; | - | 
| 2025 |  | - | 
| 2026 |  | - | 
| 2027 |  | - | 
| 2028 | if ((c->connectionType == Qt::AutoConnection && !receiverInSameThread) evaluated:  c->connectionType == Qt::AutoConnection| yes Evaluation Count:8305468 | yes Evaluation Count:46864 | 
evaluated:  !receiverInSameThread| yes Evaluation Count:7443 | yes Evaluation Count:8298028 | 
 | 7443-8305468 | 
| 2029 | || (c->connectionType == Qt::QueuedConnection)) { evaluated:  (c->connectionType == Qt::QueuedConnection)| yes Evaluation Count:17511 | yes Evaluation Count:8327362 | 
 | 17511-8327362 | 
| 2030 | queued_activate(sender, signal_index, c, argv ? argv : empty_argv); | - | 
| 2031 | continue; executed:  continue;Execution Count:24954 | 24954 | 
| 2032 |  | - | 
| 2033 | } else if (c->connectionType == Qt::BlockingQueuedConnection) { evaluated:  c->connectionType == Qt::BlockingQueuedConnection| yes Evaluation Count:544 | yes Evaluation Count:8326817 | 
 | 544-8326817 | 
| 2034 | locker.unlock(); | - | 
| 2035 | if (receiverInSameThread) { partially evaluated:  receiverInSameThread| no Evaluation Count:0 | yes Evaluation Count:544 | 
 | 0-544 | 
| 2036 | QMessageLogger("kernel/qobject.cpp", 3410, __PRETTY_FUNCTION__).warning("Qt: Dead lock detected while activating a BlockingQueuedConnection: " | - | 
| 2037 | "Sender is %s(%p), receiver is %s(%p)", | - | 
| 2038 | sender->metaObject()->className(), sender, | - | 
| 2039 | receiver->metaObject()->className(), receiver); | - | 
| 2040 | } | 0 | 
| 2041 | QSemaphore semaphore; | - | 
| 2042 | QMetaCallEvent *ev = c->isSlotObject ? evaluated:  c->isSlotObject| yes Evaluation Count:52 | yes Evaluation Count:492 | 
 | 52-492 | 
| 2043 | new QMetaCallEvent(c->slotObj, sender, signal_index, 0, 0, argv ? argv : empty_argv, &semaphore) : | - | 
| 2044 | new QMetaCallEvent(c->method_offset, c->method_relative, c->callFunction, sender, signal_index, 0, 0, argv ? argv : empty_argv, &semaphore); | - | 
| 2045 | QCoreApplication::postEvent(receiver, ev); | - | 
| 2046 | semaphore.acquire(); | - | 
| 2047 | locker.relock(); | - | 
| 2048 | continue; executed:  continue;Execution Count:544 | 544 | 
| 2049 |  | - | 
| 2050 | } | - | 
| 2051 |  | - | 
| 2052 | QConnectionSenderSwitcher sw; | - | 
| 2053 |  | - | 
| 2054 | if (receiverInSameThread) { evaluated:  receiverInSameThread| yes Evaluation Count:8326713 | yes Evaluation Count:105 | 
 | 105-8326713 | 
| 2055 | sw.switchSender(receiver, sender, signal_index); | - | 
| 2056 | } executed:  }Execution Count:8326713 | 8326713 | 
| 2057 | const QObjectPrivate::StaticMetaCallFunction callFunction = c->callFunction; | - | 
| 2058 | const int method_relative = c->method_relative; | - | 
| 2059 | if (c->isSlotObject) { evaluated:  c->isSlotObject| yes Evaluation Count:372 | yes Evaluation Count:8326447 | 
 | 372-8326447 | 
| 2060 | c->slotObj->ref(); | - | 
| 2061 | const QScopedPointer<QtPrivate::QSlotObjectBase, QSlotObjectBaseDeleter> obj(c->slotObj); | - | 
| 2062 | locker.unlock(); | - | 
| 2063 | obj->call(receiver, argv ? argv : empty_argv); | - | 
| 2064 | locker.relock(); | - | 
| 2065 | } else if (callFunction && c->method_offset <= receiver->metaObject()->methodOffset()) { executed:  }Execution Count:372evaluated:  callFunction| yes Evaluation Count:8319188 | yes Evaluation Count:7261 | 
evaluated:  c->method_offset <= receiver->metaObject()->methodOffset()| yes Evaluation Count:8316572 | yes Evaluation Count:2622 | 
 | 372-8319188 | 
| 2066 |  | - | 
| 2067 | locker.unlock(); | - | 
| 2068 | if (qt_signal_spy_callback_set.slot_begin_callback != 0) partially evaluated:  qt_signal_spy_callback_set.slot_begin_callback != 0| no Evaluation Count:0 | yes Evaluation Count:8316594 | 
 | 0-8316594 | 
| 2069 | qt_signal_spy_callback_set.slot_begin_callback(receiver, c->method(), argv ? argv : empty_argv); never executed: qt_signal_spy_callback_set.slot_begin_callback(receiver, c->method(), argv ? argv : empty_argv); | 0 | 
| 2070 |  | - | 
| 2071 | callFunction(receiver, QMetaObject::InvokeMetaMethod, method_relative, argv ? argv : empty_argv); | - | 
| 2072 |  | - | 
| 2073 | if (qt_signal_spy_callback_set.slot_end_callback != 0) partially evaluated:  qt_signal_spy_callback_set.slot_end_callback != 0| no Evaluation Count:0 | yes Evaluation Count:8316591 | 
 | 0-8316591 | 
| 2074 | qt_signal_spy_callback_set.slot_end_callback(receiver, c->method()); never executed: qt_signal_spy_callback_set.slot_end_callback(receiver, c->method()); | 0 | 
| 2075 | locker.relock(); | - | 
| 2076 | } else { executed:  }Execution Count:8316592 | 8316592 | 
| 2077 | const int method = method_relative + c->method_offset; | - | 
| 2078 | locker.unlock(); | - | 
| 2079 |  | - | 
| 2080 | if (qt_signal_spy_callback_set.slot_begin_callback != 0) { partially evaluated:  qt_signal_spy_callback_set.slot_begin_callback != 0| no Evaluation Count:0 | yes Evaluation Count:9883 | 
 | 0-9883 | 
| 2081 | qt_signal_spy_callback_set.slot_begin_callback(receiver, | - | 
| 2082 | method, | - | 
| 2083 | argv ? argv : empty_argv); | - | 
| 2084 | } | 0 | 
| 2085 |  | - | 
| 2086 | metacall(receiver, QMetaObject::InvokeMetaMethod, method, argv ? argv : empty_argv); | - | 
| 2087 |  | - | 
| 2088 | if (qt_signal_spy_callback_set.slot_end_callback != 0) partially evaluated:  qt_signal_spy_callback_set.slot_end_callback != 0| no Evaluation Count:0 | yes Evaluation Count:9883 | 
 | 0-9883 | 
| 2089 | qt_signal_spy_callback_set.slot_end_callback(receiver, method); never executed: qt_signal_spy_callback_set.slot_end_callback(receiver, method); | 0 | 
| 2090 |  | - | 
| 2091 | locker.relock(); | - | 
| 2092 | } executed:  }Execution Count:9883 | 9883 | 
| 2093 |  | - | 
| 2094 | if (connectionLists->orphaned) evaluated:  connectionLists->orphaned| yes Evaluation Count:74 | yes Evaluation Count:8326766 | 
 | 74-8326766 | 
| 2095 | break; executed:  break;Execution Count:74 | 74 | 
| 2096 | } while (c != last && (c = c->nextConnectionList) != 0); executed:  }Execution Count:8326757evaluated:  c != last| yes Evaluation Count:738601 | yes Evaluation Count:7652512 | 
partially evaluated:  (c = c->nextConnectionList) != 0| yes Evaluation Count:738601 | no Evaluation Count:0 | 
 | 0-8326757 | 
| 2097 |  | - | 
| 2098 | if (connectionLists->orphaned) evaluated:  connectionLists->orphaned| yes Evaluation Count:75 | yes Evaluation Count:7652503 | 
 | 75-7652503 | 
| 2099 | break; executed:  break;Execution Count:75 | 75 | 
| 2100 | } while (list != &connectionLists->allsignals && executed:  }Execution Count:7652504evaluated:  list != &connectionLists->allsignals| yes Evaluation Count:7652359 | yes Evaluation Count:7652555 | 
 | 7652359-7652555 | 
| 2101 |  | - | 
| 2102 | ((list = &connectionLists->allsignals), true)); partially evaluated:  ((list = &connectionLists->allsignals), true)| yes Evaluation Count:7652344 | no Evaluation Count:0 | 
 | 0-7652344 | 
| 2103 |  | - | 
| 2104 | } | - | 
| 2105 |  | - | 
| 2106 | if (qt_signal_spy_callback_set.signal_end_callback != 0) partially evaluated:  qt_signal_spy_callback_set.signal_end_callback != 0| no Evaluation Count:0 | yes Evaluation Count:7652683 | 
 | 0-7652683 | 
| 2107 | qt_signal_spy_callback_set.signal_end_callback(sender, signal_index); never executed: qt_signal_spy_callback_set.signal_end_callback(sender, signal_index); | 0 | 
| 2108 |  | - | 
| 2109 | } executed:  }Execution Count:7652686 | 7652686 | 
| 2110 |  | - | 
| 2111 |  | - | 
| 2112 |  | - | 
| 2113 |  | - | 
| 2114 |  | - | 
| 2115 | void QMetaObject::activate(QObject *sender, int signal_index, void **argv) | - | 
| 2116 | { | - | 
| 2117 | const QMetaObject *mo = sender->metaObject(); | - | 
| 2118 | while (mo->methodOffset() > signal_index) partially evaluated:  mo->methodOffset() > signal_index| no Evaluation Count:0 | yes Evaluation Count:3 | 
 | 0-3 | 
| 2119 | mo = mo->superClass(); never executed: mo = mo->superClass(); | 0 | 
| 2120 | activate(sender, mo, signal_index - mo->methodOffset(), argv); | - | 
| 2121 | } executed:  }Execution Count:3 | 3 | 
| 2122 |  | - | 
| 2123 |  | - | 
| 2124 |  | - | 
| 2125 |  | - | 
| 2126 |  | - | 
| 2127 | int QObjectPrivate::senderSignalIndex() const | - | 
| 2128 | { | - | 
| 2129 | const QObject * const q = q_func(); | - | 
| 2130 | QMutexLocker locker(signalSlotLock(q)); | - | 
| 2131 | if (!currentSender) evaluated:  !currentSender| yes Evaluation Count:5 | yes Evaluation Count:228 | 
 | 5-228 | 
| 2132 | return -1; executed:  return -1;Execution Count:5 | 5 | 
| 2133 |  | - | 
| 2134 | for (QObjectPrivate::Connection *c = senders; c; c = c->next) { evaluated:  c| yes Evaluation Count:422 | yes Evaluation Count:2 | 
 | 2-422 | 
| 2135 | if (c->sender == currentSender->sender) evaluated:  c->sender == currentSender->sender| yes Evaluation Count:226 | yes Evaluation Count:196 | 
 | 196-226 | 
| 2136 | return currentSender->signal; executed:  return currentSender->signal;Execution Count:226 | 226 | 
| 2137 | } executed:  }Execution Count:196 | 196 | 
| 2138 |  | - | 
| 2139 | return -1; executed:  return -1;Execution Count:2 | 2 | 
| 2140 | } | - | 
| 2141 | int QObjectPrivate::signalIndex(const char *signalName, | - | 
| 2142 | const QMetaObject **meta) const | - | 
| 2143 | { | - | 
| 2144 | const QObject * const q = q_func(); | - | 
| 2145 | const QMetaObject *base = q->metaObject(); | - | 
| 2146 | qt_noop(); | - | 
| 2147 | QArgumentTypeArray types; | - | 
| 2148 | QByteArray name = QMetaObjectPrivate::decodeMethodSignature(signalName, types); | - | 
| 2149 | int relative_index = QMetaObjectPrivate::indexOfSignalRelative( | - | 
| 2150 | &base, name, types.size(), types.constData()); | - | 
| 2151 | if (relative_index < 0) evaluated:  relative_index < 0| yes Evaluation Count:1 | yes Evaluation Count:866 | 
 | 1-866 | 
| 2152 | return relative_index; executed:  return relative_index;Execution Count:1 | 1 | 
| 2153 | relative_index = QMetaObjectPrivate::originalClone(base, relative_index); | - | 
| 2154 | if (meta) evaluated:  meta| yes Evaluation Count:15 | yes Evaluation Count:851 | 
 | 15-851 | 
| 2155 | *meta = base; executed:  *meta = base;Execution Count:15 | 15 | 
| 2156 | return relative_index + QMetaObjectPrivate::signalOffset(base); executed:  return relative_index + QMetaObjectPrivate::signalOffset(base);Execution Count:866 | 866 | 
| 2157 | } | - | 
| 2158 | bool QObject::setProperty(const char *name, const QVariant &value) | - | 
| 2159 | { | - | 
| 2160 | QObjectPrivate * const d = d_func(); | - | 
| 2161 | const QMetaObject* meta = metaObject(); | - | 
| 2162 | if (!name || !meta) partially evaluated:  !name| no Evaluation Count:0 | yes Evaluation Count:8179 | 
partially evaluated:  !meta| no Evaluation Count:0 | yes Evaluation Count:8179 | 
 | 0-8179 | 
| 2163 | return false; never executed: return false; | 0 | 
| 2164 |  | - | 
| 2165 | int id = meta->indexOfProperty(name); | - | 
| 2166 | if (id < 0) { evaluated:  id < 0| yes Evaluation Count:7545 | yes Evaluation Count:634 | 
 | 634-7545 | 
| 2167 | if (!d->extraData) evaluated:  !d->extraData| yes Evaluation Count:4567 | yes Evaluation Count:2978 | 
 | 2978-4567 | 
| 2168 | d->extraData = new QObjectPrivate::ExtraData; executed:  d->extraData = new QObjectPrivate::ExtraData;Execution Count:4567 | 4567 | 
| 2169 |  | - | 
| 2170 | const int idx = d->extraData->propertyNames.indexOf(name); | - | 
| 2171 |  | - | 
| 2172 | if (!value.isValid()) { evaluated:  !value.isValid()| yes Evaluation Count:4124 | yes Evaluation Count:3421 | 
 | 3421-4124 | 
| 2173 | if (idx == -1) evaluated:  idx == -1| yes Evaluation Count:4118 | yes Evaluation Count:6 | 
 | 6-4118 | 
| 2174 | return false; executed:  return false;Execution Count:4118 | 4118 | 
| 2175 | d->extraData->propertyNames.removeAt(idx); | - | 
| 2176 | d->extraData->propertyValues.removeAt(idx); | - | 
| 2177 | } else { executed:  }Execution Count:6 | 6 | 
| 2178 | if (idx == -1) { evaluated:  idx == -1| yes Evaluation Count:2148 | yes Evaluation Count:1273 | 
 | 1273-2148 | 
| 2179 | d->extraData->propertyNames.append(name); | - | 
| 2180 | d->extraData->propertyValues.append(value); | - | 
| 2181 | } else { executed:  }Execution Count:2148 | 2148 | 
| 2182 | d->extraData->propertyValues[idx] = value; | - | 
| 2183 | } executed:  }Execution Count:1273 | 1273 | 
| 2184 | } | - | 
| 2185 |  | - | 
| 2186 | QDynamicPropertyChangeEvent ev(name); | - | 
| 2187 | QCoreApplication::sendEvent(this, &ev); | - | 
| 2188 |  | - | 
| 2189 | return false; executed:  return false;Execution Count:3427 | 3427 | 
| 2190 | } | - | 
| 2191 | QMetaProperty p = meta->property(id); | - | 
| 2192 |  | - | 
| 2193 |  | - | 
| 2194 |  | - | 
| 2195 |  | - | 
| 2196 |  | - | 
| 2197 | return p.write(this, value); executed:  return p.write(this, value);Execution Count:634 | 634 | 
| 2198 | } | - | 
| 2199 | QVariant QObject::property(const char *name) const | - | 
| 2200 | { | - | 
| 2201 | const QObjectPrivate * const d = d_func(); | - | 
| 2202 | const QMetaObject* meta = metaObject(); | - | 
| 2203 | if (!name || !meta) partially evaluated:  !name| no Evaluation Count:0 | yes Evaluation Count:25046 | 
partially evaluated:  !meta| no Evaluation Count:0 | yes Evaluation Count:25046 | 
 | 0-25046 | 
| 2204 | return QVariant(); never executed: return QVariant(); | 0 | 
| 2205 |  | - | 
| 2206 | int id = meta->indexOfProperty(name); | - | 
| 2207 | if (id < 0) { evaluated:  id < 0| yes Evaluation Count:16645 | yes Evaluation Count:8401 | 
 | 8401-16645 | 
| 2208 | if (!d->extraData) evaluated:  !d->extraData| yes Evaluation Count:5600 | yes Evaluation Count:11045 | 
 | 5600-11045 | 
| 2209 | return QVariant(); executed:  return QVariant();Execution Count:5600 | 5600 | 
| 2210 | const int i = d->extraData->propertyNames.indexOf(name); | - | 
| 2211 | return d->extraData->propertyValues.value(i); executed:  return d->extraData->propertyValues.value(i);Execution Count:11045 | 11045 | 
| 2212 | } | - | 
| 2213 | QMetaProperty p = meta->property(id); | - | 
| 2214 |  | - | 
| 2215 |  | - | 
| 2216 |  | - | 
| 2217 |  | - | 
| 2218 |  | - | 
| 2219 | return p.read(this); executed:  return p.read(this);Execution Count:8401 | 8401 | 
| 2220 | } | - | 
| 2221 |  | - | 
| 2222 |  | - | 
| 2223 |  | - | 
| 2224 |  | - | 
| 2225 |  | - | 
| 2226 |  | - | 
| 2227 |  | - | 
| 2228 | QList<QByteArray> QObject::dynamicPropertyNames() const | - | 
| 2229 | { | - | 
| 2230 | const QObjectPrivate * const d = d_func(); | - | 
| 2231 | if (d->extraData) evaluated:  d->extraData| yes Evaluation Count:188 | yes Evaluation Count:1 | 
 | 1-188 | 
| 2232 | return d->extraData->propertyNames; executed:  return d->extraData->propertyNames;Execution Count:188 | 188 | 
| 2233 | return QList<QByteArray>(); executed:  return QList<QByteArray>();Execution Count:1 | 1 | 
| 2234 | } | - | 
| 2235 | static void dumpRecursive(int level, QObject *object) | - | 
| 2236 | { | - | 
| 2237 | (void)level; | - | 
| 2238 | (void)object; | - | 
| 2239 |  | - | 
| 2240 | } | 0 | 
| 2241 | void QObject::dumpObjectTree() | - | 
| 2242 | { | - | 
| 2243 | dumpRecursive(0, this); | - | 
| 2244 | } | 0 | 
| 2245 | void QObject::dumpObjectInfo() | - | 
| 2246 | { | - | 
| 2247 | } | - | 
| 2248 |  | - | 
| 2249 |  | - | 
| 2250 |  | - | 
| 2251 |  | - | 
| 2252 |  | - | 
| 2253 | uint QObject::registerUserData() | - | 
| 2254 | { | - | 
| 2255 | static int user_data_registration = 0; | - | 
| 2256 | return user_data_registration++; executed:  return user_data_registration++;Execution Count:100 | 100 | 
| 2257 | } | - | 
| 2258 |  | - | 
| 2259 |  | - | 
| 2260 |  | - | 
| 2261 |  | - | 
| 2262 | QObjectUserData::~QObjectUserData() | - | 
| 2263 | { | - | 
| 2264 | } | - | 
| 2265 |  | - | 
| 2266 |  | - | 
| 2267 |  | - | 
| 2268 |  | - | 
| 2269 | void QObject::setUserData(uint id, QObjectUserData* data) | - | 
| 2270 | { | - | 
| 2271 | QObjectPrivate * const d = d_func(); | - | 
| 2272 | if (!d->extraData) evaluated:  !d->extraData| yes Evaluation Count:1 | yes Evaluation Count:99 | 
 | 1-99 | 
| 2273 | d->extraData = new QObjectPrivate::ExtraData; executed:  d->extraData = new QObjectPrivate::ExtraData;Execution Count:1 | 1 | 
| 2274 |  | - | 
| 2275 | if (d->extraData->userData.size() <= (int) id) evaluated:  d->extraData->userData.size() <= (int) id| yes Evaluation Count:4 | yes Evaluation Count:96 | 
 | 4-96 | 
| 2276 | d->extraData->userData.resize((int) id + 1); executed:  d->extraData->userData.resize((int) id + 1);Execution Count:4 | 4 | 
| 2277 | d->extraData->userData[id] = data; | - | 
| 2278 | } executed:  }Execution Count:100 | 100 | 
| 2279 |  | - | 
| 2280 |  | - | 
| 2281 |  | - | 
| 2282 |  | - | 
| 2283 | QObjectUserData* QObject::userData(uint id) const | - | 
| 2284 | { | - | 
| 2285 | const QObjectPrivate * const d = d_func(); | - | 
| 2286 | if (!d->extraData) partially evaluated:  !d->extraData| no Evaluation Count:0 | yes Evaluation Count:100 | 
 | 0-100 | 
| 2287 | return 0; never executed: return 0; | 0 | 
| 2288 | if ((int)id < d->extraData->userData.size()) partially evaluated:  (int)id < d->extraData->userData.size()| yes Evaluation Count:100 | no Evaluation Count:0 | 
 | 0-100 | 
| 2289 | return d->extraData->userData.at(id); executed:  return d->extraData->userData.at(id);Execution Count:100 | 100 | 
| 2290 | return 0; never executed: return 0; | 0 | 
| 2291 | } | - | 
| 2292 |  | - | 
| 2293 |  | - | 
| 2294 |  | - | 
| 2295 |  | - | 
| 2296 |  | - | 
| 2297 | QDebug operator<<(QDebug dbg, const QObject *o) { | - | 
| 2298 | if (!o) evaluated:  !o| yes Evaluation Count:13 | yes Evaluation Count:33 | 
 | 13-33 | 
| 2299 | return dbg << "QObject(0x0) "; executed:  return dbg << "QObject(0x0) ";Execution Count:13 | 13 | 
| 2300 | dbg.nospace() << o->metaObject()->className() << '(' << (void *)o; | - | 
| 2301 | if (!o->objectName().isEmpty()) partially evaluated:  !o->objectName().isEmpty()| no Evaluation Count:0 | yes Evaluation Count:33 | 
 | 0-33 | 
| 2302 | dbg << ", name = " << o->objectName(); never executed: dbg << ", name = " << o->objectName(); | 0 | 
| 2303 | dbg << ')'; | - | 
| 2304 | return dbg.space(); executed:  return dbg.space();Execution Count:33 | 33 | 
| 2305 | } | - | 
| 2306 | void qDeleteInEventHandler(QObject *o) | - | 
| 2307 | { | - | 
| 2308 | delete o; | - | 
| 2309 | } executed:  }Execution Count:18530 | 18530 | 
| 2310 | QMetaObject::Connection QObject::connectImpl(const QObject *sender, void **signal, | - | 
| 2311 | const QObject *receiver, void **slot, | - | 
| 2312 | QtPrivate::QSlotObjectBase *slotObj, Qt::ConnectionType type, | - | 
| 2313 | const int *types, const QMetaObject *senderMetaObject) | - | 
| 2314 | { | - | 
| 2315 | if (!sender || !signal || !slotObj || !senderMetaObject) { partially evaluated:  !sender| no Evaluation Count:0 | yes Evaluation Count:4007 | 
partially evaluated:  !signal| no Evaluation Count:0 | yes Evaluation Count:4007 | 
partially evaluated:  !slotObj| no Evaluation Count:0 | yes Evaluation Count:4007 | 
partially evaluated:  !senderMetaObject| no Evaluation Count:0 | yes Evaluation Count:4007 | 
 | 0-4007 | 
| 2316 | QMessageLogger("kernel/qobject.cpp", 4212, __PRETTY_FUNCTION__).warning("QObject::connect: invalid null parametter"); | - | 
| 2317 | if (slotObj) | 0 | 
| 2318 | slotObj->destroyIfLastRef(); never executed: slotObj->destroyIfLastRef(); | 0 | 
| 2319 | return QMetaObject::Connection(); never executed: return QMetaObject::Connection(); | 0 | 
| 2320 | } | - | 
| 2321 | int signal_index = -1; | - | 
| 2322 | void *args[] = { &signal_index, signal }; | - | 
| 2323 | senderMetaObject->static_metacall(QMetaObject::IndexOfMethod, 0, args); | - | 
| 2324 | if (signal_index < 0 || signal_index >= QMetaObjectPrivate::get(senderMetaObject)->signalCount) { evaluated:  signal_index < 0| yes Evaluation Count:2 | yes Evaluation Count:4005 | 
partially evaluated:  signal_index >= QMetaObjectPrivate::get(senderMetaObject)->signalCount| no Evaluation Count:0 | yes Evaluation Count:4005 | 
 | 0-4005 | 
| 2325 | QMessageLogger("kernel/qobject.cpp", 4221, __PRETTY_FUNCTION__).warning("QObject::connect: signal not found in %s", senderMetaObject->className()); | - | 
| 2326 | slotObj->destroyIfLastRef(); | - | 
| 2327 | return QMetaObject::Connection(0); executed:  return QMetaObject::Connection(0);Execution Count:2 | 2 | 
| 2328 | } | - | 
| 2329 | signal_index += QMetaObjectPrivate::signalOffset(senderMetaObject); | - | 
| 2330 |  | - | 
| 2331 | QObject *s = const_cast<QObject *>(sender); | - | 
| 2332 | QObject *r = const_cast<QObject *>(receiver); | - | 
| 2333 |  | - | 
| 2334 | QOrderedMutexLocker locker(signalSlotLock(sender), | - | 
| 2335 | signalSlotLock(receiver)); | - | 
| 2336 |  | - | 
| 2337 | if (type & Qt::UniqueConnection) { evaluated:  type & Qt::UniqueConnection| yes Evaluation Count:11 | yes Evaluation Count:3994 | 
 | 11-3994 | 
| 2338 | QObjectConnectionListVector *connectionLists = QObjectPrivate::get(s)->connectionLists; | - | 
| 2339 | if (connectionLists && connectionLists->count() > signal_index) { evaluated:  connectionLists| yes Evaluation Count:9 | yes Evaluation Count:2 | 
evaluated:  connectionLists->count() > signal_index| yes Evaluation Count:7 | yes Evaluation Count:2 | 
 | 2-9 | 
| 2340 | const QObjectPrivate::Connection *c2 = | - | 
| 2341 | (*connectionLists)[signal_index].first; | - | 
| 2342 |  | - | 
| 2343 | while (c2) { evaluated:  c2| yes Evaluation Count:11 | yes Evaluation Count:4 | 
 | 4-11 | 
| 2344 | if (c2->receiver == receiver && c2->isSlotObject && c2->slotObj->compare(slot)) { evaluated:  c2->receiver == receiver| yes Evaluation Count:5 | yes Evaluation Count:6 | 
partially evaluated:  c2->isSlotObject| yes Evaluation Count:5 | no Evaluation Count:0 | 
evaluated:  c2->slotObj->compare(slot)| yes Evaluation Count:3 | yes Evaluation Count:2 | 
 | 0-6 | 
| 2345 | slotObj->destroyIfLastRef(); | - | 
| 2346 | return QMetaObject::Connection(); executed:  return QMetaObject::Connection();Execution Count:3 | 3 | 
| 2347 | } | - | 
| 2348 | c2 = c2->nextConnectionList; | - | 
| 2349 | } executed:  }Execution Count:8 | 8 | 
| 2350 | } executed:  }Execution Count:4 | 4 | 
| 2351 | type = static_cast<Qt::ConnectionType>(type ^ Qt::UniqueConnection); | - | 
| 2352 | } executed:  }Execution Count:8 | 8 | 
| 2353 |  | - | 
| 2354 | QScopedPointer<QObjectPrivate::Connection> c(new QObjectPrivate::Connection); | - | 
| 2355 | c->sender = s; | - | 
| 2356 | c->signal_index = signal_index; | - | 
| 2357 | c->receiver = r; | - | 
| 2358 | c->slotObj = slotObj; | - | 
| 2359 | c->connectionType = type; | - | 
| 2360 | c->isSlotObject = true; | - | 
| 2361 | if (types) { evaluated:  types| yes Evaluation Count:35 | yes Evaluation Count:3967 | 
 | 35-3967 | 
| 2362 | c->argumentTypes.store(types); | - | 
| 2363 | c->ownArgumentTypes = false; | - | 
| 2364 | } executed:  }Execution Count:35 | 35 | 
| 2365 |  | - | 
| 2366 | QObjectPrivate::get(s)->addConnection(signal_index, c.data()); | - | 
| 2367 | QMetaObject::Connection ret(c.take()); | - | 
| 2368 | locker.unlock(); | - | 
| 2369 |  | - | 
| 2370 | QMetaMethod method = QMetaObjectPrivate::signal(senderMetaObject, signal_index); | - | 
| 2371 | qt_noop(); | - | 
| 2372 | s->connectNotify(method); | - | 
| 2373 |  | - | 
| 2374 | return ret; executed:  return ret;Execution Count:4002 | 4002 | 
| 2375 | } | - | 
| 2376 | bool QObject::disconnect(const QMetaObject::Connection &connection) | - | 
| 2377 | { | - | 
| 2378 | QObjectPrivate::Connection *c = static_cast<QObjectPrivate::Connection *>(connection.d_ptr); | - | 
| 2379 |  | - | 
| 2380 | if (!c || !c->receiver) evaluated:  !c| yes Evaluation Count:3 | yes Evaluation Count:8 | 
partially evaluated:  !c->receiver| no Evaluation Count:0 | yes Evaluation Count:8 | 
 | 0-8 | 
| 2381 | return false; executed:  return false;Execution Count:3 | 3 | 
| 2382 |  | - | 
| 2383 | QMutex *senderMutex = signalSlotLock(c->sender); | - | 
| 2384 | QMutex *receiverMutex = signalSlotLock(c->receiver); | - | 
| 2385 | QOrderedMutexLocker locker(senderMutex, receiverMutex); | - | 
| 2386 |  | - | 
| 2387 | QObjectConnectionListVector *connectionLists = QObjectPrivate::get(c->sender)->connectionLists; | - | 
| 2388 | qt_noop(); | - | 
| 2389 | connectionLists->dirty = true; | - | 
| 2390 |  | - | 
| 2391 | *c->prev = c->next; | - | 
| 2392 | if (c->next) evaluated:  c->next| yes Evaluation Count:1 | yes Evaluation Count:7 | 
 | 1-7 | 
| 2393 | c->next->prev = c->prev; executed:  c->next->prev = c->prev;Execution Count:1 | 1 | 
| 2394 | c->receiver = 0; | - | 
| 2395 |  | - | 
| 2396 |  | - | 
| 2397 | if (c->isSlotObject) { partially evaluated:  c->isSlotObject| yes Evaluation Count:8 | no Evaluation Count:0 | 
 | 0-8 | 
| 2398 | c->slotObj->destroyIfLastRef(); | - | 
| 2399 | c->isSlotObject = false; | - | 
| 2400 | } executed:  }Execution Count:8 | 8 | 
| 2401 |  | - | 
| 2402 | const_cast<QMetaObject::Connection &>(connection).d_ptr = 0; | - | 
| 2403 | c->deref(); | - | 
| 2404 |  | - | 
| 2405 |  | - | 
| 2406 |  | - | 
| 2407 | return true; executed:  return true;Execution Count:8 | 8 | 
| 2408 | } | - | 
| 2409 | bool QObject::disconnectImpl(const QObject *sender, void **signal, const QObject *receiver, void **slot, const QMetaObject *senderMetaObject) | - | 
| 2410 | { | - | 
| 2411 | if (sender == 0 || (receiver == 0 && slot != 0)) { partially evaluated:  sender == 0| no Evaluation Count:0 | yes Evaluation Count:9 | 
evaluated:  receiver == 0| yes Evaluation Count:1 | yes Evaluation Count:8 | 
partially evaluated:  slot != 0| no Evaluation Count:0 | yes Evaluation Count:1 | 
 | 0-9 | 
| 2412 | QMessageLogger("kernel/qobject.cpp", 4378, __PRETTY_FUNCTION__).warning("QObject::disconnect: Unexpected null parameter"); | - | 
| 2413 | return false; never executed: return false; | 0 | 
| 2414 | } | - | 
| 2415 |  | - | 
| 2416 | int signal_index = -1; | - | 
| 2417 | if (signal) { partially evaluated:  signal| yes Evaluation Count:9 | no Evaluation Count:0 | 
 | 0-9 | 
| 2418 | void *args[] = { &signal_index, signal }; | - | 
| 2419 | senderMetaObject->static_metacall(QMetaObject::IndexOfMethod, 0, args); | - | 
| 2420 | if (signal_index < 0 || signal_index >= QMetaObjectPrivate::get(senderMetaObject)->signalCount) { partially evaluated:  signal_index < 0| no Evaluation Count:0 | yes Evaluation Count:9 | 
partially evaluated:  signal_index >= QMetaObjectPrivate::get(senderMetaObject)->signalCount| no Evaluation Count:0 | yes Evaluation Count:9 | 
 | 0-9 | 
| 2421 | QMessageLogger("kernel/qobject.cpp", 4387, __PRETTY_FUNCTION__).warning("QObject::disconnect: signal not found in %s", senderMetaObject->className()); | - | 
| 2422 | return false; never executed: return false; | 0 | 
| 2423 | } | - | 
| 2424 | signal_index += QMetaObjectPrivate::signalOffset(senderMetaObject); | - | 
| 2425 | } executed:  }Execution Count:9 | 9 | 
| 2426 |  | - | 
| 2427 | return QMetaObjectPrivate::disconnect(sender, signal_index, senderMetaObject, receiver, -1, slot); executed:  return QMetaObjectPrivate::disconnect(sender, signal_index, senderMetaObject, receiver, -1, slot);Execution Count:9 | 9 | 
| 2428 | } | - | 
| 2429 | QMetaObject::Connection::Connection(const QMetaObject::Connection &other) : d_ptr(other.d_ptr) | - | 
| 2430 | { | - | 
| 2431 | if (d_ptr) | 0 | 
| 2432 | static_cast<QObjectPrivate::Connection *>(d_ptr)->ref(); never executed: static_cast<QObjectPrivate::Connection *>(d_ptr)->ref(); | 0 | 
| 2433 | } | 0 | 
| 2434 |  | - | 
| 2435 | QMetaObject::Connection& QMetaObject::Connection::operator=(const QMetaObject::Connection& other) | - | 
| 2436 | { | - | 
| 2437 | if (other.d_ptr != d_ptr) { evaluated:  other.d_ptr != d_ptr| yes Evaluation Count:6 | yes Evaluation Count:1 | 
 | 1-6 | 
| 2438 | if (d_ptr) evaluated:  d_ptr| yes Evaluation Count:1 | yes Evaluation Count:5 | 
 | 1-5 | 
| 2439 | static_cast<QObjectPrivate::Connection *>(d_ptr)->deref(); executed:  static_cast<QObjectPrivate::Connection *>(d_ptr)->deref();Execution Count:1 | 1 | 
| 2440 | d_ptr = other.d_ptr; | - | 
| 2441 | if (other.d_ptr) evaluated:  other.d_ptr| yes Evaluation Count:5 | yes Evaluation Count:1 | 
 | 1-5 | 
| 2442 | static_cast<QObjectPrivate::Connection *>(other.d_ptr)->ref(); executed:  static_cast<QObjectPrivate::Connection *>(other.d_ptr)->ref();Execution Count:5 | 5 | 
| 2443 | } executed:  }Execution Count:6 | 6 | 
| 2444 | return *this; executed:  return *this;Execution Count:7 | 7 | 
| 2445 | } | - | 
| 2446 |  | - | 
| 2447 | QMetaObject::Connection::Connection() : d_ptr(0) {} executed:  }Execution Count:7 | 7 | 
| 2448 |  | - | 
| 2449 | QMetaObject::Connection::~Connection() | - | 
| 2450 | { | - | 
| 2451 | if (d_ptr) evaluated:  d_ptr| yes Evaluation Count:490308 | yes Evaluation Count:385629 | 
 | 385629-490308 | 
| 2452 | static_cast<QObjectPrivate::Connection *>(d_ptr)->deref(); executed:  static_cast<QObjectPrivate::Connection *>(d_ptr)->deref();Execution Count:490308 | 490308 | 
| 2453 | } executed:  }Execution Count:875925 | 875925 | 
| 2454 |  | - | 
| 2455 |  | - | 
| 2456 |  | - | 
|  |  |  |