Slide 1

Slide 1 text

nil safety in Go nil safety in Go nil safety in Go 

Slide 2

Slide 2 text

nil safety? nil safety? Kotlin Go val user: User? = getUser() val mail: String = user.Email // Compile Error val mail: String = user?.Email // OK var user *User mail := user.Email // Runtime Error if user != nil { mail := user.Email // OK } nil safety in Go 

Slide 3

Slide 3 text

@tenntenn さんの より 『ソースコードを堪能せよ』 nil safety in Go 

Slide 4

Slide 4 text

nil safety in Go 

Slide 5

Slide 5 text

nil safety in Go 

Slide 6

Slide 6 text

nilness nilness 関数内部のブロックを⾛査し、値がnil である か、nil でないか、unknow かを記録していく 同時にnil の値に対して危険な操作をしている箇 所を検出していく SSA 、AST ともに関数を⼀つの単位として⾛査す る そのため他の関数呼び出しは別の処理が必要 であり、⾒逃されていた nil safety in Go 

Slide 7

Slide 7 text

nilarg nilarg 全関数を⾛査して、nil になりうる型の引数に対 して、nil チェックせずに危険な操作をしていな いか確認 危険な操作を検知したら、該当の関数と引数を記 録 関数内部で関数を呼んでおり、その呼び出しが危 険な場合、再帰的に呼び出し元の関数も危険 そのため危険な関数リストを、リストの更新 がなくなるまで無限ループで更新 その後、実際に危険な関数をnil を引数として呼 び出している箇所を検出 nil safety in Go 

Slide 8

Slide 8 text

Future Work Future Work LSP に組み込めば、関数がnil でpanic することを プログラマが意識できるのでは? 無名関数の変数など、静的解析で分からない部分 までは調べられない 引数が複数ある場合、偽陽性の可能性 go vet 本体に⼊れてもらいたい… SSA ⽣成周りにバグがありそうなのでデバッグ nil safety in Go 

Slide 9

Slide 9 text

引数が複数ある場合、偽陽性の可 引数が複数ある場合、偽陽性の可 能性 能性 func doOptional(do bool, f func()) { if do { f() } } nil safety in Go 

Slide 10

Slide 10 text

links links @tenntenn さんの資料 つくったもの nilarg http://bit.ly/enjoysrc https://github.com/Matts966/refsafe https://github.com/Matts966/genelizer https://github.com/Matts966/nilarg https://go- review.googlesource.com/c/tools/+/1953 nil safety in Go   