drgn/libdrgn/error.h
Omar Sandoval 72b4aa9669 libdrgn: clean up object initialization
Rename struct drgn_object_type to struct drgn_operand_type, add a new
struct drgn_object_type which contains all of the type-related fields
from struct drgn_object, and use it to implement drgn_object_type() and
drgn_object_type_operand(), which are replacements for
drgn_object_set_common() and drgn_object_type_encoding_and_size(). This
cleans up a lot of the boilerplate around initializing objects.

Signed-off-by: Omar Sandoval <osandov@osandov.com>
2021-02-19 17:43:14 -08:00

117 lines
2.9 KiB
C

// Copyright (c) Facebook, Inc. and its affiliates.
// SPDX-License-Identifier: GPL-3.0+
/**
* @file
*
* Error helpers.
*
* See @ref Errors.
*/
#ifndef DRGN_ERROR_H
#define DRGN_ERROR_H
#include "drgn.h"
/**
* @ingroup Internals
*
* @defgroup Errors Errors
*
* Common errors.
*
* @{
*/
struct drgn_operand_type;
/**
* Global stop iteration error.
*
* This is also used as a special sentinel return in various places internally.
*/
extern struct drgn_error drgn_stop;
/** Global @ref DRGN_ERROR_OBJECT_ABSENT error. */
extern struct drgn_error drgn_error_object_absent;
struct string_builder;
/**
* Create a @ref drgn_error with a message from a @ref string_builder.
*
* This finalizes the string builder.
*/
struct drgn_error *drgn_error_from_string_builder(enum drgn_error_code code,
struct string_builder *sb);
/**
* Append a formatted @ref drgn_error to a @ref string_builder.
*
* @return @c true on success, @c false on error (if we couldn't allocate
* memory).
*/
bool string_builder_append_error(struct string_builder *sb,
struct drgn_error *err);
/** Create a @ref drgn_error from the libelf error indicator. */
struct drgn_error *drgn_error_libelf(void)
__attribute__((returns_nonnull));
/** Create a @ref drgn_error from the libdw error indicator. */
struct drgn_error *drgn_error_libdw(void)
__attribute__((returns_nonnull));
/** Create a @ref drgn_error from the libdwfl error indicator. */
struct drgn_error *drgn_error_libdwfl(void)
__attribute__((returns_nonnull));
/**
* Create a @ref drgn_error with a type name.
*
* The error code will be @ref DRGN_ERROR_TYPE.
*
* @param[in] format Format string for the type error. Must contain %s, which
* will be replaced with the type name, and no other conversion specifications.
*/
struct drgn_error *drgn_type_error(const char *format, struct drgn_type *type)
__attribute__((returns_nonnull));
/**
* Create a @ref drgn_error with a qualified type name.
*
* @sa drgn_type_error().
*/
struct drgn_error *
drgn_qualified_type_error(const char *format,
struct drgn_qualified_type qualified_type)
__attribute__((returns_nonnull));
/**
* Create a @ref drgn_error for an incomplete type.
*
* @sa drgn_type_error().
*/
struct drgn_error *drgn_error_incomplete_type(const char *format,
struct drgn_type *type);
/** Create a @ref drgn_error for invalid types to a binary operator. */
struct drgn_error *drgn_error_binary_op(const char *op_name,
struct drgn_operand_type *type1,
struct drgn_operand_type *type2)
__attribute__((returns_nonnull));
/** Create a @ref drgn_error for an invalid type to a unary operator. */
struct drgn_error *drgn_error_unary_op(const char *op_name,
struct drgn_operand_type *type)
__attribute__((returns_nonnull));
/** Create a @ref drgn_error for a failed symbol lookup. */
struct drgn_error *drgn_error_symbol_not_found(uint64_t address)
__attribute__((returns_nonnull));
/** @} */
#endif /* DRGN_ERROR_H */