Skip to content

Commit

Permalink
Merge branch 'develop' into test/fileSelector
Browse files Browse the repository at this point in the history
  • Loading branch information
namnguyen20999 authored Jul 11, 2024
2 parents ee4e3e3 + da39caa commit 36854a7
Show file tree
Hide file tree
Showing 4 changed files with 27 additions and 7 deletions.
2 changes: 1 addition & 1 deletion taipy/gui/builder/_element.py
Original file line number Diff line number Diff line change
Expand Up @@ -69,7 +69,7 @@ def update(self, **kwargs):

def _evaluate_lambdas(self, gui: Gui):
for k, lmbd in self._lambdas.items():
expr = gui._evaluate_expr(f"{{{lmbd}}}")
expr = gui._evaluate_expr(lmbd, lambda_expr=True)
gui._bind_var_val(k, _getscopeattr(gui, expr))

# Convert property value to string/function
Expand Down
6 changes: 4 additions & 2 deletions taipy/gui/gui.py
Original file line number Diff line number Diff line change
Expand Up @@ -1612,8 +1612,10 @@ def _is_in_brdcst_callback(self):
return False

# Proxy methods for Evaluator
def _evaluate_expr(self, expr: str, lazy_declare: t.Optional[bool] = False) -> t.Any:
return self.__evaluator.evaluate_expr(self, expr, lazy_declare)
def _evaluate_expr(
self, expr: str, lazy_declare: t.Optional[bool] = False, lambda_expr: t.Optional[bool] = False
) -> t.Any:
return self.__evaluator.evaluate_expr(self, expr, lazy_declare, lambda_expr)

def _re_evaluate_expr(self, var_name: str) -> t.Set[str]:
return self.__evaluator.re_evaluate_expr(self, var_name)
Expand Down
10 changes: 6 additions & 4 deletions taipy/gui/utils/_evaluator.py
Original file line number Diff line number Diff line change
Expand Up @@ -210,15 +210,17 @@ def __evaluate_holder(self, gui: Gui, holder: t.Type[_TaipyBase], expr: str) ->
_warn(f"Cannot evaluate expression {holder.__name__}({expr_hash},'{expr_hash}') for {expr}", e)
return None

def evaluate_expr(self, gui: Gui, expr: str, lazy_declare: t.Optional[bool] = False) -> t.Any:
if not self._is_expression(expr):
def evaluate_expr(
self, gui: Gui, expr: str, lazy_declare: t.Optional[bool] = False, lambda_expr: t.Optional[bool] = False
) -> t.Any:
if not self._is_expression(expr) and not lambda_expr:
return expr
var_val, var_map = self._analyze_expression(gui, expr, lazy_declare)
var_val, var_map = ({}, {}) if lambda_expr else self._analyze_expression(gui, expr, lazy_declare)
expr_hash = None
is_edge_case = False

# The expr_string is placed here in case expr get replaced by edge case
expr_string = 'f"' + expr.replace('"', '\\"') + '"'
expr_string = expr if lambda_expr else 'f"' + expr.replace('"', '\\"') + '"'
# simplify expression if it only contains var_name
m = _Evaluator.__EXPR_IS_EDGE_CASE.match(expr)
if m and not _Evaluator.__EXPR_EDGE_CASE_F_STRING.match(expr):
Expand Down
16 changes: 16 additions & 0 deletions tests/gui/builder/test_lambda.py
Original file line number Diff line number Diff line change
Expand Up @@ -31,3 +31,19 @@ def test_builder_lambda_2(gui: Gui, test_client, helpers):
tgb.text(lambda message: str(message.get(key)), mode=lambda message: "mode " + str(message.get(key))) # type: ignore[attr-defined] # noqa: B023
expected_list = ['defaultValue="value A"', 'defaultValue="value B"', 'mode="mode value A"', 'mode="mode value B"']
helpers.test_control_builder(gui, page, expected_list)

def test_builder_lambda_f_string(gui: Gui, test_client, helpers):
value = 10
gui._bind_var_val("value", value)
with tgb.Page(frame=None) as page:
tgb.text(lambda value: f"value is {value}") # type: ignore[attr-defined] # noqa: B023
expected_list = ['defaultValue="value is 10"']
helpers.test_control_builder(gui, page, expected_list)

def test_builder_simple_lambda(gui: Gui, test_client, helpers):
value = 10
gui._bind_var_val("value", value)
with tgb.Page(frame=None) as page:
tgb.text(lambda value: value) # type: ignore[attr-defined] # noqa: B023
expected_list = ['defaultValue="10"']
helpers.test_control_builder(gui, page, expected_list)

0 comments on commit 36854a7

Please sign in to comment.