File: ubjson_error.hpp

package info (click to toggle)
jsoncons 1.3.2-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 17,584 kB
  • sloc: cpp: 136,382; sh: 33; makefile: 5
file content (104 lines) | stat: -rw-r--r-- 3,324 bytes parent folder | download
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
/// Copyright 2013-2025 Daniel Parker
// Distributed under the Boost license, Version 1.0.
// (See accompanying file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)

// See https://github.com/danielaparker/jsoncons for latest version

#ifndef JSONCONS_EXT_UBJSON_UBJSON_ERROR_HPP
#define JSONCONS_EXT_UBJSON_UBJSON_ERROR_HPP

#include <string>
#include <system_error>
#include <type_traits>

#include <jsoncons/config/jsoncons_config.hpp>

namespace jsoncons { namespace ubjson {

enum class ubjson_errc
{
    success = 0,
    unexpected_eof = 1,
    source_error,
    count_required_after_type,
    length_is_negative,
    length_must_be_integer,
    unknown_type,
    invalid_utf8_text_string,
    too_many_items,
    too_few_items,
    number_too_large,
    max_nesting_depth_exceeded,
    key_expected,
    max_items_exceeded
};

class ubjson_error_category_impl
   : public std::error_category
{
public:
    const char* name() const noexcept override
    {
        return "jsoncons/ubjson";
    }
    std::string message(int ev) const override
    {
        switch (static_cast<ubjson_errc>(ev))
        {
            case ubjson_errc::unexpected_eof:
                return "Unexpected end of file";
            case ubjson_errc::source_error:
                return "Source error";
            case ubjson_errc::count_required_after_type:
                return "Type is specified for container, but count is not specified";
            case ubjson_errc::length_is_negative:
                return "Request for the length of an array, map or string returned a negative result";
            case ubjson_errc::length_must_be_integer:
                return "Length must be a integer numeric type (int8, uint8, int16, int32, int64)";
            case ubjson_errc::unknown_type:
                return "Unknown type";
            case ubjson_errc::invalid_utf8_text_string:
                return "Illegal UTF-8 encoding in text string";
            case ubjson_errc::too_many_items:
                return "Too many items were added to a UBJSON object or array of known length";
            case ubjson_errc::too_few_items:
                return "Too few items were added to a UBJSON object or array of known length";
            case ubjson_errc::number_too_large:
                return "Number exceeds implementation limits";
            case ubjson_errc::max_nesting_depth_exceeded:
                return "Data item nesting exceeds limit in options";
            case ubjson_errc::key_expected:
                return "Text string key in a map expected";
            case ubjson_errc::max_items_exceeded:
                return "Number of items in UBJSON object or array exceeds limit set in options";
            default:
                return "Unknown UBJSON parser error";
        }
    }
};

inline
const std::error_category& ubjson_error_category()
{
  static ubjson_error_category_impl instance;
  return instance;
}

inline 
std::error_code make_error_code(ubjson_errc e)
{
    return std::error_code(static_cast<int>(e),ubjson_error_category());
}


} // namespace ubjson
} // namespace jsoncons

namespace std {
    template<>
    struct is_error_code_enum<jsoncons::ubjson::ubjson_errc> : public true_type
    {
    };
} // namespace std

#endif // JSONCONS_EXT_UBJSON_UBJSON_ERROR_HPP