ValueType: Better constness for auto variable
This commit is contained in:
parent
b43572d75e
commit
c855cf8682
|
@ -4914,8 +4914,9 @@ void SymbolDatabase::setValueType(Token *tok, const ValueType &valuetype)
|
||||||
vt.constness |= 1;
|
vt.constness |= 1;
|
||||||
setValueType(autoTok, vt);
|
setValueType(autoTok, vt);
|
||||||
setAutoTokenProperties(autoTok);
|
setAutoTokenProperties(autoTok);
|
||||||
setValueType(var1Tok, *vt2);
|
setValueType(var1Tok, vt);
|
||||||
setValueType(parent->previous(), *vt2);
|
if (var1Tok != parent->previous())
|
||||||
|
setValueType(parent->previous(), *vt2);
|
||||||
Variable *var = const_cast<Variable *>(parent->previous()->variable());
|
Variable *var = const_cast<Variable *>(parent->previous()->variable());
|
||||||
if (var) {
|
if (var) {
|
||||||
var->setValueType(*vt2);
|
var->setValueType(*vt2);
|
||||||
|
|
|
@ -6094,6 +6094,7 @@ private:
|
||||||
ASSERT_EQUALS("signed int *", typeOf("; auto data = new (std::nothrow) int[100];", "data"));
|
ASSERT_EQUALS("signed int *", typeOf("; auto data = new (std::nothrow) int[100];", "data"));
|
||||||
ASSERT_EQUALS("const signed short", typeOf("short values[10]; void f() { for (const auto *x : values); }", "x"));
|
ASSERT_EQUALS("const signed short", typeOf("short values[10]; void f() { for (const auto *x : values); }", "x"));
|
||||||
ASSERT_EQUALS("signed int *", typeOf("MACRO(test) void test() { auto x = (int*)y; }", "x")); // #7931 (garbage?)
|
ASSERT_EQUALS("signed int *", typeOf("MACRO(test) void test() { auto x = (int*)y; }", "x")); // #7931 (garbage?)
|
||||||
|
ASSERT_EQUALS("const signed int", typeOf("; const auto x = 3;", "x"));
|
||||||
|
|
||||||
// Variable declaration
|
// Variable declaration
|
||||||
ASSERT_EQUALS("char *", typeOf("; char abc[] = \"abc\";", "["));
|
ASSERT_EQUALS("char *", typeOf("; char abc[] = \"abc\";", "["));
|
||||||
|
@ -6617,7 +6618,7 @@ private:
|
||||||
vartok = Token::findsimplematch(autotok, "v4 =");
|
vartok = Token::findsimplematch(autotok, "v4 =");
|
||||||
ASSERT(db && vartok && vartok->valueType());
|
ASSERT(db && vartok && vartok->valueType());
|
||||||
if (db && vartok && vartok->valueType()) {
|
if (db && vartok && vartok->valueType()) {
|
||||||
TODO_ASSERT_EQUALS(1, 0, vartok->valueType()->constness);
|
ASSERT_EQUALS(1, vartok->valueType()->constness);
|
||||||
ASSERT_EQUALS(1, vartok->valueType()->pointer);
|
ASSERT_EQUALS(1, vartok->valueType()->pointer);
|
||||||
ASSERT_EQUALS(ValueType::SIGNED, vartok->valueType()->sign);
|
ASSERT_EQUALS(ValueType::SIGNED, vartok->valueType()->sign);
|
||||||
ASSERT_EQUALS(ValueType::INT, vartok->valueType()->type);
|
ASSERT_EQUALS(ValueType::INT, vartok->valueType()->type);
|
||||||
|
@ -6707,7 +6708,7 @@ private:
|
||||||
vartok = Token::findsimplematch(autotok, "v9 =");
|
vartok = Token::findsimplematch(autotok, "v9 =");
|
||||||
ASSERT(db && vartok && vartok->valueType());
|
ASSERT(db && vartok && vartok->valueType());
|
||||||
if (db && vartok && vartok->valueType()) {
|
if (db && vartok && vartok->valueType()) {
|
||||||
TODO_ASSERT_EQUALS(1, 0, vartok->valueType()->constness);
|
ASSERT_EQUALS(1, vartok->valueType()->constness);
|
||||||
ASSERT_EQUALS(1, vartok->valueType()->pointer);
|
ASSERT_EQUALS(1, vartok->valueType()->pointer);
|
||||||
ASSERT_EQUALS(ValueType::SIGNED, vartok->valueType()->sign);
|
ASSERT_EQUALS(ValueType::SIGNED, vartok->valueType()->sign);
|
||||||
ASSERT_EQUALS(ValueType::INT, vartok->valueType()->type);
|
ASSERT_EQUALS(ValueType::INT, vartok->valueType()->type);
|
||||||
|
|
Loading…
Reference in New Issue