File: result_depends_on_errors.swift

package info (click to toggle)
swiftlang 6.0.3-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 2,519,992 kB
  • sloc: cpp: 9,107,863; ansic: 2,040,022; asm: 1,135,751; python: 296,500; objc: 82,456; f90: 60,502; lisp: 34,951; pascal: 19,946; sh: 18,133; perl: 7,482; ml: 4,937; javascript: 4,117; makefile: 3,840; awk: 3,535; xml: 914; fortran: 619; cs: 573; ruby: 573
file content (22 lines) | stat: -rw-r--r-- 945 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
// RUN: %target-typecheck-verify-swift  -enable-builtin-module -enable-experimental-feature  NonescapableTypes
// REQUIRES: asserts

import Builtin

class Klass {}

struct View {
  var pointer: UnsafeRawPointer?
}

class MethodModifiers {
    _resultDependsOnSelf func testAttrOnMethod() { } // expected-error{{Incorrect use of _resultDependsOnSelf with no result}}
}

_resultDependsOnSelf func testAttrOnFunc () -> View { return View(pointer:nil) } // expected-error{{only methods can be declared '_resultDependsOnSelf'}}

// TODO: Seems like Sema doesn't have enough info to diagnose this
func testTypeSpecifierNoResult(x : _resultDependsOn Klass) { } // todo{{'_resultDependsOn' is only valid when there is a result}}

// TODO: Sema doesn't know if a type is non-trivial, diagnose this in SILGen maybe ?
func testTypeSpecifierTrivial(x : _resultDependsOn Int) -> Int { 0 } // todo{{'_resultDependsOnSelf' is only valid on non-trivial types}}