Skip to content

Commit

Permalink
Refactor to clamp_le
Browse files Browse the repository at this point in the history
  • Loading branch information
DanielSchiavini committed Feb 27, 2024
1 parent eec9ce8 commit f8412ee
Show file tree
Hide file tree
Showing 3 changed files with 9 additions and 4 deletions.
4 changes: 2 additions & 2 deletions vyper/builtins/_convert.py
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@
bytes_data_ptr,
clamp,
clamp_basetype,
clamp_le,
get_bytearray_length,
int_clamp,
is_bytes_m_type,
Expand Down Expand Up @@ -110,8 +111,7 @@ def _clamp_numeric_convert(arg, arg_bounds, out_bounds, arg_is_signed):
# out_hi must be smaller than MAX_UINT256, so clample makes sense.
# add an assertion, just in case this assumption ever changes.
assert out_hi < 2**256 - 1, "bad assumption in numeric convert"
CLAMP_OP = "sle" if arg_is_signed else "le"
arg = clamp(CLAMP_OP, arg, out_hi)
arg = clamp_le(arg, out_hi, arg_is_signed)

return arg

Expand Down
5 changes: 5 additions & 0 deletions vyper/codegen/core.py
Original file line number Diff line number Diff line change
Expand Up @@ -1222,6 +1222,11 @@ def clamp_nonzero(arg):
return IRnode.from_list(b1.resolve(ret), typ=arg.typ)


def clamp_le(arg, hi, signed):
LE = "sle" if signed else "le"
return clamp(LE, arg, hi)


def clamp2(lo, arg, hi, signed):
with IRnode.from_list(arg).cache_when_complex("clamp2_arg") as (b1, arg):
GE = "sge" if signed else "ge"
Expand Down
4 changes: 2 additions & 2 deletions vyper/codegen/stmt.py
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@
IRnode,
append_dyn_array,
check_assign,
clamp,
clamp_le,
dummy_node_for_type,
get_dyn_array_count,
get_element_ptr,
Expand Down Expand Up @@ -255,7 +255,7 @@ def _parse_For_range(self):
with end.cache_when_complex("end") as (b1, end):
# note: the check for rounds<=rounds_bound happens in asm
# generation for `repeat`.
clamped_start = clamp("sle" if target_type.is_signed else "le", start, end)
clamped_start = clamp_le(start, end, target_type.is_signed)
rounds = b1.resolve(IRnode.from_list(["sub", end, clamped_start]))
rounds_bound = kwargs.pop("bound").int_value()
else:
Expand Down

0 comments on commit f8412ee

Please sign in to comment.