SBModule.h revision 0b93a7546473b15fb14dbc129f1fe5ed6ee14976
124943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner//===-- SBModule.h ----------------------------------------------*- C++ -*-===//
224943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner//
324943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner//                     The LLVM Compiler Infrastructure
424943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner//
524943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner// This file is distributed under the University of Illinois Open Source
624943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner// License. See LICENSE.TXT for details.
724943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner//
824943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner//===----------------------------------------------------------------------===//
924943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
1024943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner#ifndef LLDB_SBModule_h_
1124943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner#define LLDB_SBModule_h_
1224943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
135f81547fd786584b10999c087528b323b5945896Eli Friedman#include "lldb/API/SBDefines.h"
143e8c25f62f92145b6fb699b379cbfe72b1245d4aGreg Clayton#include "lldb/API/SBError.h"
153e8c25f62f92145b6fb699b379cbfe72b1245d4aGreg Clayton#include "lldb/API/SBSection.h"
16466f6c4c0783c6b5197059caccab94faf1e605e9Greg Clayton#include "lldb/API/SBSymbolContext.h"
17917c000e77fcf657099f59085d6436d179a39ea4Greg Clayton#include "lldb/API/SBValueList.h"
1824943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
1924943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattnernamespace lldb {
2024943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
2124943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattnerclass SBModule
2224943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner{
2324943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattnerpublic:
2424943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
2524943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    SBModule ();
2624943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
27538eb82a89a68dbc57251915080bd5152b333978Greg Clayton    SBModule (const SBModule &rhs);
287dd5c51fbab8384b18f20ecc125f9a1bb3c9bcb2Greg Clayton
29538eb82a89a68dbc57251915080bd5152b333978Greg Clayton    const SBModule &
30538eb82a89a68dbc57251915080bd5152b333978Greg Clayton    operator = (const SBModule &rhs);
31538eb82a89a68dbc57251915080bd5152b333978Greg Clayton
32b5a8f1498e1ddaeed5187a878d57ea0b74af9c26Greg Clayton    SBModule (lldb::SBProcess &process,
33b5a8f1498e1ddaeed5187a878d57ea0b74af9c26Greg Clayton              lldb::addr_t header_addr);
34b5a8f1498e1ddaeed5187a878d57ea0b74af9c26Greg Clayton
3524943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    ~SBModule ();
3624943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
3724943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    bool
3824943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    IsValid () const;
3924943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
40e0bd571a8050da2b3462c35c9f209cbc9755c750Jim Ingham    void
41e0bd571a8050da2b3462c35c9f209cbc9755c750Jim Ingham    Clear();
42e0bd571a8050da2b3462c35c9f209cbc9755c750Jim Ingham
43cbb52a64ea9775af1fcca2e929d0d0b4aa698de4Johnny Chen    //------------------------------------------------------------------
44cbb52a64ea9775af1fcca2e929d0d0b4aa698de4Johnny Chen    /// Get const accessor for the module file specification.
45cbb52a64ea9775af1fcca2e929d0d0b4aa698de4Johnny Chen    ///
46cbb52a64ea9775af1fcca2e929d0d0b4aa698de4Johnny Chen    /// This function returns the file for the module on the host system
47cbb52a64ea9775af1fcca2e929d0d0b4aa698de4Johnny Chen    /// that is running LLDB. This can differ from the path on the
48cbb52a64ea9775af1fcca2e929d0d0b4aa698de4Johnny Chen    /// platform since we might be doing remote debugging.
49cbb52a64ea9775af1fcca2e929d0d0b4aa698de4Johnny Chen    ///
50cbb52a64ea9775af1fcca2e929d0d0b4aa698de4Johnny Chen    /// @return
51cbb52a64ea9775af1fcca2e929d0d0b4aa698de4Johnny Chen    ///     A const reference to the file specification object.
52cbb52a64ea9775af1fcca2e929d0d0b4aa698de4Johnny Chen    //------------------------------------------------------------------
5324943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    lldb::SBFileSpec
5424943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    GetFileSpec () const;
5524943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
56cbb52a64ea9775af1fcca2e929d0d0b4aa698de4Johnny Chen    //------------------------------------------------------------------
57cbb52a64ea9775af1fcca2e929d0d0b4aa698de4Johnny Chen    /// Get accessor for the module platform file specification.
58cbb52a64ea9775af1fcca2e929d0d0b4aa698de4Johnny Chen    ///
59cbb52a64ea9775af1fcca2e929d0d0b4aa698de4Johnny Chen    /// Platform file refers to the path of the module as it is known on
60cbb52a64ea9775af1fcca2e929d0d0b4aa698de4Johnny Chen    /// the remote system on which it is being debugged. For local
61cbb52a64ea9775af1fcca2e929d0d0b4aa698de4Johnny Chen    /// debugging this is always the same as Module::GetFileSpec(). But
62cbb52a64ea9775af1fcca2e929d0d0b4aa698de4Johnny Chen    /// remote debugging might mention a file '/usr/lib/liba.dylib'
63cbb52a64ea9775af1fcca2e929d0d0b4aa698de4Johnny Chen    /// which might be locally downloaded and cached. In this case the
64cbb52a64ea9775af1fcca2e929d0d0b4aa698de4Johnny Chen    /// platform file could be something like:
65cbb52a64ea9775af1fcca2e929d0d0b4aa698de4Johnny Chen    /// '/tmp/lldb/platform-cache/remote.host.computer/usr/lib/liba.dylib'
66cbb52a64ea9775af1fcca2e929d0d0b4aa698de4Johnny Chen    /// The file could also be cached in a local developer kit directory.
67cbb52a64ea9775af1fcca2e929d0d0b4aa698de4Johnny Chen    ///
68cbb52a64ea9775af1fcca2e929d0d0b4aa698de4Johnny Chen    /// @return
69cbb52a64ea9775af1fcca2e929d0d0b4aa698de4Johnny Chen    ///     A const reference to the file specification object.
70cbb52a64ea9775af1fcca2e929d0d0b4aa698de4Johnny Chen    //------------------------------------------------------------------
71180546b3feb8c7bcca70a56776a7c4fad99ba09cGreg Clayton    lldb::SBFileSpec
72180546b3feb8c7bcca70a56776a7c4fad99ba09cGreg Clayton    GetPlatformFileSpec () const;
73180546b3feb8c7bcca70a56776a7c4fad99ba09cGreg Clayton
74180546b3feb8c7bcca70a56776a7c4fad99ba09cGreg Clayton    bool
75180546b3feb8c7bcca70a56776a7c4fad99ba09cGreg Clayton    SetPlatformFileSpec (const lldb::SBFileSpec &platform_file);
76180546b3feb8c7bcca70a56776a7c4fad99ba09cGreg Clayton
771b925206e3c4867fea9eb55a4c6460962cf32564Greg Clayton    lldb::ByteOrder
781b925206e3c4867fea9eb55a4c6460962cf32564Greg Clayton    GetByteOrder ();
791b925206e3c4867fea9eb55a4c6460962cf32564Greg Clayton
801b925206e3c4867fea9eb55a4c6460962cf32564Greg Clayton    uint32_t
811b925206e3c4867fea9eb55a4c6460962cf32564Greg Clayton    GetAddressByteSize();
821b925206e3c4867fea9eb55a4c6460962cf32564Greg Clayton
831b925206e3c4867fea9eb55a4c6460962cf32564Greg Clayton    const char *
841b925206e3c4867fea9eb55a4c6460962cf32564Greg Clayton    GetTriple ();
851b925206e3c4867fea9eb55a4c6460962cf32564Greg Clayton
8624943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    const uint8_t *
8724943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    GetUUIDBytes () const;
8824943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
89919ee60577297be31eb69f14a5901e7c6170a9caJohnny Chen    const char *
90919ee60577297be31eb69f14a5901e7c6170a9caJohnny Chen    GetUUIDString () const;
91919ee60577297be31eb69f14a5901e7c6170a9caJohnny Chen
9224943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    bool
9324943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    operator == (const lldb::SBModule &rhs) const;
9424943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
9524943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    bool
9624943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    operator != (const lldb::SBModule &rhs) const;
9724943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
983e8c25f62f92145b6fb699b379cbfe72b1245d4aGreg Clayton    lldb::SBSection
993e8c25f62f92145b6fb699b379cbfe72b1245d4aGreg Clayton    FindSection (const char *sect_name);
10024943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
1013e8c25f62f92145b6fb699b379cbfe72b1245d4aGreg Clayton    lldb::SBAddress
1023e8c25f62f92145b6fb699b379cbfe72b1245d4aGreg Clayton    ResolveFileAddress (lldb::addr_t vm_addr);
103466f6c4c0783c6b5197059caccab94faf1e605e9Greg Clayton
104466f6c4c0783c6b5197059caccab94faf1e605e9Greg Clayton    lldb::SBSymbolContext
105466f6c4c0783c6b5197059caccab94faf1e605e9Greg Clayton    ResolveSymbolContextForAddress (const lldb::SBAddress& addr,
106466f6c4c0783c6b5197059caccab94faf1e605e9Greg Clayton                                    uint32_t resolve_scope);
10724943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
10898f930f429160f9777f626c3ac6aa609f4e965d2Caroline Tice    bool
10998f930f429160f9777f626c3ac6aa609f4e965d2Caroline Tice    GetDescription (lldb::SBStream &description);
11098f930f429160f9777f626c3ac6aa609f4e965d2Caroline Tice
111b451f5f1606fc5effdc809fa2261263851fff8f5Johnny Chen    uint32_t
112b451f5f1606fc5effdc809fa2261263851fff8f5Johnny Chen    GetNumCompileUnits();
113b451f5f1606fc5effdc809fa2261263851fff8f5Johnny Chen
114b451f5f1606fc5effdc809fa2261263851fff8f5Johnny Chen    lldb::SBCompileUnit
115b451f5f1606fc5effdc809fa2261263851fff8f5Johnny Chen    GetCompileUnitAtIndex (uint32_t);
116b451f5f1606fc5effdc809fa2261263851fff8f5Johnny Chen
11743edca38dda703786e2dc7ad61169b5b445551e6Greg Clayton    size_t
11843edca38dda703786e2dc7ad61169b5b445551e6Greg Clayton    GetNumSymbols ();
11943edca38dda703786e2dc7ad61169b5b445551e6Greg Clayton
12067283641ef749fadab1884e81520e7e5ab42e91aGreg Clayton    lldb::SBSymbol
12143edca38dda703786e2dc7ad61169b5b445551e6Greg Clayton    GetSymbolAtIndex (size_t idx);
12243edca38dda703786e2dc7ad61169b5b445551e6Greg Clayton
123b3dafc6a81a014339015701c9872624f2aeddd43Greg Clayton    lldb::SBSymbol
124b3dafc6a81a014339015701c9872624f2aeddd43Greg Clayton    FindSymbol (const char *name,
125b3dafc6a81a014339015701c9872624f2aeddd43Greg Clayton                lldb::SymbolType type = eSymbolTypeAny);
126b3dafc6a81a014339015701c9872624f2aeddd43Greg Clayton
127b3dafc6a81a014339015701c9872624f2aeddd43Greg Clayton    lldb::SBSymbolContextList
128b3dafc6a81a014339015701c9872624f2aeddd43Greg Clayton    FindSymbols (const char *name,
129b3dafc6a81a014339015701c9872624f2aeddd43Greg Clayton                 lldb::SymbolType type = eSymbolTypeAny);
130b3dafc6a81a014339015701c9872624f2aeddd43Greg Clayton
1313e8c25f62f92145b6fb699b379cbfe72b1245d4aGreg Clayton    size_t
1323e8c25f62f92145b6fb699b379cbfe72b1245d4aGreg Clayton    GetNumSections ();
1333e8c25f62f92145b6fb699b379cbfe72b1245d4aGreg Clayton
1343e8c25f62f92145b6fb699b379cbfe72b1245d4aGreg Clayton    lldb::SBSection
1353e8c25f62f92145b6fb699b379cbfe72b1245d4aGreg Clayton    GetSectionAtIndex (size_t idx);
136cbb52a64ea9775af1fcca2e929d0d0b4aa698de4Johnny Chen    //------------------------------------------------------------------
137cbb52a64ea9775af1fcca2e929d0d0b4aa698de4Johnny Chen    /// Find functions by name.
138cbb52a64ea9775af1fcca2e929d0d0b4aa698de4Johnny Chen    ///
139cbb52a64ea9775af1fcca2e929d0d0b4aa698de4Johnny Chen    /// @param[in] name
140cbb52a64ea9775af1fcca2e929d0d0b4aa698de4Johnny Chen    ///     The name of the function we are looking for.
141cbb52a64ea9775af1fcca2e929d0d0b4aa698de4Johnny Chen    ///
142cbb52a64ea9775af1fcca2e929d0d0b4aa698de4Johnny Chen    /// @param[in] name_type_mask
143cbb52a64ea9775af1fcca2e929d0d0b4aa698de4Johnny Chen    ///     A logical OR of one or more FunctionNameType enum bits that
144cbb52a64ea9775af1fcca2e929d0d0b4aa698de4Johnny Chen    ///     indicate what kind of names should be used when doing the
145cbb52a64ea9775af1fcca2e929d0d0b4aa698de4Johnny Chen    ///     lookup. Bits include fully qualified names, base names,
146cbb52a64ea9775af1fcca2e929d0d0b4aa698de4Johnny Chen    ///     C++ methods, or ObjC selectors.
147cbb52a64ea9775af1fcca2e929d0d0b4aa698de4Johnny Chen    ///     See FunctionNameType for more details.
148cbb52a64ea9775af1fcca2e929d0d0b4aa698de4Johnny Chen    ///
149cbb52a64ea9775af1fcca2e929d0d0b4aa698de4Johnny Chen    /// @return
1507dd5c51fbab8384b18f20ecc125f9a1bb3c9bcb2Greg Clayton    ///     A lldb::SBSymbolContextList that gets filled in with all of
1517dd5c51fbab8384b18f20ecc125f9a1bb3c9bcb2Greg Clayton    ///     the symbol contexts for all the matches.
152cbb52a64ea9775af1fcca2e929d0d0b4aa698de4Johnny Chen    //------------------------------------------------------------------
1537dd5c51fbab8384b18f20ecc125f9a1bb3c9bcb2Greg Clayton    lldb::SBSymbolContextList
1544ed315fdc503cfdc18e89b1eb43bf87e07fd1673Greg Clayton    FindFunctions (const char *name,
1557dd5c51fbab8384b18f20ecc125f9a1bb3c9bcb2Greg Clayton                   uint32_t name_type_mask = lldb::eFunctionNameTypeAny);
1564ed315fdc503cfdc18e89b1eb43bf87e07fd1673Greg Clayton
157cbb52a64ea9775af1fcca2e929d0d0b4aa698de4Johnny Chen    //------------------------------------------------------------------
158cbb52a64ea9775af1fcca2e929d0d0b4aa698de4Johnny Chen    /// Find global and static variables by name.
159cbb52a64ea9775af1fcca2e929d0d0b4aa698de4Johnny Chen    ///
160bbc6342babdd58daa34bb35e35d7d53f59beada1Johnny Chen    /// @param[in] target
161bbc6342babdd58daa34bb35e35d7d53f59beada1Johnny Chen    ///     A valid SBTarget instance representing the debuggee.
162bbc6342babdd58daa34bb35e35d7d53f59beada1Johnny Chen    ///
163cbb52a64ea9775af1fcca2e929d0d0b4aa698de4Johnny Chen    /// @param[in] name
164cbb52a64ea9775af1fcca2e929d0d0b4aa698de4Johnny Chen    ///     The name of the global or static variable we are looking
165cbb52a64ea9775af1fcca2e929d0d0b4aa698de4Johnny Chen    ///     for.
166cbb52a64ea9775af1fcca2e929d0d0b4aa698de4Johnny Chen    ///
167bbc6342babdd58daa34bb35e35d7d53f59beada1Johnny Chen    /// @param[in] max_matches
168bbc6342babdd58daa34bb35e35d7d53f59beada1Johnny Chen    ///     Allow the number of matches to be limited to \a max_matches.
169cbb52a64ea9775af1fcca2e929d0d0b4aa698de4Johnny Chen    ///
170cbb52a64ea9775af1fcca2e929d0d0b4aa698de4Johnny Chen    /// @return
171cbb52a64ea9775af1fcca2e929d0d0b4aa698de4Johnny Chen    ///     A list of matched variables in an SBValueList.
172cbb52a64ea9775af1fcca2e929d0d0b4aa698de4Johnny Chen    //------------------------------------------------------------------
173917c000e77fcf657099f59085d6436d179a39ea4Greg Clayton    lldb::SBValueList
174917c000e77fcf657099f59085d6436d179a39ea4Greg Clayton    FindGlobalVariables (lldb::SBTarget &target,
175917c000e77fcf657099f59085d6436d179a39ea4Greg Clayton                         const char *name,
176917c000e77fcf657099f59085d6436d179a39ea4Greg Clayton                         uint32_t max_matches);
177917c000e77fcf657099f59085d6436d179a39ea4Greg Clayton
178979e20d127335143ffc89c2e37ec3a8b717ff22dEnrico Granata    lldb::SBType
179979e20d127335143ffc89c2e37ec3a8b717ff22dEnrico Granata    FindFirstType (const char* name);
180979e20d127335143ffc89c2e37ec3a8b717ff22dEnrico Granata
181979e20d127335143ffc89c2e37ec3a8b717ff22dEnrico Granata    lldb::SBTypeList
182979e20d127335143ffc89c2e37ec3a8b717ff22dEnrico Granata    FindTypes (const char* type);
183e0bd571a8050da2b3462c35c9f209cbc9755c750Jim Ingham
1840b93a7546473b15fb14dbc129f1fe5ed6ee14976Greg Clayton    lldb::SBType
1850b93a7546473b15fb14dbc129f1fe5ed6ee14976Greg Clayton    GetBasicType(lldb::BasicType type);
18649f4bf21e0fb7675d67f95dafe66a098d3205650Greg Clayton
18749f4bf21e0fb7675d67f95dafe66a098d3205650Greg Clayton    //------------------------------------------------------------------
18849f4bf21e0fb7675d67f95dafe66a098d3205650Greg Clayton    /// Get the module version numbers.
18949f4bf21e0fb7675d67f95dafe66a098d3205650Greg Clayton    ///
19049f4bf21e0fb7675d67f95dafe66a098d3205650Greg Clayton    /// Many object files have a set of version numbers that describe
19149f4bf21e0fb7675d67f95dafe66a098d3205650Greg Clayton    /// the version of the executable or shared library. Typically there
19249f4bf21e0fb7675d67f95dafe66a098d3205650Greg Clayton    /// are major, minor and build, but there may be more. This function
19349f4bf21e0fb7675d67f95dafe66a098d3205650Greg Clayton    /// will extract the versions from object files if they are available.
19449f4bf21e0fb7675d67f95dafe66a098d3205650Greg Clayton    ///
19549f4bf21e0fb7675d67f95dafe66a098d3205650Greg Clayton    /// If \a versions is NULL, or if \a num_versions is 0, the return
19649f4bf21e0fb7675d67f95dafe66a098d3205650Greg Clayton    /// value will indicate how many version numbers are available in
19749f4bf21e0fb7675d67f95dafe66a098d3205650Greg Clayton    /// this object file. Then a subsequent call can be made to this
19849f4bf21e0fb7675d67f95dafe66a098d3205650Greg Clayton    /// function with a value of \a versions and \a num_versions that
19949f4bf21e0fb7675d67f95dafe66a098d3205650Greg Clayton    /// has enough storage to store some or all version numbers.
20049f4bf21e0fb7675d67f95dafe66a098d3205650Greg Clayton    ///
20149f4bf21e0fb7675d67f95dafe66a098d3205650Greg Clayton    /// @param[out] versions
20249f4bf21e0fb7675d67f95dafe66a098d3205650Greg Clayton    ///     A pointer to an array of uint32_t types that is \a num_versions
20349f4bf21e0fb7675d67f95dafe66a098d3205650Greg Clayton    ///     long. If this value is NULL, the return value will indicate
20449f4bf21e0fb7675d67f95dafe66a098d3205650Greg Clayton    ///     how many version numbers are required for a subsequent call
20549f4bf21e0fb7675d67f95dafe66a098d3205650Greg Clayton    ///     to this function so that all versions can be retrieved. If
20649f4bf21e0fb7675d67f95dafe66a098d3205650Greg Clayton    ///     the value is non-NULL, then at most \a num_versions of the
20749f4bf21e0fb7675d67f95dafe66a098d3205650Greg Clayton    ///     existing versions numbers will be filled into \a versions.
20849f4bf21e0fb7675d67f95dafe66a098d3205650Greg Clayton    ///     If there is no version information available, \a versions
20949f4bf21e0fb7675d67f95dafe66a098d3205650Greg Clayton    ///     will be filled with \a num_versions UINT32_MAX values
21049f4bf21e0fb7675d67f95dafe66a098d3205650Greg Clayton    ///     and zero will be returned.
21149f4bf21e0fb7675d67f95dafe66a098d3205650Greg Clayton    ///
21249f4bf21e0fb7675d67f95dafe66a098d3205650Greg Clayton    /// @param[in] num_versions
21349f4bf21e0fb7675d67f95dafe66a098d3205650Greg Clayton    ///     The maximum number of entries to fill into \a versions. If
21449f4bf21e0fb7675d67f95dafe66a098d3205650Greg Clayton    ///     this value is zero, then the return value will indicate
21549f4bf21e0fb7675d67f95dafe66a098d3205650Greg Clayton    ///     how many version numbers there are in total so another call
21649f4bf21e0fb7675d67f95dafe66a098d3205650Greg Clayton    ///     to this function can be make with adequate storage in
21749f4bf21e0fb7675d67f95dafe66a098d3205650Greg Clayton    ///     \a versions to get all of the version numbers. If \a
21849f4bf21e0fb7675d67f95dafe66a098d3205650Greg Clayton    ///     num_versions is less than the actual number of version
21949f4bf21e0fb7675d67f95dafe66a098d3205650Greg Clayton    ///     numbers in this object file, only \a num_versions will be
22049f4bf21e0fb7675d67f95dafe66a098d3205650Greg Clayton    ///     filled into \a versions (if \a versions is non-NULL).
22149f4bf21e0fb7675d67f95dafe66a098d3205650Greg Clayton    ///
22249f4bf21e0fb7675d67f95dafe66a098d3205650Greg Clayton    /// @return
22349f4bf21e0fb7675d67f95dafe66a098d3205650Greg Clayton    ///     This function always returns the number of version numbers
22449f4bf21e0fb7675d67f95dafe66a098d3205650Greg Clayton    ///     that this object file has regardless of the number of
22549f4bf21e0fb7675d67f95dafe66a098d3205650Greg Clayton    ///     version numbers that were copied into \a versions.
22649f4bf21e0fb7675d67f95dafe66a098d3205650Greg Clayton    //------------------------------------------------------------------
22749f4bf21e0fb7675d67f95dafe66a098d3205650Greg Clayton    uint32_t
22849f4bf21e0fb7675d67f95dafe66a098d3205650Greg Clayton    GetVersion (uint32_t *versions,
22949f4bf21e0fb7675d67f95dafe66a098d3205650Greg Clayton                uint32_t num_versions);
23049f4bf21e0fb7675d67f95dafe66a098d3205650Greg Clayton
23124943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattnerprivate:
232b0e68d996b28cf81a28aeceefd69f7ed8d4aba99Greg Clayton    friend class SBAddress;
233b0e68d996b28cf81a28aeceefd69f7ed8d4aba99Greg Clayton    friend class SBFrame;
2343e8c25f62f92145b6fb699b379cbfe72b1245d4aGreg Clayton    friend class SBSection;
23524943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    friend class SBSymbolContext;
23624943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    friend class SBTarget;
23724943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
23824943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    explicit SBModule (const lldb::ModuleSP& module_sp);
23924943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
2400416bdf783a7dc2544b9ab034e225391f8f47343Greg Clayton    ModuleSP
2410416bdf783a7dc2544b9ab034e225391f8f47343Greg Clayton    GetSP () const;
2423e8c25f62f92145b6fb699b379cbfe72b1245d4aGreg Clayton
2430416bdf783a7dc2544b9ab034e225391f8f47343Greg Clayton    void
2440416bdf783a7dc2544b9ab034e225391f8f47343Greg Clayton    SetSP (const ModuleSP &module_sp);
24524943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
24663094e0bb161580564954dee512955c1c79d3476Greg Clayton    lldb::ModuleSP m_opaque_sp;
24724943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner};
24824943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
24924943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
25024943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner} // namespace lldb
25124943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
25224943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner#endif // LLDB_SBModule_h_
253