void QQmlDelayedError::setMessage(v8::Handle<v8::Message> message)
{
- qPersistentDispose(m_message);
- m_message = qPersistentNew<v8::Message>(message);
+ m_message = message.get();
}
void QQmlDelayedError::setErrorLocation(const QUrl &url, quint16 line, quint16 column)
*/
void QQmlDelayedError::convertMessageToError(QQmlEngine *engine) const
{
- if (!m_message.IsEmpty() && engine) {
- QQmlExpressionPrivate::exceptionToError(m_message, m_error);
- qPersistentDispose(m_message);
+ if (!!m_message && engine) {
+ QQmlExpressionPrivate::exceptionToError(v8::Handle<v8::Message>(m_message.data()), m_error);
+ m_message.reset();
}
}
{
public:
inline QQmlDelayedError() : nextError(0), prevError(0) {}
- inline ~QQmlDelayedError() { qPersistentDispose(m_message); removeError(); }
+ inline ~QQmlDelayedError() { removeError(); }
bool addError(QQmlEnginePrivate *);
prevError = 0;
}
- inline bool isValid() const { return !m_message.IsEmpty() || m_error.isValid(); }
+ inline bool isValid() const { return !!m_message || m_error.isValid(); }
inline const QQmlError &error(QQmlEngine *engine) const { convertMessageToError(engine); return m_error; }
- inline void clearError() { qPersistentDispose(m_message); m_error = QQmlError(); }
+ inline void clearError() { m_message.reset(); m_error = QQmlError(); }
void setMessage(v8::Handle<v8::Message> message);
void setErrorLocation(const QUrl &url, quint16 line, quint16 column);
void convertMessageToError(QQmlEngine *engine) const;
mutable QQmlError m_error;
- mutable v8::Persistent<v8::Message> m_message;
+ mutable QExplicitlySharedDataPointer<v8::Message> m_message;
QQmlDelayedError *nextError;
QQmlDelayedError **prevError;