Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

System locale #5081

Merged
merged 79 commits into from
Aug 8, 2024
Merged
Changes from 1 commit
Commits
Show all changes
79 commits
Select commit Hold shift + click to select a range
1c7b634
Linux support added
ashu26jha Jun 2, 2024
f6b96a9
improved interface of linux
ashu26jha Jun 14, 2024
df361b8
calendar for linux
ashu26jha Jun 14, 2024
a3d8154
added readme
ashu26jha Jun 14, 2024
bb95d79
apple locale and calendar
ashu26jha Jun 18, 2024
ee23fd2
windows locale retrieval
ashu26jha Jun 19, 2024
1b1b514
windows calendar added
ashu26jha Jun 19, 2024
9b3d8e5
Update Readme
ashu26jha Jun 19, 2024
0adf4b9
Fixed linux
ashu26jha Jul 5, 2024
fe54b79
apple fi
ashu26jha Jul 5, 2024
d7ca69e
Minor fix
ashu26jha Jul 5, 2024
1c10d33
Change module name
ashu26jha Jul 5, 2024
c243451
rustdocs
ashu26jha Jul 5, 2024
0aa332e
readme license name fix
ashu26jha Jul 6, 2024
e96b2d3
Rename Readme.md to README.md
ashu26jha Jul 6, 2024
f7212b5
Change crate name
ashu26jha Jul 7, 2024
aba5c24
Added comment for calendar in linux.rs
ashu26jha Jul 19, 2024
72c0404
Re-export modules
ashu26jha Jul 19, 2024
6dc1973
Fix bug in locale retrieval
ashu26jha Jul 19, 2024
7cc7c65
Added enum in linux.rs
ashu26jha Jul 19, 2024
4c594be
tools/graveyard/Cargo.lock removed
ashu26jha Jul 19, 2024
514f4a0
fmt
ashu26jha Jul 19, 2024
6fd9d43
Added safety comments
ashu26jha Jul 20, 2024
3534091
Refactor linux calendar
ashu26jha Jul 23, 2024
62fe2c5
Fixed macos suffixes
ashu26jha Jul 23, 2024
efd5263
Added safety comments, changed function name to plural
ashu26jha Jul 23, 2024
f59808e
fmt
ashu26jha Jul 23, 2024
ad1a293
Windows fix
ashu26jha Jul 23, 2024
68c8775
removed cfg_if
ashu26jha Jul 26, 2024
e072f7f
added ergonomic names in enum
ashu26jha Jul 26, 2024
1a786f9
one unsafe function call per block
ashu26jha Jul 26, 2024
d73f432
added safety comments for apple.rs
ashu26jha Jul 26, 2024
489c6e6
added safety comments for linux.rs
ashu26jha Jul 26, 2024
52a6bc9
remove .clone()
ashu26jha Jul 30, 2024
87dcefc
Release memory
ashu26jha Jul 30, 2024
00efc98
cargo fmt
ashu26jha Jul 30, 2024
3f41cd9
suggestion: remove mod wrapper
ashu26jha Aug 2, 2024
6be1eae
suggestion: added result type in linux.rs
ashu26jha Aug 2, 2024
de9e217
suggestion: refactor to remove .clone()
ashu26jha Aug 2, 2024
daa9ddb
remove test, will be added in further commits
ashu26jha Aug 2, 2024
f1c9367
improved error format
ashu26jha Aug 2, 2024
c3f5da0
windows error propogation fixed
ashu26jha Aug 2, 2024
b5d5a38
remove unnecessary enum in linux.rs
ashu26jha Aug 2, 2024
8a4eea4
suggestion: improve error propagation macos
ashu26jha Aug 2, 2024
c31695f
updated linux.rs to new error enum
ashu26jha Aug 2, 2024
66eacc6
remove unnecessary return in linux.rs
ashu26jha Aug 2, 2024
60c4c58
impl from UTF8Error
ashu26jha Aug 2, 2024
a3d7393
updated apple.rs error propagation
ashu26jha Aug 2, 2024
d348fc4
updated linux.rs error propagation
ashu26jha Aug 2, 2024
3a07b75
linux.rs test covering get_locales
ashu26jha Aug 3, 2024
8ace9df
corrected license
ashu26jha Aug 4, 2024
8b71b4d
added calendar test for linux
ashu26jha Aug 4, 2024
bc2987a
clippy fix
ashu26jha Aug 4, 2024
af6c742
fix: linux test assert statements
ashu26jha Aug 4, 2024
ae87b00
added apple tests
ashu26jha Aug 4, 2024
835cf07
linux test changes
ashu26jha Aug 4, 2024
439de02
change error enum to test in CI
ashu26jha Aug 4, 2024
fdf3b45
error log ci
ashu26jha Aug 4, 2024
c86f7b4
remove return
ashu26jha Aug 4, 2024
a1fe396
handle lang_str NULL case
ashu26jha Aug 4, 2024
668245f
added safety comments and remove null chars
ashu26jha Aug 4, 2024
e0451f9
fix apple calendar
ashu26jha Aug 4, 2024
a40e2c5
refactor apple.rs
ashu26jha Aug 5, 2024
549b9a5
add timezone for apple
ashu26jha Aug 5, 2024
b45216f
added safety comments
ashu26jha Aug 5, 2024
52a491a
added timezone windows.rs
ashu26jha Aug 5, 2024
6865a0b
added windows rs tests
ashu26jha Aug 5, 2024
fdbd74f
optimise: get_string()
ashu26jha Aug 6, 2024
f51575c
error propagation improve
ashu26jha Aug 6, 2024
5586b47
change order of enum
ashu26jha Aug 6, 2024
f4bd006
added comments for get_string()
ashu26jha Aug 6, 2024
1e3a9fb
refactor: get_string()
ashu26jha Aug 6, 2024
82aaf5a
error.rs and variable name changes
ashu26jha Aug 6, 2024
5d4482b
update comment
ashu26jha Aug 6, 2024
feed347
suggestion: use NullLocale instead of NullPointer
ashu26jha Aug 6, 2024
edc9855
remove nullptr error enum
ashu26jha Aug 6, 2024
d9f65d7
updated tests
ashu26jha Aug 7, 2024
de77db0
ci fix: remove into_iter()
ashu26jha Aug 7, 2024
8f3a6c0
nit: fixed ascii assertion in macos test
ashu26jha Aug 7, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
suggestion: added result type in linux.rs
  • Loading branch information
ashu26jha committed Aug 2, 2024
commit 6be1eae2ec99403c0835ffa8af3b1ea79244690e
47 changes: 30 additions & 17 deletions utils/env_preferences/src/linux.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2,11 +2,23 @@
// called LICENSE at the top level of the ICU4X source tree
// (online at: https://github.com/unicode-org/icu4x/blob/main/LICENSE ).

use std::{borrow::Cow, collections::HashMap, ffi::CStr, ptr};
use std::{collections::HashMap, ffi::CStr, ptr};

use libc::{setlocale, LC_ALL, LC_TIME};
use std::str::FromStr;

#[derive(Debug)]
pub enum LinuxError {
/// Received NULL Locale
NullLocale,

/// Error converting into `&CStr` to `&str`
ConversionError,

/// Error whenever retrived locale of categories other than defined in the `LocaleCategory`
UnknownCategory,
}

#[derive(Hash, Eq, PartialEq, Debug)]
pub enum LocaleCategory {
Character,
Expand All @@ -26,7 +38,7 @@ pub enum LocaleCategory {
}

impl FromStr for LocaleCategory {
type Err = ();
type Err = LinuxError;

fn from_str(s: &str) -> Result<Self, Self::Err> {
match s {
Expand All @@ -43,21 +55,20 @@ impl FromStr for LocaleCategory {
"LC_MEASUREMENT" => Ok(Self::Measurement),
"LC_IDENTIFICATION" => Ok(Self::Identification),
"LC_ALL" => Ok(Self::All),
_ => Ok(Self::Other(s.to_string())),
_ => Err(LinuxError::UnknownCategory),
}
}
}

pub fn get_locales() -> HashMap<LocaleCategory, String> {
pub fn get_locales() -> Result<HashMap<LocaleCategory, String>, LinuxError> {
let mut locale_map = HashMap::new();

// SAFETY: Safety is ensured because we pass a `NULL` pointer and retrieve the locale there is
// no subsequent calls for `setlocale` which could change the locale of this particular thread
let locales_ptr = unsafe { setlocale(LC_ALL, ptr::null()) };

if locales_ptr.is_null() {
locale_map.insert(LocaleCategory::All, "C".to_string());
return locale_map;
return Err(LinuxError::NullLocale);
}

// SAFETY: A valid `NULL` terminator is present which is a requirement of `from_ptr`
Expand All @@ -79,12 +90,17 @@ pub fn get_locales() -> HashMap<LocaleCategory, String> {
}
}
}

return Ok(locale_map);
}

locale_map
Err(LinuxError::ConversionError)
}

pub fn get_system_calendars() -> impl Iterator<Item = (Cow<'static, str>, Cow<'static, str>)> {
/// This only returns the calendar locale,`gnome-calendar` is the default calendar in linux
/// The locale returned is for `Gregorian` calendar
/// Related issue: https://gitlab.gnome.org/GNOME/gnome-calendar/-/issues/998
pub fn get_system_calendars() -> Result<String, LinuxError> {
// SAFETY: Safety is ensured because we pass a `NULL` pointer and retrieve the locale there is
// no subsequent calls for `setlocale` which could change the locale of this particular thread
let locale_ptr = unsafe { setlocale(LC_TIME, ptr::null()) };
Expand All @@ -96,15 +112,12 @@ pub fn get_system_calendars() -> impl Iterator<Item = (Cow<'static, str>, Cow<'s
if let Ok(str_slice) = c_str.to_str() {
// `gnome-calendar` is the default calendar and it only supports `Gregorian`.
// Related issue: https://gitlab.gnome.org/GNOME/gnome-calendar/-/issues/998
return Some((
Cow::Owned(str_slice.to_string()),
Cow::Borrowed("Gregorian"),
))
.into_iter()
.chain(None);
let calendar_locale = str_slice.to_string();
return Ok(calendar_locale);
}
else {
return Err(LinuxError::ConversionError);
}
}
Some((Cow::Borrowed("C"), Cow::Borrowed("Gregorian")))
.into_iter()
.chain(None)
Err(LinuxError::NullLocale)
}