mirror of
https://github.com/uutils/coreutils
synced 2025-01-19 00:24:13 +00:00
build: feature cleanup
This commit is contained in:
parent
3033d017b5
commit
c3c7054155
1 changed files with 21 additions and 17 deletions
36
Cargo.toml
36
Cargo.toml
|
@ -30,6 +30,20 @@ windows = [ "feat_os_windows" ]
|
||||||
## project-specific feature shortcodes
|
## project-specific feature shortcodes
|
||||||
nightly = []
|
nightly = []
|
||||||
test_unimplemented = []
|
test_unimplemented = []
|
||||||
|
# * only build `uudoc` when `--feature uudoc` is activated
|
||||||
|
uudoc = ["zip"]
|
||||||
|
## features
|
||||||
|
# "feat_acl" == enable support for ACLs (access control lists; by using`--features feat_acl`)
|
||||||
|
# NOTE:
|
||||||
|
# * On linux, the posix-acl/acl-sys crate requires `libacl` headers and shared library to be accessible in the C toolchain at compile time.
|
||||||
|
# * On FreeBSD and macOS this is not required.
|
||||||
|
feat_acl = ["cp/feat_acl"]
|
||||||
|
# "feat_selinux" == enable support for SELinux Security Context (by using `--features feat_selinux`)
|
||||||
|
# NOTE:
|
||||||
|
# * The selinux(-sys) crate requires `libselinux` headers and shared library to be accessible in the C toolchain at compile time.
|
||||||
|
# * Running a uutils compiled with `feat_selinux` requires an SELinux enabled Kernel at run time.
|
||||||
|
feat_selinux = ["cp/selinux", "id/selinux", "ls/selinux", "selinux", "feat_require_selinux"]
|
||||||
|
##
|
||||||
## feature sets
|
## feature sets
|
||||||
## (common/core and Tier1) feature sets
|
## (common/core and Tier1) feature sets
|
||||||
# "feat_common_core" == baseline core set of utilities which can be built/run on most targets
|
# "feat_common_core" == baseline core set of utilities which can be built/run on most targets
|
||||||
|
@ -122,7 +136,8 @@ feat_Tier1 = [
|
||||||
# "feat_os_macos" == set of utilities which can be built/run on the MacOS platform
|
# "feat_os_macos" == set of utilities which can be built/run on the MacOS platform
|
||||||
feat_os_macos = [
|
feat_os_macos = [
|
||||||
"feat_os_unix", ## == a modern/usual *nix platform
|
"feat_os_unix", ## == a modern/usual *nix platform
|
||||||
"feat_require_hostid",
|
#
|
||||||
|
"feat_require_unix_hostid",
|
||||||
]
|
]
|
||||||
# "feat_os_unix" == set of utilities which can be built/run on modern/usual *nix platforms
|
# "feat_os_unix" == set of utilities which can be built/run on modern/usual *nix platforms
|
||||||
feat_os_unix = [
|
feat_os_unix = [
|
||||||
|
@ -142,31 +157,21 @@ feat_os_unix_gnueabihf = [
|
||||||
"feat_Tier1",
|
"feat_Tier1",
|
||||||
#
|
#
|
||||||
"feat_require_unix",
|
"feat_require_unix",
|
||||||
|
"feat_require_unix_hostid",
|
||||||
"feat_require_unix_utmpx",
|
"feat_require_unix_utmpx",
|
||||||
"feat_require_hostid",
|
|
||||||
]
|
]
|
||||||
# "feat_os_unix_musl" == set of utilities which can be built/run on targets binding to the "musl" library (ref: <https://musl.libc.org/about.html>)
|
# "feat_os_unix_musl" == set of utilities which can be built/run on targets binding to the "musl" library (ref: <https://musl.libc.org/about.html>)
|
||||||
feat_os_unix_musl = [
|
feat_os_unix_musl = [
|
||||||
"feat_Tier1",
|
"feat_Tier1",
|
||||||
#
|
#
|
||||||
"feat_require_unix",
|
"feat_require_unix",
|
||||||
"feat_require_hostid",
|
"feat_require_unix_hostid",
|
||||||
]
|
]
|
||||||
feat_os_unix_android = [
|
feat_os_unix_android = [
|
||||||
"feat_Tier1",
|
"feat_Tier1",
|
||||||
#
|
#
|
||||||
"feat_require_unix",
|
"feat_require_unix",
|
||||||
]
|
]
|
||||||
# "feat_selinux" == set of utilities providing support for SELinux Security Context if enabled with `--features feat_selinux`.
|
|
||||||
# NOTE:
|
|
||||||
# The selinux(-sys) crate requires `libselinux` headers and shared library to be accessible in the C toolchain at compile time.
|
|
||||||
# Running a uutils compiled with `feat_selinux` requires an SELinux enabled Kernel at run time.
|
|
||||||
feat_selinux = ["cp/selinux", "id/selinux", "ls/selinux", "selinux", "feat_require_selinux"]
|
|
||||||
# "feat_acl" == set of utilities providing support for acl (access control lists) if enabled with `--features feat_acl`.
|
|
||||||
# NOTE:
|
|
||||||
# On linux, the posix-acl/acl-sys crate requires `libacl` headers and shared library to be accessible in the C toolchain at compile time.
|
|
||||||
# On FreeBSD and macOS this is not required.
|
|
||||||
feat_acl = ["cp/feat_acl"]
|
|
||||||
## feature sets with requirements (restricting cross-platform availability)
|
## feature sets with requirements (restricting cross-platform availability)
|
||||||
#
|
#
|
||||||
# ** NOTE: these `feat_require_...` sets should be minimized as much as possible to encourage cross-platform availability of utilities
|
# ** NOTE: these `feat_require_...` sets should be minimized as much as possible to encourage cross-platform availability of utilities
|
||||||
|
@ -204,8 +209,8 @@ feat_require_unix_utmpx = [
|
||||||
"users",
|
"users",
|
||||||
"who",
|
"who",
|
||||||
]
|
]
|
||||||
# "feat_require_hostid" == set of utilities requiring gethostid in libc (only some unixes provide)
|
# "feat_require_unix_hostid" == set of utilities requiring gethostid in libc (only some unixes provide)
|
||||||
feat_require_hostid = [
|
feat_require_unix_hostid = [
|
||||||
"hostid",
|
"hostid",
|
||||||
]
|
]
|
||||||
# "feat_require_selinux" == set of utilities depending on SELinux.
|
# "feat_require_selinux" == set of utilities depending on SELinux.
|
||||||
|
@ -256,7 +261,6 @@ feat_os_windows_legacy = [
|
||||||
##
|
##
|
||||||
# * bypass/override ~ translate 'test' feature name to avoid dependency collision with rust core 'test' crate (o/w surfaces as compiler errors during testing)
|
# * bypass/override ~ translate 'test' feature name to avoid dependency collision with rust core 'test' crate (o/w surfaces as compiler errors during testing)
|
||||||
test = [ "uu_test" ]
|
test = [ "uu_test" ]
|
||||||
uudoc = [ "zip" ]
|
|
||||||
|
|
||||||
[workspace]
|
[workspace]
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue