slint/internal/compiler/tests/syntax/functions/functions_purity_recursive_5220.slint
Olivier Goffart db18f4e2e5 Change the new error that detects binding loop through the window into a warning
In 80de96488a (#3397) we introduced a new
error if we detect a binding loop from the Window geomerty to its layout.
But it looks like this causes a lot of error in existing project, so
make it a warning instead.

It will continue to be an error in the live preview as this will cause a
panic otherwise.

This commit also change the text of the error to include the actual
binding loop. I hope this makes it easier for users to see the loop and
help to fix it.
2025-06-02 19:01:47 +02:00

21 lines
781 B
Text

// Copyright © SixtyFPS GmbH <info@slint.dev>
// SPDX-License-Identifier: GPL-3.0-only OR LicenseRef-Slint-Royalty-free-2.0 OR LicenseRef-Slint-Software-3.0
export component App inherits Window{
background: blue;
// ^error{Function must be called. Did you forgot the '()'?}
function blue()->color {
blue
// ^error{Function must be called. Did you forgot the '()'?}
}
in property <int> abc: get_abc1();
function get_abc1() -> int { return get_abc2(); }
// ^error{The binding for the property 'get-abc1' is part of a binding loop (root.get-abc2 -> root.get-abc1)}
function get_abc2() -> int { return get_abc1(); }
// ^error{The binding for the property 'get-abc2' is part of a binding loop (root.get-abc2 -> root.get-abc1)}
}