Skip to content

Commit

Permalink
goto-analyzer: --show-local-bitvector
Browse files Browse the repository at this point in the history
This adds --show-local-bitvector as a task to goto-analyzer.
  • Loading branch information
kroening committed Dec 26, 2024
1 parent f9a7807 commit 32bab35
Show file tree
Hide file tree
Showing 2 changed files with 26 additions and 1 deletion.
24 changes: 24 additions & 0 deletions src/goto-analyzer/goto_analyzer_parse_options.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,7 @@ Author: Daniel Kroening, [email protected]
#include <goto-programs/show_symbol_table.h>

#include <analyses/ai.h>
#include <analyses/local_bitvector_analysis.h>
#include <analyses/local_may_alias.h>
#include <ansi-c/cprover_library.h>
#include <ansi-c/gcc_version.h>
Expand Down Expand Up @@ -139,6 +140,11 @@ void goto_analyzer_parse_optionst::get_command_line_options(optionst &options)
options.set_option("show-local-may-alias", true);
options.set_option("specific-analysis", true);
}
if(cmdline.isset("show-local-bitvector"))
{
options.set_option("show-local-bitvector", true);
options.set_option("specific-analysis", true);

Check warning on line 146 in src/goto-analyzer/goto_analyzer_parse_options.cpp

View check run for this annotation

Codecov / codecov/patch

src/goto-analyzer/goto_analyzer_parse_options.cpp#L144-L146

Added lines #L144 - L146 were not covered by tests
}

// Output format choice
if(cmdline.isset("text"))
Expand Down Expand Up @@ -572,6 +578,23 @@ int goto_analyzer_parse_optionst::perform_analysis(const optionst &options)
return CPROVER_EXIT_SUCCESS;
}

if(options.get_bool_option("show-local-bitvector"))
{
namespacet ns(goto_model.symbol_table);

Check warning on line 584 in src/goto-analyzer/goto_analyzer_parse_options.cpp

View check run for this annotation

Codecov / codecov/patch

src/goto-analyzer/goto_analyzer_parse_options.cpp#L583-L584

Added lines #L583 - L584 were not covered by tests
for(const auto &gf_entry : goto_model.goto_functions.function_map)
{
std::cout << ">>>>\n";
std::cout << ">>>> " << gf_entry.first << '\n';
std::cout << ">>>>\n";
local_bitvector_analysist local_bitvector_analysis(gf_entry.second, ns);
local_bitvector_analysis.output(std::cout, gf_entry.second, ns);
std::cout << '\n';

Check warning on line 592 in src/goto-analyzer/goto_analyzer_parse_options.cpp

View check run for this annotation

Codecov / codecov/patch

src/goto-analyzer/goto_analyzer_parse_options.cpp#L586-L592

Added lines #L586 - L592 were not covered by tests
}

return CPROVER_EXIT_SUCCESS;

Check warning on line 595 in src/goto-analyzer/goto_analyzer_parse_options.cpp

View check run for this annotation

Codecov / codecov/patch

src/goto-analyzer/goto_analyzer_parse_options.cpp#L595

Added line #L595 was not covered by tests
}

label_properties(goto_model);

if(cmdline.isset("show-properties"))
Expand Down Expand Up @@ -802,6 +825,7 @@ void goto_analyzer_parse_optionst::help()
" {y--taint} {ufile_name} \t perform taint analysis using rules in given"
" file\n"
" {y--show-taint} \t print taint analysis results on stdout\n"
" {y--show-local-bitvector} \t perform procedure-local bitvector analysis\n"
" {y--show-local-may-alias} \t perform procedure-local may alias analysis\n"
"\n"
"C/C++ frontend options:\n"
Expand Down
3 changes: 2 additions & 1 deletion src/goto-analyzer/goto_analyzer_parse_options.h
Original file line number Diff line number Diff line change
Expand Up @@ -144,7 +144,8 @@ class optionst;

#define GOTO_ANALYSER_OPTIONS_SPECIFIC_ANALYSES \
"(taint):(show-taint)" \
"(show-local-may-alias)"
"(show-local-may-alias)" \
"(show-local-bitvector)"

#define GOTO_ANALYSER_OPTIONS \
OPT_FUNCTIONS \
Expand Down

0 comments on commit 32bab35

Please sign in to comment.