Fix the static analysis error: m.isVirtual is a tri-state undefined, true, or "pure", and I didn't take that into account when writing the original NS_OVERRIDE analysis.
This commit is contained in:
@@ -63,7 +63,7 @@ function signaturesMatch(m1, m2)
|
|||||||
if (m1.shortName != m2.shortName)
|
if (m1.shortName != m2.shortName)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
if (m1.isVirtual != m2.isVirtual)
|
if ((!!m1.isVirtual) != (!!m2.isVirtual))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
if (m1.isStatic != m2.isStatic)
|
if (m1.isStatic != m2.isStatic)
|
||||||
|
|||||||
@@ -2,6 +2,7 @@ class A
|
|||||||
{
|
{
|
||||||
int a(int, char*);
|
int a(int, char*);
|
||||||
void c(char);
|
void c(char);
|
||||||
|
virtual void d(int) = 0;
|
||||||
};
|
};
|
||||||
|
|
||||||
class B : A
|
class B : A
|
||||||
@@ -13,3 +14,8 @@ class C : B
|
|||||||
{
|
{
|
||||||
__attribute__((user("NS_override"))) void c(char);
|
__attribute__((user("NS_override"))) void c(char);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
class D : A
|
||||||
|
{
|
||||||
|
__attribute__((user("NS_override"))) void d(int);
|
||||||
|
};
|
||||||
|
|||||||
Reference in New Issue
Block a user