[INFO] cloning repository https://github.com/rock117/tushare-api
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/rock117/tushare-api" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Frock117%2Ftushare-api", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Frock117%2Ftushare-api'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 58c6cb86bed7a11b7991bb5bda081d89902cd1c3
[INFO] checking rock117/tushare-api against try#0c70cfbec949d241375e31c5a42066be70c720fc for pr-149681
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Frock117%2Ftushare-api" "/workspace/builds/worker-5-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-5-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/rock117/tushare-api
[INFO] finished tweaking git repo https://github.com/rock117/tushare-api
[INFO] tweaked toml for git repo https://github.com/rock117/tushare-api written to /workspace/builds/worker-5-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/rock117/tushare-api on toolchain 0c70cfbec949d241375e31c5a42066be70c720fc
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+0c70cfbec949d241375e31c5a42066be70c720fc" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/rock117/tushare-api 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" "+0c70cfbec949d241375e31c5a42066be70c720fc" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded tokio v1.47.0
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/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:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+0c70cfbec949d241375e31c5a42066be70c720fc" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 7adcdeedd93bf61348ea8aa75e1a3659a71b7fce2087d9ffbe86764b4e47eaa5
[INFO] running `Command { std: "docker" "start" "-a" "7adcdeedd93bf61348ea8aa75e1a3659a71b7fce2087d9ffbe86764b4e47eaa5", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "7adcdeedd93bf61348ea8aa75e1a3659a71b7fce2087d9ffbe86764b4e47eaa5", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "7adcdeedd93bf61348ea8aa75e1a3659a71b7fce2087d9ffbe86764b4e47eaa5", kill_on_drop: false }`
[INFO] [stdout] 7adcdeedd93bf61348ea8aa75e1a3659a71b7fce2087d9ffbe86764b4e47eaa5
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/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:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+0c70cfbec949d241375e31c5a42066be70c720fc" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 19cc3ed2adf93b618bebb633c47aac15ea9df79d2f5f393676781f8589448a2d
[INFO] running `Command { std: "docker" "start" "-a" "19cc3ed2adf93b618bebb633c47aac15ea9df79d2f5f393676781f8589448a2d", kill_on_drop: false }`
[INFO] [stderr]     Checking smallvec v1.15.1
[INFO] [stderr]    Compiling lock_api v0.4.13
[INFO] [stderr]    Compiling cc v1.2.30
[INFO] [stderr]    Compiling parking_lot_core v0.9.11
[INFO] [stderr]    Compiling syn v2.0.104
[INFO] [stderr]     Checking signal-hook-registry v1.4.5
[INFO] [stderr]     Checking socket2 v0.6.0
[INFO] [stderr]     Checking memchr v2.7.5
[INFO] [stderr]     Checking tracing-core v0.1.34
[INFO] [stderr]     Checking futures-task v0.3.31
[INFO] [stderr]     Checking hashbrown v0.15.4
[INFO] [stderr]     Checking futures-util v0.3.31
[INFO] [stderr]     Checking slab v0.4.10
[INFO] [stderr]     Checking parking_lot v0.12.4
[INFO] [stderr]     Checking aho-corasick v1.1.3
[INFO] [stderr]    Compiling serde_json v1.0.141
[INFO] [stderr]     Checking is-terminal v0.4.16
[INFO] [stderr]     Checking encoding_rs v0.8.35
[INFO] [stderr]     Checking tracing v0.1.41
[INFO] [stderr]     Checking humantime v2.2.0
[INFO] [stderr]     Checking indexmap v2.10.0
[INFO] [stderr]     Checking unicode-ident v1.0.18
[INFO] [stderr]     Checking proc-macro2 v1.0.95
[INFO] [stderr]    Compiling openssl-sys v0.9.109
[INFO] [stderr]     Checking quote v1.0.40
[INFO] [stderr]     Checking regex-automata v0.4.9
[INFO] [stderr]    Compiling openssl v0.10.73
[INFO] [stderr]    Compiling native-tls v0.2.14
[INFO] [stderr]    Compiling synstructure v0.13.2
[INFO] [stderr]     Checking regex v1.11.1
[INFO] [stderr]    Compiling zerofrom-derive v0.1.6
[INFO] [stderr]    Compiling yoke-derive v0.8.0
[INFO] [stderr]    Compiling zerovec-derive v0.11.1
[INFO] [stderr]    Compiling displaydoc v0.2.5
[INFO] [stderr]    Compiling tokio-macros v2.5.0
[INFO] [stderr]    Compiling openssl-macros v0.1.1
[INFO] [stderr]    Compiling serde_derive v1.0.219
[INFO] [stderr]     Checking env_logger v0.10.2
[INFO] [stderr]     Checking tokio v1.47.0
[INFO] [stderr]    Compiling tushare-derive v1.1.0 (/opt/rustwide/workdir/tushare-derive)
[INFO] [stderr]     Checking zerofrom v0.1.6
[INFO] [stderr]     Checking yoke v0.8.0
[INFO] [stderr]     Checking zerovec v0.11.2
[INFO] [stderr]     Checking zerotrie v0.2.2
[INFO] [stderr]     Checking tinystr v0.8.1
[INFO] [stderr]     Checking potential_utf v0.1.2
[INFO] [stderr]     Checking icu_collections v2.0.0
[INFO] [stderr]     Checking icu_locale_core v2.0.0
[INFO] [stderr]     Checking serde v1.0.219
[INFO] [stderr]     Checking icu_provider v2.0.0
[INFO] [stderr]     Checking icu_properties v2.0.1
[INFO] [stderr]     Checking icu_normalizer v2.0.0
[INFO] [stderr]     Checking idna_adapter v1.2.1
[INFO] [stderr]     Checking idna v1.0.3
[INFO] [stderr]     Checking tokio-util v0.7.15
[INFO] [stderr]     Checking tokio-native-tls v0.3.1
[INFO] [stderr]     Checking url v2.5.4
[INFO] [stderr]     Checking h2 v0.3.27
[INFO] [stderr]     Checking serde_urlencoded v0.7.1
[INFO] [stderr]     Checking hyper v0.14.32
[INFO] [stderr]     Checking hyper-tls v0.5.0
[INFO] [stderr]     Checking reqwest v0.11.27
[INFO] [stderr]     Checking tushare-api v1.1.2 (/opt/rustwide/workdir)
[INFO] [stdout] error[E0308]: mismatched types
[INFO] [stdout]    --> src/utils.rs:159:19
[INFO] [stdout]     |
[INFO] [stdout] 159 |               data: TushareData {
[INFO] [stdout]     |  ___________________^
[INFO] [stdout] 160 | |                 fields: vec![
[INFO] [stdout] 161 | |                     "ts_code".to_string(),
[INFO] [stdout] 162 | |                     "symbol".to_string(),
[INFO] [stdout] ...   |
[INFO] [stdout] 181 | |                 count: 2,
[INFO] [stdout] 182 | |             },
[INFO] [stdout]     | |_____________^ expected `Option<TushareData>`, found `TushareData`
[INFO] [stdout]     |
[INFO] [stdout]     = note: expected enum `std::option::Option<TushareData>`
[INFO] [stdout]              found struct `TushareData`
[INFO] [stdout] help: try wrapping the expression in `Some`
[INFO] [stdout]     |
[INFO] [stdout] 159 ~             data: Some(TushareData {
[INFO] [stdout] 160 |                 fields: vec![
[INFO] [stdout] ...
[INFO] [stdout] 181 |                 count: 2,
[INFO] [stdout] 182 ~             }),
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/types.rs:211:17
[INFO] [stdout]     |
[INFO] [stdout] 211 |     pub fn iter(&self) -> std::slice::Iter<T> {
[INFO] [stdout]     |                 ^^^^^     ^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 211 |     pub fn iter(&self) -> std::slice::Iter<'_, T> {
[INFO] [stdout]     |                                            +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/types.rs:216:21
[INFO] [stdout]     |
[INFO] [stdout] 216 |     pub fn iter_mut(&mut self) -> std::slice::IterMut<T> {
[INFO] [stdout]     |                     ^^^^^^^^^     ^^^^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                     |
[INFO] [stdout]     |                     the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 216 |     pub fn iter_mut(&mut self) -> std::slice::IterMut<'_, T> {
[INFO] [stdout]     |                                                       +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `LogConfig`
[INFO] [stdout]  --> examples/tracing_example.rs:6:65
[INFO] [stdout]   |
[INFO] [stdout] 6 | use tushare_api::{TushareClient, TushareRequest, Api, LogLevel, LogConfig};
[INFO] [stdout]   |                                                                 ^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unexpected `cfg` condition value: `tracing-log`
[INFO] [stdout]   --> examples/tracing_example.rs:14:36
[INFO] [stdout]    |
[INFO] [stdout] 14 |     #[cfg(all(feature = "tracing", feature = "tracing-log"))] 
[INFO] [stdout]    |                                    ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: expected values for `feature` are: `all_types`, `bigdecimal`, `chrono`, `default`, `rust_decimal`, `tracing`, and `uuid`
[INFO] [stdout]    = help: consider adding `tracing-log` as a feature in `Cargo.toml`
[INFO] [stdout]    = note: see <https://doc.rust-lang.org/nightly/rustc/check-cfg/cargo-specifics.html> for more information about checking conditional configuration
[INFO] [stdout]    = note: `#[warn(unexpected_cfgs)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Api`, `TushareClient`, and `request`
[INFO] [stdout]  --> examples/generic_pagination_example.rs:1:19
[INFO] [stdout]   |
[INFO] [stdout] 1 | use tushare_api::{TushareClient, Api, request, TushareEntityList};
[INFO] [stdout]   |                   ^^^^^^^^^^^^^  ^^^  ^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `json`
[INFO] [stdout]  --> examples/debug_custom_type.rs:7:25
[INFO] [stdout]   |
[INFO] [stdout] 7 | use serde_json::{Value, json};
[INFO] [stdout]   |                         ^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `stock_code`, `stock_price`, and `stock_volume` are never read
[INFO] [stdout]   --> examples/debug_custom_type.rs:47:5
[INFO] [stdout]    |
[INFO] [stdout] 45 | pub struct SimpleStock {
[INFO] [stdout]    |            ----------- fields in this struct
[INFO] [stdout] 46 |     #[tushare(field = "code")]
[INFO] [stdout] 47 |     stock_code: String,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 50 |     stock_price: SimpleDecimal,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 53 |     stock_volume: Option<SimpleDecimal>,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `SimpleStock` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0382]: use of moved value: `response.data`
[INFO] [stdout]    --> src/lib.rs:130:20
[INFO] [stdout]     |
[INFO] [stdout] 129 |         assert_eq!(response.data.map(|data| data.items.len()).unwrap_or(0), 2);
[INFO] [stdout]     |                    ------------- ---------------------------- `response.data` moved due to this method call
[INFO] [stdout]     |                    |
[INFO] [stdout]     |                    help: consider calling `.as_ref()` or `.as_mut()` to borrow the type's contents
[INFO] [stdout] 130 |         assert_eq!(response.data.map(|data| data.items.len()).unwrap_or(0), 2);
[INFO] [stdout]     |                    ^^^^^^^^^^^^^ value used here after move
[INFO] [stdout]     |
[INFO] [stdout] note: `std::option::Option::<T>::map` takes ownership of the receiver `self`, which moves `response.data`
[INFO] [stdout]    --> /rustc/0c70cfbec949d241375e31c5a42066be70c720fc/library/core/src/option.rs:1160:27
[INFO] [stdout]     = note: move occurs because `response.data` has type `std::option::Option<TushareData>`, which does not implement the `Copy` trait
[INFO] [stdout] help: you can `clone` the value and consume it, but this might not be your desired behavior
[INFO] [stdout]     |
[INFO] [stdout] 129 |         assert_eq!(response.data.clone().map(|data| data.items.len()).unwrap_or(0), 2);
[INFO] [stdout]     |                                 ++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] Some errors have detailed explanations: E0308, E0382.
[INFO] [stdout] 
[INFO] [stdout] For more information about an error, try `rustc --explain E0308`.
[INFO] [stdout] 
[INFO] [stdout] error[E0609]: no field `fields` on type `Option<TushareData>`
[INFO] [stdout]   --> examples/generic_api_usage.rs:28:42
[INFO] [stdout]    |
[INFO] [stdout] 28 |     println!("返回字段: {:?}", response.data.fields);
[INFO] [stdout]    |                                              ^^^^^^ unknown field
[INFO] [stdout]    |
[INFO] [stdout] help: one of the expressions' fields has a field of the same name
[INFO] [stdout]    |
[INFO] [stdout] 28 |     println!("返回字段: {:?}", response.data.unwrap().fields);
[INFO] [stdout]    |                                              +++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0609]: no field `items` on type `Option<TushareData>`
[INFO] [stdout]   --> examples/generic_api_usage.rs:29:40
[INFO] [stdout]    |
[INFO] [stdout] 29 |     println!("数据条数: {}", response.data.items.len());
[INFO] [stdout]    |                                            ^^^^^ unknown field
[INFO] [stdout]    |
[INFO] [stdout] help: one of the expressions' fields has a field of the same name
[INFO] [stdout]    |
[INFO] [stdout] 29 |     println!("数据条数: {}", response.data.unwrap().items.len());
[INFO] [stdout]    |                                            +++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0609]: no field `items` on type `Option<TushareData>`
[INFO] [stdout]   --> examples/generic_api_usage.rs:33:36
[INFO] [stdout]    |
[INFO] [stdout] 33 |     for (i, item) in response.data.items.iter().take(5).enumerate() {
[INFO] [stdout]    |                                    ^^^^^ unknown field
[INFO] [stdout]    |
[INFO] [stdout] help: one of the expressions' fields has a field of the same name
[INFO] [stdout]    |
[INFO] [stdout] 33 |     for (i, item) in response.data.unwrap().items.iter().take(5).enumerate() {
[INFO] [stdout]    |                                    +++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0609]: no field `items` on type `Option<TushareData>`
[INFO] [stdout]   --> examples/generic_api_usage.rs:48:45
[INFO] [stdout]    |
[INFO] [stdout] 48 |     if let Some(stock_data) = response.data.items.first() {
[INFO] [stdout]    |                                             ^^^^^ unknown field
[INFO] [stdout]    |
[INFO] [stdout] help: one of the expressions' fields has a field of the same name
[INFO] [stdout]    |
[INFO] [stdout] 48 |     if let Some(stock_data) = response.data.unwrap().items.first() {
[INFO] [stdout]    |                                             +++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0609]: no field `fields` on type `Option<TushareData>`
[INFO] [stdout]   --> examples/generic_api_usage.rs:50:45
[INFO] [stdout]    |
[INFO] [stdout] 50 |         for (field, value) in response.data.fields.iter().zip(stock_data.iter()) {
[INFO] [stdout]    |                                             ^^^^^^ unknown field
[INFO] [stdout]    |
[INFO] [stdout] help: one of the expressions' fields has a field of the same name
[INFO] [stdout]    |
[INFO] [stdout] 50 |         for (field, value) in response.data.unwrap().fields.iter().zip(stock_data.iter()) {
[INFO] [stdout]    |                                             +++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0282]: type annotations needed
[INFO] [stdout]   --> examples/generic_api_usage.rs:50:63
[INFO] [stdout]    |
[INFO] [stdout] 50 |         for (field, value) in response.data.fields.iter().zip(stock_data.iter()) {
[INFO] [stdout]    |                                                               ^^^^^^^^^^ cannot infer type
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `tushare-api` (lib test) due to 2 previous errors
[INFO] [stderr] warning: build failed, waiting for other jobs to finish...
[INFO] [stdout] Some errors have detailed explanations: E0282, E0609.
[INFO] [stdout] 
[INFO] [stdout] For more information about an error, try `rustc --explain E0282`.
[INFO] [stdout] 
[INFO] [stdout] error[E0308]: mismatched types
[INFO] [stdout]   --> examples/generic_pagination_example.rs:21:15
[INFO] [stdout]    |
[INFO] [stdout] 21 |           data: TushareData {
[INFO] [stdout]    |  _______________^
[INFO] [stdout] 22 | |             fields: vec!["ts_code".to_string(), "name".to_string(), "area".to_string()],
[INFO] [stdout] 23 | |             items: vec![
[INFO] [stdout] 24 | |                 vec![json!("000001.SZ"), json!("平安银行"), json!("深圳")],
[INFO] [stdout] ...  |
[INFO] [stdout] 29 | |             count: 4500,
[INFO] [stdout] 30 | |         },
[INFO] [stdout]    | |_________^ expected `Option<TushareData>`, found `TushareData`
[INFO] [stdout]    |
[INFO] [stdout]    = note: expected enum `Option<TushareData>`
[INFO] [stdout]             found struct `TushareData`
[INFO] [stdout] help: try wrapping the expression in `Some`
[INFO] [stdout]    |
[INFO] [stdout] 21 ~         data: Some(TushareData {
[INFO] [stdout] 22 |             fields: vec!["ts_code".to_string(), "name".to_string(), "area".to_string()],
[INFO] [stdout] ...
[INFO] [stdout] 29 |             count: 4500,
[INFO] [stdout] 30 ~         }),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `tushare-api` (example "generic_api_usage") due to 6 previous errors
[INFO] [stdout] error[E0609]: no field `items` on type `Option<TushareData>`
[INFO] [stdout]   --> examples/env_usage.rs:32:54
[INFO] [stdout]    |
[INFO] [stdout] 32 |             println!("✅ 成功获取到 {} 条记录", response.data.items.len());
[INFO] [stdout]    |                                                               ^^^^^ unknown field
[INFO] [stdout]    |
[INFO] [stdout] help: one of the expressions' fields has a field of the same name
[INFO] [stdout]    |
[INFO] [stdout] 32 |             println!("✅ 成功获取到 {} 条记录", response.data.unwrap().items.len());
[INFO] [stdout]    |                                                               +++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0609]: no field `items` on type `Option<TushareData>`
[INFO] [stdout]   --> examples/env_usage.rs:36:44
[INFO] [stdout]    |
[INFO] [stdout] 36 |             for (i, item) in response.data.items.iter().take(5).enumerate() {
[INFO] [stdout]    |                                            ^^^^^ unknown field
[INFO] [stdout]    |
[INFO] [stdout] help: one of the expressions' fields has a field of the same name
[INFO] [stdout]    |
[INFO] [stdout] 36 |             for (i, item) in response.data.unwrap().items.iter().take(5).enumerate() {
[INFO] [stdout]    |                                            +++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0609]: no field `items` on type `Option<TushareData>`
[INFO] [stdout]   --> examples/env_usage.rs:63:47
[INFO] [stdout]    |
[INFO] [stdout] 63 |             if let Some(item) = response.data.items.first() {
[INFO] [stdout]    |                                               ^^^^^ unknown field
[INFO] [stdout]    |
[INFO] [stdout] help: one of the expressions' fields has a field of the same name
[INFO] [stdout]    |
[INFO] [stdout] 63 |             if let Some(item) = response.data.unwrap().items.first() {
[INFO] [stdout]    |                                               +++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0609]: no field `fields` on type `Option<TushareData>`
[INFO] [stdout]   --> examples/env_usage.rs:65:53
[INFO] [stdout]    |
[INFO] [stdout] 65 |                 for (field, value) in response.data.fields.iter().zip(item.iter()) {
[INFO] [stdout]    |                                                     ^^^^^^ unknown field
[INFO] [stdout]    |
[INFO] [stdout] help: one of the expressions' fields has a field of the same name
[INFO] [stdout]    |
[INFO] [stdout] 65 |                 for (field, value) in response.data.unwrap().fields.iter().zip(item.iter()) {
[INFO] [stdout]    |                                                     +++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0282]: type annotations needed
[INFO] [stdout]   --> examples/env_usage.rs:65:71
[INFO] [stdout]    |
[INFO] [stdout] 65 |                 for (field, value) in response.data.fields.iter().zip(item.iter()) {
[INFO] [stdout]    |                                                                       ^^^^ cannot infer type
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0609]: no field `items` on type `Option<TushareData>`
[INFO] [stdout]   --> examples/basic_usage.rs:25:52
[INFO] [stdout]    |
[INFO] [stdout] 25 |             println!("成功获取到 {} 条记录", response.data.items.len());
[INFO] [stdout]    |                                                            ^^^^^ unknown field
[INFO] [stdout]    |
[INFO] [stdout] help: one of the expressions' fields has a field of the same name
[INFO] [stdout]    |
[INFO] [stdout] 25 |             println!("成功获取到 {} 条记录", response.data.unwrap().items.len());
[INFO] [stdout]    |                                                            +++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0609]: no field `items` on type `Option<TushareData>`
[INFO] [stdout]   --> examples/basic_usage.rs:29:44
[INFO] [stdout]    |
[INFO] [stdout] 29 |             for (i, item) in response.data.items.iter().take(10).enumerate() {
[INFO] [stdout]    |                                            ^^^^^ unknown field
[INFO] [stdout]    |
[INFO] [stdout] help: one of the expressions' fields has a field of the same name
[INFO] [stdout]    |
[INFO] [stdout] 29 |             for (i, item) in response.data.unwrap().items.iter().take(10).enumerate() {
[INFO] [stdout]    |                                            +++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] For more information about this error, try `rustc --explain E0308`.
[INFO] [stdout] 
[INFO] [stdout] error[E0609]: no field `items` on type `Option<TushareData>`
[INFO] [stdout]   --> examples/basic_usage.rs:65:47
[INFO] [stdout]    |
[INFO] [stdout] 65 |             if let Some(item) = response.data.items.first() {
[INFO] [stdout]    |                                               ^^^^^ unknown field
[INFO] [stdout]    |
[INFO] [stdout] help: one of the expressions' fields has a field of the same name
[INFO] [stdout]    |
[INFO] [stdout] 65 |             if let Some(item) = response.data.unwrap().items.first() {
[INFO] [stdout]    |                                               +++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0609]: no field `fields` on type `Option<TushareData>`
[INFO] [stdout]   --> examples/basic_usage.rs:67:53
[INFO] [stdout]    |
[INFO] [stdout] 67 |                 for (field, value) in response.data.fields.iter().zip(item.iter()) {
[INFO] [stdout]    |                                                     ^^^^^^ unknown field
[INFO] [stdout]    |
[INFO] [stdout] help: one of the expressions' fields has a field of the same name
[INFO] [stdout]    |
[INFO] [stdout] 67 |                 for (field, value) in response.data.unwrap().fields.iter().zip(item.iter()) {
[INFO] [stdout]    |                                                     +++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0282]: type annotations needed
[INFO] [stdout]   --> examples/basic_usage.rs:67:71
[INFO] [stdout]    |
[INFO] [stdout] 67 |                 for (field, value) in response.data.fields.iter().zip(item.iter()) {
[INFO] [stdout]    |                                                                       ^^^^ cannot infer type
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] Some errors have detailed explanations: E0282, E0609.
[INFO] [stdout] 
[INFO] [stdout] For more information about an error, try `rustc --explain E0282`.
[INFO] [stdout] 
[INFO] [stdout] Some errors have detailed explanations: E0282, E0609.
[INFO] [stdout] 
[INFO] [stdout] For more information about an error, try `rustc --explain E0282`.
[INFO] [stdout] 
[INFO] [stdout] error[E0609]: no field `items` on type `Option<TushareData>`
[INFO] [stdout]   --> examples/logging_example.rs:81:64
[INFO] [stdout]    |
[INFO] [stdout] 81 |                 println!("✅ API 调用成功，返回 {} 条记录", response.data.items.len());
[INFO] [stdout]    |                                                                           ^^^^^ unknown field
[INFO] [stdout]    |
[INFO] [stdout] help: one of the expressions' fields has a field of the same name
[INFO] [stdout]    |
[INFO] [stdout] 81 |                 println!("✅ API 调用成功，返回 {} 条记录", response.data.unwrap().items.len());
[INFO] [stdout]    |                                                                           +++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `tushare-api` (example "generic_pagination_example") due to 1 previous error; 1 warning emitted
[INFO] [stderr] error: could not compile `tushare-api` (example "basic_usage") due to 5 previous errors
[INFO] [stderr] error: could not compile `tushare-api` (example "env_usage") due to 5 previous errors
[INFO] [stdout] For more information about this error, try `rustc --explain E0609`.
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `tushare-api` (example "logging_example") due to 1 previous error
[INFO] running `Command { std: "docker" "inspect" "19cc3ed2adf93b618bebb633c47aac15ea9df79d2f5f393676781f8589448a2d", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "19cc3ed2adf93b618bebb633c47aac15ea9df79d2f5f393676781f8589448a2d", kill_on_drop: false }`
[INFO] [stdout] 19cc3ed2adf93b618bebb633c47aac15ea9df79d2f5f393676781f8589448a2d
