From 337b3cc6b75acd00cef0c58cd793be5b6d1a1d90 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?D=C3=A1niel=20Buga?= Date: Fri, 3 Jan 2025 15:36:30 +0100 Subject: [PATCH] Use `_CONFIG_` to separate config prefix and key (#2848) * Use two underscores to separate prefix * Change separator to _CONFIG_ --------- Co-authored-by: Scott Mabin --- esp-config/CHANGELOG.md | 2 + esp-config/src/generate.rs | 70 +++++++++++++++++++------------- esp-hal-embassy/CHANGELOG.md | 2 + esp-hal-embassy/MIGRATING-0.5.md | 14 +++++++ esp-hal/CHANGELOG.md | 2 + esp-hal/MIGRATING-0.22.md | 18 +++++++- esp-ieee802154/CHANGELOG.md | 2 + esp-ieee802154/MIGRATING-0.4.md | 15 +++++++ esp-ieee802154/src/lib.rs | 2 +- esp-wifi/CHANGELOG.md | 2 + esp-wifi/MIGRATING-0.11.md | 18 ++++++++ esp-wifi/src/lib.rs | 45 ++++++++++---------- examples/.cargo/config.toml | 2 +- 13 files changed, 142 insertions(+), 52 deletions(-) create mode 100644 esp-ieee802154/MIGRATING-0.4.md diff --git a/esp-config/CHANGELOG.md b/esp-config/CHANGELOG.md index 94c435aa723..140d4472f7f 100644 --- a/esp-config/CHANGELOG.md +++ b/esp-config/CHANGELOG.md @@ -15,6 +15,8 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 ### Changed +- Crate prefixes and configuration keys are now separated by `_CONFIG_` (#2848) + ### Removed ## 0.2.0 - 2024-11-20 diff --git a/esp-config/src/generate.rs b/esp-config/src/generate.rs index ede216f5d27..3a9f6711522 100644 --- a/esp-config/src/generate.rs +++ b/esp-config/src/generate.rs @@ -249,7 +249,7 @@ fn integer_in_range(range: &Range, value: &Value) -> Result<(), Error> { /// /// Unknown keys with the supplied prefix will cause this function to panic. pub fn generate_config( - prefix: &str, + crate_name: &str, config: &[(&str, &str, Value, Option)], emit_md_tables: bool, ) -> HashMap { @@ -264,7 +264,7 @@ pub fn generate_config( let mut selected_config = String::from(SELECTED_TABLE_HEADER); // Ensure that the prefix is `SCREAMING_SNAKE_CASE`: - let prefix = screaming_snake_case(prefix); + let prefix = format!("{}_CONFIG_", screaming_snake_case(crate_name)); // Build a lookup table for any provided validators; we must prefix the // name of the config and transform it to SCREAMING_SNAKE_CASE so that @@ -273,7 +273,7 @@ pub fn generate_config( .iter() .flat_map(|(name, _description, _default, validator)| { if let Some(validator) = validator { - let name = format!("{prefix}_{}", screaming_snake_case(name)); + let name = format!("{prefix}{}", screaming_snake_case(name)); Some((name, validator)) } else { None @@ -293,7 +293,7 @@ pub fn generate_config( emit_configuration(&prefix, &configs, &mut selected_config); if emit_md_tables { - let file_name = snake_case(&prefix); + let file_name = snake_case(crate_name); write_config_tables(&file_name, doc_table, selected_config); } @@ -341,7 +341,7 @@ fn create_config( let mut configs = HashMap::new(); for (name, description, default, _validator) in config { - let name = format!("{prefix}_{}", screaming_snake_case(name)); + let name = format!("{prefix}{}", screaming_snake_case(name)); configs.insert(name.clone(), default.clone()); // Write documentation table line: @@ -361,7 +361,7 @@ fn capture_from_env(prefix: &str, configs: &mut HashMap) { // Try and capture input from the environment: for (var, value) in env::vars() { - if var.strip_prefix(prefix).is_some() { + if var.starts_with(prefix) { let Some(cfg) = configs.get_mut(&var) else { unknown.push(var); continue; @@ -388,7 +388,7 @@ fn emit_configuration( selected_config: &mut String, ) { for (name, value) in configs.iter() { - let cfg_name = snake_case(name.trim_start_matches(&format!("{prefix}_"))); + let cfg_name = snake_case(name.trim_start_matches(prefix)); println!("cargo:rustc-check-cfg=cfg({cfg_name})"); if let Value::Bool(true) = value { @@ -464,10 +464,10 @@ mod test { fn env_override() { temp_env::with_vars( [ - ("ESP_TEST_NUMBER", Some("0xaa")), - ("ESP_TEST_NUMBER_SIGNED", Some("-999")), - ("ESP_TEST_STRING", Some("Hello world!")), - ("ESP_TEST_BOOL", Some("true")), + ("ESP_TEST_CONFIG_NUMBER", Some("0xaa")), + ("ESP_TEST_CONFIG_NUMBER_SIGNED", Some("-999")), + ("ESP_TEST_CONFIG_STRING", Some("Hello world!")), + ("ESP_TEST_CONFIG_BOOL", Some("true")), ], || { let configs = generate_config( @@ -491,28 +491,28 @@ mod test { // some values have changed assert_eq!( - match configs.get("ESP_TEST_NUMBER").unwrap() { + match configs.get("ESP_TEST_CONFIG_NUMBER").unwrap() { Value::Integer(num) => *num, _ => unreachable!(), }, 0xaa ); assert_eq!( - match configs.get("ESP_TEST_NUMBER_SIGNED").unwrap() { + match configs.get("ESP_TEST_CONFIG_NUMBER_SIGNED").unwrap() { Value::Integer(num) => *num, _ => unreachable!(), }, -999 ); assert_eq!( - match configs.get("ESP_TEST_STRING").unwrap() { + match configs.get("ESP_TEST_CONFIG_STRING").unwrap() { Value::String(val) => val, _ => unreachable!(), }, "Hello world!" ); assert_eq!( - match configs.get("ESP_TEST_BOOL").unwrap() { + match configs.get("ESP_TEST_CONFIG_BOOL").unwrap() { Value::Bool(val) => *val, _ => unreachable!(), }, @@ -521,21 +521,21 @@ mod test { // the rest are the defaults assert_eq!( - match configs.get("ESP_TEST_NUMBER_DEFAULT").unwrap() { + match configs.get("ESP_TEST_CONFIG_NUMBER_DEFAULT").unwrap() { Value::Integer(num) => *num, _ => unreachable!(), }, 999 ); assert_eq!( - match configs.get("ESP_TEST_STRING_DEFAULT").unwrap() { + match configs.get("ESP_TEST_CONFIG_STRING_DEFAULT").unwrap() { Value::String(val) => val, _ => unreachable!(), }, "Demo" ); assert_eq!( - match configs.get("ESP_TEST_BOOL_DEFAULT").unwrap() { + match configs.get("ESP_TEST_CONFIG_BOOL_DEFAULT").unwrap() { Value::Bool(val) => *val, _ => unreachable!(), }, @@ -549,10 +549,10 @@ mod test { fn builtin_validation_passes() { temp_env::with_vars( [ - ("ESP_TEST_POSITIVE_NUMBER", Some("7")), - ("ESP_TEST_NEGATIVE_NUMBER", Some("-1")), - ("ESP_TEST_NON_NEGATIVE_NUMBER", Some("0")), - ("ESP_TEST_RANGE", Some("9")), + ("ESP_TEST_CONFIG_POSITIVE_NUMBER", Some("7")), + ("ESP_TEST_CONFIG_NEGATIVE_NUMBER", Some("-1")), + ("ESP_TEST_CONFIG_NON_NEGATIVE_NUMBER", Some("0")), + ("ESP_TEST_CONFIG_RANGE", Some("9")), ], || { generate_config( @@ -591,7 +591,7 @@ mod test { #[test] fn custom_validation_passes() { - temp_env::with_vars([("ESP_TEST_NUMBER", Some("13"))], || { + temp_env::with_vars([("ESP_TEST_CONFIG_NUMBER", Some("13"))], || { generate_config( "esp-test", &[( @@ -615,7 +615,7 @@ mod test { #[test] #[should_panic] fn builtin_validation_bails() { - temp_env::with_vars([("ESP_TEST_POSITIVE_NUMBER", Some("-99"))], || { + temp_env::with_vars([("ESP_TEST_CONFIG_POSITIVE_NUMBER", Some("-99"))], || { generate_config( "esp-test", &[( @@ -632,7 +632,7 @@ mod test { #[test] #[should_panic] fn custom_validation_bails() { - temp_env::with_vars([("ESP_TEST_NUMBER", Some("37"))], || { + temp_env::with_vars([("ESP_TEST_CONFIG_NUMBER", Some("37"))], || { generate_config( "esp-test", &[( @@ -658,8 +658,8 @@ mod test { fn env_unknown_bails() { temp_env::with_vars( [ - ("ESP_TEST_NUMBER", Some("0xaa")), - ("ESP_TEST_RANDOM_VARIABLE", Some("")), + ("ESP_TEST_CONFIG_NUMBER", Some("0xaa")), + ("ESP_TEST_CONFIG_RANDOM_VARIABLE", Some("")), ], || { generate_config( @@ -674,7 +674,7 @@ mod test { #[test] #[should_panic] fn env_invalid_values_bails() { - temp_env::with_vars([("ESP_TEST_NUMBER", Some("Hello world"))], || { + temp_env::with_vars([("ESP_TEST_CONFIG_NUMBER", Some("Hello world"))], || { generate_config( "esp-test", &[("number", "NA", Value::Integer(999), None)], @@ -682,4 +682,18 @@ mod test { ); }); } + + #[test] + fn env_unknown_prefix_is_ignored() { + temp_env::with_vars( + [("ESP_TEST_OTHER_CONFIG_NUMBER", Some("Hello world"))], + || { + generate_config( + "esp-test", + &[("number", "NA", Value::Integer(999), None)], + false, + ); + }, + ); + } } diff --git a/esp-hal-embassy/CHANGELOG.md b/esp-hal-embassy/CHANGELOG.md index 9482b188b1e..03e83cbdcea 100644 --- a/esp-hal-embassy/CHANGELOG.md +++ b/esp-hal-embassy/CHANGELOG.md @@ -14,6 +14,8 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 - Bump MSRV to 1.83 (#2615) +- Config: Crate prefixes and configuration keys are now separated by `_CONFIG_` (#2848) + ### Fixed ### Removed diff --git a/esp-hal-embassy/MIGRATING-0.5.md b/esp-hal-embassy/MIGRATING-0.5.md index 921c13c4448..a8ff8589987 100644 --- a/esp-hal-embassy/MIGRATING-0.5.md +++ b/esp-hal-embassy/MIGRATING-0.5.md @@ -1 +1,15 @@ # Migration Guide from 0.5.x to v0.6.x + +## Crate configuration changes + +To prevent ambiguity between configurations, we had to change the naming format of configuration +keys. Before, we used `{prefix}_{key}`, which meant that esp-hal and esp-hal-* configuration keys +were impossible to tell apart. To fix this issue, we are changing the separator from one underscore +character to `_CONFIG_`. This also means that users will have to change their `config.toml` +configurations to match the new format. + +```diff + [env] +-ESP_HAL_EMBASSY_LOW_POWER_WAIT="false" ++ESP_HAL_EMBASSY_CONFIG_LOW_POWER_WAIT="false" +``` diff --git a/esp-hal/CHANGELOG.md b/esp-hal/CHANGELOG.md index af6485bebb1..e0b7748b51d 100644 --- a/esp-hal/CHANGELOG.md +++ b/esp-hal/CHANGELOG.md @@ -182,6 +182,8 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 - The `Camera` and `I8080` drivers' constructors now only accepts blocking-mode DMA channels. (#2519) - Many peripherals are now disabled by default and also get disabled when the driver is dropped (#2544) +- Config: Crate prefixes and configuration keys are now separated by `_CONFIG_` (#2848) + ### Fixed - Fix conflict between `RtcClock::get_xtal_freq` and `Rtc::disable_rom_message_printing` (#2360) diff --git a/esp-hal/MIGRATING-0.22.md b/esp-hal/MIGRATING-0.22.md index fce9779dda3..3a50f105d6e 100644 --- a/esp-hal/MIGRATING-0.22.md +++ b/esp-hal/MIGRATING-0.22.md @@ -343,6 +343,21 @@ The reexports that were previously part of the prelude are available through oth + uart0.set_at_cmd(AtCmdConfig::default().with_cmd_char(b'#')); ``` + +## Crate configuration changes + +To prevent ambiguity between configurations, we had to change the naming format of configuration +keys. Before, we used `{prefix}_{key}`, which meant that esp-hal and esp-hal-* configuration keys +were impossible to tell apart. To fix this issue, we are changing the separator from one underscore +character to `_CONFIG_`. This also means that users will have to change their `config.toml` +configurations to match the new format. + +```diff + [env] +-ESP_HAL_PLACE_SPI_DRIVER_IN_RAM="true" ++ESP_HAL_CONFIG_PLACE_SPI_DRIVER_IN_RAM="true" +``` + ## UART changes The `Config` struct's setters are now prefixed with `with_`. `parity_none`, `parity_even`, @@ -353,4 +368,5 @@ The `Config` struct's setters are now prefixed with `with_`. `parity_none`, `par - .rx_fifo_full_threshold(30) + .with_rx_fifo_full_threshold(30) - .parity_even(); -+ .with_parity(Parity::Even); \ No newline at end of file ++ .with_parity(Parity::Even); +``` diff --git a/esp-ieee802154/CHANGELOG.md b/esp-ieee802154/CHANGELOG.md index 658aec3ae2d..b11f9205d7e 100644 --- a/esp-ieee802154/CHANGELOG.md +++ b/esp-ieee802154/CHANGELOG.md @@ -14,6 +14,8 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 - Bump MSRV to 1.83 (#2615) +- Config: Crate prefixes and configuration keys are now separated by `_CONFIG_` (#2848) + ### Fixed ### Removed diff --git a/esp-ieee802154/MIGRATING-0.4.md b/esp-ieee802154/MIGRATING-0.4.md new file mode 100644 index 00000000000..3f3c1717d2b --- /dev/null +++ b/esp-ieee802154/MIGRATING-0.4.md @@ -0,0 +1,15 @@ +# Migration Guide from 0.4.x to v0.5.x + +## Crate configuration changes + +To prevent ambiguity between configurations, we had to change the naming format of configuration +keys. Before, we used `{prefix}_{key}`, which meant that esp-hal and esp-hal-* configuration keys +were impossible to tell apart. To fix this issue, we are changing the separator from one underscore +character to `_CONFIG_`. This also means that users will have to change their `config.toml` +configurations to match the new format. + +```diff + [env] +-ESP_IEEE802154_RX_QUEUE_SIZE = "50" ++ESP_IEEE802154_CONFIG_RX_QUEUE_SIZE = "50" +``` diff --git a/esp-ieee802154/src/lib.rs b/esp-ieee802154/src/lib.rs index 65400db64da..3dc6bb40367 100644 --- a/esp-ieee802154/src/lib.rs +++ b/esp-ieee802154/src/lib.rs @@ -67,7 +67,7 @@ struct QueueConfig { } pub(crate) const CONFIG: QueueConfig = QueueConfig { - rx_queue_size: esp_config_int!(usize, "ESP_IEEE802154_RX_QUEUE_SIZE"), + rx_queue_size: esp_config_int!(usize, "ESP_IEEE802154_CONFIG_RX_QUEUE_SIZE"), }; /// IEEE 802.15.4 driver configuration diff --git a/esp-wifi/CHANGELOG.md b/esp-wifi/CHANGELOG.md index 4834735ca7c..eb907eaf444 100644 --- a/esp-wifi/CHANGELOG.md +++ b/esp-wifi/CHANGELOG.md @@ -39,6 +39,8 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 - `phy_enable_usb` is enabled by default (#2446) - Removed `get_` prefixes from functions (#2528) +- Config: Crate prefixes and configuration keys are now separated by `_CONFIG_` (#2848) + ### Fixed - Fixed a possible crash when parsing results from a radius server (#2380) diff --git a/esp-wifi/MIGRATING-0.11.md b/esp-wifi/MIGRATING-0.11.md index 71b1cd4852c..cca35e52097 100644 --- a/esp-wifi/MIGRATING-0.11.md +++ b/esp-wifi/MIGRATING-0.11.md @@ -1 +1,19 @@ # Migration Guide from 0.11.x to v0.12.x + +## Crate configuration changes + +To prevent ambiguity between configurations, we had to change the naming format of configuration +keys. Before, we used `{prefix}_{key}`, which meant that esp-hal and esp-hal-* configuration keys +were impossible to tell apart. To fix this issue, we are changing the separator from one to two +underscore characters. This also means that users will have to change their `config.toml` +configurations to match the new format. + +```diff + [env] +-ESP_WIFI_RX_QUEUE_SIZE = "16" +-ESP_WIFI_STATIC_RX_BUF_NUM = "32" +-ESP_WIFI_DYNAMIC_RX_BUF_NUM = "16" ++ESP_WIFI_CONFIG_RX_QUEUE_SIZE = "16" ++ESP_WIFI_CONFIG_STATIC_RX_BUF_NUM = "32" ++ESP_WIFI_CONFIG_DYNAMIC_RX_BUF_NUM = "16" +``` diff --git a/esp-wifi/src/lib.rs b/esp-wifi/src/lib.rs index 0edfcea9e45..4fa728485e4 100644 --- a/esp-wifi/src/lib.rs +++ b/esp-wifi/src/lib.rs @@ -196,27 +196,30 @@ struct Config { } pub(crate) const CONFIG: config::EspWifiConfig = config::EspWifiConfig { - rx_queue_size: esp_config_int!(usize, "ESP_WIFI_RX_QUEUE_SIZE"), - tx_queue_size: esp_config_int!(usize, "ESP_WIFI_TX_QUEUE_SIZE"), - static_rx_buf_num: esp_config_int!(usize, "ESP_WIFI_STATIC_RX_BUF_NUM"), - dynamic_rx_buf_num: esp_config_int!(usize, "ESP_WIFI_DYNAMIC_RX_BUF_NUM"), - static_tx_buf_num: esp_config_int!(usize, "ESP_WIFI_STATIC_TX_BUF_NUM"), - dynamic_tx_buf_num: esp_config_int!(usize, "ESP_WIFI_DYNAMIC_TX_BUF_NUM"), - csi_enable: esp_config_bool!("ESP_WIFI_CSI_ENABLE"), - ampdu_rx_enable: esp_config_bool!("ESP_WIFI_AMPDU_RX_ENABLE"), - ampdu_tx_enable: esp_config_bool!("ESP_WIFI_AMPDU_TX_ENABLE"), - amsdu_tx_enable: esp_config_bool!("ESP_WIFI_AMSDU_TX_ENABLE"), - rx_ba_win: esp_config_int!(usize, "ESP_WIFI_RX_BA_WIN"), - max_burst_size: esp_config_int!(usize, "ESP_WIFI_MAX_BURST_SIZE"), - country_code: esp_config_str!("ESP_WIFI_COUNTRY_CODE"), - country_code_operating_class: esp_config_int!(u8, "ESP_WIFI_COUNTRY_CODE_OPERATING_CLASS"), - mtu: esp_config_int!(usize, "ESP_WIFI_MTU"), - tick_rate_hz: esp_config_int!(u32, "ESP_WIFI_TICK_RATE_HZ"), - listen_interval: esp_config_int!(u16, "ESP_WIFI_LISTEN_INTERVAL"), - beacon_timeout: esp_config_int!(u16, "ESP_WIFI_BEACON_TIMEOUT"), - ap_beacon_timeout: esp_config_int!(u16, "ESP_WIFI_AP_BEACON_TIMEOUT"), - failure_retry_cnt: esp_config_int!(u8, "ESP_WIFI_FAILURE_RETRY_CNT"), - scan_method: esp_config_int!(u32, "ESP_WIFI_SCAN_METHOD"), + rx_queue_size: esp_config_int!(usize, "ESP_WIFI_CONFIG_RX_QUEUE_SIZE"), + tx_queue_size: esp_config_int!(usize, "ESP_WIFI_CONFIG_TX_QUEUE_SIZE"), + static_rx_buf_num: esp_config_int!(usize, "ESP_WIFI_CONFIG_STATIC_RX_BUF_NUM"), + dynamic_rx_buf_num: esp_config_int!(usize, "ESP_WIFI_CONFIG_DYNAMIC_RX_BUF_NUM"), + static_tx_buf_num: esp_config_int!(usize, "ESP_WIFI_CONFIG_STATIC_TX_BUF_NUM"), + dynamic_tx_buf_num: esp_config_int!(usize, "ESP_WIFI_CONFIG_DYNAMIC_TX_BUF_NUM"), + csi_enable: esp_config_bool!("ESP_WIFI_CONFIG_CSI_ENABLE"), + ampdu_rx_enable: esp_config_bool!("ESP_WIFI_CONFIG_AMPDU_RX_ENABLE"), + ampdu_tx_enable: esp_config_bool!("ESP_WIFI_CONFIG_AMPDU_TX_ENABLE"), + amsdu_tx_enable: esp_config_bool!("ESP_WIFI_CONFIG_AMSDU_TX_ENABLE"), + rx_ba_win: esp_config_int!(usize, "ESP_WIFI_CONFIG_RX_BA_WIN"), + max_burst_size: esp_config_int!(usize, "ESP_WIFI_CONFIG_MAX_BURST_SIZE"), + country_code: esp_config_str!("ESP_WIFI_CONFIG_COUNTRY_CODE"), + country_code_operating_class: esp_config_int!( + u8, + "ESP_WIFI_CONFIG_COUNTRY_CODE_OPERATING_CLASS" + ), + mtu: esp_config_int!(usize, "ESP_WIFI_CONFIG_MTU"), + tick_rate_hz: esp_config_int!(u32, "ESP_WIFI_CONFIG_TICK_RATE_HZ"), + listen_interval: esp_config_int!(u16, "ESP_WIFI_CONFIG_LISTEN_INTERVAL"), + beacon_timeout: esp_config_int!(u16, "ESP_WIFI_CONFIG_BEACON_TIMEOUT"), + ap_beacon_timeout: esp_config_int!(u16, "ESP_WIFI_CONFIG_AP_BEACON_TIMEOUT"), + failure_retry_cnt: esp_config_int!(u8, "ESP_WIFI_CONFIG_FAILURE_RETRY_CNT"), + scan_method: esp_config_int!(u32, "ESP_WIFI_CONFIG_SCAN_METHOD"), }; // Validate the configuration at compile time diff --git a/examples/.cargo/config.toml b/examples/.cargo/config.toml index 600f74b2ea4..28c6f091bef 100644 --- a/examples/.cargo/config.toml +++ b/examples/.cargo/config.toml @@ -33,7 +33,7 @@ PASSWORD = "PASSWORD" STATIC_IP = "1.1.1.1 " GATEWAY_IP = "1.1.1.1" HOST_IP = "1.1.1.1" -ESP_WIFI_CSI_ENABLE = "true" +ESP_WIFI_CONFIG_CSI_ENABLE = "true" [unstable] build-std = ["alloc", "core"]