1 //===- tools/dsymutil/dsymutil.h - dsymutil high-level functionality ------===//
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
7 //===----------------------------------------------------------------------===//
11 /// This file contains the class declaration for the code that parses STABS
12 /// debug maps that are embedded in the binaries symbol tables.
14 //===----------------------------------------------------------------------===//
16 #ifndef LLVM_TOOLS_DSYMUTIL_DSYMUTIL_H
17 #define LLVM_TOOLS_DSYMUTIL_DSYMUTIL_H
20 #include "LinkUtils.h"
21 #include "llvm/ADT/ArrayRef.h"
22 #include "llvm/ADT/StringRef.h"
23 #include "llvm/Support/Compiler.h"
24 #include "llvm/Support/ErrorOr.h"
34 /// Extract the DebugMaps from the given file.
35 /// The file has to be a MachO object file. Multiple debug maps can be
36 /// returned when the file is universal (aka fat) binary.
37 ErrorOr
<std::vector
<std::unique_ptr
<DebugMap
>>>
38 parseDebugMap(StringRef InputFile
, ArrayRef
<std::string
> Archs
,
39 StringRef PrependPath
, bool PaperTrailWarnings
, bool Verbose
,
42 /// Dump the symbol table
43 bool dumpStab(StringRef InputFile
, ArrayRef
<std::string
> Archs
,
44 StringRef PrependPath
= "");
46 /// Link the Dwarf debug info as directed by the passed DebugMap \p DM into a
47 /// DwarfFile named \p OutputFilename. \returns false if the link failed.
48 bool linkDwarf(raw_fd_ostream
&OutFile
, BinaryHolder
&BinHolder
,
49 const DebugMap
&DM
, LinkOptions Options
);
51 } // end namespace dsymutil
52 } // end namespace llvm
54 #endif // LLVM_TOOLS_DSYMUTIL_DSYMUTIL_H