[INFO] updating cached repository doxxx/raytracer [INFO] running `"git" "fetch" "--all"` [INFO] [stdout] Fetching origin [INFO] [stderr] From git://github.com/doxxx/raytracer [INFO] [stderr] * branch HEAD -> FETCH_HEAD [INFO] running `"git" "clone" "work/cache/sources/gh/doxxx/raytracer" "work/ex/pr-60466/sources/master#7840a0b753a065a41999f1fb6028f67d33e3fdd5/gh/doxxx/raytracer"` [INFO] [stderr] Cloning into 'work/ex/pr-60466/sources/master#7840a0b753a065a41999f1fb6028f67d33e3fdd5/gh/doxxx/raytracer'... [INFO] [stderr] done. [INFO] running `"git" "clone" "work/cache/sources/gh/doxxx/raytracer" "work/ex/pr-60466/sources/try#6a9f0b6cc40687e25f9d772e3b10bab335c63853/gh/doxxx/raytracer"` [INFO] [stderr] Cloning into 'work/ex/pr-60466/sources/try#6a9f0b6cc40687e25f9d772e3b10bab335c63853/gh/doxxx/raytracer'... [INFO] [stderr] done. [INFO] running `"git" "rev-parse" "HEAD"` [INFO] [stdout] 27048ee94758fb681a3eb3796caf8db9824d1d11 [INFO] sha for GitHub repo doxxx/raytracer: 27048ee94758fb681a3eb3796caf8db9824d1d11 [INFO] validating manifest of doxxx/raytracer on toolchain master#7840a0b753a065a41999f1fb6028f67d33e3fdd5 [INFO] running `"/mnt/crater-raid/crater/work/local/cargo-home/bin/cargo" "+7840a0b753a065a41999f1fb6028f67d33e3fdd5-alt" "read-manifest" "--manifest-path" "Cargo.toml"` [INFO] validating manifest of doxxx/raytracer on toolchain try#6a9f0b6cc40687e25f9d772e3b10bab335c63853 [INFO] running `"/mnt/crater-raid/crater/work/local/cargo-home/bin/cargo" "+6a9f0b6cc40687e25f9d772e3b10bab335c63853-alt" "read-manifest" "--manifest-path" "Cargo.toml"` [INFO] started frobbing doxxx/raytracer [INFO] finished frobbing doxxx/raytracer [INFO] frobbed toml for doxxx/raytracer written to work/ex/pr-60466/sources/master#7840a0b753a065a41999f1fb6028f67d33e3fdd5/gh/doxxx/raytracer/Cargo.toml [INFO] started frobbing doxxx/raytracer [INFO] finished frobbing doxxx/raytracer [INFO] frobbed toml for doxxx/raytracer written to work/ex/pr-60466/sources/try#6a9f0b6cc40687e25f9d772e3b10bab335c63853/gh/doxxx/raytracer/Cargo.toml [INFO] crate doxxx/raytracer already has a lockfile, it will not be regenerated [INFO] running `"/mnt/crater-raid/crater/work/local/cargo-home/bin/cargo" "+7840a0b753a065a41999f1fb6028f67d33e3fdd5-alt" "fetch" "--locked" "--manifest-path" "Cargo.toml"` [INFO] running `"/mnt/crater-raid/crater/work/local/cargo-home/bin/cargo" "+6a9f0b6cc40687e25f9d772e3b10bab335c63853-alt" "fetch" "--locked" "--manifest-path" "Cargo.toml"` [INFO] checking doxxx/raytracer against master#7840a0b753a065a41999f1fb6028f67d33e3fdd5 for pr-60466 [INFO] running `"docker" "create" "-v" "/mnt/crater-raid/crater/work/local/target-dirs/pr-60466/worker-0/master#7840a0b753a065a41999f1fb6028f67d33e3fdd5:/opt/crater/target:rw,Z" "-v" "/mnt/crater-raid/crater/work/ex/pr-60466/sources/master#7840a0b753a065a41999f1fb6028f67d33e3fdd5/gh/doxxx/raytracer:/opt/crater/workdir:ro,Z" "-v" "/mnt/crater-raid/crater/work/local/cargo-home:/opt/crater/cargo-home:ro,Z" "-v" "/mnt/crater-raid/crater/work/local/rustup-home:/opt/crater/rustup-home:ro,Z" "-e" "USER_ID=1000" "-e" "SOURCE_DIR=/opt/crater/workdir" "-e" "MAP_USER_ID=1000" "-e" "CARGO_TARGET_DIR=/opt/crater/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/crater/cargo-home" "-e" "RUSTUP_HOME=/opt/crater/rustup-home" "-w" "/opt/crater/workdir" "-m" "1536M" "--network" "none" "rustops/crates-build-env" "/opt/crater/cargo-home/bin/cargo" "+7840a0b753a065a41999f1fb6028f67d33e3fdd5-alt" "check" "--frozen" "--all" "--all-targets"` [INFO] [stdout] 84d8082a6039d8c0f914429b239d68fce2d3bc58fbc3acdae849121ee4787f67 [INFO] running `"docker" "start" "-a" "84d8082a6039d8c0f914429b239d68fce2d3bc58fbc3acdae849121ee4787f67"` [INFO] [stderr] Checking scopeguard v0.3.2 [INFO] [stderr] Checking rand v0.4.2 [INFO] [stderr] Compiling peg v0.5.4 [INFO] [stderr] Checking clap v2.25.1 [INFO] [stderr] Checking pbr v1.0.0 [INFO] [stderr] Checking num-complex v0.2.0 [INFO] [stderr] Checking crossbeam-epoch v0.3.1 [INFO] [stderr] Checking crossbeam-deque v0.2.0 [INFO] [stderr] Checking rayon-core v1.4.1 [INFO] [stderr] Checking rayon v0.8.2 [INFO] [stderr] Checking rayon v1.0.2 [INFO] [stderr] Compiling raytracer v0.1.0 (/opt/crater/workdir) [INFO] [stderr] Checking jpeg-decoder v0.1.13 [INFO] [stderr] Checking image v0.14.0 [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> /opt/crater/target/debug/build/raytracer-8cce5711dbbe16ea/out/sdl_grammar.rs:89:167 [INFO] [stderr] | [INFO] [stderr] 89 | fn __parse_object_shape < 'input > ( __input : & 'input str , __state : & mut ParseState < 'input > , __pos : usize , renderOptions : &Options ) -> RuleResult < Box > { # ! [ allow ( non_snake_case , unused ) ] { let __choice_res = __parse_planar_shape ( __input , __state , __pos , renderOptions ) ; match __choice_res { Matched ( __pos , __value ) => Matched ( __pos , __value ) , Failed => { let __choice_res = __parse_solid_shape ( __input , __state , __pos , renderOptions ) ; match __choice_res { Matched ( __pos , __value ) => Matched ( __pos , __value ) , Failed => __parse_mesh ( __input , __state , __pos , renderOptions ) } } } } } [INFO] [stderr] | ^^^^^ help: use `dyn`: `dyn Shape` [INFO] [stderr] | [INFO] [stderr] = note: #[warn(bare_trait_objects)] on by default [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> /opt/crater/target/debug/build/raytracer-8cce5711dbbe16ea/out/sdl_grammar.rs:91:167 [INFO] [stderr] | [INFO] [stderr] 91 | fn __parse_planar_shape < 'input > ( __input : & 'input str , __state : & mut ParseState < 'input > , __pos : usize , renderOptions : &Options ) -> RuleResult < Box > { # ! [ allow ( non_snake_case , unused ) ] { let __choice_res = __parse_plane ( __input , __state , __pos , renderOptions ) ; match __choice_res { Matched ( __pos , __value ) => Matched ( __pos , __value ) , Failed => { let __choice_res = __parse_xyrect ( __input , __state , __pos , renderOptions ) ; match __choice_res { Matched ( __pos , __value ) => Matched ( __pos , __value ) , Failed => { let __choice_res = __parse_xzrect ( __input , __state , __pos , renderOptions ) ; match __choice_res { Matched ( __pos , __value ) => Matched ( __pos , __value ) , Failed => __parse_zyrect ( __input , __state , __pos , renderOptions ) } } } } } } } [INFO] [stderr] | ^^^^^ help: use `dyn`: `dyn Shape` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> /opt/crater/target/debug/build/raytracer-8cce5711dbbe16ea/out/sdl_grammar.rs:93:166 [INFO] [stderr] | [INFO] [stderr] 93 | fn __parse_solid_shape < 'input > ( __input : & 'input str , __state : & mut ParseState < 'input > , __pos : usize , renderOptions : &Options ) -> RuleResult < Box > { # ! [ allow ( non_snake_case , unused ) ] { let __choice_res = __parse_sphere ( __input , __state , __pos , renderOptions ) ; match __choice_res { Matched ( __pos , __value ) => Matched ( __pos , __value ) , Failed => { let __choice_res = __parse_cylinder ( __input , __state , __pos , renderOptions ) ; match __choice_res { Matched ( __pos , __value ) => Matched ( __pos , __value ) , Failed => { let __choice_res = __parse_torus ( __input , __state , __pos , renderOptions ) ; match __choice_res { Matched ( __pos , __value ) => Matched ( __pos , __value ) , Failed => { let __choice_res = __parse_cube ( __input , __state , __pos , renderOptions ) ; match __choice_res { Matched ( __pos , __value ) => Matched ( __pos , __value ) , Failed => { let __choice_res = __parse_csg ( __input , __state , __pos , renderOptions ) ; match __choice_res { Matched ( __pos , __value ) => Matched ( __pos , __value ) , Failed => __parse_homogenous_medium ( __input , __state , __pos , renderOptions ) } } } } } } } } } } } [INFO] [stderr] | ^^^^^ help: use `dyn`: `dyn Shape` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> /opt/crater/target/debug/build/raytracer-8cce5711dbbe16ea/out/sdl_grammar.rs:95:158 [INFO] [stderr] | [INFO] [stderr] 95 | fn __parse_csg < 'input > ( __input : & 'input str , __state : & mut ParseState < 'input > , __pos : usize , renderOptions : &Options ) -> RuleResult < Box > { # ! [ allow ( non_snake_case , unused ) ] { let __choice_res = __parse_csg_union ( __input , __state , __pos , renderOptions ) ; match __choice_res { Matched ( __pos , __value ) => Matched ( __pos , __value ) , Failed => { let __choice_res = __parse_csg_intersection ( __input , __state , __pos , renderOptions ) ; match __choice_res { Matched ( __pos , __value ) => Matched ( __pos , __value ) , Failed => __parse_csg_difference ( __input , __state , __pos , renderOptions ) } } } } } [INFO] [stderr] | ^^^^^ help: use `dyn`: `dyn Shape` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> /opt/crater/target/debug/build/raytracer-8cce5711dbbe16ea/out/sdl_grammar.rs:97:164 [INFO] [stderr] | [INFO] [stderr] 97 | fn __parse_csg_union < 'input > ( __input : & 'input str , __state : & mut ParseState < 'input > , __pos : usize , renderOptions : &Options ) -> RuleResult < Box > { # ! [ allow ( non_snake_case , unused ) ] { let __seq_res = { let __seq_res = { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = slice_eq ( __input , __state , __pos , "union" ) ; match __seq_res { Matched ( __pos , _ ) => { { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } } Failed => Failed , } } } Failed => Failed , } } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_OPEN_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_solid_shape ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , a ) => { { let __seq_res = __parse_solid_shape ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , b ) => { { let __seq_res = match __parse_transforms ( __input , __state , __pos , renderOptions ) { Matched ( __newpos , __value ) => { Matched ( __newpos , Some ( __value ) ) } , Failed => { Matched ( __pos , None ) } , } ; match __seq_res { Matched ( __pos , transform ) => { { let __seq_res = __parse_CLOSE_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { Matched ( __pos , { [INFO] [stderr] | ^^^^^ help: use `dyn`: `dyn Shape` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> /opt/crater/target/debug/build/raytracer-8cce5711dbbe16ea/out/sdl_grammar.rs:101:171 [INFO] [stderr] | [INFO] [stderr] 101 | fn __parse_csg_intersection < 'input > ( __input : & 'input str , __state : & mut ParseState < 'input > , __pos : usize , renderOptions : &Options ) -> RuleResult < Box > { # ! [ allow ( non_snake_case , unused ) ] { let __seq_res = { let __seq_res = { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = slice_eq ( __input , __state , __pos , "intersection" ) ; match __seq_res { Matched ( __pos , _ ) => { { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } } Failed => Failed , } } } Failed => Failed , } } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_OPEN_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_solid_shape ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , a ) => { { let __seq_res = __parse_solid_shape ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , b ) => { { let __seq_res = match __parse_transforms ( __input , __state , __pos , renderOptions ) { Matched ( __newpos , __value ) => { Matched ( __newpos , Some ( __value ) ) } , Failed => { Matched ( __pos , None ) } , } ; match __seq_res { Matched ( __pos , transform ) => { { let __seq_res = __parse_CLOSE_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { Matched ( __pos , { [INFO] [stderr] | ^^^^^ help: use `dyn`: `dyn Shape` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> /opt/crater/target/debug/build/raytracer-8cce5711dbbe16ea/out/sdl_grammar.rs:105:169 [INFO] [stderr] | [INFO] [stderr] 105 | fn __parse_csg_difference < 'input > ( __input : & 'input str , __state : & mut ParseState < 'input > , __pos : usize , renderOptions : &Options ) -> RuleResult < Box > { # ! [ allow ( non_snake_case , unused ) ] { let __seq_res = { let __seq_res = { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = slice_eq ( __input , __state , __pos , "difference" ) ; match __seq_res { Matched ( __pos , _ ) => { { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } } Failed => Failed , } } } Failed => Failed , } } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_OPEN_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_solid_shape ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , a ) => { { let __seq_res = __parse_solid_shape ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , b ) => { { let __seq_res = match __parse_transforms ( __input , __state , __pos , renderOptions ) { Matched ( __newpos , __value ) => { Matched ( __newpos , Some ( __value ) ) } , Failed => { Matched ( __pos , None ) } , } ; match __seq_res { Matched ( __pos , transform ) => { { let __seq_res = __parse_CLOSE_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { Matched ( __pos , { [INFO] [stderr] | ^^^^^ help: use `dyn`: `dyn Shape` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> /opt/crater/target/debug/build/raytracer-8cce5711dbbe16ea/out/sdl_grammar.rs:109:161 [INFO] [stderr] | [INFO] [stderr] 109 | fn __parse_sphere < 'input > ( __input : & 'input str , __state : & mut ParseState < 'input > , __pos : usize , renderOptions : &Options ) -> RuleResult < Box > { # ! [ allow ( non_snake_case , unused ) ] { let __seq_res = { let __seq_res = { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = slice_eq ( __input , __state , __pos , "sphere" ) ; match __seq_res { Matched ( __pos , _ ) => { { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } } Failed => Failed , } } } Failed => Failed , } } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_OPEN_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = match __parse_origin ( __input , __state , __pos , renderOptions ) { Matched ( __newpos , __value ) => { Matched ( __newpos , Some ( __value ) ) } , Failed => { Matched ( __pos , None ) } , } ; match __seq_res { Matched ( __pos , o ) => { { let __seq_res = match __parse_radius ( __input , __state , __pos , renderOptions ) { Matched ( __newpos , __value ) => { Matched ( __newpos , Some ( __value ) ) } , Failed => { Matched ( __pos , None ) } , } ; match __seq_res { Matched ( __pos , r ) => { { let __seq_res = match __parse_transforms ( __input , __state , __pos , renderOptions ) { Matched ( __newpos , __value ) => { Matched ( __newpos , Some ( __value ) ) } , Failed => { Matched ( __pos , None ) } , } ; match __seq_res { Matched ( __pos , transform ) => { { let __seq_res = __parse_CLOSE_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { Matched ( __pos , { [INFO] [stderr] | ^^^^^ help: use `dyn`: `dyn Shape` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> /opt/crater/target/debug/build/raytracer-8cce5711dbbe16ea/out/sdl_grammar.rs:115:163 [INFO] [stderr] | [INFO] [stderr] 115 | fn __parse_cylinder < 'input > ( __input : & 'input str , __state : & mut ParseState < 'input > , __pos : usize , renderOptions : &Options ) -> RuleResult < Box > { # ! [ allow ( non_snake_case , unused ) ] { let __seq_res = { let __seq_res = { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = slice_eq ( __input , __state , __pos , "cylinder" ) ; match __seq_res { Matched ( __pos , _ ) => { { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } } Failed => Failed , } } } Failed => Failed , } } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_OPEN_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = match __parse_radius ( __input , __state , __pos , renderOptions ) { Matched ( __newpos , __value ) => { Matched ( __newpos , Some ( __value ) ) } , Failed => { Matched ( __pos , None ) } , } ; match __seq_res { Matched ( __pos , r ) => { { let __seq_res = match __parse_height ( __input , __state , __pos , renderOptions ) { Matched ( __newpos , __value ) => { Matched ( __newpos , Some ( __value ) ) } , Failed => { Matched ( __pos , None ) } , } ; match __seq_res { Matched ( __pos , h ) => { { let __seq_res = match __parse_transforms ( __input , __state , __pos , renderOptions ) { Matched ( __newpos , __value ) => { Matched ( __newpos , Some ( __value ) ) } , Failed => { Matched ( __pos , None ) } , } ; match __seq_res { Matched ( __pos , transform ) => { { let __seq_res = __parse_CLOSE_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { Matched ( __pos , { [INFO] [stderr] | ^^^^^ help: use `dyn`: `dyn Shape` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> /opt/crater/target/debug/build/raytracer-8cce5711dbbe16ea/out/sdl_grammar.rs:119:160 [INFO] [stderr] | [INFO] [stderr] 119 | fn __parse_torus < 'input > ( __input : & 'input str , __state : & mut ParseState < 'input > , __pos : usize , renderOptions : &Options ) -> RuleResult < Box > { # ! [ allow ( non_snake_case , unused ) ] { let __seq_res = { let __seq_res = { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = slice_eq ( __input , __state , __pos , "torus" ) ; match __seq_res { Matched ( __pos , _ ) => { { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } } Failed => Failed , } } } Failed => Failed , } } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_OPEN_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_radius ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , r1 ) => { { let __seq_res = __parse_radius ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , r2 ) => { { let __seq_res = match __parse_transforms ( __input , __state , __pos , renderOptions ) { Matched ( __newpos , __value ) => { Matched ( __newpos , Some ( __value ) ) } , Failed => { Matched ( __pos , None ) } , } ; match __seq_res { Matched ( __pos , transform ) => { { let __seq_res = __parse_CLOSE_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { Matched ( __pos , { [INFO] [stderr] | ^^^^^ help: use `dyn`: `dyn Shape` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> /opt/crater/target/debug/build/raytracer-8cce5711dbbe16ea/out/sdl_grammar.rs:123:160 [INFO] [stderr] | [INFO] [stderr] 123 | fn __parse_plane < 'input > ( __input : & 'input str , __state : & mut ParseState < 'input > , __pos : usize , renderOptions : &Options ) -> RuleResult < Box > { # ! [ allow ( non_snake_case , unused ) ] { let __seq_res = { let __seq_res = { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = slice_eq ( __input , __state , __pos , "plane" ) ; match __seq_res { Matched ( __pos , _ ) => { { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } } Failed => Failed , } } } Failed => Failed , } } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_OPEN_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = match __parse_origin ( __input , __state , __pos , renderOptions ) { Matched ( __newpos , __value ) => { Matched ( __newpos , Some ( __value ) ) } , Failed => { Matched ( __pos , None ) } , } ; match __seq_res { Matched ( __pos , o ) => { { let __seq_res = __parse_plane_normal ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , n ) => { { let __seq_res = match __parse_transforms ( __input , __state , __pos , renderOptions ) { Matched ( __newpos , __value ) => { Matched ( __newpos , Some ( __value ) ) } , Failed => { Matched ( __pos , None ) } , } ; match __seq_res { Matched ( __pos , transform ) => { { let __seq_res = __parse_CLOSE_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { Matched ( __pos , { [INFO] [stderr] | ^^^^^ help: use `dyn`: `dyn Shape` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> /opt/crater/target/debug/build/raytracer-8cce5711dbbe16ea/out/sdl_grammar.rs:131:159 [INFO] [stderr] | [INFO] [stderr] 131 | fn __parse_mesh < 'input > ( __input : & 'input str , __state : & mut ParseState < 'input > , __pos : usize , renderOptions : &Options ) -> RuleResult < Box > { # ! [ allow ( non_snake_case , unused ) ] { let __seq_res = { let __seq_res = { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = slice_eq ( __input , __state , __pos , "mesh" ) ; match __seq_res { Matched ( __pos , _ ) => { { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } } Failed => Failed , } } } Failed => Failed , } } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_OPEN_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_mesh_file ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , p ) => { { let __seq_res = match __parse_transforms ( __input , __state , __pos , renderOptions ) { Matched ( __newpos , __value ) => { Matched ( __newpos , Some ( __value ) ) } , Failed => { Matched ( __pos , None ) } , } ; match __seq_res { Matched ( __pos , transform ) => { { let __seq_res = __parse_CLOSE_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { Matched ( __pos , { [INFO] [stderr] | ^^^^^ help: use `dyn`: `dyn Shape` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> /opt/crater/target/debug/build/raytracer-8cce5711dbbe16ea/out/sdl_grammar.rs:137:161 [INFO] [stderr] | [INFO] [stderr] 137 | fn __parse_xyrect < 'input > ( __input : & 'input str , __state : & mut ParseState < 'input > , __pos : usize , renderOptions : &Options ) -> RuleResult < Box > { # ! [ allow ( non_snake_case , unused ) ] { let __seq_res = { let __seq_res = { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = slice_eq ( __input , __state , __pos , "xyrect" ) ; match __seq_res { Matched ( __pos , _ ) => { { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } } Failed => Failed , } } } Failed => Failed , } } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_OPEN_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = match __parse_origin ( __input , __state , __pos , renderOptions ) { Matched ( __newpos , __value ) => { Matched ( __newpos , Some ( __value ) ) } , Failed => { Matched ( __pos , None ) } , } ; match __seq_res { Matched ( __pos , o ) => { { let __seq_res = __parse_width ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , w ) => { { let __seq_res = __parse_height ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , h ) => { { let __seq_res = match __parse_reverse ( __input , __state , __pos , renderOptions ) { Matched ( __newpos , __value ) => { Matched ( __newpos , Some ( __value ) ) } , Failed => { Matched ( __pos , None ) } , } ; match __seq_res { Matched ( __pos , r ) => { { let __seq_res = match __parse_transforms ( __input , __state , __pos , renderOptions ) { Matched ( __newpos , __value ) => { Matched ( __newpos , Some ( __value ) ) } , Failed => { Matched ( __pos , None ) } , } ; match __seq_res { Matched ( __pos , transform ) => { { let __seq_res = __parse_CLOSE_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { Matched ( __pos , { [INFO] [stderr] | ^^^^^ help: use `dyn`: `dyn Shape` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> /opt/crater/target/debug/build/raytracer-8cce5711dbbe16ea/out/sdl_grammar.rs:141:161 [INFO] [stderr] | [INFO] [stderr] 141 | fn __parse_xzrect < 'input > ( __input : & 'input str , __state : & mut ParseState < 'input > , __pos : usize , renderOptions : &Options ) -> RuleResult < Box > { # ! [ allow ( non_snake_case , unused ) ] { let __seq_res = { let __seq_res = { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = slice_eq ( __input , __state , __pos , "xzrect" ) ; match __seq_res { Matched ( __pos , _ ) => { { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } } Failed => Failed , } } } Failed => Failed , } } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_OPEN_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = match __parse_origin ( __input , __state , __pos , renderOptions ) { Matched ( __newpos , __value ) => { Matched ( __newpos , Some ( __value ) ) } , Failed => { Matched ( __pos , None ) } , } ; match __seq_res { Matched ( __pos , o ) => { { let __seq_res = __parse_width ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , w ) => { { let __seq_res = __parse_height ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , h ) => { { let __seq_res = match __parse_reverse ( __input , __state , __pos , renderOptions ) { Matched ( __newpos , __value ) => { Matched ( __newpos , Some ( __value ) ) } , Failed => { Matched ( __pos , None ) } , } ; match __seq_res { Matched ( __pos , r ) => { { let __seq_res = match __parse_transforms ( __input , __state , __pos , renderOptions ) { Matched ( __newpos , __value ) => { Matched ( __newpos , Some ( __value ) ) } , Failed => { Matched ( __pos , None ) } , } ; match __seq_res { Matched ( __pos , transform ) => { { let __seq_res = __parse_CLOSE_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { Matched ( __pos , { [INFO] [stderr] | ^^^^^ help: use `dyn`: `dyn Shape` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> /opt/crater/target/debug/build/raytracer-8cce5711dbbe16ea/out/sdl_grammar.rs:145:161 [INFO] [stderr] | [INFO] [stderr] 145 | fn __parse_zyrect < 'input > ( __input : & 'input str , __state : & mut ParseState < 'input > , __pos : usize , renderOptions : &Options ) -> RuleResult < Box > { # ! [ allow ( non_snake_case , unused ) ] { let __seq_res = { let __seq_res = { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = slice_eq ( __input , __state , __pos , "zyrect" ) ; match __seq_res { Matched ( __pos , _ ) => { { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } } Failed => Failed , } } } Failed => Failed , } } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_OPEN_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = match __parse_origin ( __input , __state , __pos , renderOptions ) { Matched ( __newpos , __value ) => { Matched ( __newpos , Some ( __value ) ) } , Failed => { Matched ( __pos , None ) } , } ; match __seq_res { Matched ( __pos , o ) => { { let __seq_res = __parse_width ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , w ) => { { let __seq_res = __parse_height ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , h ) => { { let __seq_res = match __parse_reverse ( __input , __state , __pos , renderOptions ) { Matched ( __newpos , __value ) => { Matched ( __newpos , Some ( __value ) ) } , Failed => { Matched ( __pos , None ) } , } ; match __seq_res { Matched ( __pos , r ) => { { let __seq_res = match __parse_transforms ( __input , __state , __pos , renderOptions ) { Matched ( __newpos , __value ) => { Matched ( __newpos , Some ( __value ) ) } , Failed => { Matched ( __pos , None ) } , } ; match __seq_res { Matched ( __pos , transform ) => { { let __seq_res = __parse_CLOSE_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { Matched ( __pos , { [INFO] [stderr] | ^^^^^ help: use `dyn`: `dyn Shape` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> /opt/crater/target/debug/build/raytracer-8cce5711dbbe16ea/out/sdl_grammar.rs:155:159 [INFO] [stderr] | [INFO] [stderr] 155 | fn __parse_cube < 'input > ( __input : & 'input str , __state : & mut ParseState < 'input > , __pos : usize , renderOptions : &Options ) -> RuleResult < Box > { # ! [ allow ( non_snake_case , unused ) ] { let __seq_res = { let __seq_res = { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = slice_eq ( __input , __state , __pos , "cube" ) ; match __seq_res { Matched ( __pos , _ ) => { { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } } Failed => Failed , } } } Failed => Failed , } } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_OPEN_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_point ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , p1 ) => { { let __seq_res = __parse_point ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , p2 ) => { { let __seq_res = match __parse_transforms ( __input , __state , __pos , renderOptions ) { Matched ( __newpos , __value ) => { Matched ( __newpos , Some ( __value ) ) } , Failed => { Matched ( __pos , None ) } , } ; match __seq_res { Matched ( __pos , transform ) => { { let __seq_res = __parse_CLOSE_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { Matched ( __pos , { [INFO] [stderr] | ^^^^^ help: use `dyn`: `dyn Shape` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> /opt/crater/target/debug/build/raytracer-8cce5711dbbe16ea/out/sdl_grammar.rs:159:172 [INFO] [stderr] | [INFO] [stderr] 159 | fn __parse_homogenous_medium < 'input > ( __input : & 'input str , __state : & mut ParseState < 'input > , __pos : usize , renderOptions : &Options ) -> RuleResult < Box > { # ! [ allow ( non_snake_case , unused ) ] { let __seq_res = { let __seq_res = { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = slice_eq ( __input , __state , __pos , "homogenous_medium" ) ; match __seq_res { Matched ( __pos , _ ) => { { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } } Failed => Failed , } } } Failed => Failed , } } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_OPEN_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_density ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , density ) => { { let __seq_res = __parse_solid_shape ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , boundary ) => { { let __seq_res = match __parse_transforms ( __input , __state , __pos , renderOptions ) { Matched ( __newpos , __value ) => { Matched ( __newpos , Some ( __value ) ) } , Failed => { Matched ( __pos , None ) } , } ; match __seq_res { Matched ( __pos , transform ) => { { let __seq_res = __parse_CLOSE_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { Matched ( __pos , { [INFO] [stderr] | ^^^^^ help: use `dyn`: `dyn Shape` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> /opt/crater/target/debug/build/raytracer-8cce5711dbbe16ea/out/sdl_grammar.rs:167:170 [INFO] [stderr] | [INFO] [stderr] 167 | fn __parse_object_material < 'input > ( __input : & 'input str , __state : & mut ParseState < 'input > , __pos : usize , renderOptions : &Options ) -> RuleResult < Box > { # ! [ allow ( non_snake_case , unused ) ] { let __seq_res = { let __seq_res = { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = slice_eq ( __input , __state , __pos , "material" ) ; match __seq_res { Matched ( __pos , _ ) => { { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } } Failed => Failed , } } } Failed => Failed , } } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_OPEN_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_material ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , material ) => { { let __seq_res = __parse_CLOSE_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { Matched ( __pos , { [INFO] [stderr] | ^^^^^^^^ help: use `dyn`: `dyn Material` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> /opt/crater/target/debug/build/raytracer-8cce5711dbbe16ea/out/sdl_grammar.rs:171:163 [INFO] [stderr] | [INFO] [stderr] 171 | fn __parse_material < 'input > ( __input : & 'input str , __state : & mut ParseState < 'input > , __pos : usize , renderOptions : &Options ) -> RuleResult < Box > { # ! [ allow ( non_snake_case , unused ) ] { let __choice_res = __parse_lambertian ( __input , __state , __pos , renderOptions ) ; match __choice_res { Matched ( __pos , __value ) => Matched ( __pos , __value ) , Failed => { let __choice_res = __parse_metal ( __input , __state , __pos , renderOptions ) ; match __choice_res { Matched ( __pos , __value ) => Matched ( __pos , __value ) , Failed => { let __choice_res = __parse_dielectric ( __input , __state , __pos , renderOptions ) ; match __choice_res { Matched ( __pos , __value ) => Matched ( __pos , __value ) , Failed => { let __choice_res = __parse_diffuse_light ( __input , __state , __pos , renderOptions ) ; match __choice_res { Matched ( __pos , __value ) => Matched ( __pos , __value ) , Failed => __parse_isotropic ( __input , __state , __pos , renderOptions ) } } } } } } } } } [INFO] [stderr] | ^^^^^^^^ help: use `dyn`: `dyn Material` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> /opt/crater/target/debug/build/raytracer-8cce5711dbbe16ea/out/sdl_grammar.rs:173:165 [INFO] [stderr] | [INFO] [stderr] 173 | fn __parse_lambertian < 'input > ( __input : & 'input str , __state : & mut ParseState < 'input > , __pos : usize , renderOptions : &Options ) -> RuleResult < Box > { # ! [ allow ( non_snake_case , unused ) ] { let __seq_res = { let __seq_res = { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = slice_eq ( __input , __state , __pos , "lambertian" ) ; match __seq_res { Matched ( __pos , _ ) => { { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } } Failed => Failed , } } } Failed => Failed , } } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_texture ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , texture ) => { Matched ( __pos , { [INFO] [stderr] | ^^^^^^^^ help: use `dyn`: `dyn Material` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> /opt/crater/target/debug/build/raytracer-8cce5711dbbe16ea/out/sdl_grammar.rs:177:160 [INFO] [stderr] | [INFO] [stderr] 177 | fn __parse_metal < 'input > ( __input : & 'input str , __state : & mut ParseState < 'input > , __pos : usize , renderOptions : &Options ) -> RuleResult < Box > { # ! [ allow ( non_snake_case , unused ) ] { let __seq_res = { let __seq_res = { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = slice_eq ( __input , __state , __pos , "metal" ) ; match __seq_res { Matched ( __pos , _ ) => { { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } } Failed => Failed , } } } Failed => Failed , } } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_fuzz ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , fuzz ) => { { let __seq_res = __parse_texture ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , texture ) => { Matched ( __pos , { [INFO] [stderr] | ^^^^^^^^ help: use `dyn`: `dyn Material` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> /opt/crater/target/debug/build/raytracer-8cce5711dbbe16ea/out/sdl_grammar.rs:183:165 [INFO] [stderr] | [INFO] [stderr] 183 | fn __parse_dielectric < 'input > ( __input : & 'input str , __state : & mut ParseState < 'input > , __pos : usize , renderOptions : &Options ) -> RuleResult < Box > { # ! [ allow ( non_snake_case , unused ) ] { let __seq_res = { let __seq_res = { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = slice_eq ( __input , __state , __pos , "dielectric" ) ; match __seq_res { Matched ( __pos , _ ) => { { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } } Failed => Failed , } } } Failed => Failed , } } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_ior ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , ior ) => { { let __seq_res = match __parse_fuzz ( __input , __state , __pos , renderOptions ) { Matched ( __newpos , __value ) => { Matched ( __newpos , Some ( __value ) ) } , Failed => { Matched ( __pos , None ) } , } ; match __seq_res { Matched ( __pos , fuzz ) => { Matched ( __pos , { [INFO] [stderr] | ^^^^^^^^ help: use `dyn`: `dyn Material` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> /opt/crater/target/debug/build/raytracer-8cce5711dbbe16ea/out/sdl_grammar.rs:189:168 [INFO] [stderr] | [INFO] [stderr] 189 | fn __parse_diffuse_light < 'input > ( __input : & 'input str , __state : & mut ParseState < 'input > , __pos : usize , renderOptions : &Options ) -> RuleResult < Box > { # ! [ allow ( non_snake_case , unused ) ] { let __seq_res = { let __seq_res = { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = slice_eq ( __input , __state , __pos , "diffuse_light" ) ; match __seq_res { Matched ( __pos , _ ) => { { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } } Failed => Failed , } } } Failed => Failed , } } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_intensity ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , i ) => { { let __seq_res = __parse_texture ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , texture ) => { Matched ( __pos , { [INFO] [stderr] | ^^^^^^^^ help: use `dyn`: `dyn Material` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> /opt/crater/target/debug/build/raytracer-8cce5711dbbe16ea/out/sdl_grammar.rs:197:164 [INFO] [stderr] | [INFO] [stderr] 197 | fn __parse_isotropic < 'input > ( __input : & 'input str , __state : & mut ParseState < 'input > , __pos : usize , renderOptions : &Options ) -> RuleResult < Box > { # ! [ allow ( non_snake_case , unused ) ] { let __seq_res = { let __seq_res = { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = slice_eq ( __input , __state , __pos , "isotropic" ) ; match __seq_res { Matched ( __pos , _ ) => { { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } } Failed => Failed , } } } Failed => Failed , } } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_texture ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , texture ) => { Matched ( __pos , { [INFO] [stderr] | ^^^^^^^^ help: use `dyn`: `dyn Material` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> /opt/crater/target/debug/build/raytracer-8cce5711dbbe16ea/out/sdl_grammar.rs:89:167 [INFO] [stderr] | [INFO] [stderr] 89 | fn __parse_object_shape < 'input > ( __input : & 'input str , __state : & mut ParseState < 'input > , __pos : usize , renderOptions : &Options ) -> RuleResult < Box > { # ! [ allow ( non_snake_case , unused ) ] { let __choice_res = __parse_planar_shape ( __input , __state , __pos , renderOptions ) ; match __choice_res { Matched ( __pos , __value ) => Matched ( __pos , __value ) , Failed => { let __choice_res = __parse_solid_shape ( __input , __state , __pos , renderOptions ) ; match __choice_res { Matched ( __pos , __value ) => Matched ( __pos , __value ) , Failed => __parse_mesh ( __input , __state , __pos , renderOptions ) } } } } } [INFO] [stderr] | ^^^^^ help: use `dyn`: `dyn Shape` [INFO] [stderr] | [INFO] [stderr] = note: #[warn(bare_trait_objects)] on by default [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> /opt/crater/target/debug/build/raytracer-8cce5711dbbe16ea/out/sdl_grammar.rs:91:167 [INFO] [stderr] | [INFO] [stderr] 91 | fn __parse_planar_shape < 'input > ( __input : & 'input str , __state : & mut ParseState < 'input > , __pos : usize , renderOptions : &Options ) -> RuleResult < Box > { # ! [ allow ( non_snake_case , unused ) ] { let __choice_res = __parse_plane ( __input , __state , __pos , renderOptions ) ; match __choice_res { Matched ( __pos , __value ) => Matched ( __pos , __value ) , Failed => { let __choice_res = __parse_xyrect ( __input , __state , __pos , renderOptions ) ; match __choice_res { Matched ( __pos , __value ) => Matched ( __pos , __value ) , Failed => { let __choice_res = __parse_xzrect ( __input , __state , __pos , renderOptions ) ; match __choice_res { Matched ( __pos , __value ) => Matched ( __pos , __value ) , Failed => __parse_zyrect ( __input , __state , __pos , renderOptions ) } } } } } } } [INFO] [stderr] | ^^^^^ help: use `dyn`: `dyn Shape` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> /opt/crater/target/debug/build/raytracer-8cce5711dbbe16ea/out/sdl_grammar.rs:93:166 [INFO] [stderr] | [INFO] [stderr] 93 | fn __parse_solid_shape < 'input > ( __input : & 'input str , __state : & mut ParseState < 'input > , __pos : usize , renderOptions : &Options ) -> RuleResult < Box > { # ! [ allow ( non_snake_case , unused ) ] { let __choice_res = __parse_sphere ( __input , __state , __pos , renderOptions ) ; match __choice_res { Matched ( __pos , __value ) => Matched ( __pos , __value ) , Failed => { let __choice_res = __parse_cylinder ( __input , __state , __pos , renderOptions ) ; match __choice_res { Matched ( __pos , __value ) => Matched ( __pos , __value ) , Failed => { let __choice_res = __parse_torus ( __input , __state , __pos , renderOptions ) ; match __choice_res { Matched ( __pos , __value ) => Matched ( __pos , __value ) , Failed => { let __choice_res = __parse_cube ( __input , __state , __pos , renderOptions ) ; match __choice_res { Matched ( __pos , __value ) => Matched ( __pos , __value ) , Failed => { let __choice_res = __parse_csg ( __input , __state , __pos , renderOptions ) ; match __choice_res { Matched ( __pos , __value ) => Matched ( __pos , __value ) , Failed => __parse_homogenous_medium ( __input , __state , __pos , renderOptions ) } } } } } } } } } } } [INFO] [stderr] | ^^^^^ help: use `dyn`: `dyn Shape` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> /opt/crater/target/debug/build/raytracer-8cce5711dbbe16ea/out/sdl_grammar.rs:95:158 [INFO] [stderr] | [INFO] [stderr] 95 | fn __parse_csg < 'input > ( __input : & 'input str , __state : & mut ParseState < 'input > , __pos : usize , renderOptions : &Options ) -> RuleResult < Box > { # ! [ allow ( non_snake_case , unused ) ] { let __choice_res = __parse_csg_union ( __input , __state , __pos , renderOptions ) ; match __choice_res { Matched ( __pos , __value ) => Matched ( __pos , __value ) , Failed => { let __choice_res = __parse_csg_intersection ( __input , __state , __pos , renderOptions ) ; match __choice_res { Matched ( __pos , __value ) => Matched ( __pos , __value ) , Failed => __parse_csg_difference ( __input , __state , __pos , renderOptions ) } } } } } [INFO] [stderr] | ^^^^^ help: use `dyn`: `dyn Shape` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> /opt/crater/target/debug/build/raytracer-8cce5711dbbe16ea/out/sdl_grammar.rs:97:164 [INFO] [stderr] | [INFO] [stderr] 97 | fn __parse_csg_union < 'input > ( __input : & 'input str , __state : & mut ParseState < 'input > , __pos : usize , renderOptions : &Options ) -> RuleResult < Box > { # ! [ allow ( non_snake_case , unused ) ] { let __seq_res = { let __seq_res = { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = slice_eq ( __input , __state , __pos , "union" ) ; match __seq_res { Matched ( __pos , _ ) => { { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } } Failed => Failed , } } } Failed => Failed , } } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_OPEN_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_solid_shape ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , a ) => { { let __seq_res = __parse_solid_shape ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , b ) => { { let __seq_res = match __parse_transforms ( __input , __state , __pos , renderOptions ) { Matched ( __newpos , __value ) => { Matched ( __newpos , Some ( __value ) ) } , Failed => { Matched ( __pos , None ) } , } ; match __seq_res { Matched ( __pos , transform ) => { { let __seq_res = __parse_CLOSE_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { Matched ( __pos , { [INFO] [stderr] | ^^^^^ help: use `dyn`: `dyn Shape` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> /opt/crater/target/debug/build/raytracer-8cce5711dbbe16ea/out/sdl_grammar.rs:101:171 [INFO] [stderr] | [INFO] [stderr] 101 | fn __parse_csg_intersection < 'input > ( __input : & 'input str , __state : & mut ParseState < 'input > , __pos : usize , renderOptions : &Options ) -> RuleResult < Box > { # ! [ allow ( non_snake_case , unused ) ] { let __seq_res = { let __seq_res = { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = slice_eq ( __input , __state , __pos , "intersection" ) ; match __seq_res { Matched ( __pos , _ ) => { { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } } Failed => Failed , } } } Failed => Failed , } } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_OPEN_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_solid_shape ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , a ) => { { let __seq_res = __parse_solid_shape ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , b ) => { { let __seq_res = match __parse_transforms ( __input , __state , __pos , renderOptions ) { Matched ( __newpos , __value ) => { Matched ( __newpos , Some ( __value ) ) } , Failed => { Matched ( __pos , None ) } , } ; match __seq_res { Matched ( __pos , transform ) => { { let __seq_res = __parse_CLOSE_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { Matched ( __pos , { [INFO] [stderr] | ^^^^^ help: use `dyn`: `dyn Shape` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> /opt/crater/target/debug/build/raytracer-8cce5711dbbe16ea/out/sdl_grammar.rs:105:169 [INFO] [stderr] | [INFO] [stderr] 105 | fn __parse_csg_difference < 'input > ( __input : & 'input str , __state : & mut ParseState < 'input > , __pos : usize , renderOptions : &Options ) -> RuleResult < Box > { # ! [ allow ( non_snake_case , unused ) ] { let __seq_res = { let __seq_res = { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = slice_eq ( __input , __state , __pos , "difference" ) ; match __seq_res { Matched ( __pos , _ ) => { { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } } Failed => Failed , } } } Failed => Failed , } } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_OPEN_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_solid_shape ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , a ) => { { let __seq_res = __parse_solid_shape ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , b ) => { { let __seq_res = match __parse_transforms ( __input , __state , __pos , renderOptions ) { Matched ( __newpos , __value ) => { Matched ( __newpos , Some ( __value ) ) } , Failed => { Matched ( __pos , None ) } , } ; match __seq_res { Matched ( __pos , transform ) => { { let __seq_res = __parse_CLOSE_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { Matched ( __pos , { [INFO] [stderr] | ^^^^^ help: use `dyn`: `dyn Shape` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> /opt/crater/target/debug/build/raytracer-8cce5711dbbe16ea/out/sdl_grammar.rs:109:161 [INFO] [stderr] | [INFO] [stderr] 109 | fn __parse_sphere < 'input > ( __input : & 'input str , __state : & mut ParseState < 'input > , __pos : usize , renderOptions : &Options ) -> RuleResult < Box > { # ! [ allow ( non_snake_case , unused ) ] { let __seq_res = { let __seq_res = { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = slice_eq ( __input , __state , __pos , "sphere" ) ; match __seq_res { Matched ( __pos , _ ) => { { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } } Failed => Failed , } } } Failed => Failed , } } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_OPEN_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = match __parse_origin ( __input , __state , __pos , renderOptions ) { Matched ( __newpos , __value ) => { Matched ( __newpos , Some ( __value ) ) } , Failed => { Matched ( __pos , None ) } , } ; match __seq_res { Matched ( __pos , o ) => { { let __seq_res = match __parse_radius ( __input , __state , __pos , renderOptions ) { Matched ( __newpos , __value ) => { Matched ( __newpos , Some ( __value ) ) } , Failed => { Matched ( __pos , None ) } , } ; match __seq_res { Matched ( __pos , r ) => { { let __seq_res = match __parse_transforms ( __input , __state , __pos , renderOptions ) { Matched ( __newpos , __value ) => { Matched ( __newpos , Some ( __value ) ) } , Failed => { Matched ( __pos , None ) } , } ; match __seq_res { Matched ( __pos , transform ) => { { let __seq_res = __parse_CLOSE_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { Matched ( __pos , { [INFO] [stderr] | ^^^^^ help: use `dyn`: `dyn Shape` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> /opt/crater/target/debug/build/raytracer-8cce5711dbbe16ea/out/sdl_grammar.rs:115:163 [INFO] [stderr] | [INFO] [stderr] 115 | fn __parse_cylinder < 'input > ( __input : & 'input str , __state : & mut ParseState < 'input > , __pos : usize , renderOptions : &Options ) -> RuleResult < Box > { # ! [ allow ( non_snake_case , unused ) ] { let __seq_res = { let __seq_res = { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = slice_eq ( __input , __state , __pos , "cylinder" ) ; match __seq_res { Matched ( __pos , _ ) => { { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } } Failed => Failed , } } } Failed => Failed , } } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_OPEN_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = match __parse_radius ( __input , __state , __pos , renderOptions ) { Matched ( __newpos , __value ) => { Matched ( __newpos , Some ( __value ) ) } , Failed => { Matched ( __pos , None ) } , } ; match __seq_res { Matched ( __pos , r ) => { { let __seq_res = match __parse_height ( __input , __state , __pos , renderOptions ) { Matched ( __newpos , __value ) => { Matched ( __newpos , Some ( __value ) ) } , Failed => { Matched ( __pos , None ) } , } ; match __seq_res { Matched ( __pos , h ) => { { let __seq_res = match __parse_transforms ( __input , __state , __pos , renderOptions ) { Matched ( __newpos , __value ) => { Matched ( __newpos , Some ( __value ) ) } , Failed => { Matched ( __pos , None ) } , } ; match __seq_res { Matched ( __pos , transform ) => { { let __seq_res = __parse_CLOSE_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { Matched ( __pos , { [INFO] [stderr] | ^^^^^ help: use `dyn`: `dyn Shape` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> /opt/crater/target/debug/build/raytracer-8cce5711dbbe16ea/out/sdl_grammar.rs:119:160 [INFO] [stderr] | [INFO] [stderr] 119 | fn __parse_torus < 'input > ( __input : & 'input str , __state : & mut ParseState < 'input > , __pos : usize , renderOptions : &Options ) -> RuleResult < Box > { # ! [ allow ( non_snake_case , unused ) ] { let __seq_res = { let __seq_res = { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = slice_eq ( __input , __state , __pos , "torus" ) ; match __seq_res { Matched ( __pos , _ ) => { { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } } Failed => Failed , } } } Failed => Failed , } } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_OPEN_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_radius ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , r1 ) => { { let __seq_res = __parse_radius ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , r2 ) => { { let __seq_res = match __parse_transforms ( __input , __state , __pos , renderOptions ) { Matched ( __newpos , __value ) => { Matched ( __newpos , Some ( __value ) ) } , Failed => { Matched ( __pos , None ) } , } ; match __seq_res { Matched ( __pos , transform ) => { { let __seq_res = __parse_CLOSE_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { Matched ( __pos , { [INFO] [stderr] | ^^^^^ help: use `dyn`: `dyn Shape` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> /opt/crater/target/debug/build/raytracer-8cce5711dbbe16ea/out/sdl_grammar.rs:123:160 [INFO] [stderr] | [INFO] [stderr] 123 | fn __parse_plane < 'input > ( __input : & 'input str , __state : & mut ParseState < 'input > , __pos : usize , renderOptions : &Options ) -> RuleResult < Box > { # ! [ allow ( non_snake_case , unused ) ] { let __seq_res = { let __seq_res = { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = slice_eq ( __input , __state , __pos , "plane" ) ; match __seq_res { Matched ( __pos , _ ) => { { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } } Failed => Failed , } } } Failed => Failed , } } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_OPEN_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = match __parse_origin ( __input , __state , __pos , renderOptions ) { Matched ( __newpos , __value ) => { Matched ( __newpos , Some ( __value ) ) } , Failed => { Matched ( __pos , None ) } , } ; match __seq_res { Matched ( __pos , o ) => { { let __seq_res = __parse_plane_normal ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , n ) => { { let __seq_res = match __parse_transforms ( __input , __state , __pos , renderOptions ) { Matched ( __newpos , __value ) => { Matched ( __newpos , Some ( __value ) ) } , Failed => { Matched ( __pos , None ) } , } ; match __seq_res { Matched ( __pos , transform ) => { { let __seq_res = __parse_CLOSE_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { Matched ( __pos , { [INFO] [stderr] | ^^^^^ help: use `dyn`: `dyn Shape` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> /opt/crater/target/debug/build/raytracer-8cce5711dbbe16ea/out/sdl_grammar.rs:131:159 [INFO] [stderr] | [INFO] [stderr] 131 | fn __parse_mesh < 'input > ( __input : & 'input str , __state : & mut ParseState < 'input > , __pos : usize , renderOptions : &Options ) -> RuleResult < Box > { # ! [ allow ( non_snake_case , unused ) ] { let __seq_res = { let __seq_res = { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = slice_eq ( __input , __state , __pos , "mesh" ) ; match __seq_res { Matched ( __pos , _ ) => { { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } } Failed => Failed , } } } Failed => Failed , } } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_OPEN_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_mesh_file ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , p ) => { { let __seq_res = match __parse_transforms ( __input , __state , __pos , renderOptions ) { Matched ( __newpos , __value ) => { Matched ( __newpos , Some ( __value ) ) } , Failed => { Matched ( __pos , None ) } , } ; match __seq_res { Matched ( __pos , transform ) => { { let __seq_res = __parse_CLOSE_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { Matched ( __pos , { [INFO] [stderr] | ^^^^^ help: use `dyn`: `dyn Shape` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> /opt/crater/target/debug/build/raytracer-8cce5711dbbe16ea/out/sdl_grammar.rs:137:161 [INFO] [stderr] | [INFO] [stderr] 137 | fn __parse_xyrect < 'input > ( __input : & 'input str , __state : & mut ParseState < 'input > , __pos : usize , renderOptions : &Options ) -> RuleResult < Box > { # ! [ allow ( non_snake_case , unused ) ] { let __seq_res = { let __seq_res = { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = slice_eq ( __input , __state , __pos , "xyrect" ) ; match __seq_res { Matched ( __pos , _ ) => { { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } } Failed => Failed , } } } Failed => Failed , } } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_OPEN_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = match __parse_origin ( __input , __state , __pos , renderOptions ) { Matched ( __newpos , __value ) => { Matched ( __newpos , Some ( __value ) ) } , Failed => { Matched ( __pos , None ) } , } ; match __seq_res { Matched ( __pos , o ) => { { let __seq_res = __parse_width ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , w ) => { { let __seq_res = __parse_height ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , h ) => { { let __seq_res = match __parse_reverse ( __input , __state , __pos , renderOptions ) { Matched ( __newpos , __value ) => { Matched ( __newpos , Some ( __value ) ) } , Failed => { Matched ( __pos , None ) } , } ; match __seq_res { Matched ( __pos , r ) => { { let __seq_res = match __parse_transforms ( __input , __state , __pos , renderOptions ) { Matched ( __newpos , __value ) => { Matched ( __newpos , Some ( __value ) ) } , Failed => { Matched ( __pos , None ) } , } ; match __seq_res { Matched ( __pos , transform ) => { { let __seq_res = __parse_CLOSE_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { Matched ( __pos , { [INFO] [stderr] | ^^^^^ help: use `dyn`: `dyn Shape` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> /opt/crater/target/debug/build/raytracer-8cce5711dbbe16ea/out/sdl_grammar.rs:141:161 [INFO] [stderr] | [INFO] [stderr] 141 | fn __parse_xzrect < 'input > ( __input : & 'input str , __state : & mut ParseState < 'input > , __pos : usize , renderOptions : &Options ) -> RuleResult < Box > { # ! [ allow ( non_snake_case , unused ) ] { let __seq_res = { let __seq_res = { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = slice_eq ( __input , __state , __pos , "xzrect" ) ; match __seq_res { Matched ( __pos , _ ) => { { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } } Failed => Failed , } } } Failed => Failed , } } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_OPEN_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = match __parse_origin ( __input , __state , __pos , renderOptions ) { Matched ( __newpos , __value ) => { Matched ( __newpos , Some ( __value ) ) } , Failed => { Matched ( __pos , None ) } , } ; match __seq_res { Matched ( __pos , o ) => { { let __seq_res = __parse_width ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , w ) => { { let __seq_res = __parse_height ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , h ) => { { let __seq_res = match __parse_reverse ( __input , __state , __pos , renderOptions ) { Matched ( __newpos , __value ) => { Matched ( __newpos , Some ( __value ) ) } , Failed => { Matched ( __pos , None ) } , } ; match __seq_res { Matched ( __pos , r ) => { { let __seq_res = match __parse_transforms ( __input , __state , __pos , renderOptions ) { Matched ( __newpos , __value ) => { Matched ( __newpos , Some ( __value ) ) } , Failed => { Matched ( __pos , None ) } , } ; match __seq_res { Matched ( __pos , transform ) => { { let __seq_res = __parse_CLOSE_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { Matched ( __pos , { [INFO] [stderr] | ^^^^^ help: use `dyn`: `dyn Shape` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> /opt/crater/target/debug/build/raytracer-8cce5711dbbe16ea/out/sdl_grammar.rs:145:161 [INFO] [stderr] | [INFO] [stderr] 145 | fn __parse_zyrect < 'input > ( __input : & 'input str , __state : & mut ParseState < 'input > , __pos : usize , renderOptions : &Options ) -> RuleResult < Box > { # ! [ allow ( non_snake_case , unused ) ] { let __seq_res = { let __seq_res = { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = slice_eq ( __input , __state , __pos , "zyrect" ) ; match __seq_res { Matched ( __pos , _ ) => { { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } } Failed => Failed , } } } Failed => Failed , } } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_OPEN_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = match __parse_origin ( __input , __state , __pos , renderOptions ) { Matched ( __newpos , __value ) => { Matched ( __newpos , Some ( __value ) ) } , Failed => { Matched ( __pos , None ) } , } ; match __seq_res { Matched ( __pos , o ) => { { let __seq_res = __parse_width ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , w ) => { { let __seq_res = __parse_height ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , h ) => { { let __seq_res = match __parse_reverse ( __input , __state , __pos , renderOptions ) { Matched ( __newpos , __value ) => { Matched ( __newpos , Some ( __value ) ) } , Failed => { Matched ( __pos , None ) } , } ; match __seq_res { Matched ( __pos , r ) => { { let __seq_res = match __parse_transforms ( __input , __state , __pos , renderOptions ) { Matched ( __newpos , __value ) => { Matched ( __newpos , Some ( __value ) ) } , Failed => { Matched ( __pos , None ) } , } ; match __seq_res { Matched ( __pos , transform ) => { { let __seq_res = __parse_CLOSE_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { Matched ( __pos , { [INFO] [stderr] | ^^^^^ help: use `dyn`: `dyn Shape` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> /opt/crater/target/debug/build/raytracer-8cce5711dbbe16ea/out/sdl_grammar.rs:155:159 [INFO] [stderr] | [INFO] [stderr] 155 | fn __parse_cube < 'input > ( __input : & 'input str , __state : & mut ParseState < 'input > , __pos : usize , renderOptions : &Options ) -> RuleResult < Box > { # ! [ allow ( non_snake_case , unused ) ] { let __seq_res = { let __seq_res = { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = slice_eq ( __input , __state , __pos , "cube" ) ; match __seq_res { Matched ( __pos , _ ) => { { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } } Failed => Failed , } } } Failed => Failed , } } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_OPEN_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_point ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , p1 ) => { { let __seq_res = __parse_point ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , p2 ) => { { let __seq_res = match __parse_transforms ( __input , __state , __pos , renderOptions ) { Matched ( __newpos , __value ) => { Matched ( __newpos , Some ( __value ) ) } , Failed => { Matched ( __pos , None ) } , } ; match __seq_res { Matched ( __pos , transform ) => { { let __seq_res = __parse_CLOSE_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { Matched ( __pos , { [INFO] [stderr] | ^^^^^ help: use `dyn`: `dyn Shape` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> /opt/crater/target/debug/build/raytracer-8cce5711dbbe16ea/out/sdl_grammar.rs:159:172 [INFO] [stderr] | [INFO] [stderr] 159 | fn __parse_homogenous_medium < 'input > ( __input : & 'input str , __state : & mut ParseState < 'input > , __pos : usize , renderOptions : &Options ) -> RuleResult < Box > { # ! [ allow ( non_snake_case , unused ) ] { let __seq_res = { let __seq_res = { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = slice_eq ( __input , __state , __pos , "homogenous_medium" ) ; match __seq_res { Matched ( __pos , _ ) => { { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } } Failed => Failed , } } } Failed => Failed , } } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_OPEN_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_density ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , density ) => { { let __seq_res = __parse_solid_shape ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , boundary ) => { { let __seq_res = match __parse_transforms ( __input , __state , __pos , renderOptions ) { Matched ( __newpos , __value ) => { Matched ( __newpos , Some ( __value ) ) } , Failed => { Matched ( __pos , None ) } , } ; match __seq_res { Matched ( __pos , transform ) => { { let __seq_res = __parse_CLOSE_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { Matched ( __pos , { [INFO] [stderr] | ^^^^^ help: use `dyn`: `dyn Shape` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> /opt/crater/target/debug/build/raytracer-8cce5711dbbe16ea/out/sdl_grammar.rs:167:170 [INFO] [stderr] | [INFO] [stderr] 167 | fn __parse_object_material < 'input > ( __input : & 'input str , __state : & mut ParseState < 'input > , __pos : usize , renderOptions : &Options ) -> RuleResult < Box > { # ! [ allow ( non_snake_case , unused ) ] { let __seq_res = { let __seq_res = { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = slice_eq ( __input , __state , __pos , "material" ) ; match __seq_res { Matched ( __pos , _ ) => { { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } } Failed => Failed , } } } Failed => Failed , } } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_OPEN_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_material ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , material ) => { { let __seq_res = __parse_CLOSE_BRACE ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , _ ) => { Matched ( __pos , { [INFO] [stderr] | ^^^^^^^^ help: use `dyn`: `dyn Material` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> /opt/crater/target/debug/build/raytracer-8cce5711dbbe16ea/out/sdl_grammar.rs:171:163 [INFO] [stderr] | [INFO] [stderr] 171 | fn __parse_material < 'input > ( __input : & 'input str , __state : & mut ParseState < 'input > , __pos : usize , renderOptions : &Options ) -> RuleResult < Box > { # ! [ allow ( non_snake_case , unused ) ] { let __choice_res = __parse_lambertian ( __input , __state , __pos , renderOptions ) ; match __choice_res { Matched ( __pos , __value ) => Matched ( __pos , __value ) , Failed => { let __choice_res = __parse_metal ( __input , __state , __pos , renderOptions ) ; match __choice_res { Matched ( __pos , __value ) => Matched ( __pos , __value ) , Failed => { let __choice_res = __parse_dielectric ( __input , __state , __pos , renderOptions ) ; match __choice_res { Matched ( __pos , __value ) => Matched ( __pos , __value ) , Failed => { let __choice_res = __parse_diffuse_light ( __input , __state , __pos , renderOptions ) ; match __choice_res { Matched ( __pos , __value ) => Matched ( __pos , __value ) , Failed => __parse_isotropic ( __input , __state , __pos , renderOptions ) } } } } } } } } } [INFO] [stderr] | ^^^^^^^^ help: use `dyn`: `dyn Material` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> /opt/crater/target/debug/build/raytracer-8cce5711dbbe16ea/out/sdl_grammar.rs:173:165 [INFO] [stderr] | [INFO] [stderr] 173 | fn __parse_lambertian < 'input > ( __input : & 'input str , __state : & mut ParseState < 'input > , __pos : usize , renderOptions : &Options ) -> RuleResult < Box > { # ! [ allow ( non_snake_case , unused ) ] { let __seq_res = { let __seq_res = { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = slice_eq ( __input , __state , __pos , "lambertian" ) ; match __seq_res { Matched ( __pos , _ ) => { { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } } Failed => Failed , } } } Failed => Failed , } } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_texture ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , texture ) => { Matched ( __pos , { [INFO] [stderr] | ^^^^^^^^ help: use `dyn`: `dyn Material` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> /opt/crater/target/debug/build/raytracer-8cce5711dbbe16ea/out/sdl_grammar.rs:177:160 [INFO] [stderr] | [INFO] [stderr] 177 | fn __parse_metal < 'input > ( __input : & 'input str , __state : & mut ParseState < 'input > , __pos : usize , renderOptions : &Options ) -> RuleResult < Box > { # ! [ allow ( non_snake_case , unused ) ] { let __seq_res = { let __seq_res = { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = slice_eq ( __input , __state , __pos , "metal" ) ; match __seq_res { Matched ( __pos , _ ) => { { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } } Failed => Failed , } } } Failed => Failed , } } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_fuzz ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , fuzz ) => { { let __seq_res = __parse_texture ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , texture ) => { Matched ( __pos , { [INFO] [stderr] | ^^^^^^^^ help: use `dyn`: `dyn Material` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> /opt/crater/target/debug/build/raytracer-8cce5711dbbe16ea/out/sdl_grammar.rs:183:165 [INFO] [stderr] | [INFO] [stderr] 183 | fn __parse_dielectric < 'input > ( __input : & 'input str , __state : & mut ParseState < 'input > , __pos : usize , renderOptions : &Options ) -> RuleResult < Box > { # ! [ allow ( non_snake_case , unused ) ] { let __seq_res = { let __seq_res = { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = slice_eq ( __input , __state , __pos , "dielectric" ) ; match __seq_res { Matched ( __pos , _ ) => { { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } } Failed => Failed , } } } Failed => Failed , } } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_ior ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , ior ) => { { let __seq_res = match __parse_fuzz ( __input , __state , __pos , renderOptions ) { Matched ( __newpos , __value ) => { Matched ( __newpos , Some ( __value ) ) } , Failed => { Matched ( __pos , None ) } , } ; match __seq_res { Matched ( __pos , fuzz ) => { Matched ( __pos , { [INFO] [stderr] | ^^^^^^^^ help: use `dyn`: `dyn Material` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> /opt/crater/target/debug/build/raytracer-8cce5711dbbe16ea/out/sdl_grammar.rs:189:168 [INFO] [stderr] | [INFO] [stderr] 189 | fn __parse_diffuse_light < 'input > ( __input : & 'input str , __state : & mut ParseState < 'input > , __pos : usize , renderOptions : &Options ) -> RuleResult < Box > { # ! [ allow ( non_snake_case , unused ) ] { let __seq_res = { let __seq_res = { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = slice_eq ( __input , __state , __pos , "diffuse_light" ) ; match __seq_res { Matched ( __pos , _ ) => { { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } } Failed => Failed , } } } Failed => Failed , } } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_intensity ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , i ) => { { let __seq_res = __parse_texture ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , texture ) => { Matched ( __pos , { [INFO] [stderr] | ^^^^^^^^ help: use `dyn`: `dyn Material` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> /opt/crater/target/debug/build/raytracer-8cce5711dbbe16ea/out/sdl_grammar.rs:197:164 [INFO] [stderr] | [INFO] [stderr] 197 | fn __parse_isotropic < 'input > ( __input : & 'input str , __state : & mut ParseState < 'input > , __pos : usize , renderOptions : &Options ) -> RuleResult < Box > { # ! [ allow ( non_snake_case , unused ) ] { let __seq_res = { let __seq_res = { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = slice_eq ( __input , __state , __pos , "isotropic" ) ; match __seq_res { Matched ( __pos , _ ) => { { let mut __repeat_pos = __pos ; loop { let __pos = __repeat_pos ; let __step_res = __parse_HIDDEN ( __input , __state , __pos , renderOptions ) ; match __step_res { Matched ( __newpos , __value ) => { __repeat_pos = __newpos ; } , Failed => { break ; } } } Matched ( __repeat_pos , ( ) ) } } Failed => Failed , } } } Failed => Failed , } } ; match __seq_res { Matched ( __pos , _ ) => { { let __seq_res = __parse_texture ( __input , __state , __pos , renderOptions ) ; match __seq_res { Matched ( __pos , texture ) => { Matched ( __pos , { [INFO] [stderr] | ^^^^^^^^ help: use `dyn`: `dyn Material` [INFO] [stderr] [INFO] [stderr] Finished dev [unoptimized + debuginfo] target(s) in 23.34s [INFO] running `"docker" "inspect" "84d8082a6039d8c0f914429b239d68fce2d3bc58fbc3acdae849121ee4787f67"` [INFO] running `"docker" "rm" "-f" "84d8082a6039d8c0f914429b239d68fce2d3bc58fbc3acdae849121ee4787f67"` [INFO] [stdout] 84d8082a6039d8c0f914429b239d68fce2d3bc58fbc3acdae849121ee4787f67