libpulse_binding/
utf8.rs

1// Copyright 2017 Lyndon Brown
2//
3// This file is part of the PulseAudio Rust language binding.
4//
5// Licensed under the MIT license or the Apache license (version 2.0), at your option. You may not
6// copy, modify, or distribute this file except in compliance with said license. You can find copies
7// of these licenses either in the LICENSE-MIT and LICENSE-APACHE files, or alternatively at
8// <http://opensource.org/licenses/MIT> and <http://www.apache.org/licenses/LICENSE-2.0>
9// respectively.
10//
11// Portions of documentation are copied from the LGPL 2.1+ licensed PulseAudio C headers on a
12// fair-use basis, as discussed in the overall project readme (available in the git repository).
13
14//! UTF-8 validation functions.
15//!
16//! Bindings are not provided here for most of the PulseAudio UTF-8 functions since Rust has built
17//! in UTF-8 handling and thus they should be entirely unnecessary.
18
19use std::os::raw::{c_char, c_void};
20use std::ffi::{CStr, CString};
21
22/// Converts a UTF-8 string to the current locale.
23pub fn utf8_to_locale(s: &str) -> Option<String> {
24    // Warning: New CStrings will be immediately freed if not bound to a variable, leading to
25    // as_ptr() giving dangling pointers!
26    let c_str = CString::new(s).unwrap();
27    let tmp_ptr: *const c_char = unsafe { capi::pa_utf8_to_locale(c_str.as_ptr()) };
28    if tmp_ptr.is_null() {
29        return None;
30    }
31    unsafe {
32        let ret = Some(CStr::from_ptr(tmp_ptr).to_string_lossy().into_owned());
33        capi::pa_xfree(tmp_ptr as *mut c_void);
34        ret
35    }
36}