blob: 8f206e4354ad97dfce9a20aee9e8faf7ff001fce [file] [log] [blame]
//===-- mlir-c/Debug.h - C API for MLIR/LLVM debugging functions --*- C -*-===//
//
// Part of the LLVM Project, under the Apache License v2.0 with LLVM
// Exceptions.
// See https://llvm.org/LICENSE.txt for license information.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
//
//===----------------------------------------------------------------------===//
#include "mlir-c/Support.h"
#include <stdbool.h>
#ifdef __cplusplus
extern "C" {
#endif
/// Sets the global debugging flag.
MLIR_CAPI_EXPORTED void mlirEnableGlobalDebug(bool enable);
/// Retuns `true` if the global debugging flag is set, false otherwise.
MLIR_CAPI_EXPORTED bool mlirIsGlobalDebugEnabled();
/// Sets the current debug type, similarly to `-debug-only=type` in the
/// command-line tools. Note that global debug should be enabled for any output
/// to be produced.
MLIR_CAPI_EXPORTED void mlirSetGlobalDebugType(const char *type);
/// Sets multiple current debug types, similarly to `-debug-only=type1,type2" in
/// the command-line tools. Note that global debug should be enabled for any
/// output to be produced.
MLIR_CAPI_EXPORTED void mlirSetGlobalDebugTypes(const char **types, intptr_t n);
/// Adds to the current debug type state, similarly to
/// `-debug-only=prev_type,new_type` in the command-line tools. Note that global
/// debug should be enabled for any output to be produced. A single append call
/// can be reverted with mlirPopAppendedGlobalDebugTypes.
MLIR_CAPI_EXPORTED void mlirAppendGlobalDebugType(const char *type);
/// Adds to the current debug type state, similarly to
/// `-debug-only=prev_type,new_type1,new_type2` in the command-line tools. Note
/// that global debug should be enabled for any output to be produced. A single
/// append call can be reverted with mlirPopAppendedGlobalDebugTypes.
MLIR_CAPI_EXPORTED void mlirAppendGlobalDebugTypes(const char **types,
intptr_t n);
/// Restores the current debug type state to its state before the last append
/// call. An appended state of `-debug-only=prev_type,new_type1,new_type2` would
/// be `-debug-only=prev_type` after this call.
MLIR_CAPI_EXPORTED void mlirPopAppendedGlobalDebugTypes();
/// Checks if `type` is set as the current debug type.
MLIR_CAPI_EXPORTED bool mlirIsCurrentDebugType(const char *type);
#ifdef __cplusplus
}
#endif
#ifndef MLIR_C_DEBUG_H
#define MLIR_C_DEBUG_H
#endif // MLIR_C_DEBUG_H