From 001c9917ace09f7b1c80d96eb067e1d37e86c546 Mon Sep 17 00:00:00 2001 From: Lexi Winter Date: Fri, 27 Jun 2025 12:08:58 +0100 Subject: improve error handling --- nihil.ucl/boolean.ccm | 55 ++++++++++++++++++++++++++++++++++++++++++++------- 1 file changed, 48 insertions(+), 7 deletions(-) (limited to 'nihil.ucl/boolean.ccm') diff --git a/nihil.ucl/boolean.ccm b/nihil.ucl/boolean.ccm index 78ede17..068dfdd 100644 --- a/nihil.ucl/boolean.ccm +++ b/nihil.ucl/boolean.ccm @@ -7,6 +7,8 @@ module; #include #include #include +#include +#include #include #include @@ -22,20 +24,36 @@ export struct boolean final : object { inline static constexpr object_type ucl_type = object_type::boolean; - // Create a new boolean from a UCL object. - boolean(ref_t, ::ucl_object_t const *uobj); - boolean(noref_t, ::ucl_object_t *uobj); - - // Create a new default-initialised boolean. + /* + * Create a boolean holding the value false. Throws std::system_error + * on failure. + */ boolean(); - // Create a new boolean from a value. - explicit boolean(contained_type value); + /* + * Create a boolean holding a specific value. Throws std::system_error + * on failure. + */ + explicit boolean(bool); + + /* + * Create a new boolean from a UCL object. Throws type_mismatch + * on failure. + */ + boolean(ref_t, ::ucl_object_t const *uobj); + boolean(noref_t, ::ucl_object_t *uobj); // Return this object's value. auto value(this boolean const &self) -> contained_type; }; +/* + * Boolean constructors. These return an error instead of throwing. + */ + +export [[nodiscard]] auto +make_boolean(boolean::contained_type = false) -> std::expected; + /* * Comparison operators. */ @@ -48,3 +66,26 @@ export auto operator<=> (boolean const &a, boolean::contained_type b) -> std::strong_ordering; } // namespace nihil::ucl + +/* + * std::formatter for a boolean. This provides the same format operations + * as std::formatter. + */ +export template<> +struct std::formatter +{ + std::formatter base_formatter; + + template + constexpr ParseContext::iterator parse(ParseContext& ctx) + { + return base_formatter.parse(ctx); + } + + template + FmtContext::iterator format(nihil::ucl::boolean const &o, + FmtContext& ctx) const + { + return base_formatter.format(o.value(), ctx); + } +}; -- cgit v1.2.3