ValueType: Better constness for auto variable

This commit is contained in:
Daniel Marjamäki 2019-02-23 18:15:05 +01:00
parent b43572d75e
commit c855cf8682
2 changed files with 6 additions and 4 deletions

View File

@ -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);

View File

@ -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);