diff options
| author | Felix Morgner <felix.morgner@gmail.com> | 2026-06-05 08:55:54 +0200 |
|---|---|---|
| committer | Felix Morgner <felix.morgner@gmail.com> | 2026-06-05 08:55:54 +0200 |
| commit | 81fa478a642b25715adecf27c283e6f15334d705 (patch) | |
| tree | 6e0bb3c889cfb9d38bac6b735512459cbbce064b /cabinet | |
| parent | 1ca48e3790e69e63c3789a32d541e4086e849030 (diff) | |
| download | cabinet-81fa478a642b25715adecf27c283e6f15334d705.tar.xz cabinet-81fa478a642b25715adecf27c283e6f15334d705.zip | |
magic: implement file descriptor support
Diffstat (limited to 'cabinet')
| -rw-r--r-- | cabinet/magic.cpp | 10 | ||||
| -rw-r--r-- | cabinet/magic.hpp | 1 | ||||
| -rw-r--r-- | cabinet/main.cpp | 9 |
3 files changed, 16 insertions, 4 deletions
diff --git a/cabinet/magic.cpp b/cabinet/magic.cpp index b5c1aaa..08b3046 100644 --- a/cabinet/magic.cpp +++ b/cabinet/magic.cpp @@ -63,6 +63,16 @@ namespace cab return result; } + auto magic::process(int file_descriptor) -> std::expected<std::string, std::string> + { + auto result = ::magic_descriptor(m_cookie, file_descriptor); + if (!result) + { + return std::unexpected{std::string{::magic_error(m_cookie)}}; + } + return result; + } + auto swap(magic & lhs, magic & rhs) noexcept -> void { auto temp = std::move(lhs); diff --git a/cabinet/magic.hpp b/cabinet/magic.hpp index 222d488..96f4b08 100644 --- a/cabinet/magic.hpp +++ b/cabinet/magic.hpp @@ -55,6 +55,7 @@ namespace cab auto operator=(magic && other) noexcept -> magic &; auto process(std::filesystem::path path) -> std::expected<std::string, std::string>; + auto process(int file_descriptor) -> std::expected<std::string, std::string>; private: explicit magic(::magic_t cookie) noexcept; diff --git a/cabinet/main.cpp b/cabinet/main.cpp index 77a73ca..db2d43b 100644 --- a/cabinet/main.cpp +++ b/cabinet/main.cpp @@ -1,7 +1,8 @@ #include <cabinet/magic.hpp> +#include <fcntl.h> + #include <cstdlib> -#include <filesystem> #include <iostream> #include <print> @@ -15,19 +16,19 @@ auto main(int argc, char ** argv) -> int return EXIT_FAILURE; } - auto magic = cab::magic::open(flags::follow_symlinks | flags::mime_type); + auto magic = cab::magic::open(flags::follow_symlinks | flags::mime_type | flags::forward_errors); if (!magic) { std::println(std::cerr, "Failed to initialize libmagic: {}", magic.error().message()); return EXIT_FAILURE; } - auto mime_type = magic->process(std::filesystem::path{argv[1]}); + auto fd = open(argv[1], O_RDONLY); + auto mime_type = magic->process(fd); if (!mime_type) { std::println(std::cerr, "Failed to determine file type: {}", mime_type.error()); return EXIT_FAILURE; } - std::println("{}: {}", argv[1], mime_type.value()); } |
