16 research outputs found
Scaling Symbolic Execution to Large Software Systems
Static analysis is the analysis of a program without executing it, usually
carried out by an automated tool. Symbolic execution is a popular static
analysis technique used both in program verification and in bug detection
software. It works by interpreting the code, introducing a symbol for each
value unknown at compile time (e.g. user-given inputs), and carrying out
calculations symbolically. The analysis engine strives to explore multiple
execution paths simultaneously, although checking all paths is an intractable
problem, due to the vast number of possibilities.
We focus on an error finding framework called the Clang Static Analyzer, and
the infrastructure built around it named CodeChecker. The emphasis is on
achieving end-to-end scalability. This includes the run time and memory
consumption of the analysis, bug presentation to the users, automatic false
positive suppression, incremental analysis, pattern discovery in the results,
and usage in continuous integration loops. We also outline future directions
and open problems concerning these tools.
While a rich literature exists on program verification software, error
finding tools normally need to settle for survey papers on individual
techniques. In this paper, we not only discuss individual methods, but also how
these decisions interact and reinforce each other, creating a system that is
greater than the sum of its parts. Although the Clang Static Analyzer can only
handle C-family languages, the techniques introduced in this paper are mostly
language-independent and applicable to other similar static analysis tools
Static Code Analysis with CodeChecker
CodeChecker is an open source project that integrates different static
analysis tools such as the Clang Static Analyzer and Clang-Tidy into the build
systems, continuous integration loops, and development workflows of C++
programmers. It has a powerful issue management system to make it easier to
evaluate the reports of the static analysis tools.
This document was handed out as supportive material for a code analysis
lecture at the 2018 3COWS conference in Kosice, Slovakia
An Extension to the Subtype Relationship in C++ Implemented with Template Metaprogramming
Families of independent classes, where each class represents a separate, orthogonal concern are highly attractive for implementing collaboration-based design. However, required subtype relationship between such families cannot be expressed in many programming languages
