Skip to content

Commit

Permalink
[#432] Replace the relative path of the configuration file with the s…
Browse files Browse the repository at this point in the history
…tandard configuration path
  • Loading branch information
brosier01 committed Dec 24, 2024
1 parent 2d59ec1 commit 1db3c2a
Show file tree
Hide file tree
Showing 3 changed files with 20 additions and 23 deletions.
2 changes: 1 addition & 1 deletion iceoryx2-cli/iox2-config/src/commands.rs
Original file line number Diff line number Diff line change
Expand Up @@ -113,7 +113,7 @@ pub fn show() -> Result<()> {
}

pub fn generate() -> Result<()> {
let config_dir = dirs::config_dir().unwrap().join("iceoryx2/");
let config_dir = dirs::config_dir().unwrap().join("iceoryx2");
fs::create_dir_all(&config_dir)?;

let default_file_path = config_dir.join("config.toml");
Expand Down
1 change: 1 addition & 0 deletions iceoryx2/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -39,6 +39,7 @@ cdr = { workspace = true }
toml = { workspace = true }
sha1_smol = { workspace = true }
tiny-fn = { workspace = true }
dirs = { workspace = true }

[dev-dependencies]
iceoryx2-bb-testing = { workspace = true }
Expand Down
40 changes: 18 additions & 22 deletions iceoryx2/src/config.rs
Original file line number Diff line number Diff line change
Expand Up @@ -69,22 +69,20 @@
//! # }
//! ```
use dirs;
use iceoryx2_bb_container::semantic_string::SemanticString;
use iceoryx2_bb_elementary::lazy_singleton::*;
use iceoryx2_bb_posix::{file::FileBuilder, shared_memory::AccessMode};
use iceoryx2_bb_system_types::file_name::FileName;
use iceoryx2_bb_system_types::file_path::FilePath;
use iceoryx2_bb_system_types::path::Path;
use serde::{Deserialize, Serialize};
use std::time::Duration;
use std::{os::unix::ffi::OsStrExt, time::Duration};

use iceoryx2_bb_log::{debug, fail, trace, warn};

use crate::service::port_factory::publisher::UnableToDeliverStrategy;

/// Path to the default config file
pub const DEFAULT_CONFIG_FILE: &[u8] = b"config/iceoryx2.toml";

/// Failures occurring while creating a new [`Config`] object with [`Config::from_file()`] or
/// [`Config::setup_global_config_from_file()`]
#[derive(Debug, Clone, Copy, Eq, Hash, PartialEq)]
Expand Down Expand Up @@ -403,25 +401,23 @@ impl Config {
/// [`Config::setup_global_config_from_file()`]
/// is called after this function was called, no file will be loaded since the global default
/// config was already populated.
pub fn global_config() -> &'static Config {
if !ICEORYX2_CONFIG.is_initialized() {
match Config::setup_global_config_from_file(unsafe {
&FilePath::new_unchecked(DEFAULT_CONFIG_FILE)
}) {
Ok(_) => (),
Err(ConfigCreationError::FailedToOpenConfigFile) => {
debug!(from "Config::global_config()", "Default config file not found, populate config with default values.");
ICEORYX2_CONFIG.set_value(Config::default());
}
Err(ConfigCreationError::FailedToReadConfigFileContents) => {
warn!(from "Config::global_config()", "Default config file found but unable to read content, populate config with default values.");
ICEORYX2_CONFIG.set_value(Config::default());
}
Err(ConfigCreationError::UnableToDeserializeContents) => {
warn!(from "Config::global_config()", "Default config file found but unable to load data, populate config with default values.");
ICEORYX2_CONFIG.set_value(Config::default());
}
}
if !ICEORYX2_CONFIG.is_initialized()
&& Config::setup_global_config_from_file(unsafe {
&FilePath::new_unchecked(
dirs::config_dir()
.unwrap()
.join("iceoryx2")
.join("config.toml")
.as_os_str()
.as_bytes(),
)
})
.is_err()
{
warn!(from "Config::global_config()", "Default config file found but unable to read data, populate config with default values.");
ICEORYX2_CONFIG.set_value(Config::default());
}

ICEORYX2_CONFIG.get()
Expand Down

0 comments on commit 1db3c2a

Please sign in to comment.