Skip to main content

yash_env/system/
sysconf.rs

1// This file is part of yash, an extended POSIX shell.
2// Copyright (C) 2025 WATANABE Yuki
3//
4// This program is free software: you can redistribute it and/or modify
5// it under the terms of the GNU General Public License as published by
6// the Free Software Foundation, either version 3 of the License, or
7// (at your option) any later version.
8//
9// This program is distributed in the hope that it will be useful,
10// but WITHOUT ANY WARRANTY; without even the implied warranty of
11// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12// GNU General Public License for more details.
13//
14// You should have received a copy of the GNU General Public License
15// along with this program.  If not, see <https://www.gnu.org/licenses/>.
16
17//! Items for obtaining system configuration information
18
19use super::Result;
20use crate::str::UnixString;
21use std::ffi::CString;
22
23/// Trait for getting system configuration information
24pub trait Sysconf {
25    /// Returns the standard `$PATH` value where all standard utilities are
26    /// expected to be found.
27    ///
28    /// This is a thin wrapper around `confstr(_CS_PATH, …)`.
29    fn confstr_path(&self) -> Result<UnixString>;
30}
31
32/// Trait for getting the path to the shell executable
33pub trait ShellPath {
34    // TODO: Should return `Cow<CStr>` instead
35    /// Returns the path to the shell executable.
36    ///
37    /// If possible, this function should return the path to the current shell
38    /// executable. Otherwise, it should return the path to the default POSIX
39    /// shell.
40    fn shell_path(&self) -> CString;
41}