diff options
author | Andrei Karas <akaras@inbox.ru> | 2015-06-30 21:06:43 +0300 |
---|---|---|
committer | Andrei Karas <akaras@inbox.ru> | 2015-06-30 21:06:43 +0300 |
commit | 7feb97f26f549181e44dc13e40b21eb3aff54ef3 (patch) | |
tree | 4dd97e77963e5f29d56840223cd686dca4dbb348 /src/analysis/expression.cpp | |
parent | f161ad8300a76df40608dd28f0bb75e4b662ffaa (diff) | |
download | paranucker-7feb97f26f549181e44dc13e40b21eb3aff54ef3.tar.gz paranucker-7feb97f26f549181e44dc13e40b21eb3aff54ef3.tar.bz2 paranucker-7feb97f26f549181e44dc13e40b21eb3aff54ef3.tar.xz paranucker-7feb97f26f549181e44dc13e40b21eb3aff54ef3.zip |
Add into analysis ignoring variables if variable get unknown value.
Diffstat (limited to 'src/analysis/expression.cpp')
-rw-r--r-- | src/analysis/expression.cpp | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/src/analysis/expression.cpp b/src/analysis/expression.cpp index 177c4ec..fa14172 100644 --- a/src/analysis/expression.cpp +++ b/src/analysis/expression.cpp @@ -113,6 +113,18 @@ void analyseModifyExpr(ModifyExprNode *node, const WalkItem &wi, WalkItem &wo) Node *arg = skipNop(node->args[0]); if (arg) { + std::string var1 = getVariableName(arg); + std::string var2 = getVariableName(node->args[1]); + // var2 not found in known checking pointer + if (wi.needCheckNullVars.find(var2) == wi.needCheckNullVars.end() && + wi.knownVars.find(var2) == wi.knownVars.end()) + { + //Log::log("removed var: %s\n", var1.c_str()); + removeNeedCheckNullVar(wo, var1); + wo.removeNullVars.insert(var1); +// return; + } + if (arg == INDIRECT_REF) { reportParmDeclNullPointer(node, |