From: Marc Mutz Date: Tue, 21 Aug 2012 08:05:41 +0000 (+0200) Subject: QVariant: prevent QVariant(QMetaType::Type) from compiling X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=939338c273539b51e622e61e5f375571eff3619e;p=profile%2Fivi%2Fqtbase.git QVariant: prevent QVariant(QMetaType::Type) from compiling Reported-by: Stephen Chu Change-Id: I298973174ff10f4462f04f3358c974c04dfd3383 Reviewed-by: Jędrzej Nowacki Reviewed-by: Stephen Chu --- diff --git a/src/corelib/kernel/qvariant.h b/src/corelib/kernel/qvariant.h index bde67ed..07043b1 100644 --- a/src/corelib/kernel/qvariant.h +++ b/src/corelib/kernel/qvariant.h @@ -454,6 +454,13 @@ public: private: // force compile error, prevent QVariant(bool) to be called inline QVariant(void *) Q_DECL_EQ_DELETE; + // QVariant::Type is marked as \obsolete, but we don't want to + // provide a constructor from its intended replacement, + // QMetaType::Type, instead, because the idea behind these + // constructors is flawed in the first place. But we also don't + // want QVariant(QMetaType::String) to compile and falsely be an + // int variant, so delete this constructor: + QVariant(QMetaType::Type) Q_DECL_EQ_DELETE; #ifdef QT_NO_CAST_FROM_ASCII // force compile error when implicit conversion is not wanted inline QVariant(const char *) Q_DECL_EQ_DELETE;