Slide 1

Slide 1 text

Scala におけるコンパイラエラーとの付き合い方 by Chen (@Chen__TS) Scala わいわい勉強会 #3 / 2024-09-06

Slide 2

Slide 2 text

君だれ? 通称 : ちぇん Twitter : @Chen__TS GitHub : @ChenCMD 趣味 : プログラミング 職業 : バックエンドエンジニア 最近の悩み : 何もしてないのに コンパイラエラーをよく踏む

Slide 3

Slide 3 text

こう思いませんでしたか? 3/22

Slide 4

Slide 4 text

「君、コンパイラエラー踏みすぎじゃない?」 4/22

Slide 5

Slide 5 text

みんなコンパイラエラーを踏んでいることに気づ いてないだけなのでは? 5/22

Slide 6

Slide 6 text

コンパイラエラーはどういうときに見れるの? コンパイル時に出力されるエラー 6/22

Slide 7

Slide 7 text

コンパイラエラーはどういうときに見れるの? コンパイル時に出力されるエラー Presentation Compiler を通して出力されるエラー ※Presentation Compiler とは? コーディング中に高速にエラーや補完等のフィー ドバックを与えるためにコンパイラに搭載された コード解析機能のこと 7/22

Slide 8

Slide 8 text

コンパイラエラーが既知のものかを調べる方法 使用する Scala のバージョンを Nightly に上げて試す Maven リポジトリから指定するバージョンを取得できます https://repo1.maven.org/maven2/org/scala-lang/scala3- compiler_3/maven-metadata.xml 8/22

Slide 9

Slide 9 text

コンパイラエラーが既知のものかを調べる方法 使用する Scala のバージョンを Nightly に上げて試す Maven リポジトリから指定するバージョンを取得できます https://repo1.maven.org/maven2/org/scala-lang/scala3- compiler_3/maven-metadata.xml 出力されているスタックトレースを元に Scala や ScalaMeta のリポジトリ の Issues を検索する スタックトレースが同一でも原因が違うこともある 基本的には、確実に既知と言い切れなければ報告して良い (と思う) 9/22

Slide 10

Slide 10 text

Issue を作る 10/22

Slide 11

Slide 11 text

Issue を作る その前に 先程のコードをそのまま Issue に貼ったとして、それを見た開発者の気持ちを 考えてみる ※あくまでも想像です 11/22

Slide 12

Slide 12 text

Issue を作る その前に 先程のコードをそのまま Issue に貼ったとして、それを見た開発者の気持ちを 考えてみる ※あくまでも想像です 「何だこのめちゃくちゃに長いコードは...」 12/22

Slide 13

Slide 13 text

Issue を作る その前に 先程のコードをそのまま Issue に貼ったとして、それを見た開発者の気持ちを 考えてみる ※あくまでも想像です 「何だこのめちゃくちゃに長いコードは...」 「よくわからない依存関係も import されてる...」 13/22

Slide 14

Slide 14 text

Issue を作る その前に 先程のコードをそのまま Issue に貼ったとして、それを見た開発者の気持ちを 考えてみる ※あくまでも想像です 「何だこのめちゃくちゃに長いコードは...」 「よくわからない依存関係も import されてる...」 「原因がさっぱりわからん...」 こうなることが容易に想像できる 14/22

Slide 15

Slide 15 text

そうだ、Minimization をしよう。 15/22

Slide 16

Slide 16 text

Minimization とは? コンパイラエラーが発生する最小のコードを作る工程 エラーに関係ないのであれば、import 等も極限まで削除する "Minimization" == "最小再現例" (日本語で言及されてることはあまり見かけませんが...) 16/22

Slide 17

Slide 17 text

Minimization の手順 ※ちぇん個人のやり方です 1. コードをある程度小さなコード辺にする コードに関数が複数ある場合は一つずつ削除してみる 17/22

Slide 18

Slide 18 text

Minimization の手順 ※ちぇん個人のやり方です 1. コードをある程度小さなコード辺にする コードに関数が複数ある場合は一つずつ削除してみる 2. import をすべて無くす import 先のコードをコピーして持ってきて import を消していく 18/22

Slide 19

Slide 19 text

Minimization の手順 ※ちぇん個人のやり方です 1. コードをある程度小さなコード辺にする コードに関数が複数ある場合は一つずつ削除してみる 2. import をすべて無くす import 先のコードをコピーして持ってきて import を消していく 3. これを更に細かく小さくしていく trait や引数、関数呼び出し等、一つずつ削除してみる 19/22

Slide 20

Slide 20 text

今度こそ Issue を作る 基本的にテンプレートに従って書 けば OK 今回の場合はこんな感じ あとは見返して を押すだけ 20/22

Slide 21

Slide 21 text

まとめ コンパイラエラーは誰にでも起こりうるし、気づいていないだけで既に踏 んでいるかもしれない エラーメッセージをしっかりと読んで原因のファイルを特定することが最 初のステップ Scala のバージョンを上げたり、スタックトレースを元にリポジトリの Issues を検索して既知のエラーかどうかを調べるのが次のステップ 未知のエラーならば Minimization コードを作成し、Issue を報告すること を目指すのがオススメ 21/22

Slide 22

Slide 22 text

Scala におけるコンパイラエラーとの付き合い方 by Chen (@Chen__TS) Twemoji : CreativeCommons-BY-4.0 Scala わいわい勉強会 #3 / 2024-09-06 22/22