slint/internal/compiler/tests/syntax/basic/rotation.slint
Olivier Goffart 12393e21bd
syntax_tests: allow to update tests, and don't use a regexp (#8589)
* syntax_tests: allow to "bless" tests, and don't use a regexp

A regexp was used at the beginning because I thought we would want to
allow error to contains things that were not predictable or that would
often change. But this is not the case¹. It is better to actually test
for the full error message

¹ well actually it was the case for path, but there is another substitution to 
 `📂` for the manifest directory

* syntax_tests: Bless the tests

* syntax_tests: Manual adjust after bless

Because there used to be comments on the same line of the message which
bless don't support

* Fix error message with path on windows

 - The debug implementation of path make double slash, that's not what
   we want to show the user
 - normalize paths to use `/` so the test passes
2025-06-02 16:47:33 +02:00

81 lines
2.9 KiB
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 Ex1 := Rectangle {
// ^warning{':=' to declare a component is deprecated. The new syntax declare components with 'component MyComponent {'. Read the documentation for more info}
Rectangle {
rotation-origin-x: width / 2;
rotation-angle: 45deg;
// ^error{rotation properties can only be applied to the Image or Text element}
rotation-origin-y: width / 2;
}
Rectangle {
// ^error{rotation properties can only be applied to the Image or Text element}
rotation-origin-x: width / 2;
rotation-origin-y: width / 2;
}
Text {
rotation-angle: 90deg;
}
}
RotImg := Image {
// ^warning{':=' to declare a component is deprecated. The new syntax declare components with 'component MyComponent {'. Read the documentation for more info}
rotation-angle: 45deg;
}
JustAnImage := Image {}
// ^warning{':=' to declare a component is deprecated. The new syntax declare components with 'component MyComponent {'. Read the documentation for more info}
ImageWithChild := Image {
// ^warning{':=' to declare a component is deprecated. The new syntax declare components with 'component MyComponent {'. Read the documentation for more info}
Rectangle {}
}
export Ex2 := Rectangle {
// ^warning{':=' to declare a component is deprecated. The new syntax declare components with 'component MyComponent {'. Read the documentation for more info}
Image {
// ^error{Elements with rotation properties cannot have children elements}
rotation-angle: 45deg;
Rectangle {}
}
RotImg {
// ^error{Elements with rotation properties cannot have children elements}
Rectangle {}
}
ImageWithChild {
// ^error{Elements with rotation properties cannot have children elements}
rotation-origin-x: 45px;
}
JustAnImage {
// ^error{Elements with rotation properties cannot have children elements}
rotation-angle: 45deg;
Rectangle {}
}
}
export Ex3 := Rectangle {
// ^warning{':=' to declare a component is deprecated. The new syntax declare components with 'component MyComponent {'. Read the documentation for more info}
i1 := Image {
// ^error{Elements with rotation properties cannot have children elements}
Rectangle {}
}
i2 := Rectangle {}
// ^error{rotation properties can only be applied to the Image or Text element}
TouchArea {
clicked => {
i1.rotation-angle = 60deg;
i2.rotation-origin-x = 10px;
}
}
}
export component Ex4 {
in property rot <=> rect . rotation-angle;
rect := Rectangle {}
// ^error{rotation properties can only be applied to the Image or Text element}
}