improve array2d.is_valid

This commit is contained in:
blueloveTH 2024-11-06 15:21:52 +08:00
parent 009917baed
commit b939df167d
3 changed files with 26 additions and 15 deletions

View File

@ -22,7 +22,10 @@ class array2d(Generic[T]):
def __repr__(self) -> str: ... def __repr__(self) -> str: ...
def __iter__(self) -> Iterator[tuple[int, int, T]]: ... def __iter__(self) -> Iterator[tuple[int, int, T]]: ...
@overload
def is_valid(self, col: int, row: int) -> bool: ... def is_valid(self, col: int, row: int) -> bool: ...
@overload
def is_valid(self, pos: vec2i) -> bool: ...
def get(self, col: int, row: int, default=None) -> T | None: def get(self, col: int, row: int, default=None) -> T | None:
"""Returns the value at the given position or the default value if out of bounds.""" """Returns the value at the given position or the default value if out of bounds."""

View File

@ -89,12 +89,21 @@ static bool array2d_numel(int argc, py_Ref argv) {
} }
static bool array2d_is_valid(int argc, py_Ref argv) { static bool array2d_is_valid(int argc, py_Ref argv) {
PY_CHECK_ARGC(3);
c11_array2d* self = py_touserdata(argv); c11_array2d* self = py_touserdata(argv);
int col, row;
if(argc == 2) {
PY_CHECK_ARG_TYPE(1, tp_vec2i);
c11_vec2i pos = py_tovec2i(py_arg(1));
col = pos.x;
row = pos.y;
} else if(argc == 3) {
PY_CHECK_ARG_TYPE(1, tp_int); PY_CHECK_ARG_TYPE(1, tp_int);
PY_CHECK_ARG_TYPE(2, tp_int); PY_CHECK_ARG_TYPE(2, tp_int);
int col = py_toint(py_arg(1)); col = py_toint(py_arg(1));
int row = py_toint(py_arg(2)); row = py_toint(py_arg(2));
} else {
return TypeError("is_valid() expected 2 or 3 arguments");
}
py_newbool(py_retval(), py_array2d_is_valid(self, col, row)); py_newbool(py_retval(), py_array2d_is_valid(self, col, row));
return true; return true;
} }
@ -315,7 +324,7 @@ static bool array2d_tolist(int argc, py_Ref argv) {
return true; return true;
} }
static bool array2d_render(int argc, py_Ref argv){ static bool array2d_render(int argc, py_Ref argv) {
PY_CHECK_ARGC(1); PY_CHECK_ARGC(1);
c11_sbuf buf; c11_sbuf buf;
c11_sbuf__ctor(&buf); c11_sbuf__ctor(&buf);
@ -326,9 +335,7 @@ static bool array2d_render(int argc, py_Ref argv){
if(!py_str(item)) return false; if(!py_str(item)) return false;
c11_sbuf__write_sv(&buf, py_tosv(py_retval())); c11_sbuf__write_sv(&buf, py_tosv(py_retval()));
} }
if(j < self->n_rows - 1){ if(j < self->n_rows - 1) c11_sbuf__write_char(&buf, '\n');
c11_sbuf__write_char(&buf, '\n');
}
} }
c11_sbuf__py_submit(&buf, py_retval()); c11_sbuf__py_submit(&buf, py_retval());
return true; return true;

View File

@ -1,4 +1,5 @@
from array2d import array2d from array2d import array2d
from linalg import vec2i
# test error args for __init__ # test error args for __init__
try: try:
@ -15,12 +16,12 @@ assert a.height == a.n_rows == 4
assert a.numel == 8 assert a.numel == 8
# test is_valid # test is_valid
assert a.is_valid(0, 0) assert a.is_valid(0, 0) and a.is_valid(vec2i(0, 0))
assert a.is_valid(1, 3) assert a.is_valid(1, 3) and a.is_valid(vec2i(1, 3))
assert not a.is_valid(2, 0) assert not a.is_valid(2, 0) and not a.is_valid(vec2i(2, 0))
assert not a.is_valid(0, 4) assert not a.is_valid(0, 4) and not a.is_valid(vec2i(0, 4))
assert not a.is_valid(-1, 0) assert not a.is_valid(-1, 0) and not a.is_valid(vec2i(-1, 0))
assert not a.is_valid(0, -1) assert not a.is_valid(0, -1) and not a.is_valid(vec2i(0, -1))
# test get # test get
assert a.get(0, 0) == 0 assert a.get(0, 0) == 0