xref: /freebsd/contrib/llvm-project/lldb/bindings/python/python.swig (revision bc5304a006238115291e7568583632889dffbab9)
1/*
2   lldb.swig
3
4   This is the input file for SWIG, to create the appropriate C++ wrappers and
5   functions for various scripting languages, to enable them to call the
6   liblldb Script Bridge functions.
7*/
8
9/* Define our module docstring. */
10%define DOCSTRING
11"The lldb module contains the public APIs for Python binding.
12
13Some of the important classes are described here:
14
15* :py:class:`SBTarget`: Represents the target program running under the debugger.
16* :py:class:`SBProcess`: Represents the process associated with the target program.
17* :py:class:`SBThread`: Represents a thread of execution. :py:class:`SBProcess` contains SBThreads.
18* :py:class:`SBFrame`: Represents one of the stack frames associated with a thread. :py:class:`SBThread`
19  contains SBFrame(s).
20* :py:class:`SBSymbolContext`: A container that stores various debugger related info.
21* :py:class:`SBValue`: Represents the value of a variable, a register, or an expression.
22* :py:class:`SBModule`: Represents an executable image and its associated object and symbol
23  files.  :py:class:`SBTarget` contains SBModule.
24* :py:class:`SBBreakpoint`: Represents a logical breakpoint and its associated settings.
25  :py:class:`SBTarget` contains SBBreakpoints.
26* :py:class:`SBSymbol`: Represents the symbol possibly associated with a stack frame.
27* :py:class:`SBCompileUnit`: Represents a compilation unit, or compiled source file.
28* :py:class:`SBFunction`: Represents a generic function, which can be inlined or not.
29* :py:class:`SBBlock`: Represents a lexical block. :py:class:`SBFunction` contains SBBlocks.
30* :py:class:`SBLineEntry`: Specifies an association with a contiguous range of instructions
31  and a source file location. :py:class:`SBCompileUnit` contains SBLineEntry.
32
33The different enums in the `lldb` module are described in :doc:`python_api_enums`.
34
35"
36%enddef
37
38/*
39Since version 3.0.9, swig's logic for importing the native module has changed in
40a way that is incompatible with our usage of the python module as __init__.py
41(See swig bug #769).  Fortunately, since version 3.0.11, swig provides a way for
42us to override the module import logic to suit our needs. This does that.
43
44Older swig versions will simply ignore this setting.
45*/
46%define MODULEIMPORT
47"try:
48    # Try an absolute import first.  If we're being loaded from lldb,
49    # _lldb should be a built-in module.
50    import $module
51except ImportError:
52    # Relative import should work if we are being loaded by Python.
53    from . import $module"
54%enddef
55// These versions will not generate working python modules, so error out early.
56#if SWIG_VERSION >= 0x030009 && SWIG_VERSION < 0x030011
57#error Swig versions 3.0.9 and 3.0.10 are incompatible with lldb.
58#endif
59
60// The name of the module to be created.
61%module(docstring=DOCSTRING, moduleimport=MODULEIMPORT) lldb
62
63// Parameter types will be used in the autodoc string.
64%feature("autodoc", "1");
65
66%define ARRAYHELPER(type,name)
67%inline %{
68type *new_ ## name (int nitems) {
69   return (type *) malloc(sizeof(type)*nitems);
70}
71void delete_ ## name(type *t) {
72   free(t);
73}
74type name ## _get(type *t, int index) {
75   return t[index];
76}
77void name ## _set(type *t, int index, type val) {
78   t[index] = val;
79}
80%}
81%enddef
82
83%pythoncode%{
84import uuid
85import re
86import os
87
88import six
89%}
90
91// Include the version of swig that was used to generate this interface.
92%define EMBED_VERSION(VERSION)
93%pythoncode%{
94# SWIG_VERSION is written as a single hex number, but the components of it are
95# meant to be interpreted in decimal. So, 0x030012 is swig 3.0.12, and not
96# 3.0.18.
97def _to_int(hex):
98    return hex // 0x10 % 0x10 * 10 + hex % 0x10
99swig_version = (_to_int(VERSION // 0x10000), _to_int(VERSION // 0x100), _to_int(VERSION))
100del _to_int
101%}
102%enddef
103EMBED_VERSION(SWIG_VERSION)
104
105%pythoncode%{
106# ===================================
107# Iterator for lldb container objects
108# ===================================
109def lldb_iter(obj, getsize, getelem):
110    """A generator adaptor to support iteration for lldb container objects."""
111    size = getattr(obj, getsize)
112    elem = getattr(obj, getelem)
113    for i in range(size()):
114        yield elem(i)
115%}
116
117%include <std_string.i>
118%include "python-typemaps.swig"
119%include "macros.swig"
120%include "headers.swig"
121
122%{
123#include "../source/Plugins/ScriptInterpreter/Python/PythonDataObjects.h"
124#include "../bindings/python/python-swigsafecast.swig"
125using namespace lldb_private;
126using namespace lldb_private::python;
127using namespace lldb;
128%}
129
130%include "interfaces.swig"
131%include "python-extensions.swig"
132%include "python-wrapper.swig"
133
134%pythoncode%{
135_initialize = True
136try:
137   import lldbconfig
138   _initialize = lldbconfig.INITIALIZE
139except ImportError:
140   pass
141debugger_unique_id = 0
142if _initialize:
143   SBDebugger.Initialize()
144debugger = None
145target = None
146process = None
147thread = None
148frame = None
149%}
150