Skip to content
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

Better error messages on ErgoTree evaluation #720

Merged
merged 74 commits into from
Sep 27, 2023
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
74 commits
Select commit Hold shift + click to select a range
2428e3e
make Evaluable::eval's environment a mutable ref;
greenhat Jul 17, 2023
0e819e9
add EvalError::WrappedWithEnvError with evaluation env attached;
greenhat Jul 18, 2023
65b129d
draft SourceSpan and SourceSpanWrapper;
greenhat Jul 19, 2023
35dd5ac
enrich Append eval error with source span;
greenhat Jul 21, 2023
a96a7c9
Move source_span module to the ergotree-ir crate root;
greenhat Jul 24, 2023
eda5e27
draft pretty printer types and smoke test;
greenhat Jul 24, 2023
8b3d624
draft Print trait IR nodes;
greenhat Jul 24, 2023
7a562f7
draft Printer trait tracking current position and indentation level;
greenhat Aug 1, 2023
7f28707
draft Print impl for Expr;
greenhat Aug 2, 2023
868076b
draft the expr printing and running eval again in reduce_to_crypto;
greenhat Aug 2, 2023
e46c92e
extract EvalError into a separate module;
greenhat Aug 3, 2023
e20f087
merge wrapped EvalError variants into one;
greenhat Aug 3, 2023
01cb82f
extract EvalErrorDetails and add wrap_with_src for EvalError;
greenhat Aug 3, 2023
c99f6ce
impl Print for BlockValue;
greenhat Aug 4, 2023
c10d084
formatting;
greenhat Aug 4, 2023
0eb274b
impl Print for ValDef and Constant;
greenhat Aug 7, 2023
8bb1181
impl Print for ValUse, fix indentations and new lines in pretty printer;
greenhat Aug 7, 2023
c6b94db
Rename Span to SourceSpan and switch it to offset+length based repres…
greenhat Aug 8, 2023
be311ac
impl Print for BinOp;
greenhat Aug 8, 2023
a948266
fix nested error wrapping, add division by zero eval test;
greenhat Aug 8, 2023
d353c71
fix spanned Expr construction in Print implementations;
greenhat Aug 8, 2023
e320143
rework wrapped EvalError variants, add custom Display impl for wrappe…
greenhat Sep 22, 2023
bf365dd
add source span test eval error;
greenhat Aug 9, 2023
9f8dfea
impl Print for GlobalVars;
greenhat Aug 11, 2023
e26d18e
impl pretty printing for ByIndex and add out of bounds error test;
greenhat Sep 22, 2023
955e751
add span check in pretty error tests;
greenhat Aug 15, 2023
a5e40f7
impl Display impl for Constant (primitive and composite types);
greenhat Aug 15, 2023
cf0efe3
Display impl for SType;
greenhat Aug 16, 2023
da54af0
implement Display for all Literal variants;
greenhat Aug 18, 2023
22ca326
set empty source span for IR nodes that can only fail at runtime due …
greenhat Aug 21, 2023
e355048
add details to error messages in EvalError variants;
greenhat Aug 21, 2023
8cf9c87
fix formatting;
greenhat Aug 21, 2023
922e2ad
update compiler tests expected results
greenhat Aug 21, 2023
54412d4
Wrap SubstConstants in Spanned;
greenhat Aug 22, 2023
c2747ad
Wrap ByteArrayToLong in Spanned;
greenhat Aug 22, 2023
ae4fd0f
Wrap ByteArrayToBigInt in Spanned;
greenhat Aug 22, 2023
afd73c6
wrap MethodCall in Spanned;
greenhat Aug 22, 2023
7ff21c0
wrap PropertyCall in Spanned;
greenhat Aug 22, 2023
47960ba
wrap Negation in Spanned
greenhat Aug 22, 2023
e9e24e1
wrap OptionGet in Spanned;
greenhat Aug 22, 2023
d8b4384
wrap OptionIsDefined in Spanned;
greenhat Aug 22, 2023
b0ef00f
wrap OptionGetOrElse in Spanned;
greenhat Aug 22, 2023
cc905f5
wrap ExtractRegisterAs in Spanned;
greenhat Aug 22, 2023
a2f2a6c
wrap Slice in Spanned;
greenhat Aug 22, 2023
984dbe6
wrap Fold in Spanned;
greenhat Aug 22, 2023
cbbc6d5
wrap Filter, Fold and ForAll in Spanned;
greenhat Aug 22, 2023
99489da
wrap SelectField in Spanned;
greenhat Aug 22, 2023
25c24f8
wrap SelectField and GetVar in Spanned;
greenhat Aug 22, 2023
dd6ac14
wrap Deserialize* into Spanned;
greenhat Aug 22, 2023
986fc41
wrap TreeLookup in Spanned;
greenhat Aug 22, 2023
1e282b6
fix expected formatting in pretty printer tests;
greenhat Aug 22, 2023
9eb85a1
fix formatting;
greenhat Aug 22, 2023
6bb6761
update expected source spans in binop pretty print test;
greenhat Aug 23, 2023
91e2a0f
skip ConstPlaceholder in pretty printer;
greenhat Aug 23, 2023
5b3873b
fix source span in expected pretty printer test;
greenhat Aug 23, 2023
824ed24
move Print trait and implementations into a separate module;
greenhat Sep 4, 2023
40301df
add EIP23 refresh contract as pretty printer test;
greenhat Sep 5, 2023
ec07000
add Print impl for various IR nodes and print EIP23 refresh contract;
greenhat Sep 6, 2023
b55a0b3
add EIP23 update contract as pretty printer test;
greenhat Sep 7, 2023
aa23f31
add EIP23 ballot contract as pretty printer test;
greenhat Sep 7, 2023
1456b1d
add EIP23 oracle contract as pretty printer test;
greenhat Sep 7, 2023
b81978c
add ageusd bank contract to pretty printer test
greenhat Sep 8, 2023
91c3cf4
add ageusd update contract to pretty printer test;
greenhat Sep 8, 2023
b1e4091
add eip14 amm pool and swap contracts to pretty printer tests;
greenhat Sep 11, 2023
4d09d26
add the rest of amm_conc_pool_* EIP22 auction contracts to the pretty…
greenhat Sep 13, 2023
d1b0e56
add doc comment;
greenhat Sep 13, 2023
0eefaef
pretty printer for ByteArrayTo* IR nodes;
greenhat Sep 14, 2023
7c99195
impl Print for LongToByteArray and CalcSha256;
greenhat Sep 19, 2023
1f7a246
implmennt pretty printing for And, Or, LogicalNot, Xor, SubstConstant…
greenhat Sep 20, 2023
b049864
fix build after rebase;
greenhat Sep 22, 2023
0bd29ad
implement pretty printing for BitInversion, OptionGetOrElse, Slice, F…
greenhat Sep 22, 2023
b6e6084
impl Print for DeserializeRegister and DeserializeContext
greenhat Sep 26, 2023
ee9b159
code formatting
greenhat Sep 27, 2023
3a62672
impl pretty printer for MultiplyGroup, Exponentiate, XorOf, TreeLooku…
greenhat Sep 27, 2023
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
Prev Previous commit
Next Next commit
add EIP23 update contract as pretty printer test;
  • Loading branch information
greenhat committed Sep 22, 2023
commit b55a0b307d058b7dd254b983d163abd0783f1d47
40 changes: 40 additions & 0 deletions ergotree-ir/src/pretty_printer.rs
Original file line number Diff line number Diff line change
Expand Up @@ -292,4 +292,44 @@ mod tests {
"#]],
)
}

#[test]
fn eip23_update_contract() {
let ergo_tree_bytes = base16::decode("100f0400040004000402040204020e20472b4b6250655368566d597133743677397a24432646294a404d635166546a570400040004000e203f4428472d4b6150645367566b5970337336763979244226452948404d625165010005000400040cd80ad601b2a4730000d602db63087201d603b27202730100d604b2a5730200d605db63087204d606b2a5730300d607b27205730400d6088c720701d6098c720702d60ab27202730500d1ededed938c7203017306edededed937203b2720573070093c17201c1720493c672010405c67204040593c672010504c672040504efe6c672040661edededed93db63087206db6308a793c27206c2a792c17206c1a7918cc77206018cc7a701efe6c67206046192b0b5a4d9010b63d801d60ddb6308720b9591b1720d7308d801d60ec6720b070eededed938cb2720d73090001730a93e4c6720b05048cc7a70193e4c6720b060ecbc2720495ede6720ee6c6720b0805ed93e4720e720893e4c6720b08057209ed938c720a017208938c720a027209730b730cd9010b41639a8c720b018cb2db63088c720b02730d00027e730e05").unwrap();
let ergo_tree = ErgoTree::sigma_parse_bytes(&ergo_tree_bytes).unwrap();
check_pretty(
ergo_tree.proposition().unwrap(),
expect![[r#"
{
val v1 = INPUTS(0)
val v2 = v1.tokens
val v3 = v2(0)
val v4 = OUTPUTS(0)
val v5 = v4.tokens
val v6 = OUTPUTS(1)
val v7 = v5(1)
val v8 = v7._1
val v9 = v7._2
val v10 = v2(1)
sigmaProp(v3._1 == "472b4b6250655368566d597133743677397a24432646294a404d635166546a57" && v3 == v5(0) && v1.value == v4.value && v1.getReg(4) == v4.getReg(4) && v1.getReg(5) == v4.getReg(5) && !v4.getReg(6).isDefined() && v6.tokens == SELF.tokens && v6.propBytes == SELF.propBytes && v6.value >= SELF.value && v6.creationInfo._1 > SELF.creationInfo._1 && !v6.getReg(4).isDefined() && INPUTS.filter({
(v11: Box) =>
{
val v13 = v11.tokens
if (v13.size > 0) {
val v14 = v11.getReg(7)
v13(0)._1 == "3f4428472d4b6150645367566b5970337336763979244226452948404d625165" && v11.getReg(5).get == SELF.creationInfo._1 && v11.getReg(6).get == blake2b256(v4.propBytes) && if (v14.isDefined() && v11.getReg(8).isDefined()) v14.get == v8 && v11.getReg(8).get == v9 else v10._1 == v8 && v10._2 == v9
}
else false
}

}
).fold(0)({
(v11: (Long, Box)) =>
v11._1 + v11._2.tokens(0)._2
}
) >= upcast(6))
}
"#]],
)
}
}
29 changes: 27 additions & 2 deletions ergotree-ir/src/pretty_printer/print.rs
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ use thiserror::Error;
use crate::mir::bin_op::BinOp;
use crate::mir::block::BlockValue;
use crate::mir::bool_to_sigma::BoolToSigmaProp;
use crate::mir::calc_blake2b256::CalcBlake2b256;
use crate::mir::coll_append::Append;
use crate::mir::coll_by_index::ByIndex;
use crate::mir::coll_filter::Filter;
Expand All @@ -20,6 +21,7 @@ use crate::mir::func_value::FuncValue;
use crate::mir::get_var::GetVar;
use crate::mir::global_vars::GlobalVars;
use crate::mir::if_op::If;
use crate::mir::logical_not::LogicalNot;
use crate::mir::option_get::OptionGet;
use crate::mir::option_is_defined::OptionIsDefined;
use crate::mir::property_call::PropertyCall;
Expand Down Expand Up @@ -69,7 +71,7 @@ impl Print for Expr {
Expr::LongToByteArray(_) => todo!(),
Expr::Collection(_) => todo!(),
Expr::Tuple(v) => v.print(w),
Expr::CalcBlake2b256(_) => todo!(),
Expr::CalcBlake2b256(v) => v.print(w),
Expr::CalcSha256(_) => todo!(),
Expr::Context => todo!(),
Expr::Global => todo!(),
Expand All @@ -82,7 +84,7 @@ impl Print for Expr {
Expr::Or(_) => todo!(),
Expr::Xor(_) => todo!(),
Expr::Atleast(_) => todo!(),
Expr::LogicalNot(_) => todo!(),
Expr::LogicalNot(v) => v.print(w),
Expr::Negation(_) => todo!(),
Expr::BitInversion(_) => todo!(),
Expr::OptionGet(v) => v.expr().print(w),
Expand Down Expand Up @@ -549,3 +551,26 @@ impl Print for ExtractAmount {
.into())
}
}

impl Print for LogicalNot {
fn print(&self, w: &mut dyn Printer) -> Result<Expr, PrintError> {
write!(w, "!")?;
let input = self.input.print(w)?;
Ok(LogicalNot {
input: Box::new(input),
}
.into())
}
}

impl Print for CalcBlake2b256 {
fn print(&self, w: &mut dyn Printer) -> Result<Expr, PrintError> {
write!(w, "blake2b256(")?;
let input = self.input.print(w)?;
write!(w, ")")?;
Ok(CalcBlake2b256 {
input: Box::new(input),
}
.into())
}
}