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:**
[](https://github.com/stanislav-tkach/os_info/actions)
[](https://codecov.io/gh/stanislav-tkach/os_info)
[](https://deps.rs/repo/github/stanislav-tkach/os_info)
**Project info:**
[](https://docs.rs/os_info)
[](https://crates.io/crates/os_info)
[](https://github.com/stanislav-tkach/os_info/blob/master/LICENSE)
**Project details:**
[](https://github.com/stanislav-tkach/os_info)

## 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
|