[INFO] updating cached repository https://github.com/gswirski/blobby_volley [INFO] running `"git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "-c" "remote.origin.fetch=refs/heads/*:refs/heads/*" "fetch" "origin" "--force" "--prune"` [INFO] running `"git" "rev-parse" "HEAD"` [INFO] [stdout] 3f822fa5cd36ee05b63d98137cf0409e257ab88d [INFO] checking gswirski/blobby_volley against try#9ff4d07208097950831ed4ea9d76feb1eafc8baa for pr-69340 [INFO] running `"git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fgswirski%2Fblobby_volley" "/workspace/builds/worker-3/source"` [INFO] [stderr] Cloning into '/workspace/builds/worker-3/source'... [INFO] [stderr] done. [INFO] validating manifest of git repo https://github.com/gswirski/blobby_volley on toolchain 9ff4d07208097950831ed4ea9d76feb1eafc8baa [INFO] running `"/workspace/cargo-home/bin/cargo" "+9ff4d07208097950831ed4ea9d76feb1eafc8baa" "read-manifest" "--manifest-path" "Cargo.toml"` [INFO] started tweaking git repo https://github.com/gswirski/blobby_volley [INFO] finished tweaking git repo https://github.com/gswirski/blobby_volley [INFO] tweaked toml for git repo https://github.com/gswirski/blobby_volley written to /workspace/builds/worker-3/source/Cargo.toml [INFO] crate git repo https://github.com/gswirski/blobby_volley already has a lockfile, it will not be regenerated [INFO] running `"/workspace/cargo-home/bin/cargo" "+9ff4d07208097950831ed4ea9d76feb1eafc8baa" "fetch" "--locked" "--manifest-path" "Cargo.toml"` [INFO] [stderr] warning: An explicit [[bin]] section is specified in Cargo.toml which currently [INFO] [stderr] disables Cargo from automatically inferring other binary targets. [INFO] [stderr] This inference behavior will change in the Rust 2018 edition and the following [INFO] [stderr] files will be included as a binary target: [INFO] [stderr] [INFO] [stderr] * /workspace/builds/worker-3/source/src/main.rs [INFO] [stderr] [INFO] [stderr] This is likely to break cargo build or cargo test as these files may not be [INFO] [stderr] ready to be compiled as a binary target today. You can future-proof yourself [INFO] [stderr] and disable this warning by adding `autobins = false` to your [package] [INFO] [stderr] section. You may also move the files to a location where Cargo would not [INFO] [stderr] automatically infer them to be a target, such as in subfolders. [INFO] [stderr] [INFO] [stderr] For more information on this warning you can consult [INFO] [stderr] https://github.com/rust-lang/cargo/issues/5330 [INFO] [stderr] warning: path `/workspace/builds/worker-3/source/src/main.rs` was erroneously implicitly accepted for binary `blobby`, [INFO] [stderr] please set bin.path in Cargo.toml [INFO] [stderr] warning: dependency (gl) specified without providing a local path, Git repository, or version to use. This will be considered an error in future versions [INFO] [stderr] error: the lock file /workspace/builds/worker-3/source/Cargo.lock needs to be updated but --locked was passed to prevent this [INFO] [stderr] If you want to try to generate the lock file without accessing the network, use the --offline flag. [INFO] the lockfile is outdated, regenerating it [INFO] running `"/workspace/cargo-home/bin/cargo" "+9ff4d07208097950831ed4ea9d76feb1eafc8baa" "generate-lockfile" "--manifest-path" "Cargo.toml" "-Zno-index-update"` [INFO] [stderr] Updating git repository `https://github.com/tomaka/glutin` [INFO] running `"/workspace/cargo-home/bin/cargo" "+9ff4d07208097950831ed4ea9d76feb1eafc8baa" "fetch" "--locked" "--manifest-path" "Cargo.toml"` [INFO] [stderr] warning: An explicit [[bin]] section is specified in Cargo.toml which currently [INFO] [stderr] disables Cargo from automatically inferring other binary targets. [INFO] [stderr] This inference behavior will change in the Rust 2018 edition and the following [INFO] [stderr] files will be included as a binary target: [INFO] [stderr] [INFO] [stderr] * /workspace/builds/worker-3/source/src/main.rs [INFO] [stderr] [INFO] [stderr] This is likely to break cargo build or cargo test as these files may not be [INFO] [stderr] ready to be compiled as a binary target today. You can future-proof yourself [INFO] [stderr] and disable this warning by adding `autobins = false` to your [package] [INFO] [stderr] section. You may also move the files to a location where Cargo would not [INFO] [stderr] automatically infer them to be a target, such as in subfolders. [INFO] [stderr] [INFO] [stderr] For more information on this warning you can consult [INFO] [stderr] https://github.com/rust-lang/cargo/issues/5330 [INFO] [stderr] warning: path `/workspace/builds/worker-3/source/src/main.rs` was erroneously implicitly accepted for binary `blobby`, [INFO] [stderr] please set bin.path in Cargo.toml [INFO] [stderr] warning: dependency (gl) specified without providing a local path, Git repository, or version to use. This will be considered an error in future versions [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] running `"docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "MAP_USER_ID=0" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--network" "none" "rustops/crates-build-env" "/opt/rustwide/cargo-home/bin/cargo" "+9ff4d07208097950831ed4ea9d76feb1eafc8baa" "check" "--frozen" "--all" "--all-targets"` [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] [stdout] 2c05c39dec0b6cc80840da3476f12b2efe4397b60d62912e1822587cfedb8058 [INFO] running `"docker" "start" "-a" "2c05c39dec0b6cc80840da3476f12b2efe4397b60d62912e1822587cfedb8058"` [INFO] [stderr] warning: An explicit [[bin]] section is specified in Cargo.toml which currently [INFO] [stderr] disables Cargo from automatically inferring other binary targets. [INFO] [stderr] This inference behavior will change in the Rust 2018 edition and the following [INFO] [stderr] files will be included as a binary target: [INFO] [stderr] [INFO] [stderr] * /opt/rustwide/workdir/src/main.rs [INFO] [stderr] [INFO] [stderr] This is likely to break cargo build or cargo test as these files may not be [INFO] [stderr] ready to be compiled as a binary target today. You can future-proof yourself [INFO] [stderr] and disable this warning by adding `autobins = false` to your [package] [INFO] [stderr] section. You may also move the files to a location where Cargo would not [INFO] [stderr] automatically infer them to be a target, such as in subfolders. [INFO] [stderr] [INFO] [stderr] For more information on this warning you can consult [INFO] [stderr] https://github.com/rust-lang/cargo/issues/5330 [INFO] [stderr] warning: path `/opt/rustwide/workdir/src/main.rs` was erroneously implicitly accepted for binary `blobby`, [INFO] [stderr] please set bin.path in Cargo.toml [INFO] [stderr] warning: dependency (gl) specified without providing a local path, Git repository, or version to use. This will be considered an error in future versions [INFO] [stderr] Compiling glutin_egl_sys v0.1.4 (https://github.com/tomaka/glutin#9283ab5c) [INFO] [stderr] Compiling glutin_glx_sys v0.1.6 (https://github.com/tomaka/glutin#9283ab5c) [INFO] [stderr] Checking smithay-client-toolkit v0.6.6 [INFO] [stderr] Checking winit v0.21.0 [INFO] [stderr] Checking glutin v0.23.0 (https://github.com/tomaka/glutin#9283ab5c) [INFO] [stderr] Checking blobby_volley v0.0.1 (/opt/rustwide/workdir) [INFO] [stderr] error: invalid suffix `is` for integer literal [INFO] [stderr] --> src/renderer.rs:50:21 [INFO] [stderr] | [INFO] [stderr] 50 | let precision = 400is; [INFO] [stderr] | ^^^^^ invalid suffix `is` [INFO] [stderr] | [INFO] [stderr] = help: the suffix must be one of the integral types (`u32`, `isize`, etc) [INFO] [stderr] [INFO] [stderr] error: invalid suffix `is` for integer literal [INFO] [stderr] --> src/renderer.rs:50:21 [INFO] [stderr] | [INFO] [stderr] 50 | let precision = 400is; [INFO] [stderr] | ^^^^^ invalid suffix `is` [INFO] [stderr] | [INFO] [stderr] = help: the suffix must be one of the integral types (`u32`, `isize`, etc) [INFO] [stderr] [INFO] [stderr] error[E0432]: unresolved imports `glutin::ElementState`, `glutin::Event`, `glutin::VirtualKeyCode` [INFO] [stderr] --> src/os.rs:4:5 [INFO] [stderr] | [INFO] [stderr] 4 | ElementState, [INFO] [stderr] | ^^^^^^^^^^^^ no `ElementState` in the root [INFO] [stderr] 5 | Event, [INFO] [stderr] | ^^^^^ [INFO] [stderr] | | [INFO] [stderr] | no `Event` in the root [INFO] [stderr] | help: a similar name exists in the module: `event` [INFO] [stderr] 6 | VirtualKeyCode, [INFO] [stderr] | ^^^^^^^^^^^^^^ no `VirtualKeyCode` in the root [INFO] [stderr] [INFO] [stderr] error[E0432]: unresolved import `std::num::Float` [INFO] [stderr] --> src/geom.rs:1:5 [INFO] [stderr] | [INFO] [stderr] 1 | use std::num::Float; [INFO] [stderr] | ^^^^^^^^^^^^^^^ no `Float` in `num` [INFO] [stderr] [INFO] [stderr] error[E0432]: unresolved import `std::num::Float` [INFO] [stderr] --> src/physics.rs:2:5 [INFO] [stderr] | [INFO] [stderr] 2 | use std::num::Float; [INFO] [stderr] | ^^^^^^^^^^^^^^^ no `Float` in `num` [INFO] [stderr] [INFO] [stderr] error[E0432]: unresolved import `std::num::Float` [INFO] [stderr] --> src/game.rs:4:5 [INFO] [stderr] | [INFO] [stderr] 4 | use std::num::Float; [INFO] [stderr] | ^^^^^^^^^^^^^^^ no `Float` in `num` [INFO] [stderr] [INFO] [stderr] error[E0432]: unresolved import `glutin::VirtualKeyCode` [INFO] [stderr] --> src/game.rs:5:5 [INFO] [stderr] | [INFO] [stderr] 5 | use glutin::VirtualKeyCode; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ no `VirtualKeyCode` in the root [INFO] [stderr] [INFO] [stderr] error[E0432]: unresolved import `std::num::Float` [INFO] [stderr] --> src/renderer.rs:4:5 [INFO] [stderr] | [INFO] [stderr] 4 | use std::num::Float; [INFO] [stderr] | ^^^^^^^^^^^^^^^ no `Float` in `num` [INFO] [stderr] [INFO] [stderr] error[E0433]: failed to resolve: could not find `WindowBuilder` in `glutin` [INFO] [stderr] --> src/os.rs:18:30 [INFO] [stderr] | [INFO] [stderr] 18 | let window = glutin::WindowBuilder::new() [INFO] [stderr] | ^^^^^^^^^^^^^ could not find `WindowBuilder` in `glutin` [INFO] [stderr] [INFO] [stderr] error[E0412]: cannot find type `Window` in crate `glutin` [INFO] [stderr] --> src/os.rs:10:25 [INFO] [stderr] | [INFO] [stderr] 10 | pub window: glutin::Window, [INFO] [stderr] | ^^^^^^ not found in `glutin` [INFO] [stderr] | [INFO] [stderr] help: possible candidates are found in other modules, you can import them into scope [INFO] [stderr] | [INFO] [stderr] 1 | use glutin::platform::unix::x11::Window; [INFO] [stderr] | [INFO] [stderr] 1 | use glutin::platform::unix::x11::ffi::Window; [INFO] [stderr] | [INFO] [stderr] 1 | use glutin::window::Window; [INFO] [stderr] | [INFO] [stderr] 1 | use os::Window; [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] error[E0425]: cannot find function `load` in crate `gl` [INFO] [stderr] --> src/graphics.rs:15:9 [INFO] [stderr] | [INFO] [stderr] 15 | gl::load(&window.window); [INFO] [stderr] | ^^^^ not found in `gl` [INFO] [stderr] | [INFO] [stderr] help: possible candidate is found in another module, you can import it into scope [INFO] [stderr] | [INFO] [stderr] 1 | use graphics::load; [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] error[E0599]: no method named `push_all` found for struct `std::vec::Vec` in the current scope [INFO] [stderr] --> src/renderer.rs:8:14 [INFO] [stderr] | [INFO] [stderr] 8 | vertices.push_all(&render_player(&world.player)[..]); [INFO] [stderr] | ^^^^^^^^ method not found in `std::vec::Vec` [INFO] [stderr] [INFO] [stderr] error[E0599]: no method named `push_all` found for struct `std::vec::Vec` in the current scope [INFO] [stderr] --> src/renderer.rs:9:14 [INFO] [stderr] | [INFO] [stderr] 9 | vertices.push_all(&render_player(&world.opponent)[..]); [INFO] [stderr] | ^^^^^^^^ method not found in `std::vec::Vec` [INFO] [stderr] [INFO] [stderr] error[E0599]: no method named `push_all` found for struct `std::vec::Vec` in the current scope [INFO] [stderr] --> src/renderer.rs:10:14 [INFO] [stderr] | [INFO] [stderr] 10 | vertices.push_all(&render_ball(&world.ball)[..]); [INFO] [stderr] | ^^^^^^^^ method not found in `std::vec::Vec` [INFO] [stderr] [INFO] [stderr] error[E0599]: no method named `push_all` found for struct `std::vec::Vec` in the current scope [INFO] [stderr] --> src/renderer.rs:11:14 [INFO] [stderr] | [INFO] [stderr] 11 | vertices.push_all(&render_net()[..]); [INFO] [stderr] | ^^^^^^^^ method not found in `std::vec::Vec` [INFO] [stderr] [INFO] [stderr] error[E0599]: no method named `map_in_place` found for struct `std::vec::Vec` in the current scope [INFO] [stderr] --> src/renderer.rs:15:14 [INFO] [stderr] | [INFO] [stderr] 15 | vertices.map_in_place(|v| { [INFO] [stderr] | ^^^^^^^^^^^^ method not found in `std::vec::Vec` [INFO] [stderr] [INFO] [stderr] error[E0599]: no method named `push_all` found for struct `std::vec::Vec` in the current scope [INFO] [stderr] --> src/renderer.rs:38:14 [INFO] [stderr] | [INFO] [stderr] 38 | vertices.push_all(&render_circle(player.x, player.y, 0.13)[..]); [INFO] [stderr] | ^^^^^^^^ method not found in `std::vec::Vec` [INFO] [stderr] [INFO] [stderr] error[E0599]: no method named `push_all` found for struct `std::vec::Vec` in the current scope [INFO] [stderr] --> src/renderer.rs:39:14 [INFO] [stderr] | [INFO] [stderr] 39 | vertices.push_all(&render_circle(player.x, player.y + 0.13, 0.1)[..]); [INFO] [stderr] | ^^^^^^^^ method not found in `std::vec::Vec` [INFO] [stderr] [INFO] [stderr] error[E0599]: no function or associated item named `from_slice` found for struct `std::ffi::CString` in the current scope [INFO] [stderr] --> src/graphics.rs:32:71 [INFO] [stderr] | [INFO] [stderr] 32 | let pos_attr = gl::GetAttribLocation(shader_program, CString::from_slice("position".as_bytes()).as_ptr()); [INFO] [stderr] | ^^^^^^^^^^ function or associated item not found in `std::ffi::CString` [INFO] [stderr] [INFO] [stderr] error[E0599]: no function or associated item named `from_slice` found for struct `std::ffi::CString` in the current scope [INFO] [stderr] --> src/graphics.rs:77:47 [INFO] [stderr] | [INFO] [stderr] 77 | gl::ShaderSource(shader, 1, &CString::from_slice(src.as_bytes()).as_ptr(), ptr::null()); [INFO] [stderr] | ^^^^^^^^^^ function or associated item not found in `std::ffi::CString` [INFO] [stderr] [INFO] [stderr] error: aborting due to 19 previous errors [INFO] [stderr] [INFO] [stderr] Some errors have detailed explanations: E0412, E0425, E0432, E0433, E0599. [INFO] [stderr] For more information about an error, try `rustc --explain E0412`. [INFO] [stderr] error: could not compile `blobby_volley`. [INFO] [stderr] [INFO] [stderr] To learn more, run the command again with --verbose. [INFO] [stderr] warning: build failed, waiting for other jobs to finish... [INFO] [stderr] error[E0432]: unresolved imports `glutin::ElementState`, `glutin::Event`, `glutin::VirtualKeyCode` [INFO] [stderr] --> src/os.rs:4:5 [INFO] [stderr] | [INFO] [stderr] 4 | ElementState, [INFO] [stderr] | ^^^^^^^^^^^^ no `ElementState` in the root [INFO] [stderr] 5 | Event, [INFO] [stderr] | ^^^^^ [INFO] [stderr] | | [INFO] [stderr] | no `Event` in the root [INFO] [stderr] | help: a similar name exists in the module: `event` [INFO] [stderr] 6 | VirtualKeyCode, [INFO] [stderr] | ^^^^^^^^^^^^^^ no `VirtualKeyCode` in the root [INFO] [stderr] [INFO] [stderr] error[E0432]: unresolved import `std::num::Float` [INFO] [stderr] --> src/geom.rs:1:5 [INFO] [stderr] | [INFO] [stderr] 1 | use std::num::Float; [INFO] [stderr] | ^^^^^^^^^^^^^^^ no `Float` in `num` [INFO] [stderr] [INFO] [stderr] error[E0432]: unresolved import `std::num::Float` [INFO] [stderr] --> src/physics.rs:2:5 [INFO] [stderr] | [INFO] [stderr] 2 | use std::num::Float; [INFO] [stderr] | ^^^^^^^^^^^^^^^ no `Float` in `num` [INFO] [stderr] [INFO] [stderr] error[E0432]: unresolved import `std::num::Float` [INFO] [stderr] --> src/game.rs:4:5 [INFO] [stderr] | [INFO] [stderr] 4 | use std::num::Float; [INFO] [stderr] | ^^^^^^^^^^^^^^^ no `Float` in `num` [INFO] [stderr] [INFO] [stderr] error[E0432]: unresolved import `glutin::VirtualKeyCode` [INFO] [stderr] --> src/game.rs:5:5 [INFO] [stderr] | [INFO] [stderr] 5 | use glutin::VirtualKeyCode; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ no `VirtualKeyCode` in the root [INFO] [stderr] [INFO] [stderr] error[E0432]: unresolved import `std::num::Float` [INFO] [stderr] --> src/renderer.rs:4:5 [INFO] [stderr] | [INFO] [stderr] 4 | use std::num::Float; [INFO] [stderr] | ^^^^^^^^^^^^^^^ no `Float` in `num` [INFO] [stderr] [INFO] [stderr] error[E0433]: failed to resolve: could not find `WindowBuilder` in `glutin` [INFO] [stderr] --> src/os.rs:18:30 [INFO] [stderr] | [INFO] [stderr] 18 | let window = glutin::WindowBuilder::new() [INFO] [stderr] | ^^^^^^^^^^^^^ could not find `WindowBuilder` in `glutin` [INFO] [stderr] [INFO] [stderr] error[E0412]: cannot find type `Window` in crate `glutin` [INFO] [stderr] --> src/os.rs:10:25 [INFO] [stderr] | [INFO] [stderr] 10 | pub window: glutin::Window, [INFO] [stderr] | ^^^^^^ not found in `glutin` [INFO] [stderr] | [INFO] [stderr] help: possible candidates are found in other modules, you can import them into scope [INFO] [stderr] | [INFO] [stderr] 1 | use glutin::platform::unix::x11::Window; [INFO] [stderr] | [INFO] [stderr] 1 | use glutin::platform::unix::x11::ffi::Window; [INFO] [stderr] | [INFO] [stderr] 1 | use glutin::window::Window; [INFO] [stderr] | [INFO] [stderr] 1 | use os::Window; [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] error[E0425]: cannot find function `load` in crate `gl` [INFO] [stderr] --> src/graphics.rs:15:9 [INFO] [stderr] | [INFO] [stderr] 15 | gl::load(&window.window); [INFO] [stderr] | ^^^^ not found in `gl` [INFO] [stderr] | [INFO] [stderr] help: possible candidate is found in another module, you can import it into scope [INFO] [stderr] | [INFO] [stderr] 1 | use graphics::load; [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] error[E0599]: no method named `push_all` found for struct `std::vec::Vec` in the current scope [INFO] [stderr] --> src/renderer.rs:8:14 [INFO] [stderr] | [INFO] [stderr] 8 | vertices.push_all(&render_player(&world.player)[..]); [INFO] [stderr] | ^^^^^^^^ method not found in `std::vec::Vec` [INFO] [stderr] [INFO] [stderr] error[E0599]: no method named `push_all` found for struct `std::vec::Vec` in the current scope [INFO] [stderr] --> src/renderer.rs:9:14 [INFO] [stderr] | [INFO] [stderr] 9 | vertices.push_all(&render_player(&world.opponent)[..]); [INFO] [stderr] | ^^^^^^^^ method not found in `std::vec::Vec` [INFO] [stderr] [INFO] [stderr] error[E0599]: no method named `push_all` found for struct `std::vec::Vec` in the current scope [INFO] [stderr] --> src/renderer.rs:10:14 [INFO] [stderr] | [INFO] [stderr] 10 | vertices.push_all(&render_ball(&world.ball)[..]); [INFO] [stderr] | ^^^^^^^^ method not found in `std::vec::Vec` [INFO] [stderr] [INFO] [stderr] error[E0599]: no method named `push_all` found for struct `std::vec::Vec` in the current scope [INFO] [stderr] --> src/renderer.rs:11:14 [INFO] [stderr] | [INFO] [stderr] 11 | vertices.push_all(&render_net()[..]); [INFO] [stderr] | ^^^^^^^^ method not found in `std::vec::Vec` [INFO] [stderr] [INFO] [stderr] error[E0599]: no method named `map_in_place` found for struct `std::vec::Vec` in the current scope [INFO] [stderr] --> src/renderer.rs:15:14 [INFO] [stderr] | [INFO] [stderr] 15 | vertices.map_in_place(|v| { [INFO] [stderr] | ^^^^^^^^^^^^ method not found in `std::vec::Vec` [INFO] [stderr] [INFO] [stderr] error[E0599]: no method named `push_all` found for struct `std::vec::Vec` in the current scope [INFO] [stderr] --> src/renderer.rs:38:14 [INFO] [stderr] | [INFO] [stderr] 38 | vertices.push_all(&render_circle(player.x, player.y, 0.13)[..]); [INFO] [stderr] | ^^^^^^^^ method not found in `std::vec::Vec` [INFO] [stderr] [INFO] [stderr] error[E0599]: no method named `push_all` found for struct `std::vec::Vec` in the current scope [INFO] [stderr] --> src/renderer.rs:39:14 [INFO] [stderr] | [INFO] [stderr] 39 | vertices.push_all(&render_circle(player.x, player.y + 0.13, 0.1)[..]); [INFO] [stderr] | ^^^^^^^^ method not found in `std::vec::Vec` [INFO] [stderr] [INFO] [stderr] error[E0599]: no function or associated item named `from_slice` found for struct `std::ffi::CString` in the current scope [INFO] [stderr] --> src/graphics.rs:32:71 [INFO] [stderr] | [INFO] [stderr] 32 | let pos_attr = gl::GetAttribLocation(shader_program, CString::from_slice("position".as_bytes()).as_ptr()); [INFO] [stderr] | ^^^^^^^^^^ function or associated item not found in `std::ffi::CString` [INFO] [stderr] [INFO] [stderr] error[E0599]: no function or associated item named `from_slice` found for struct `std::ffi::CString` in the current scope [INFO] [stderr] --> src/graphics.rs:77:47 [INFO] [stderr] | [INFO] [stderr] 77 | gl::ShaderSource(shader, 1, &CString::from_slice(src.as_bytes()).as_ptr(), ptr::null()); [INFO] [stderr] | ^^^^^^^^^^ function or associated item not found in `std::ffi::CString` [INFO] [stderr] [INFO] [stderr] error: aborting due to 19 previous errors [INFO] [stderr] [INFO] [stderr] Some errors have detailed explanations: E0412, E0425, E0432, E0433, E0599. [INFO] [stderr] For more information about an error, try `rustc --explain E0412`. [INFO] [stderr] error: could not compile `blobby_volley`. [INFO] [stderr] [INFO] [stderr] To learn more, run the command again with --verbose. [INFO] running `"docker" "inspect" "2c05c39dec0b6cc80840da3476f12b2efe4397b60d62912e1822587cfedb8058"` [INFO] running `"docker" "rm" "-f" "2c05c39dec0b6cc80840da3476f12b2efe4397b60d62912e1822587cfedb8058"` [INFO] [stdout] 2c05c39dec0b6cc80840da3476f12b2efe4397b60d62912e1822587cfedb8058