blob: 793fbe71840dabf90ff8a4cedc2c8b3fd97c70f3 [file] [log] [blame]
// RUN: %target-typecheck-verify-swift -enable-throw-without-try
// Test the -enable-throw-without-try option. Throwing function calls should
// not require annotation with 'try'.
// rdar://21444103 - only at the top level
func foo() throws -> Int { return 0 }
// That applies to global "script" code.
var global: Int = 0
global = foo() // no error
global = try foo() // still no error
var global2: Int = foo() // no error
var global3: Int = try foo() // no error
// That includes autoclosures.
func doLazy(_ fn: @autoclosure () throws -> Int) {}
doLazy(foo())
// It doesn't include explicit closures.
var closure: () -> () = {
_ = foo() // expected-error {{call can throw, but it is not marked with 'try' and the error is not handled}}
doLazy(foo()) // expected-error {{call can throw but is not marked with 'try'}}
// expected-note@-1 {{did you mean to use 'try'?}} {{10-10=try }}
// expected-note@-2 {{did you mean to handle error as optional value?}} {{10-10=try? }}
// expected-note@-3 {{did you mean to disable error propagation?}} {{10-10=try! }}
}
// Or any other sort of structure.
struct A {
static var lazyCache: Int = foo() // expected-error {{call can throw, but errors cannot be thrown out of a global variable initializer}}
}
func baz() throws -> Int {
var x: Int = 0
x = foo() // expected-error{{call can throw but is not marked with 'try'}}
// expected-note@-1 {{did you mean to use 'try'?}} {{7-7=try }}
// expected-note@-2 {{did you mean to handle error as optional value?}} {{7-7=try? }}
// expected-note@-3 {{did you mean to disable error propagation?}} {{7-7=try! }}
x = try foo() // no error
return x
}
func baz2() -> Int {
var x: Int = 0
x = foo() // expected-error{{call can throw, but it is not marked with 'try' and the error is not handled}}
x = try foo() // expected-error{{errors thrown from here are not handled}}
return x
}
// SR-11016
protocol SR_11016_P {
func bar() throws
}
class SR_11016_C {
var foo: SR_11016_P?
func someMethod() throws {
foo?.bar() // expected-error {{call can throw but is not marked with 'try'}}
// expected-note @-1 {{did you mean to use 'try'?}}{{5-5=try }}
// expected-note @-2 {{did you mean to handle error as optional value?}}{{5-5=try? }}
// expected-note @-3 {{did you mean to disable error propagation?}}{{5-5=try! }}
}
}