summaryrefslogtreecommitdiff
path: root/Userland/Utilities/df.cpp
diff options
context:
space:
mode:
authorArda Cinar <kuzux92@gmail.com>2022-12-10 10:48:28 +0300
committerSam Atkins <atkinssj@gmail.com>2023-01-02 20:11:18 +0000
commit76fce0b89941e2df06c4b806f6aa21abdd7ed8cc (patch)
tree239da0c3d870b692932eb8949d05a65e2307a2a2 /Userland/Utilities/df.cpp
parentc8fadff9b1c5d7cde8d041893aca565dc1af7d15 (diff)
downloadserenity-76fce0b89941e2df06c4b806f6aa21abdd7ed8cc.zip
df: Add an option to display used/available inodes
Diffstat (limited to 'Userland/Utilities/df.cpp')
-rw-r--r--Userland/Utilities/df.cpp70
1 files changed, 52 insertions, 18 deletions
diff --git a/Userland/Utilities/df.cpp b/Userland/Utilities/df.cpp
index f92cb3b7bd..760b0456d2 100644
--- a/Userland/Utilities/df.cpp
+++ b/Userland/Utilities/df.cpp
@@ -13,8 +13,6 @@
#include <inttypes.h>
#include <stdlib.h>
-static bool flag_human_readable = false;
-
struct FileSystem {
DeprecatedString fs;
size_t total_block_count { 0 };
@@ -27,30 +25,48 @@ struct FileSystem {
ErrorOr<int> serenity_main(Main::Arguments arguments)
{
+ bool flag_human_readable = false;
+ bool flag_inode_info = false;
+
Core::ArgsParser args_parser;
args_parser.set_general_help("Display free disk space of each partition.");
args_parser.add_option(flag_human_readable, "Print human-readable sizes", "human-readable", 'h');
+ args_parser.add_option(flag_inode_info, "Show inode information as well", "inodes", 'i');
args_parser.parse(arguments);
auto file = TRY(Core::Stream::File::open("/sys/kernel/df"sv, Core::Stream::OpenMode::Read));
- if (flag_human_readable) {
- outln("Filesystem Size Used Available Used% Mount point");
- } else {
- outln("Filesystem Blocks Used Available Used% Mount point");
+ Vector<StringView> headers;
+ TRY(headers.try_append(flag_human_readable ? "Size"sv : "Blocks"sv));
+ TRY(headers.try_append("Used"sv));
+ TRY(headers.try_append("Available"sv));
+ TRY(headers.try_append("Used%"sv));
+ if (flag_inode_info) {
+ TRY(headers.try_append("Inodes"sv));
+ TRY(headers.try_append("IUsed"sv));
+ TRY(headers.try_append("IAvailable"sv));
+ TRY(headers.try_append("IUsed%"sv));
}
+ TRY(headers.try_append("Mount point"sv));
+
+ out("{:12} ", "Filesystem");
+
+ for (auto& header : headers)
+ out("{:>12} ", header);
+ outln();
auto file_contents = TRY(file->read_until_eof());
auto json_result = TRY(JsonValue::from_string(file_contents));
auto const& json = json_result.as_array();
- json.for_each([](auto& value) {
+ json.for_each([&](auto& value) {
auto& fs_object = value.as_object();
auto fs = fs_object.get("class_name"sv).to_deprecated_string();
auto total_block_count = fs_object.get("total_block_count"sv).to_u64();
auto free_block_count = fs_object.get("free_block_count"sv).to_u64();
auto used_block_count = total_block_count - free_block_count;
- [[maybe_unused]] auto total_inode_count = fs_object.get("total_inode_count"sv).to_u64();
- [[maybe_unused]] auto free_inode_count = fs_object.get("free_inode_count"sv).to_u64();
+ auto total_inode_count = fs_object.get("total_inode_count"sv).to_u64();
+ auto free_inode_count = fs_object.get("free_inode_count"sv).to_u64();
+ auto used_inode_count = total_inode_count - free_inode_count;
auto block_size = fs_object.get("block_size"sv).to_u64();
auto mount_point = fs_object.get("mount_point"sv).to_deprecated_string();
@@ -58,18 +74,36 @@ ErrorOr<int> serenity_main(Main::Arguments arguments)
if (total_block_count != 0)
used_percentage = (used_block_count * 100) / total_block_count;
- out("{:10}", fs);
+ auto used_inode_percentage = 100;
+ if (total_inode_count != 0)
+ used_inode_percentage = (used_inode_count * 100) / total_inode_count;
+
+ out("{:12} ", fs);
if (flag_human_readable) {
- out("{:>10} ", human_readable_size(total_block_count * block_size));
- out("{:>10} ", human_readable_size(used_block_count * block_size));
- out("{:>10} ", human_readable_size(free_block_count * block_size));
- out("{:>9}% ", used_percentage);
+ out("{:>12} ", human_readable_size(total_block_count * block_size));
+ out("{:>12} ", human_readable_size(used_block_count * block_size));
+ out("{:>12} ", human_readable_size(free_block_count * block_size));
+ out("{:>11}% ", used_percentage);
} else {
- out("{:>10} ", (uint64_t)total_block_count);
- out("{:>10} ", (uint64_t)used_block_count);
- out("{:>10} ", (uint64_t)free_block_count);
- out("{:>9}% ", used_percentage);
+ out("{:>12} ", (uint64_t)total_block_count);
+ out("{:>12} ", (uint64_t)used_block_count);
+ out("{:>12} ", (uint64_t)free_block_count);
+ out("{:>11}% ", used_percentage);
+ }
+
+ if (flag_inode_info) {
+ if (flag_human_readable) {
+ out("{:>12} ", human_readable_quantity(total_inode_count));
+ out("{:>12} ", human_readable_quantity(used_inode_count));
+ out("{:>12} ", human_readable_quantity(free_inode_count));
+ out("{:>11}% ", used_inode_percentage);
+ } else {
+ out("{:>12} ", (uint64_t)total_inode_count);
+ out("{:>12} ", (uint64_t)used_inode_count);
+ out("{:>12} ", (uint64_t)free_inode_count);
+ out("{:>11}% ", used_inode_percentage);
+ }
}
out("{}", mount_point);