blob: 6e34f2df67f7b1995cdc6d2c438f567171588ac4 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
|
# os_info
**Status:**
[data:image/s3,"s3://crabby-images/ba46b/ba46ba740ba240e1585d722d2e58587d9575f50f" alt="CI"](https://github.com/stanislav-tkach/os_info/actions)
[data:image/s3,"s3://crabby-images/73a52/73a52f475baf6f4ca685f7243a110ca4cf4c80d8" alt="Coverage"](https://codecov.io/gh/stanislav-tkach/os_info)
[data:image/s3,"s3://crabby-images/c0f94/c0f94d218fbf300c1d4eb90423bca152dc1f0331" alt="Dependency status"](https://deps.rs/repo/github/stanislav-tkach/os_info)
**Project info:**
[data:image/s3,"s3://crabby-images/20a5d/20a5d4d1f73522a9e70ade0db0edee0644d78feb" alt="Docs.rs"](https://docs.rs/os_info)
[data:image/s3,"s3://crabby-images/e0b94/e0b94e9097eb02106137a7fcc4b11704edce3be4" alt="Latest version"](https://crates.io/crates/os_info)
[data:image/s3,"s3://crabby-images/82433/82433156eea4627f1777284998b6fa0c2f264c94" alt="License"](https://github.com/stanislav-tkach/os_info/blob/master/LICENSE)
**Project details:**
[data:image/s3,"s3://crabby-images/0609e/0609e26bd61fa235c03810818b12a5fbd1443159" alt="LoC"](https://github.com/stanislav-tkach/os_info)
data:image/s3,"s3://crabby-images/63919/639191dd54d5485f1d2e388173f530ea833cb442" alt="Rust 1.60+ required"
## Overview
This project consists of two parts: the library that can be used to detect the
operating system type (including version and bitness) and the command line tool
that uses the library.
### Library (`os_info`)
#### `os_info` usage
To use this crate, add `os_info` as a dependency to your project's Cargo.toml:
```toml
[dependencies]
os_info = "3"
```
This project has `serde` as an optional dependency, so if you don't need it, then
you can speed up compilation disabling it:
```toml
[dependencies]
os_info = { version = "3", default-features = false }
```
#### Example
```rust
let info = os_info::get();
// Print full information:
println!("OS information: {info}");
// Print information separately:
println!("Type: {}", info.os_type());
println!("Version: {}", info.version());
println!("Bitness: {}", info.bitness());
println!("Architecture: {}", info.architecture());
```
### Command line tool (`os_info_cli`)
A simple wrapper around the `os_info` library.
#### Installation
This tool can be installed using the following cargo command:
```console
cargo install os_info_cli
```
#### `os_info_cli` usage
Despite being named `os_info_cli` during installation, it is actually named
`os_info`. You can use the `--help` flag to see available options:
```console
os_info --help
```
## Supported operating systems
Right now, the following operating system types can be returned:
- Alpaquita Linux
- Alpine Linux
- Amazon Linux AMI
- Android
- Arch Linux
- Artix Linux
- CentOS
- Debian
- DragonFly BSD
- Emscripten
- EndeavourOS
- Fedora
- FreeBSD
- Garuda Linux
- Gentoo Linux
- HardenedBSD
- Illumos
- Linux
- macOS (Mac OS X or OS X)
- Manjaro
- Mariner
- MidnightBSD
- Mint
- NetBSD
- NixOS
- OpenBSD
- openSUSE
- Oracle Linux
- Pop!_OS
- Raspberry Pi OS
- Red Hat Linux
- Red Hat Enterprise Linux
- Redox
- Solus
- SUSE Linux Enterprise Server
- Ubuntu
- Unknown
- Windows
If you need support for more OS types, I am looking forward to your Pull Request.
## License
`os_info` is licensed under the MIT license. See [LICENSE] for the details.
[lsb_release]: http://refspecs.linuxbase.org/LSB_2.0.1/LSB-PDA/LSB-PDA/lsbrelease.html
[LICENSE]: https://github.com/stanislav-tkach/os_info/blob/master/LICENSE
|