Skip to content

Property description now taken from front-end #571

New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Merged
merged 1 commit into from
Jun 24, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion regression/ebmc/CLI/json-properties.desc
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ json-properties.v
activate-multi-line-match
\[
\{
"description": "",
"description": "always 1 == 2",
"location": \{
"file": "json-properties\.v",
"line": "3",
Expand Down
4 changes: 1 addition & 3 deletions src/ebmc/ebmc_properties.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -73,7 +73,6 @@ ebmc_propertiest ebmc_propertiest::from_transition_system(
properties.properties.back().name = symbol.display_name();
properties.properties.back().original_expr = symbol.value;
properties.properties.back().location = symbol.location;
properties.properties.back().expr_string = value_as_string;
properties.properties.back().mode = symbol.mode;
properties.properties.back().description =
id2string(symbol.location.get_comment());
Expand Down Expand Up @@ -172,10 +171,9 @@ ebmc_propertiest ebmc_propertiest::from_command_line(
auto &p = properties.properties.back();
p.original_expr = expr;
p.normalized_expr = normalize_property(expr);
p.expr_string = expr_as_string;
p.mode = transition_system.main_symbol->mode;
p.location.make_nil();
p.description = "command-line assertion";
p.description = expr_as_string;
p.name = "command-line assertion";

return properties;
Expand Down
1 change: 0 additions & 1 deletion src/ebmc/ebmc_properties.h
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,6 @@ class ebmc_propertiest
std::size_t number = 0;
irep_idt identifier, name;
source_locationt location;
std::string expr_string;
irep_idt mode;
exprt original_expr;
exprt normalized_expr;
Expand Down
2 changes: 1 addition & 1 deletion src/ebmc/liveness_to_safety.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -246,7 +246,7 @@ void liveness_to_safetyt::operator()()
else
{
throw ebmc_errort().with_location(property.location)
<< "no liveness-to-safety translation for " << property.expr_string;
<< "no liveness-to-safety translation for " << property.description;
}
}
}
Expand Down
2 changes: 1 addition & 1 deletion src/ebmc/report_results.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -98,7 +98,7 @@ void report_results(
if(property.is_disabled())
continue;

message.status() << "[" << property.name << "] " << property.expr_string
message.status() << "[" << property.name << "] " << property.description
<< ": ";

using statust = ebmc_propertiest::propertyt::statust;
Expand Down
41 changes: 21 additions & 20 deletions src/ebmc/show_properties.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -33,36 +33,37 @@ void ebmc_baset::show_properties()
{
unsigned p_nr=1;

auto make_xml =
[](const ebmc_propertiest::propertyt &p, std::size_t p_nr) -> xmlt {
xmlt xml("property");
xml.set_attribute("name", id2string(p.name));

xml.new_element("number").data = std::to_string(p_nr); // will go away
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Just curious: what will go away and when?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

That's just a moved comment, not new. You can't use the number for anything (we use the property identifier instead), so it's really redundant.

xml.new_element("description").data = p.description;

if(p.location.is_not_nil())
xml.new_element("location") = ::xml(p.location);

return xml;
};

for(const auto &p : properties.properties)
{
switch (static_cast<ui_message_handlert &>(message.get_message_handler()).get_ui()) {
switch(static_cast<ui_message_handlert &>(message.get_message_handler())
.get_ui())
{
case ui_message_handlert::uit::XML_UI:
{
xmlt xml("property");
xml.set_attribute("name", id2string(p.name));

xml.new_element("number").data=std::to_string(p_nr); // will go away
xml.new_element("expression").data=p.expr_string;
xml.new_element("description").data=p.description;

if(p.location.is_not_nil())
xml.new_element("location")=::xml(p.location);

std::cout << xml << '\n';
}
std::cout << make_xml(p, p_nr) << '\n';
break;

case ui_message_handlert::uit::PLAIN:
std::cout << p.name << ": ";
std::cout << p.expr_string;
if(!p.description.empty())
std::cout << " (" << p.description << ")";
std::cout << '\n';
std::cout << p.name << ": " << p.description << '\n';
break;

case ui_message_handlert::uit::JSON_UI:
default:;
}

p_nr++;
}
}
Expand Down
1 change: 1 addition & 0 deletions src/smvlang/smv_typecheck.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1491,6 +1491,7 @@ void smv_typecheckt::convert(smv_parse_treet::modulet &smv_module)
spec_symbol.mode = "SMV";
spec_symbol.value = it->expr;
spec_symbol.location = it->location;
spec_symbol.location.set_comment(to_string(it->expr));

if(smv_module.name == "smv::main")
spec_symbol.pretty_name = spec_symbol.base_name;
Expand Down
4 changes: 4 additions & 0 deletions src/verilog/verilog_synthesis.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -2323,6 +2323,8 @@ void verilog_synthesist::synth_assert_assume_cover(
cond = sva_cover_exprt(cond);
}

symbol.location.set_comment(to_string(cond));

symbol.value = std::move(cond);
}

Expand Down Expand Up @@ -2374,6 +2376,8 @@ void verilog_synthesist::synth_assert_assume_cover(
else
PRECONDITION(false);

symbol.location.set_comment(to_string(cond));

symbol.value = std::move(cond);
}

Expand Down