mirror of
				https://github.com/slint-ui/slint.git
				synced 2025-11-04 05:34:37 +00:00 
			
		
		
		
	* 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
		
	
			
		
			
				
	
	
		
			56 lines
		
	
	
	
		
			2.1 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
			
		
		
	
	
			56 lines
		
	
	
	
		
			2.1 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
 | 
						|
 | 
						|
Abc := Rectangle {
 | 
						|
//  ^warning{':=' to declare a component is deprecated. The new syntax declare components with 'component MyComponent {'. Read the documentation for more info}
 | 
						|
    function par() {}
 | 
						|
}
 | 
						|
 | 
						|
export Xxx := Rectangle {
 | 
						|
//         ^warning{':=' to declare a component is deprecated. The new syntax declare components with 'component MyComponent {'. Read the documentation for more info}
 | 
						|
    function fooo(a: int, a: int) -> int { return a; }
 | 
						|
//                        ^error{Duplicated argument name 'a'}
 | 
						|
 | 
						|
    function plop2() -> int {
 | 
						|
//  ^error{Cannot convert string to int}
 | 
						|
        return 45;
 | 
						|
        "xxx"
 | 
						|
    }
 | 
						|
 | 
						|
    function plop3() { return 45; "xxx" }
 | 
						|
 | 
						|
    function plop4(string: int) -> int {  return "45"; }
 | 
						|
//                                        ^error{Cannot convert string to int}
 | 
						|
 | 
						|
    function plop5() {  plop4("456") }
 | 
						|
//                            ^error{Cannot convert string to int}
 | 
						|
 | 
						|
 | 
						|
    function background() {}
 | 
						|
//           ^error{Cannot declare function 'background' when a property with the same name exists}
 | 
						|
 | 
						|
 | 
						|
    Abc {
 | 
						|
        property <int> par;
 | 
						|
//                     ^error{Cannot declare property 'par' when a function with the same name exists}
 | 
						|
        callback par();
 | 
						|
//               ^error{Cannot declare callback 'par' when a function with the same name exists}
 | 
						|
    }
 | 
						|
 | 
						|
    TouchArea {
 | 
						|
        function clicked() {}
 | 
						|
//               ^error{Cannot override 'clicked'}
 | 
						|
    }
 | 
						|
 | 
						|
    Abc {  par => {} }
 | 
						|
//         ^error{'par' is not a callback in Abc}
 | 
						|
    aa := Abc { par: 42; }
 | 
						|
//              ^error{Cannot assign to par in Abc because it does not have a valid property type}
 | 
						|
    Abc { par <=> aa.par; }
 | 
						|
//        ^error{Cannot assign to par in Abc because it does not have a valid property type}
 | 
						|
//        ^^error{Cannot bind to a function}
 | 
						|
//                   ^^^error{The function 'par' is private. Annotate it with 'public' to make it accessible from other components}
 | 
						|
    fooo => {}
 | 
						|
//  ^error{'fooo' is not a callback in Rectangle}
 | 
						|
 | 
						|
}
 |