LIEF: Library to Instrument Executable Formats
Version 1.0.0
Toggle main menu visibility
Loading...
Searching...
No Matches
lief-install
x86_64
static
include
LIEF
errors.hpp
Go to the documentation of this file.
1
/* Copyright 2021 - 2026 R. Thomas
2
* Copyright 2021 - 2026 Quarkslab
3
*
4
* Licensed under the Apache License, Version 2.0 (the "License");
5
* you may not use this file except in compliance with the License.
6
* You may obtain a copy of the License at
7
*
8
* http://www.apache.org/licenses/LICENSE-2.0
9
*
10
* Unless required by applicable law or agreed to in writing, software
11
* distributed under the License is distributed on an "AS IS" BASIS,
12
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
* See the License for the specific language governing permissions and
14
* limitations under the License.
15
*/
16
#ifndef LIEF_ERROR_H
17
#define LIEF_ERROR_H
18
#include <cstdint>
19
#include <string>
20
#include <
LIEF/compiler_attributes.hpp
>
21
#include <LIEF/third-party/expected.hpp>
22
24
enum class
lief_errors
: uint32_t {
25
read_error
= 1,
26
not_found
,
27
not_implemented
,
28
not_supported
,
29
30
corrupted
,
31
conversion_error
,
32
33
read_out_of_bound
,
34
asn1_bad_tag
,
35
file_error
,
36
37
file_format_error
,
38
parsing_error
,
39
build_error
,
40
41
data_too_large
,
42
require_extended_version
,
43
inconsistent
,
44
/*
45
* When adding a new error, do not forget
46
* to update the Python bindings as well (pyErr.cpp) and Rust bindings:
47
* lief/src/error.rs
48
*/
49
};
50
51
const
char
*
to_string
(
lief_errors
err);
52
54
inline
tl::unexpected<lief_errors>
make_error_code
(
lief_errors
e) {
55
return
tl::make_unexpected(e);
56
}
57
58
59
namespace
LIEF
{
77
template
<
typename
T>
78
class
LIEF_MAYBE_UNUSED
result
:
public
tl::expected<T, lief_errors> {
79
public
:
80
using
ExpectedType
= T;
81
using
tl::expected<T,
lief_errors
>::expected;
82
result
(tl::expected<T, lief_errors> e) :
83
tl::expected<T,
lief_errors
>::expected(std::move(e)) {}
84
};
85
87
template
<
class
T>
88
lief_errors
get_error
(
result<T>
& err) {
89
return
err.error();
90
}
91
93
template
<
class
T>
94
lief_errors
as_lief_err
(
result<T>
& err) {
95
return
err.error();
96
}
97
99
struct
ok_t
{};
100
102
inline
ok_t
ok
() {
103
return
ok_t
{};
104
}
105
118
class
LIEF_MAYBE_UNUSED
ok_error_t
:
public
result
<ok_t> {
119
public
:
120
using
result
<
ok_t
>
::result
;
121
};
122
123
inline
bool
is_ok
(
const
ok_error_t
& val) {
124
return
val.has_value();
125
}
126
127
inline
bool
is_err
(
const
ok_error_t
& val) {
128
return
!
is_ok
(val);
129
}
130
131
}
132
133
extern
template
class
tl::expected<LIEF::ok_t, lief_errors>;
134
extern
template
class
LIEF::result<LIEF::ok_t>
;
135
extern
template
class
tl::expected<uint64_t, lief_errors>;
136
extern
template
class
LIEF::result<uint64_t>
;
137
extern
template
class
tl::expected<uint32_t, lief_errors>;
138
extern
template
class
LIEF::result<uint32_t>
;
139
extern
template
class
tl::expected<std::string, lief_errors>;
140
extern
template
class
LIEF::result<std::string>
;
141
142
#endif
LIEF::ok_error_t
Opaque structure that is used by LIEF to avoid writing result<void> f(...). Instead,...
Definition
errors.hpp:118
LIEF::result
Wrapper that contains an Object (T) or an error.
Definition
errors.hpp:78
LIEF::result::result
result(tl::expected< T, lief_errors > e)
Definition
errors.hpp:82
LIEF::result::ExpectedType
T ExpectedType
Definition
errors.hpp:80
compiler_attributes.hpp
LIEF_MAYBE_UNUSED
#define LIEF_MAYBE_UNUSED
Definition
compiler_attributes.hpp:62
lief_errors
lief_errors
LIEF error codes definition.
Definition
errors.hpp:24
lief_errors::require_extended_version
@ require_extended_version
Definition
errors.hpp:42
lief_errors::file_format_error
@ file_format_error
Definition
errors.hpp:37
lief_errors::data_too_large
@ data_too_large
Definition
errors.hpp:41
lief_errors::read_out_of_bound
@ read_out_of_bound
Definition
errors.hpp:33
lief_errors::conversion_error
@ conversion_error
Definition
errors.hpp:31
lief_errors::build_error
@ build_error
Definition
errors.hpp:39
lief_errors::not_implemented
@ not_implemented
Definition
errors.hpp:27
lief_errors::not_found
@ not_found
Definition
errors.hpp:26
lief_errors::corrupted
@ corrupted
Definition
errors.hpp:30
lief_errors::asn1_bad_tag
@ asn1_bad_tag
Definition
errors.hpp:34
lief_errors::not_supported
@ not_supported
Definition
errors.hpp:28
lief_errors::read_error
@ read_error
Definition
errors.hpp:25
lief_errors::parsing_error
@ parsing_error
Definition
errors.hpp:38
lief_errors::inconsistent
@ inconsistent
Definition
errors.hpp:43
lief_errors::file_error
@ file_error
Definition
errors.hpp:35
make_error_code
tl::unexpected< lief_errors > make_error_code(lief_errors e)
Create a standard error code from lief_errors.
Definition
errors.hpp:54
to_string
const char * to_string(lief_errors err)
LIEF
LIEF namespace.
Definition
Abstract/Binary.hpp:41
LIEF::is_ok
bool is_ok(const ok_error_t &val)
Definition
errors.hpp:123
LIEF::get_error
lief_errors get_error(result< T > &err)
Get the error code associated with the result.
Definition
errors.hpp:88
LIEF::ok
ok_t ok()
Return success for function with return type ok_error_t.
Definition
errors.hpp:102
LIEF::is_err
bool is_err(const ok_error_t &val)
Definition
errors.hpp:127
LIEF::as_lief_err
lief_errors as_lief_err(result< T > &err)
Return the lief_errors when the provided result<T> is an error.
Definition
errors.hpp:94
LIEF::ok_t
Opaque structure used by ok_error_t.
Definition
errors.hpp:99
Generated by
1.17.0