[INFO] cloning repository https://github.com/Astral-Beast/bevy-hex-map
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/Astral-Beast/bevy-hex-map" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FAstral-Beast%2Fbevy-hex-map", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FAstral-Beast%2Fbevy-hex-map'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] c8fb2d48b07b21d24bac107ff92b0f83c8311b2a
[INFO] checking Astral-Beast/bevy-hex-map against master#36b21637e93b038453924d3c66821089e71d8baa for pr-143164
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FAstral-Beast%2Fbevy-hex-map" "/workspace/builds/worker-6-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-6-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/Astral-Beast/bevy-hex-map
[INFO] finished tweaking git repo https://github.com/Astral-Beast/bevy-hex-map
[INFO] tweaked toml for git repo https://github.com/Astral-Beast/bevy-hex-map written to /workspace/builds/worker-6-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/Astral-Beast/bevy-hex-map on toolchain 36b21637e93b038453924d3c66821089e71d8baa
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+36b21637e93b038453924d3c66821089e71d8baa" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/Astral-Beast/bevy-hex-map already has a lockfile, it will not be regenerated
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+36b21637e93b038453924d3c66821089e71d8baa" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded piper v0.2.2
[INFO] [stderr]   Downloaded blocking v1.6.0
[INFO] [stderr]   Downloaded gilrs-core v0.5.11
[INFO] [stderr]   Downloaded nix v0.28.0
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/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" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:cf8efcab8866f2cf4285301c7418e2f4f2a9b088c91ba69c40d5b659f81557f7" "/opt/rustwide/cargo-home/bin/cargo" "+36b21637e93b038453924d3c66821089e71d8baa" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] c9780d85a5ab702b3f8b41997773b05c112ff7de0737e923e1814b4f19fe7c3e
[INFO] running `Command { std: "docker" "start" "-a" "c9780d85a5ab702b3f8b41997773b05c112ff7de0737e923e1814b4f19fe7c3e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "c9780d85a5ab702b3f8b41997773b05c112ff7de0737e923e1814b4f19fe7c3e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "c9780d85a5ab702b3f8b41997773b05c112ff7de0737e923e1814b4f19fe7c3e", kill_on_drop: false }`
[INFO] [stdout] c9780d85a5ab702b3f8b41997773b05c112ff7de0737e923e1814b4f19fe7c3e
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/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" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:cf8efcab8866f2cf4285301c7418e2f4f2a9b088c91ba69c40d5b659f81557f7" "/opt/rustwide/cargo-home/bin/cargo" "+36b21637e93b038453924d3c66821089e71d8baa" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 46b9b177acb63a5bd9488804cad3e1d087cd38fb80306aff76f32205b44355f3
[INFO] running `Command { std: "docker" "start" "-a" "46b9b177acb63a5bd9488804cad3e1d087cd38fb80306aff76f32205b44355f3", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.83
[INFO] [stderr]    Compiling serde v1.0.202
[INFO] [stderr]     Checking memchr v2.7.2
[INFO] [stderr]     Checking event-listener v5.3.0
[INFO] [stderr]     Checking async-executor v1.11.0
[INFO] [stderr]     Checking event-listener v4.0.3
[INFO] [stderr]     Checking unicode-width v0.1.12
[INFO] [stderr]    Compiling cc v1.0.98
[INFO] [stderr]     Checking piper v0.2.2
[INFO] [stderr]    Compiling syn v1.0.109
[INFO] [stderr]     Checking miniz_oxide v0.7.3
[INFO] [stderr]    Compiling nix v0.28.0
[INFO] [stderr]     Checking xkeysym v0.2.0
[INFO] [stderr]     Checking codespan-reporting v0.11.1
[INFO] [stderr]     Checking event-listener-strategy v0.4.0
[INFO] [stderr]     Checking async-lock v3.3.0
[INFO] [stderr]     Checking flate2 v1.0.30
[INFO] [stderr]     Checking event-listener-strategy v0.5.2
[INFO] [stderr]     Checking async-channel v2.3.1
[INFO] [stderr]     Checking bevy_tasks v0.13.2
[INFO] [stderr]     Checking aho-corasick v1.1.3
[INFO] [stderr]     Checking png v0.17.13
[INFO] [stderr]    Compiling quote v1.0.36
[INFO] [stderr]     Checking blocking v1.6.0
[INFO] [stderr]     Checking async-fs v2.1.2
[INFO] [stderr]    Compiling syn v2.0.65
[INFO] [stderr]    Compiling blake3 v1.5.1
[INFO] [stderr]     Checking regex-automata v0.4.6
[INFO] [stderr]     Checking regex v1.10.4
[INFO] [stderr]    Compiling derive_more v0.99.17
[INFO] [stderr]    Compiling bevy_macro_utils v0.13.2
[INFO] [stderr]    Compiling encase_derive_impl v0.7.0
[INFO] [stderr]     Checking ruzstd v0.5.0
[INFO] [stderr]    Compiling serde_derive v1.0.202
[INFO] [stderr]    Compiling thiserror-impl v1.0.61
[INFO] [stderr]    Compiling bytemuck_derive v1.6.0
[INFO] [stderr]    Compiling tracing-attributes v0.1.27
[INFO] [stderr]    Compiling bevy_utils_proc_macros v0.13.2
[INFO] [stderr]    Compiling bevy_reflect_derive v0.13.2
[INFO] [stderr]    Compiling bevy_ecs_macros v0.13.2
[INFO] [stderr]    Compiling bevy_derive v0.13.2
[INFO] [stderr]    Compiling bevy_asset_macros v0.13.2
[INFO] [stderr]    Compiling bevy_render_macros v0.13.2
[INFO] [stderr]    Compiling gltf-derive v1.4.1
[INFO] [stderr]    Compiling bevy_gizmos_macros v0.13.2
[INFO] [stderr]    Compiling encase_derive v0.7.0
[INFO] [stderr]    Compiling bevy_encase_derive v0.13.2
[INFO] [stderr]     Checking bytemuck v1.16.0
[INFO] [stderr]     Checking thiserror v1.0.61
[INFO] [stderr]     Checking tracing v0.1.40
[INFO] [stderr]     Checking image v0.24.9
[INFO] [stderr]     Checking bitflags v2.5.0
[INFO] [stderr]     Checking hashbrown v0.14.5
[INFO] [stderr]     Checking smallvec v1.13.2
[INFO] [stderr]     Checking glam v0.25.0
[INFO] [stderr]     Checking uuid v1.8.0
[INFO] [stderr]     Checking erased-serde v0.4.5
[INFO] [stderr]     Checking serde_json v1.0.117
[INFO] [stderr]     Checking spirv v0.3.0+sdk-1.3.268.0
[INFO] [stderr]     Checking gpu-alloc-types v0.3.0
[INFO] [stderr]     Checking gpu-descriptor-types v0.1.2
[INFO] [stderr]     Checking wgpu-types v0.19.2
[INFO] [stderr]     Checking ron v0.8.1
[INFO] [stderr]     Checking rustix v0.38.34
[INFO] [stderr]     Checking xkbcommon-dl v0.4.2
[INFO] [stderr]     Checking alsa v0.9.0
[INFO] [stderr]     Checking tracing-subscriber v0.3.18
[INFO] [stderr]     Checking parking_lot_core v0.9.10
[INFO] [stderr]     Checking gpu-alloc v0.6.0
[INFO] [stderr]     Checking parking_lot v0.12.2
[INFO] [stderr]     Checking gilrs-core v0.5.11
[INFO] [stderr]     Checking indexmap v2.2.6
[INFO] [stderr]     Checking gpu-descriptor v0.2.4
[INFO] [stderr]     Checking gltf-json v1.4.1
[INFO] [stderr]     Checking gilrs v0.10.7
[INFO] [stderr]     Checking cpal v0.15.3
[INFO] [stderr]     Checking rodio v0.17.3
[INFO] [stderr]     Checking petgraph v0.6.5
[INFO] [stderr]     Checking naga v0.19.2
[INFO] [stderr]     Checking bevy_math v0.13.2
[INFO] [stderr]     Checking hexasphere v10.0.0
[INFO] [stderr]     Checking bevy_mikktspace v0.13.2
[INFO] [stderr]     Checking encase v0.7.0
[INFO] [stderr]     Checking bevy_utils v0.13.2
[INFO] [stderr]     Checking gltf v1.4.1
[INFO] [stderr]     Checking bevy_reflect v0.13.2
[INFO] [stderr]     Checking polling v3.7.0
[INFO] [stderr]     Checking x11rb v0.13.1
[INFO] [stderr]     Checking calloop v0.12.4
[INFO] [stderr]     Checking winit v0.29.15
[INFO] [stderr]     Checking wgpu-hal v0.19.4
[INFO] [stderr]     Checking naga_oil v0.13.0
[INFO] [stderr]     Checking accesskit_winit v0.17.0
[INFO] [stderr]     Checking bevy_ecs v0.13.2
[INFO] [stderr]     Checking wgpu-core v0.19.4
[INFO] [stderr]     Checking bevy_app v0.13.2
[INFO] [stderr]     Checking bevy_log v0.13.2
[INFO] [stderr]     Checking bevy_core v0.13.2
[INFO] [stderr]     Checking bevy_input v0.13.2
[INFO] [stderr]     Checking bevy_time v0.13.2
[INFO] [stderr]     Checking bevy_a11y v0.13.2
[INFO] [stderr]     Checking bevy_asset v0.13.2
[INFO] [stderr]     Checking bevy_hierarchy v0.13.2
[INFO] [stderr]     Checking bevy_diagnostic v0.13.2
[INFO] [stderr]     Checking bevy_transform v0.13.2
[INFO] [stderr]     Checking bevy_window v0.13.2
[INFO] [stderr]     Checking bevy_gilrs v0.13.2
[INFO] [stderr]     Checking bevy_winit v0.13.2
[INFO] [stderr]     Checking bevy_audio v0.13.2
[INFO] [stderr]     Checking wgpu v0.19.4
[INFO] [stderr]     Checking bevy_render v0.13.2
[INFO] [stderr]     Checking bevy_core_pipeline v0.13.2
[INFO] [stderr]     Checking bevy_scene v0.13.2
[INFO] [stderr]     Checking bevy_animation v0.13.2
[INFO] [stderr]     Checking bevy_sprite v0.13.2
[INFO] [stderr]     Checking bevy_pbr v0.13.2
[INFO] [stderr]     Checking bevy_text v0.13.2
[INFO] [stderr]     Checking bevy_ui v0.13.2
[INFO] [stderr]     Checking bevy_gizmos v0.13.2
[INFO] [stderr]     Checking bevy_gltf v0.13.2
[INFO] [stderr]     Checking bevy_internal v0.13.2
[INFO] [stderr]     Checking bevy v0.13.2
[INFO] [stderr]     Checking bevy-hex-map v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused imports: `PlaneMeshBuilder`, `TextureDescriptor`, `TextureUsages`, `camera::RenderTarget`, `ecs::bundle`, `input::mouse::MouseButtonInput`, `log::tracing_subscriber::fmt::format`, `ui::node_bundles`, and `vec2`
[INFO] [stdout]   --> src/main.rs:4:5
[INFO] [stdout]    |
[INFO] [stdout] 4  |     ecs::bundle, input::mouse::MouseButtonInput, log::tracing_subscriber::fmt::format, math::{vec2, vec3}, prelude::*, render::{
[INFO] [stdout]    |     ^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^         ^^^^
[INFO] [stdout] 5  |         camera::RenderTarget,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 6  |         mesh::{Indices, PlaneMeshBuilder},
[INFO] [stdout]    |                         ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 9  |             Extent3d, PrimitiveTopology, TextureDescriptor, TextureDimension, TextureFormat,
[INFO] [stdout]    |                                          ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 10 |             TextureUsages,
[INFO] [stdout]    |             ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 14 |     }, ui::node_bundles
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around method argument
[INFO] [stdout]   --> src/main.rs:18:22
[INFO] [stdout]    |
[INFO] [stdout] 18 |         .add_plugins((MyRenderPlugin))
[INFO] [stdout]    |                      ^              ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 18 -         .add_plugins((MyRenderPlugin))
[INFO] [stdout] 18 +         .add_plugins(MyRenderPlugin)
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/main.rs:132:28
[INFO] [stdout]     |
[INFO] [stdout] 132 |     let opposite_leg:f32 = ((PI / 6.0).tan() * HEX_INNER_RADIUS) ;
[INFO] [stdout]     |                            ^                                   ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 132 -     let opposite_leg:f32 = ((PI / 6.0).tan() * HEX_INNER_RADIUS) ;
[INFO] [stdout] 132 +     let opposite_leg:f32 = (PI / 6.0).tan() * HEX_INNER_RADIUS ;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `PlaneMeshBuilder`, `TextureDescriptor`, `TextureUsages`, `camera::RenderTarget`, `ecs::bundle`, `input::mouse::MouseButtonInput`, `log::tracing_subscriber::fmt::format`, `ui::node_bundles`, and `vec2`
[INFO] [stdout]   --> src/main.rs:4:5
[INFO] [stdout]    |
[INFO] [stdout] 4  |     ecs::bundle, input::mouse::MouseButtonInput, log::tracing_subscriber::fmt::format, math::{vec2, vec3}, prelude::*, render::{
[INFO] [stdout]    |     ^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^         ^^^^
[INFO] [stdout] 5  |         camera::RenderTarget,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 6  |         mesh::{Indices, PlaneMeshBuilder},
[INFO] [stdout]    |                         ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 9  |             Extent3d, PrimitiveTopology, TextureDescriptor, TextureDimension, TextureFormat,
[INFO] [stdout]    |                                          ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 10 |             TextureUsages,
[INFO] [stdout]    |             ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 14 |     }, ui::node_bundles
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around method argument
[INFO] [stdout]   --> src/main.rs:18:22
[INFO] [stdout]    |
[INFO] [stdout] 18 |         .add_plugins((MyRenderPlugin))
[INFO] [stdout]    |                      ^              ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 18 -         .add_plugins((MyRenderPlugin))
[INFO] [stdout] 18 +         .add_plugins(MyRenderPlugin)
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/main.rs:132:28
[INFO] [stdout]     |
[INFO] [stdout] 132 |     let opposite_leg:f32 = ((PI / 6.0).tan() * HEX_INNER_RADIUS) ;
[INFO] [stdout]     |                            ^                                   ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 132 -     let opposite_leg:f32 = ((PI / 6.0).tan() * HEX_INNER_RADIUS) ;
[INFO] [stdout] 132 +     let opposite_leg:f32 = (PI / 6.0).tan() * HEX_INNER_RADIUS ;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `position`, `index`, and `biome` are never read
[INFO] [stdout]   --> src/main.rs:62:9
[INFO] [stdout]    |
[INFO] [stdout] 61 | struct Hex {
[INFO] [stdout]    |        --- fields in this struct
[INFO] [stdout] 62 |     pub position: Vec3,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 63 |     pub index: Vec3,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout] 64 |     pub biome: Biome
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_biome_material` is never used
[INFO] [stdout]    --> src/main.rs:224:8
[INFO] [stdout]     |
[INFO] [stdout] 223 | impl Biome {
[INFO] [stdout]     | ---------- method in this implementation
[INFO] [stdout] 224 |     fn get_biome_material(&self) -> Color {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `position`, `index`, and `biome` are never read
[INFO] [stdout]   --> src/main.rs:62:9
[INFO] [stdout]    |
[INFO] [stdout] 61 | struct Hex {
[INFO] [stdout]    |        --- fields in this struct
[INFO] [stdout] 62 |     pub position: Vec3,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 63 |     pub index: Vec3,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout] 64 |     pub biome: Biome
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_biome_material` is never used
[INFO] [stdout]    --> src/main.rs:224:8
[INFO] [stdout]     |
[INFO] [stdout] 223 | impl Biome {
[INFO] [stdout]     | ---------- method in this implementation
[INFO] [stdout] 224 |     fn get_biome_material(&self) -> Color {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 28s
[INFO] running `Command { std: "docker" "inspect" "46b9b177acb63a5bd9488804cad3e1d087cd38fb80306aff76f32205b44355f3", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "46b9b177acb63a5bd9488804cad3e1d087cd38fb80306aff76f32205b44355f3", kill_on_drop: false }`
[INFO] [stdout] 46b9b177acb63a5bd9488804cad3e1d087cd38fb80306aff76f32205b44355f3
