16498aff2SJonas Devlieghere%header %{
26498aff2SJonas Devlieghere
36498aff2SJonas Devliegheretemplate <typename T>
46498aff2SJonas DevliegherePyObject *
56498aff2SJonas DevlieghereSBTypeToSWIGWrapper (T* item);
66498aff2SJonas Devlieghere
76498aff2SJonas Devlieghereclass PyErr_Cleaner
86498aff2SJonas Devlieghere{
96498aff2SJonas Devliegherepublic:
106498aff2SJonas Devlieghere    PyErr_Cleaner(bool print=false) :
116498aff2SJonas Devlieghere    m_print(print)
126498aff2SJonas Devlieghere    {
136498aff2SJonas Devlieghere    }
146498aff2SJonas Devlieghere
156498aff2SJonas Devlieghere    ~PyErr_Cleaner()
166498aff2SJonas Devlieghere    {
176498aff2SJonas Devlieghere        if (PyErr_Occurred())
186498aff2SJonas Devlieghere        {
196498aff2SJonas Devlieghere            if(m_print && !PyErr_ExceptionMatches(PyExc_SystemExit))
206498aff2SJonas Devlieghere                PyErr_Print();
216498aff2SJonas Devlieghere            PyErr_Clear();
226498aff2SJonas Devlieghere        }
236498aff2SJonas Devlieghere    }
246498aff2SJonas Devlieghere
256498aff2SJonas Devlieghereprivate:
266498aff2SJonas Devlieghere    bool m_print;
276498aff2SJonas Devlieghere};
286498aff2SJonas Devlieghere
296498aff2SJonas Devlieghere%}
306498aff2SJonas Devlieghere
316498aff2SJonas Devlieghere%wrapper %{
326498aff2SJonas Devlieghere
336498aff2SJonas Devlieghere// resolve a dotted Python name in the form
346498aff2SJonas Devlieghere// foo.bar.baz.Foobar to an actual Python object
356498aff2SJonas Devlieghere// if pmodule is NULL, the __main__ module will be used
366498aff2SJonas Devlieghere// as the starting point for the search
376498aff2SJonas Devlieghere
386498aff2SJonas Devlieghere
396498aff2SJonas Devlieghere// This function is called by lldb_private::ScriptInterpreterPython::BreakpointCallbackFunction(...)
406498aff2SJonas Devlieghere// and is used when a script command is attached to a breakpoint for execution.
416498aff2SJonas Devlieghere
426498aff2SJonas DevlieghereSWIGEXPORT llvm::Expected<bool>
436498aff2SJonas DevlieghereLLDBSwigPythonBreakpointCallbackFunction
446498aff2SJonas Devlieghere(
456498aff2SJonas Devlieghere    const char *python_function_name,
466498aff2SJonas Devlieghere    const char *session_dictionary_name,
476498aff2SJonas Devlieghere    const lldb::StackFrameSP& frame_sp,
486498aff2SJonas Devlieghere    const lldb::BreakpointLocationSP& bp_loc_sp,
496498aff2SJonas Devlieghere    lldb_private::StructuredDataImpl *args_impl
506498aff2SJonas Devlieghere)
516498aff2SJonas Devlieghere{
526498aff2SJonas Devlieghere    using namespace llvm;
536498aff2SJonas Devlieghere
546498aff2SJonas Devlieghere    lldb::SBFrame sb_frame (frame_sp);
556498aff2SJonas Devlieghere    lldb::SBBreakpointLocation sb_bp_loc(bp_loc_sp);
566498aff2SJonas Devlieghere
576498aff2SJonas Devlieghere    PyErr_Cleaner py_err_cleaner(true);
586498aff2SJonas Devlieghere    auto dict = PythonModule::MainModule().ResolveName<PythonDictionary>(session_dictionary_name);
596498aff2SJonas Devlieghere    auto pfunc = PythonObject::ResolveNameWithDictionary<PythonCallable>(python_function_name, dict);
606498aff2SJonas Devlieghere
616498aff2SJonas Devlieghere    unsigned max_positional_args;
626498aff2SJonas Devlieghere    if (auto arg_info = pfunc.GetArgInfo())
636498aff2SJonas Devlieghere        max_positional_args = arg_info.get().max_positional_args;
646498aff2SJonas Devlieghere    else
656498aff2SJonas Devlieghere        return arg_info.takeError();
666498aff2SJonas Devlieghere
676498aff2SJonas Devlieghere    PythonObject frame_arg(PyRefType::Owned, SBTypeToSWIGWrapper(sb_frame));
686498aff2SJonas Devlieghere    PythonObject bp_loc_arg(PyRefType::Owned, SBTypeToSWIGWrapper(sb_bp_loc));
696498aff2SJonas Devlieghere
706498aff2SJonas Devlieghere    auto result = [&] () -> Expected<PythonObject> {
716498aff2SJonas Devlieghere        // If the called function doesn't take extra_args, drop them here:
726498aff2SJonas Devlieghere        if (max_positional_args < 4) {
736498aff2SJonas Devlieghere            return pfunc.Call(frame_arg, bp_loc_arg, dict);
746498aff2SJonas Devlieghere        } else {
756498aff2SJonas Devlieghere            lldb::SBStructuredData *args_value = new lldb::SBStructuredData(args_impl);
766498aff2SJonas Devlieghere            PythonObject args_arg(PyRefType::Owned, SBTypeToSWIGWrapper(args_value));
776498aff2SJonas Devlieghere            return pfunc.Call(frame_arg, bp_loc_arg, args_arg, dict);
786498aff2SJonas Devlieghere        }
796498aff2SJonas Devlieghere    } ();
806498aff2SJonas Devlieghere
816498aff2SJonas Devlieghere    if (!result)
826498aff2SJonas Devlieghere        return result.takeError();
836498aff2SJonas Devlieghere
846498aff2SJonas Devlieghere    // Only False counts as false!
856498aff2SJonas Devlieghere    return result.get().get() != Py_False;
866498aff2SJonas Devlieghere}
876498aff2SJonas Devlieghere
886498aff2SJonas Devlieghere// This function is called by lldb_private::ScriptInterpreterPython::WatchpointCallbackFunction(...)
896498aff2SJonas Devlieghere// and is used when a script command is attached to a watchpoint for execution.
906498aff2SJonas Devlieghere
916498aff2SJonas DevlieghereSWIGEXPORT bool
926498aff2SJonas DevlieghereLLDBSwigPythonWatchpointCallbackFunction
936498aff2SJonas Devlieghere(
946498aff2SJonas Devlieghere    const char *python_function_name,
956498aff2SJonas Devlieghere    const char *session_dictionary_name,
966498aff2SJonas Devlieghere    const lldb::StackFrameSP& frame_sp,
976498aff2SJonas Devlieghere    const lldb::WatchpointSP& wp_sp
986498aff2SJonas Devlieghere)
996498aff2SJonas Devlieghere{
1006498aff2SJonas Devlieghere    lldb::SBFrame sb_frame (frame_sp);
1016498aff2SJonas Devlieghere    lldb::SBWatchpoint sb_wp(wp_sp);
1026498aff2SJonas Devlieghere
1036498aff2SJonas Devlieghere    bool stop_at_watchpoint = true;
1046498aff2SJonas Devlieghere
1056498aff2SJonas Devlieghere    PyErr_Cleaner py_err_cleaner(true);
1066498aff2SJonas Devlieghere
1076498aff2SJonas Devlieghere    auto dict = PythonModule::MainModule().ResolveName<PythonDictionary>(session_dictionary_name);
1086498aff2SJonas Devlieghere    auto pfunc = PythonObject::ResolveNameWithDictionary<PythonCallable>(python_function_name, dict);
1096498aff2SJonas Devlieghere
1106498aff2SJonas Devlieghere    if (!pfunc.IsAllocated())
1116498aff2SJonas Devlieghere        return stop_at_watchpoint;
1126498aff2SJonas Devlieghere
1136498aff2SJonas Devlieghere    PythonObject frame_arg(PyRefType::Owned, SBTypeToSWIGWrapper(sb_frame));
1146498aff2SJonas Devlieghere    PythonObject wp_arg(PyRefType::Owned, SBTypeToSWIGWrapper(sb_wp));
1156498aff2SJonas Devlieghere    PythonObject result = pfunc(frame_arg, wp_arg, dict);
1166498aff2SJonas Devlieghere
1176498aff2SJonas Devlieghere    if (result.get() == Py_False)
1186498aff2SJonas Devlieghere        stop_at_watchpoint = false;
1196498aff2SJonas Devlieghere
1206498aff2SJonas Devlieghere    return stop_at_watchpoint;
1216498aff2SJonas Devlieghere}
1226498aff2SJonas Devlieghere
1236498aff2SJonas DevlieghereSWIGEXPORT bool
1246498aff2SJonas DevlieghereLLDBSwigPythonCallTypeScript
1256498aff2SJonas Devlieghere(
1266498aff2SJonas Devlieghere    const char *python_function_name,
1276498aff2SJonas Devlieghere    const void *session_dictionary,
1286498aff2SJonas Devlieghere    const lldb::ValueObjectSP& valobj_sp,
1296498aff2SJonas Devlieghere    void** pyfunct_wrapper,
1306498aff2SJonas Devlieghere    const lldb::TypeSummaryOptionsSP& options_sp,
1316498aff2SJonas Devlieghere    std::string& retval
1326498aff2SJonas Devlieghere)
1336498aff2SJonas Devlieghere{
1346498aff2SJonas Devlieghere    lldb::SBValue sb_value (valobj_sp);
1356498aff2SJonas Devlieghere    lldb::SBTypeSummaryOptions sb_options(options_sp.get());
1366498aff2SJonas Devlieghere
1376498aff2SJonas Devlieghere    retval.clear();
1386498aff2SJonas Devlieghere
1396498aff2SJonas Devlieghere    if (!python_function_name || !session_dictionary)
1406498aff2SJonas Devlieghere        return false;
1416498aff2SJonas Devlieghere
1426498aff2SJonas Devlieghere    PyObject *pfunc_impl = nullptr;
1436498aff2SJonas Devlieghere
1446498aff2SJonas Devlieghere    if (pyfunct_wrapper && *pyfunct_wrapper && PyFunction_Check (*pyfunct_wrapper))
1456498aff2SJonas Devlieghere    {
1466498aff2SJonas Devlieghere        pfunc_impl = (PyObject*)(*pyfunct_wrapper);
1476498aff2SJonas Devlieghere        if (pfunc_impl->ob_refcnt == 1)
1486498aff2SJonas Devlieghere        {
1496498aff2SJonas Devlieghere            Py_XDECREF(pfunc_impl);
1506498aff2SJonas Devlieghere            pfunc_impl = NULL;
1516498aff2SJonas Devlieghere        }
1526498aff2SJonas Devlieghere    }
1536498aff2SJonas Devlieghere
1546498aff2SJonas Devlieghere    PyObject *py_dict = (PyObject*)session_dictionary;
1556498aff2SJonas Devlieghere    if (!PythonDictionary::Check(py_dict))
1566498aff2SJonas Devlieghere        return true;
1576498aff2SJonas Devlieghere
1586498aff2SJonas Devlieghere    PythonDictionary dict(PyRefType::Borrowed, py_dict);
1596498aff2SJonas Devlieghere
1606498aff2SJonas Devlieghere    PyErr_Cleaner pyerr_cleanup(true);  // show Python errors
1616498aff2SJonas Devlieghere
1626498aff2SJonas Devlieghere    PythonCallable pfunc(PyRefType::Borrowed, pfunc_impl);
1636498aff2SJonas Devlieghere
1646498aff2SJonas Devlieghere    if (!pfunc.IsAllocated())
1656498aff2SJonas Devlieghere    {
1666498aff2SJonas Devlieghere        pfunc = PythonObject::ResolveNameWithDictionary<PythonCallable>(python_function_name, dict);
1676498aff2SJonas Devlieghere        if (!pfunc.IsAllocated())
1686498aff2SJonas Devlieghere            return false;
1696498aff2SJonas Devlieghere
1706498aff2SJonas Devlieghere        if (pyfunct_wrapper)
1716498aff2SJonas Devlieghere        {
1726498aff2SJonas Devlieghere            *pyfunct_wrapper = pfunc.get();
1736498aff2SJonas Devlieghere            Py_XINCREF(pfunc.get());
1746498aff2SJonas Devlieghere        }
1756498aff2SJonas Devlieghere    }
1766498aff2SJonas Devlieghere
1776498aff2SJonas Devlieghere    PythonObject result;
1786498aff2SJonas Devlieghere    auto argc = pfunc.GetArgInfo();
1796498aff2SJonas Devlieghere    if (!argc) {
1806498aff2SJonas Devlieghere        llvm::consumeError(argc.takeError());
1816498aff2SJonas Devlieghere        return false;
1826498aff2SJonas Devlieghere    }
1836498aff2SJonas Devlieghere
1846498aff2SJonas Devlieghere    PythonObject value_arg(PyRefType::Owned, SBTypeToSWIGWrapper(sb_value));
1856498aff2SJonas Devlieghere    PythonObject options_arg(PyRefType::Owned, SBTypeToSWIGWrapper(sb_options));
1866498aff2SJonas Devlieghere
1876498aff2SJonas Devlieghere    if (argc.get().max_positional_args < 3)
1886498aff2SJonas Devlieghere        result = pfunc(value_arg,dict);
1896498aff2SJonas Devlieghere    else
1906498aff2SJonas Devlieghere        result = pfunc(value_arg,dict,options_arg);
1916498aff2SJonas Devlieghere
1926498aff2SJonas Devlieghere    retval = result.Str().GetString().str();
1936498aff2SJonas Devlieghere
1946498aff2SJonas Devlieghere    return true;
1956498aff2SJonas Devlieghere}
1966498aff2SJonas Devlieghere
1976498aff2SJonas DevlieghereSWIGEXPORT void*
1986498aff2SJonas DevlieghereLLDBSwigPythonCreateSyntheticProvider
1996498aff2SJonas Devlieghere(
2006498aff2SJonas Devlieghere    const char *python_class_name,
2016498aff2SJonas Devlieghere    const char *session_dictionary_name,
2026498aff2SJonas Devlieghere    const lldb::ValueObjectSP& valobj_sp
2036498aff2SJonas Devlieghere)
2046498aff2SJonas Devlieghere{
2056498aff2SJonas Devlieghere    if (python_class_name == NULL || python_class_name[0] == '\0' || !session_dictionary_name)
2066498aff2SJonas Devlieghere        Py_RETURN_NONE;
2076498aff2SJonas Devlieghere
2086498aff2SJonas Devlieghere    PyErr_Cleaner py_err_cleaner(true);
2096498aff2SJonas Devlieghere
2106498aff2SJonas Devlieghere    auto dict = PythonModule::MainModule().ResolveName<PythonDictionary>(session_dictionary_name);
2116498aff2SJonas Devlieghere    auto pfunc = PythonObject::ResolveNameWithDictionary<PythonCallable>(python_class_name,dict);
2126498aff2SJonas Devlieghere
2136498aff2SJonas Devlieghere    if (!pfunc.IsAllocated())
2146498aff2SJonas Devlieghere        Py_RETURN_NONE;
2156498aff2SJonas Devlieghere
2166498aff2SJonas Devlieghere    // I do not want the SBValue to be deallocated when going out of scope because python
2176498aff2SJonas Devlieghere    // has ownership of it and will manage memory for this object by itself
2186498aff2SJonas Devlieghere    lldb::SBValue *sb_value = new lldb::SBValue(valobj_sp);
2196498aff2SJonas Devlieghere    sb_value->SetPreferSyntheticValue(false);
2206498aff2SJonas Devlieghere
2216498aff2SJonas Devlieghere    PythonObject val_arg(PyRefType::Owned, SBTypeToSWIGWrapper(sb_value));
2226498aff2SJonas Devlieghere    if (!val_arg.IsAllocated())
2236498aff2SJonas Devlieghere        Py_RETURN_NONE;
2246498aff2SJonas Devlieghere
2256498aff2SJonas Devlieghere    PythonObject result = pfunc(val_arg, dict);
2266498aff2SJonas Devlieghere
2276498aff2SJonas Devlieghere    if (result.IsAllocated())
2286498aff2SJonas Devlieghere        return result.release();
2296498aff2SJonas Devlieghere
2306498aff2SJonas Devlieghere    Py_RETURN_NONE;
2316498aff2SJonas Devlieghere}
2326498aff2SJonas Devlieghere
2336498aff2SJonas DevlieghereSWIGEXPORT void*
2346498aff2SJonas DevlieghereLLDBSwigPythonCreateCommandObject
2356498aff2SJonas Devlieghere(
2366498aff2SJonas Devlieghere    const char *python_class_name,
2376498aff2SJonas Devlieghere    const char *session_dictionary_name,
2386498aff2SJonas Devlieghere    const lldb::DebuggerSP debugger_sp
2396498aff2SJonas Devlieghere)
2406498aff2SJonas Devlieghere{
2416498aff2SJonas Devlieghere    if (python_class_name == NULL || python_class_name[0] == '\0' || !session_dictionary_name)
2426498aff2SJonas Devlieghere        Py_RETURN_NONE;
2436498aff2SJonas Devlieghere
2446498aff2SJonas Devlieghere    PyErr_Cleaner py_err_cleaner(true);
2456498aff2SJonas Devlieghere    auto dict = PythonModule::MainModule().ResolveName<PythonDictionary>(session_dictionary_name);
2466498aff2SJonas Devlieghere    auto pfunc = PythonObject::ResolveNameWithDictionary<PythonCallable>(python_class_name, dict);
2476498aff2SJonas Devlieghere
2486498aff2SJonas Devlieghere    if (!pfunc.IsAllocated())
2496498aff2SJonas Devlieghere        return nullptr;
2506498aff2SJonas Devlieghere
2516498aff2SJonas Devlieghere    lldb::SBDebugger debugger_sb(debugger_sp);
2526498aff2SJonas Devlieghere    PythonObject debugger_arg(PyRefType::Owned, SBTypeToSWIGWrapper(debugger_sb));
2536498aff2SJonas Devlieghere    PythonObject result = pfunc(debugger_arg, dict);
2546498aff2SJonas Devlieghere
2556498aff2SJonas Devlieghere    if (result.IsAllocated())
2566498aff2SJonas Devlieghere        return result.release();
2576498aff2SJonas Devlieghere
2586498aff2SJonas Devlieghere    Py_RETURN_NONE;
2596498aff2SJonas Devlieghere}
2606498aff2SJonas Devlieghere
2616498aff2SJonas DevlieghereSWIGEXPORT void*
2626498aff2SJonas DevlieghereLLDBSwigPythonCreateScriptedThreadPlan
2636498aff2SJonas Devlieghere(
2646498aff2SJonas Devlieghere    const char *python_class_name,
2656498aff2SJonas Devlieghere    const char *session_dictionary_name,
2666498aff2SJonas Devlieghere    lldb_private::StructuredDataImpl *args_impl,
2676498aff2SJonas Devlieghere    std::string &error_string,
2686498aff2SJonas Devlieghere    const lldb::ThreadPlanSP& thread_plan_sp
2696498aff2SJonas Devlieghere)
2706498aff2SJonas Devlieghere{
2716498aff2SJonas Devlieghere    if (python_class_name == NULL || python_class_name[0] == '\0' || !session_dictionary_name)
2726498aff2SJonas Devlieghere        Py_RETURN_NONE;
2736498aff2SJonas Devlieghere
2746498aff2SJonas Devlieghere
2756498aff2SJonas Devlieghere    PyErr_Cleaner py_err_cleaner(true);
2766498aff2SJonas Devlieghere
2776498aff2SJonas Devlieghere    auto dict = PythonModule::MainModule().ResolveName<PythonDictionary>(session_dictionary_name);
2786498aff2SJonas Devlieghere    auto pfunc = PythonObject::ResolveNameWithDictionary<PythonCallable>(python_class_name, dict);
2796498aff2SJonas Devlieghere
2806498aff2SJonas Devlieghere    if (!pfunc.IsAllocated()) {
2816498aff2SJonas Devlieghere        error_string.append("could not find script class: ");
2826498aff2SJonas Devlieghere        error_string.append(python_class_name);
2836498aff2SJonas Devlieghere        return nullptr;
2846498aff2SJonas Devlieghere    }
2856498aff2SJonas Devlieghere
286b79dff02SJonas Devlieghere    // I do not want the SBThreadPlan to be deallocated when going out of scope
287b79dff02SJonas Devlieghere    // because python has ownership of it and will manage memory for this
288b79dff02SJonas Devlieghere    // object by itself
289b79dff02SJonas Devlieghere    PythonObject tp_arg(PyRefType::Owned, SBTypeToSWIGWrapper(new lldb::SBThreadPlan(thread_plan_sp)));
2906498aff2SJonas Devlieghere
2916498aff2SJonas Devlieghere    if (!tp_arg.IsAllocated())
2926498aff2SJonas Devlieghere        Py_RETURN_NONE;
2936498aff2SJonas Devlieghere
2946498aff2SJonas Devlieghere    llvm::Expected<PythonCallable::ArgInfo> arg_info = pfunc.GetArgInfo();
2956498aff2SJonas Devlieghere    if (!arg_info) {
2966498aff2SJonas Devlieghere        llvm::handleAllErrors(
2976498aff2SJonas Devlieghere            arg_info.takeError(),
2986498aff2SJonas Devlieghere            [&](PythonException &E) {
2996498aff2SJonas Devlieghere                error_string.append(E.ReadBacktrace());
3006498aff2SJonas Devlieghere            },
3016498aff2SJonas Devlieghere            [&](const llvm::ErrorInfoBase &E) {
3026498aff2SJonas Devlieghere                error_string.append(E.message());
3036498aff2SJonas Devlieghere            });
3046498aff2SJonas Devlieghere        Py_RETURN_NONE;
3056498aff2SJonas Devlieghere    }
3066498aff2SJonas Devlieghere
3076498aff2SJonas Devlieghere    PythonObject result = {};
3086498aff2SJonas Devlieghere    if (arg_info.get().max_positional_args == 2) {
3096498aff2SJonas Devlieghere        if (args_impl != nullptr) {
3106498aff2SJonas Devlieghere           error_string.assign("args passed, but __init__ does not take an args dictionary");
3116498aff2SJonas Devlieghere           Py_RETURN_NONE;
3126498aff2SJonas Devlieghere        }
3136498aff2SJonas Devlieghere        result = pfunc(tp_arg, dict);
3146498aff2SJonas Devlieghere    } else if (arg_info.get().max_positional_args >= 3) {
315b79dff02SJonas Devlieghere        PythonObject args_arg(PyRefType::Owned, SBTypeToSWIGWrapper(new lldb::SBStructuredData(args_impl)));
3166498aff2SJonas Devlieghere        result = pfunc(tp_arg, args_arg, dict);
3176498aff2SJonas Devlieghere    } else {
3186498aff2SJonas Devlieghere        error_string.assign("wrong number of arguments in __init__, should be 2 or 3 (not including self)");
3196498aff2SJonas Devlieghere        Py_RETURN_NONE;
3206498aff2SJonas Devlieghere    }
3216498aff2SJonas Devlieghere
3226498aff2SJonas Devlieghere    // FIXME: At this point we should check that the class we found supports all the methods
3236498aff2SJonas Devlieghere    // that we need.
3246498aff2SJonas Devlieghere
3256498aff2SJonas Devlieghere    if (result.IsAllocated())
3266498aff2SJonas Devlieghere        return result.release();
3276498aff2SJonas Devlieghere    Py_RETURN_NONE;
3286498aff2SJonas Devlieghere}
3296498aff2SJonas Devlieghere
3306498aff2SJonas DevlieghereSWIGEXPORT bool
3316498aff2SJonas DevlieghereLLDBSWIGPythonCallThreadPlan
3326498aff2SJonas Devlieghere(
3336498aff2SJonas Devlieghere    void *implementor,
3346498aff2SJonas Devlieghere    const char *method_name,
3356498aff2SJonas Devlieghere    lldb_private::Event *event,
3366498aff2SJonas Devlieghere    bool &got_error
3376498aff2SJonas Devlieghere)
3386498aff2SJonas Devlieghere{
3396498aff2SJonas Devlieghere    got_error = false;
3406498aff2SJonas Devlieghere
3416498aff2SJonas Devlieghere    PyErr_Cleaner py_err_cleaner(false);
3426498aff2SJonas Devlieghere    PythonObject self(PyRefType::Borrowed, static_cast<PyObject*>(implementor));
3436498aff2SJonas Devlieghere    auto pfunc = self.ResolveName<PythonCallable>(method_name);
3446498aff2SJonas Devlieghere
3456498aff2SJonas Devlieghere    if (!pfunc.IsAllocated())
3466498aff2SJonas Devlieghere        return false;
3476498aff2SJonas Devlieghere
3486498aff2SJonas Devlieghere    PythonObject result;
3496498aff2SJonas Devlieghere    if (event != nullptr)
3506498aff2SJonas Devlieghere    {
3516498aff2SJonas Devlieghere        lldb::SBEvent sb_event(event);
3526498aff2SJonas Devlieghere        PythonObject event_arg(PyRefType::Owned, SBTypeToSWIGWrapper(sb_event));
3536498aff2SJonas Devlieghere        result = pfunc(event_arg);
3546498aff2SJonas Devlieghere    }
3556498aff2SJonas Devlieghere    else
3566498aff2SJonas Devlieghere        result = pfunc();
3576498aff2SJonas Devlieghere
3586498aff2SJonas Devlieghere    if (PyErr_Occurred())
3596498aff2SJonas Devlieghere    {
3606498aff2SJonas Devlieghere        got_error = true;
3616498aff2SJonas Devlieghere        printf ("Return value was neither false nor true for call to %s.\n", method_name);
3626498aff2SJonas Devlieghere        PyErr_Print();
3636498aff2SJonas Devlieghere        return false;
3646498aff2SJonas Devlieghere    }
3656498aff2SJonas Devlieghere
3666498aff2SJonas Devlieghere    if (result.get() == Py_True)
3676498aff2SJonas Devlieghere        return true;
3686498aff2SJonas Devlieghere    else if (result.get() == Py_False)
3696498aff2SJonas Devlieghere        return false;
3706498aff2SJonas Devlieghere
3716498aff2SJonas Devlieghere    // Somebody returned the wrong thing...
3726498aff2SJonas Devlieghere    got_error = true;
3736498aff2SJonas Devlieghere    printf ("Wrong return value type for call to %s.\n", method_name);
3746498aff2SJonas Devlieghere    return false;
3756498aff2SJonas Devlieghere}
3766498aff2SJonas Devlieghere
3776498aff2SJonas DevlieghereSWIGEXPORT void *
3786498aff2SJonas DevlieghereLLDBSwigPythonCreateScriptedBreakpointResolver
3796498aff2SJonas Devlieghere(
3806498aff2SJonas Devlieghere    const char *python_class_name,
3816498aff2SJonas Devlieghere    const char *session_dictionary_name,
3826498aff2SJonas Devlieghere    lldb_private::StructuredDataImpl *args_impl,
3836498aff2SJonas Devlieghere    lldb::BreakpointSP &breakpoint_sp
3846498aff2SJonas Devlieghere)
3856498aff2SJonas Devlieghere{
3866498aff2SJonas Devlieghere    if (python_class_name == NULL || python_class_name[0] == '\0' || !session_dictionary_name)
3876498aff2SJonas Devlieghere        Py_RETURN_NONE;
3886498aff2SJonas Devlieghere
3896498aff2SJonas Devlieghere    PyErr_Cleaner py_err_cleaner(true);
3906498aff2SJonas Devlieghere
3916498aff2SJonas Devlieghere    auto dict = PythonModule::MainModule().ResolveName<PythonDictionary>(session_dictionary_name);
3926498aff2SJonas Devlieghere    auto pfunc = PythonObject::ResolveNameWithDictionary<PythonCallable>(python_class_name, dict);
3936498aff2SJonas Devlieghere
3946498aff2SJonas Devlieghere    if (!pfunc.IsAllocated())
3956498aff2SJonas Devlieghere        return nullptr;
3966498aff2SJonas Devlieghere
3976498aff2SJonas Devlieghere    lldb::SBBreakpoint *bkpt_value = new lldb::SBBreakpoint(breakpoint_sp);
3986498aff2SJonas Devlieghere
3996498aff2SJonas Devlieghere    PythonObject bkpt_arg(PyRefType::Owned, SBTypeToSWIGWrapper(bkpt_value));
4006498aff2SJonas Devlieghere
4016498aff2SJonas Devlieghere    lldb::SBStructuredData *args_value = new lldb::SBStructuredData(args_impl);
4026498aff2SJonas Devlieghere    PythonObject args_arg(PyRefType::Owned, SBTypeToSWIGWrapper(args_value));
4036498aff2SJonas Devlieghere
4046498aff2SJonas Devlieghere    PythonObject result = pfunc(bkpt_arg, args_arg, dict);
4056498aff2SJonas Devlieghere    // FIXME: At this point we should check that the class we found supports all the methods
4066498aff2SJonas Devlieghere    // that we need.
4076498aff2SJonas Devlieghere
4086498aff2SJonas Devlieghere    if (result.IsAllocated())
4096498aff2SJonas Devlieghere    {
4106498aff2SJonas Devlieghere        // Check that __callback__ is defined:
4116498aff2SJonas Devlieghere        auto callback_func = result.ResolveName<PythonCallable>("__callback__");
4126498aff2SJonas Devlieghere        if (callback_func.IsAllocated())
4136498aff2SJonas Devlieghere            return result.release();
4146498aff2SJonas Devlieghere        else
4156498aff2SJonas Devlieghere            result.release();
4166498aff2SJonas Devlieghere    }
4176498aff2SJonas Devlieghere    Py_RETURN_NONE;
4186498aff2SJonas Devlieghere}
4196498aff2SJonas Devlieghere
4206498aff2SJonas DevlieghereSWIGEXPORT unsigned int
4216498aff2SJonas DevlieghereLLDBSwigPythonCallBreakpointResolver
4226498aff2SJonas Devlieghere(
4236498aff2SJonas Devlieghere    void *implementor,
4246498aff2SJonas Devlieghere    const char *method_name,
4256498aff2SJonas Devlieghere    lldb_private::SymbolContext *sym_ctx
4266498aff2SJonas Devlieghere)
4276498aff2SJonas Devlieghere{
4286498aff2SJonas Devlieghere    PyErr_Cleaner py_err_cleaner(false);
4296498aff2SJonas Devlieghere    PythonObject self(PyRefType::Borrowed, static_cast<PyObject*>(implementor));
4306498aff2SJonas Devlieghere    auto pfunc = self.ResolveName<PythonCallable>(method_name);
4316498aff2SJonas Devlieghere
4326498aff2SJonas Devlieghere    if (!pfunc.IsAllocated())
4336498aff2SJonas Devlieghere        return 0;
4346498aff2SJonas Devlieghere
4356498aff2SJonas Devlieghere    PythonObject result;
4366498aff2SJonas Devlieghere    if (sym_ctx != nullptr) {
4376498aff2SJonas Devlieghere      lldb::SBSymbolContext sb_sym_ctx(sym_ctx);
4386498aff2SJonas Devlieghere      PythonObject sym_ctx_arg(PyRefType::Owned, SBTypeToSWIGWrapper(sb_sym_ctx));
4396498aff2SJonas Devlieghere      result = pfunc(sym_ctx_arg);
4406498aff2SJonas Devlieghere    } else
4416498aff2SJonas Devlieghere      result = pfunc();
4426498aff2SJonas Devlieghere
4436498aff2SJonas Devlieghere    if (PyErr_Occurred())
4446498aff2SJonas Devlieghere    {
4456498aff2SJonas Devlieghere        PyErr_Print();
44652712d3fSLawrence D'Anna        PyErr_Clear();
4476498aff2SJonas Devlieghere        return 0;
4486498aff2SJonas Devlieghere    }
4496498aff2SJonas Devlieghere
4506498aff2SJonas Devlieghere    // The callback will return a bool, but we're need to also return ints
4516498aff2SJonas Devlieghere    // so we're squirrelling the bool through as an int...  And if you return
4526498aff2SJonas Devlieghere    // nothing, we'll continue.
4536498aff2SJonas Devlieghere    if (strcmp(method_name, "__callback__") == 0) {
4546498aff2SJonas Devlieghere        if (result.get() == Py_False)
4556498aff2SJonas Devlieghere          return 0;
4566498aff2SJonas Devlieghere        else
4576498aff2SJonas Devlieghere          return 1;
4586498aff2SJonas Devlieghere    }
4596498aff2SJonas Devlieghere
46052712d3fSLawrence D'Anna    long long ret_val = unwrapOrSetPythonException(As<long long>(result));
461478619cfSMuhammad Omair Javaid
46252712d3fSLawrence D'Anna    if (PyErr_Occurred()) {
46352712d3fSLawrence D'Anna        PyErr_Print();
46452712d3fSLawrence D'Anna        PyErr_Clear();
46552712d3fSLawrence D'Anna        return 0;
46652712d3fSLawrence D'Anna    }
4676498aff2SJonas Devlieghere
4686498aff2SJonas Devlieghere    return ret_val;
4696498aff2SJonas Devlieghere}
4706498aff2SJonas Devlieghere
4711b1d9815SJim InghamSWIGEXPORT void *
4721b1d9815SJim InghamLLDBSwigPythonCreateScriptedStopHook
4731b1d9815SJim Ingham(
4741b1d9815SJim Ingham    lldb::TargetSP target_sp,
4751b1d9815SJim Ingham    const char *python_class_name,
4761b1d9815SJim Ingham    const char *session_dictionary_name,
4771b1d9815SJim Ingham    lldb_private::StructuredDataImpl *args_impl,
4781b1d9815SJim Ingham    Status &error
4791b1d9815SJim Ingham)
4801b1d9815SJim Ingham{
4811b1d9815SJim Ingham    if (python_class_name == NULL || python_class_name[0] == '\0') {
4821b1d9815SJim Ingham        error.SetErrorString("Empty class name.");
4831b1d9815SJim Ingham        Py_RETURN_NONE;
4841b1d9815SJim Ingham    }
4851b1d9815SJim Ingham    if (!session_dictionary_name) {
4861b1d9815SJim Ingham      error.SetErrorString("No session dictionary");
4871b1d9815SJim Ingham      Py_RETURN_NONE;
4881b1d9815SJim Ingham    }
4891b1d9815SJim Ingham
4901b1d9815SJim Ingham    PyErr_Cleaner py_err_cleaner(true);
4911b1d9815SJim Ingham
4921b1d9815SJim Ingham    auto dict =
4931b1d9815SJim Ingham        PythonModule::MainModule().ResolveName<PythonDictionary>(
4941b1d9815SJim Ingham            session_dictionary_name);
4951b1d9815SJim Ingham    auto pfunc =
4961b1d9815SJim Ingham        PythonObject::ResolveNameWithDictionary<PythonCallable>(
4971b1d9815SJim Ingham            python_class_name, dict);
4981b1d9815SJim Ingham
4991b1d9815SJim Ingham    if (!pfunc.IsAllocated()) {
5001b1d9815SJim Ingham        error.SetErrorStringWithFormat("Could not find class: %s.",
5011b1d9815SJim Ingham                                       python_class_name);
5021b1d9815SJim Ingham        return nullptr;
5031b1d9815SJim Ingham    }
5041b1d9815SJim Ingham
5051b1d9815SJim Ingham    lldb::SBTarget *target_val
5061b1d9815SJim Ingham        = new lldb::SBTarget(target_sp);
5071b1d9815SJim Ingham
5081b1d9815SJim Ingham    PythonObject target_arg(PyRefType::Owned, SBTypeToSWIGWrapper(target_val));
5091b1d9815SJim Ingham
5101b1d9815SJim Ingham    lldb::SBStructuredData *args_value = new lldb::SBStructuredData(args_impl);
5111b1d9815SJim Ingham    PythonObject args_arg(PyRefType::Owned, SBTypeToSWIGWrapper(args_value));
5121b1d9815SJim Ingham
5131b1d9815SJim Ingham    PythonObject result = pfunc(target_arg, args_arg, dict);
5141b1d9815SJim Ingham
5151b1d9815SJim Ingham    if (result.IsAllocated())
5161b1d9815SJim Ingham    {
5171b1d9815SJim Ingham        // Check that the handle_stop callback is defined:
5181b1d9815SJim Ingham        auto callback_func = result.ResolveName<PythonCallable>("handle_stop");
5191b1d9815SJim Ingham        if (callback_func.IsAllocated()) {
5201b1d9815SJim Ingham          if (auto args_info = callback_func.GetArgInfo()) {
5211b1d9815SJim Ingham            size_t num_args = (*args_info).max_positional_args;
5221b1d9815SJim Ingham            if (num_args != 2) {
5231b1d9815SJim Ingham              error.SetErrorStringWithFormat("Wrong number of args for "
524*2f95c50aSRichard Smith              "handle_stop callback, should be 2 (excluding self), got: %zu",
5251b1d9815SJim Ingham              num_args);
5261b1d9815SJim Ingham              Py_RETURN_NONE;
5271b1d9815SJim Ingham            } else
5281b1d9815SJim Ingham              return result.release();
5291b1d9815SJim Ingham          } else {
5301b1d9815SJim Ingham            error.SetErrorString("Couldn't get num arguments for handle_stop "
5311b1d9815SJim Ingham                                 "callback.");
5321b1d9815SJim Ingham            Py_RETURN_NONE;
5331b1d9815SJim Ingham          }
5341b1d9815SJim Ingham          return result.release();
5351b1d9815SJim Ingham        }
5361b1d9815SJim Ingham        else {
5371b1d9815SJim Ingham          error.SetErrorStringWithFormat("Class \"%s\" is missing the required "
5381b1d9815SJim Ingham                                         "handle_stop callback.",
5391b1d9815SJim Ingham                                         python_class_name);
5401b1d9815SJim Ingham          result.release();
5411b1d9815SJim Ingham        }
5421b1d9815SJim Ingham    }
5431b1d9815SJim Ingham    Py_RETURN_NONE;
5441b1d9815SJim Ingham}
5451b1d9815SJim Ingham
5461b1d9815SJim InghamSWIGEXPORT bool
5471b1d9815SJim InghamLLDBSwigPythonStopHookCallHandleStop
5481b1d9815SJim Ingham(
5491b1d9815SJim Ingham    void *implementor,
5501b1d9815SJim Ingham    lldb::ExecutionContextRefSP exc_ctx_sp,
5511b1d9815SJim Ingham    lldb::StreamSP stream
5521b1d9815SJim Ingham)
5531b1d9815SJim Ingham{
5541b1d9815SJim Ingham    // handle_stop will return a bool with the meaning "should_stop"...
5551b1d9815SJim Ingham    // If you return nothing we'll assume we are going to stop.
5561b1d9815SJim Ingham    // Also any errors should return true, since we should stop on error.
5571b1d9815SJim Ingham
5581b1d9815SJim Ingham    PyErr_Cleaner py_err_cleaner(false);
5591b1d9815SJim Ingham    PythonObject self(PyRefType::Borrowed, static_cast<PyObject*>(implementor));
5601b1d9815SJim Ingham    auto pfunc = self.ResolveName<PythonCallable>("handle_stop");
5611b1d9815SJim Ingham
5621b1d9815SJim Ingham    if (!pfunc.IsAllocated())
5631b1d9815SJim Ingham        return true;
5641b1d9815SJim Ingham
5651b1d9815SJim Ingham    PythonObject result;
5661b1d9815SJim Ingham    lldb::SBExecutionContext sb_exc_ctx(exc_ctx_sp);
5671b1d9815SJim Ingham    PythonObject exc_ctx_arg(PyRefType::Owned, SBTypeToSWIGWrapper(sb_exc_ctx));
5681b1d9815SJim Ingham    lldb::SBStream sb_stream;
5691b1d9815SJim Ingham    PythonObject sb_stream_arg(PyRefType::Owned,
5701b1d9815SJim Ingham                               SBTypeToSWIGWrapper(sb_stream));
5711b1d9815SJim Ingham    result = pfunc(exc_ctx_arg, sb_stream_arg);
5721b1d9815SJim Ingham
5731b1d9815SJim Ingham    if (PyErr_Occurred())
5741b1d9815SJim Ingham    {
5751b1d9815SJim Ingham        stream->PutCString("Python error occurred handling stop-hook.");
5761b1d9815SJim Ingham        PyErr_Print();
5771b1d9815SJim Ingham        PyErr_Clear();
5781b1d9815SJim Ingham        return true;
5791b1d9815SJim Ingham    }
5801b1d9815SJim Ingham
5811b1d9815SJim Ingham    // Now add the result to the output stream.  SBStream only
5821b1d9815SJim Ingham    // makes an internally help StreamString which I can't interpose, so I
5831b1d9815SJim Ingham    // have to copy it over here.
5841b1d9815SJim Ingham    stream->PutCString(sb_stream.GetData());
5851b1d9815SJim Ingham
5861b1d9815SJim Ingham    if (result.get() == Py_False)
5871b1d9815SJim Ingham      return false;
5881b1d9815SJim Ingham    else
5891b1d9815SJim Ingham      return true;
5901b1d9815SJim Ingham}
5911b1d9815SJim Ingham
5926498aff2SJonas Devlieghere// wrapper that calls an optional instance member of an object taking no arguments
5936498aff2SJonas Devliegherestatic PyObject*
5946498aff2SJonas DevlieghereLLDBSwigPython_CallOptionalMember
5956498aff2SJonas Devlieghere(
5966498aff2SJonas Devlieghere    PyObject* implementor,
5976498aff2SJonas Devlieghere    char* callee_name,
5986498aff2SJonas Devlieghere    PyObject* ret_if_not_found = Py_None,
5996498aff2SJonas Devlieghere    bool* was_found = NULL
6006498aff2SJonas Devlieghere)
6016498aff2SJonas Devlieghere{
6026498aff2SJonas Devlieghere    PyErr_Cleaner py_err_cleaner(false);
6036498aff2SJonas Devlieghere
6046498aff2SJonas Devlieghere    PythonObject self(PyRefType::Borrowed, static_cast<PyObject*>(implementor));
6056498aff2SJonas Devlieghere    auto pfunc = self.ResolveName<PythonCallable>(callee_name);
6066498aff2SJonas Devlieghere
6076498aff2SJonas Devlieghere    if (!pfunc.IsAllocated())
6086498aff2SJonas Devlieghere    {
6096498aff2SJonas Devlieghere        if (was_found)
6106498aff2SJonas Devlieghere            *was_found = false;
6116498aff2SJonas Devlieghere        Py_XINCREF(ret_if_not_found);
6126498aff2SJonas Devlieghere        return ret_if_not_found;
6136498aff2SJonas Devlieghere    }
6146498aff2SJonas Devlieghere
6156498aff2SJonas Devlieghere    if (was_found)
6166498aff2SJonas Devlieghere        *was_found = true;
6176498aff2SJonas Devlieghere
6186498aff2SJonas Devlieghere    PythonObject result = pfunc();
6196498aff2SJonas Devlieghere    return result.release();
6206498aff2SJonas Devlieghere}
6216498aff2SJonas Devlieghere
6226498aff2SJonas DevlieghereSWIGEXPORT size_t
6236498aff2SJonas DevlieghereLLDBSwigPython_CalculateNumChildren
6246498aff2SJonas Devlieghere(
6256498aff2SJonas Devlieghere    PyObject *implementor,
6266498aff2SJonas Devlieghere    uint32_t max
6276498aff2SJonas Devlieghere)
6286498aff2SJonas Devlieghere{
6296498aff2SJonas Devlieghere    PythonObject self(PyRefType::Borrowed, implementor);
6306498aff2SJonas Devlieghere    auto pfunc = self.ResolveName<PythonCallable>("num_children");
6316498aff2SJonas Devlieghere
6326498aff2SJonas Devlieghere    if (!pfunc.IsAllocated())
6336498aff2SJonas Devlieghere        return 0;
6346498aff2SJonas Devlieghere
6356498aff2SJonas Devlieghere    auto arg_info = pfunc.GetArgInfo();
6366498aff2SJonas Devlieghere    if (!arg_info) {
6376498aff2SJonas Devlieghere        llvm::consumeError(arg_info.takeError());
6386498aff2SJonas Devlieghere        return 0;
6396498aff2SJonas Devlieghere    }
6406498aff2SJonas Devlieghere
64152712d3fSLawrence D'Anna    size_t ret_val;
642478619cfSMuhammad Omair Javaid    if (arg_info.get().max_positional_args < 1)
64352712d3fSLawrence D'Anna        ret_val = unwrapOrSetPythonException(As<long long>(pfunc.Call()));
644478619cfSMuhammad Omair Javaid    else
64552712d3fSLawrence D'Anna        ret_val = unwrapOrSetPythonException(As<long long>(pfunc.Call(PythonInteger(max))));
646478619cfSMuhammad Omair Javaid
64752712d3fSLawrence D'Anna    if (PyErr_Occurred())
6486498aff2SJonas Devlieghere    {
6496498aff2SJonas Devlieghere        PyErr_Print();
6506498aff2SJonas Devlieghere        PyErr_Clear();
65152712d3fSLawrence D'Anna        return 0;
6526498aff2SJonas Devlieghere    }
6536498aff2SJonas Devlieghere
6546498aff2SJonas Devlieghere    if (arg_info.get().max_positional_args < 1)
6556498aff2SJonas Devlieghere        ret_val = std::min(ret_val, static_cast<size_t>(max));
6566498aff2SJonas Devlieghere
6576498aff2SJonas Devlieghere    return ret_val;
6586498aff2SJonas Devlieghere}
6596498aff2SJonas Devlieghere
6606498aff2SJonas DevlieghereSWIGEXPORT PyObject*
6616498aff2SJonas DevlieghereLLDBSwigPython_GetChildAtIndex
6626498aff2SJonas Devlieghere(
6636498aff2SJonas Devlieghere    PyObject *implementor,
6646498aff2SJonas Devlieghere    uint32_t idx
6656498aff2SJonas Devlieghere)
6666498aff2SJonas Devlieghere{
6676498aff2SJonas Devlieghere    PyErr_Cleaner py_err_cleaner(true);
6686498aff2SJonas Devlieghere
6696498aff2SJonas Devlieghere    PythonObject self(PyRefType::Borrowed, implementor);
6706498aff2SJonas Devlieghere    auto pfunc = self.ResolveName<PythonCallable>("get_child_at_index");
6716498aff2SJonas Devlieghere
6726498aff2SJonas Devlieghere    if (!pfunc.IsAllocated())
6736498aff2SJonas Devlieghere        return nullptr;
6746498aff2SJonas Devlieghere
6756498aff2SJonas Devlieghere    PythonObject result = pfunc(PythonInteger(idx));
6766498aff2SJonas Devlieghere
6776498aff2SJonas Devlieghere    if (!result.IsAllocated())
6786498aff2SJonas Devlieghere        return nullptr;
6796498aff2SJonas Devlieghere
6806498aff2SJonas Devlieghere    lldb::SBValue* sbvalue_ptr = nullptr;
6816498aff2SJonas Devlieghere    if (SWIG_ConvertPtr(result.get(), (void**)&sbvalue_ptr, SWIGTYPE_p_lldb__SBValue, 0) == -1)
6826498aff2SJonas Devlieghere        return nullptr;
6836498aff2SJonas Devlieghere
6846498aff2SJonas Devlieghere    if (sbvalue_ptr == nullptr)
6856498aff2SJonas Devlieghere        return nullptr;
6866498aff2SJonas Devlieghere
6876498aff2SJonas Devlieghere    return result.release();
6886498aff2SJonas Devlieghere}
6896498aff2SJonas Devlieghere
6906498aff2SJonas DevlieghereSWIGEXPORT int
6916498aff2SJonas DevlieghereLLDBSwigPython_GetIndexOfChildWithName
6926498aff2SJonas Devlieghere(
6936498aff2SJonas Devlieghere    PyObject *implementor,
6946498aff2SJonas Devlieghere    const char* child_name
6956498aff2SJonas Devlieghere)
6966498aff2SJonas Devlieghere{
6976498aff2SJonas Devlieghere    PyErr_Cleaner py_err_cleaner(true);
6986498aff2SJonas Devlieghere
6996498aff2SJonas Devlieghere    PythonObject self(PyRefType::Borrowed, implementor);
7006498aff2SJonas Devlieghere    auto pfunc = self.ResolveName<PythonCallable>("get_child_index");
7016498aff2SJonas Devlieghere
7026498aff2SJonas Devlieghere    if (!pfunc.IsAllocated())
7036498aff2SJonas Devlieghere        return UINT32_MAX;
7046498aff2SJonas Devlieghere
70552712d3fSLawrence D'Anna    llvm::Expected<PythonObject> result = pfunc.Call(PythonString(child_name));
7066498aff2SJonas Devlieghere
70752712d3fSLawrence D'Anna    long long retval = unwrapOrSetPythonException(As<long long>(std::move(result)));
70852712d3fSLawrence D'Anna
70952712d3fSLawrence D'Anna    if (PyErr_Occurred()) {
71052712d3fSLawrence D'Anna        PyErr_Clear(); // FIXME print this? do something else
7116498aff2SJonas Devlieghere        return UINT32_MAX;
71252712d3fSLawrence D'Anna    }
7136498aff2SJonas Devlieghere
7146498aff2SJonas Devlieghere    if (retval >= 0)
7156498aff2SJonas Devlieghere        return (uint32_t)retval;
7166498aff2SJonas Devlieghere
7176498aff2SJonas Devlieghere    return UINT32_MAX;
7186498aff2SJonas Devlieghere}
7196498aff2SJonas Devlieghere
7206498aff2SJonas DevlieghereSWIGEXPORT bool
7216498aff2SJonas DevlieghereLLDBSwigPython_UpdateSynthProviderInstance
7226498aff2SJonas Devlieghere(
7236498aff2SJonas Devlieghere    PyObject *implementor
7246498aff2SJonas Devlieghere)
7256498aff2SJonas Devlieghere{
7266498aff2SJonas Devlieghere    bool ret_val = false;
7276498aff2SJonas Devlieghere
7286498aff2SJonas Devlieghere    static char callee_name[] = "update";
7296498aff2SJonas Devlieghere
7306498aff2SJonas Devlieghere    PyObject* py_return = LLDBSwigPython_CallOptionalMember(implementor,callee_name);
7316498aff2SJonas Devlieghere
7326498aff2SJonas Devlieghere    if (py_return == Py_True)
7336498aff2SJonas Devlieghere        ret_val = true;
7346498aff2SJonas Devlieghere
7356498aff2SJonas Devlieghere    Py_XDECREF(py_return);
7366498aff2SJonas Devlieghere
7376498aff2SJonas Devlieghere    return ret_val;
7386498aff2SJonas Devlieghere}
7396498aff2SJonas Devlieghere
7406498aff2SJonas DevlieghereSWIGEXPORT bool
7416498aff2SJonas DevlieghereLLDBSwigPython_MightHaveChildrenSynthProviderInstance
7426498aff2SJonas Devlieghere(
7436498aff2SJonas Devlieghere    PyObject *implementor
7446498aff2SJonas Devlieghere)
7456498aff2SJonas Devlieghere{
7466498aff2SJonas Devlieghere    bool ret_val = false;
7476498aff2SJonas Devlieghere
7486498aff2SJonas Devlieghere    static char callee_name[] = "has_children";
7496498aff2SJonas Devlieghere
7506498aff2SJonas Devlieghere    PyObject* py_return = LLDBSwigPython_CallOptionalMember(implementor,callee_name, Py_True);
7516498aff2SJonas Devlieghere
7526498aff2SJonas Devlieghere    if (py_return == Py_True)
7536498aff2SJonas Devlieghere        ret_val = true;
7546498aff2SJonas Devlieghere
7556498aff2SJonas Devlieghere    Py_XDECREF(py_return);
7566498aff2SJonas Devlieghere
7576498aff2SJonas Devlieghere    return ret_val;
7586498aff2SJonas Devlieghere}
7596498aff2SJonas Devlieghere
7606498aff2SJonas DevlieghereSWIGEXPORT PyObject*
7616498aff2SJonas DevlieghereLLDBSwigPython_GetValueSynthProviderInstance
7626498aff2SJonas Devlieghere(
7636498aff2SJonas Devlieghere    PyObject *implementor
7646498aff2SJonas Devlieghere)
7656498aff2SJonas Devlieghere{
7666498aff2SJonas Devlieghere    PyObject* ret_val = nullptr;
7676498aff2SJonas Devlieghere
7686498aff2SJonas Devlieghere    static char callee_name[] = "get_value";
7696498aff2SJonas Devlieghere
7706498aff2SJonas Devlieghere    PyObject* py_return = LLDBSwigPython_CallOptionalMember(implementor,callee_name, Py_None);
7716498aff2SJonas Devlieghere
7726498aff2SJonas Devlieghere    if (py_return == Py_None || py_return == nullptr)
7736498aff2SJonas Devlieghere        ret_val = nullptr;
7746498aff2SJonas Devlieghere
7756498aff2SJonas Devlieghere    lldb::SBValue* sbvalue_ptr = NULL;
7766498aff2SJonas Devlieghere
7776498aff2SJonas Devlieghere    if (SWIG_ConvertPtr(py_return, (void**)&sbvalue_ptr, SWIGTYPE_p_lldb__SBValue, 0) == -1)
7786498aff2SJonas Devlieghere        ret_val = nullptr;
7796498aff2SJonas Devlieghere    else if (sbvalue_ptr == NULL)
7806498aff2SJonas Devlieghere        ret_val = nullptr;
7816498aff2SJonas Devlieghere    else
7826498aff2SJonas Devlieghere        ret_val = py_return;
7836498aff2SJonas Devlieghere
7846498aff2SJonas Devlieghere    Py_XDECREF(py_return);
7856498aff2SJonas Devlieghere    return ret_val;
7866498aff2SJonas Devlieghere}
7876498aff2SJonas Devlieghere
7886498aff2SJonas DevlieghereSWIGEXPORT void*
7896498aff2SJonas DevlieghereLLDBSWIGPython_CastPyObjectToSBValue
7906498aff2SJonas Devlieghere(
7916498aff2SJonas Devlieghere    PyObject* data
7926498aff2SJonas Devlieghere)
7936498aff2SJonas Devlieghere{
7946498aff2SJonas Devlieghere    lldb::SBValue* sb_ptr = NULL;
7956498aff2SJonas Devlieghere
7966498aff2SJonas Devlieghere    int valid_cast = SWIG_ConvertPtr(data, (void**)&sb_ptr, SWIGTYPE_p_lldb__SBValue, 0);
7976498aff2SJonas Devlieghere
7986498aff2SJonas Devlieghere    if (valid_cast == -1)
7996498aff2SJonas Devlieghere        return NULL;
8006498aff2SJonas Devlieghere
8016498aff2SJonas Devlieghere    return sb_ptr;
8026498aff2SJonas Devlieghere}
8036498aff2SJonas Devlieghere
8046498aff2SJonas DevlieghereSWIGEXPORT bool
8056498aff2SJonas DevlieghereLLDBSwigPythonCallCommand
8066498aff2SJonas Devlieghere(
8076498aff2SJonas Devlieghere    const char *python_function_name,
8086498aff2SJonas Devlieghere    const char *session_dictionary_name,
8096498aff2SJonas Devlieghere    lldb::DebuggerSP& debugger,
8106498aff2SJonas Devlieghere    const char* args,
8116498aff2SJonas Devlieghere    lldb_private::CommandReturnObject& cmd_retobj,
8126498aff2SJonas Devlieghere    lldb::ExecutionContextRefSP exe_ctx_ref_sp
8136498aff2SJonas Devlieghere)
8146498aff2SJonas Devlieghere{
8156498aff2SJonas Devlieghere    lldb::SBCommandReturnObject cmd_retobj_sb(cmd_retobj);
8166498aff2SJonas Devlieghere    lldb::SBDebugger debugger_sb(debugger);
8176498aff2SJonas Devlieghere    lldb::SBExecutionContext exe_ctx_sb(exe_ctx_ref_sp);
8186498aff2SJonas Devlieghere
8196498aff2SJonas Devlieghere    PyErr_Cleaner py_err_cleaner(true);
8206498aff2SJonas Devlieghere    auto dict = PythonModule::MainModule().ResolveName<PythonDictionary>(session_dictionary_name);
8216498aff2SJonas Devlieghere    auto pfunc = PythonObject::ResolveNameWithDictionary<PythonCallable>(python_function_name, dict);
8226498aff2SJonas Devlieghere
8236498aff2SJonas Devlieghere    if (!pfunc.IsAllocated())
8246498aff2SJonas Devlieghere        return false;
8256498aff2SJonas Devlieghere
8266498aff2SJonas Devlieghere    // pass the pointer-to cmd_retobj_sb or watch the underlying object disappear from under you
8276498aff2SJonas Devlieghere    // see comment above for SBCommandReturnObjectReleaser for further details
8286498aff2SJonas Devlieghere    auto argc = pfunc.GetArgInfo();
8296498aff2SJonas Devlieghere    if (!argc) {
8306498aff2SJonas Devlieghere        llvm::consumeError(argc.takeError());
8316498aff2SJonas Devlieghere        return false;
8326498aff2SJonas Devlieghere    }
8336498aff2SJonas Devlieghere    PythonObject debugger_arg(PyRefType::Owned, SBTypeToSWIGWrapper(debugger_sb));
8346498aff2SJonas Devlieghere    PythonObject exe_ctx_arg(PyRefType::Owned, SBTypeToSWIGWrapper(exe_ctx_sb));
8356498aff2SJonas Devlieghere    PythonObject cmd_retobj_arg(PyRefType::Owned, SBTypeToSWIGWrapper(&cmd_retobj_sb));
8366498aff2SJonas Devlieghere
8376498aff2SJonas Devlieghere    if (argc.get().max_positional_args < 5u)
8386498aff2SJonas Devlieghere        pfunc(debugger_arg, PythonString(args), cmd_retobj_arg, dict);
8396498aff2SJonas Devlieghere    else
8406498aff2SJonas Devlieghere        pfunc(debugger_arg, PythonString(args), exe_ctx_arg, cmd_retobj_arg, dict);
8416498aff2SJonas Devlieghere
8426498aff2SJonas Devlieghere    return true;
8436498aff2SJonas Devlieghere}
8446498aff2SJonas Devlieghere
8456498aff2SJonas DevlieghereSWIGEXPORT bool
8466498aff2SJonas DevlieghereLLDBSwigPythonCallCommandObject
8476498aff2SJonas Devlieghere(
8486498aff2SJonas Devlieghere    PyObject *implementor,
8496498aff2SJonas Devlieghere    lldb::DebuggerSP& debugger,
8506498aff2SJonas Devlieghere    const char* args,
8516498aff2SJonas Devlieghere    lldb_private::CommandReturnObject& cmd_retobj,
8526498aff2SJonas Devlieghere    lldb::ExecutionContextRefSP exe_ctx_ref_sp
8536498aff2SJonas Devlieghere)
8546498aff2SJonas Devlieghere{
8556498aff2SJonas Devlieghere    lldb::SBCommandReturnObject cmd_retobj_sb(cmd_retobj);
8566498aff2SJonas Devlieghere    lldb::SBDebugger debugger_sb(debugger);
8576498aff2SJonas Devlieghere    lldb::SBExecutionContext exe_ctx_sb(exe_ctx_ref_sp);
8586498aff2SJonas Devlieghere
8596498aff2SJonas Devlieghere    PyErr_Cleaner py_err_cleaner(true);
8606498aff2SJonas Devlieghere
8616498aff2SJonas Devlieghere    PythonObject self(PyRefType::Borrowed, implementor);
8626498aff2SJonas Devlieghere    auto pfunc = self.ResolveName<PythonCallable>("__call__");
8636498aff2SJonas Devlieghere
8646498aff2SJonas Devlieghere    if (!pfunc.IsAllocated())
8656498aff2SJonas Devlieghere        return false;
8666498aff2SJonas Devlieghere
8676498aff2SJonas Devlieghere    // pass the pointer-to cmd_retobj_sb or watch the underlying object disappear from under you
8686498aff2SJonas Devlieghere    // see comment above for SBCommandReturnObjectReleaser for further details
8696498aff2SJonas Devlieghere    PythonObject debugger_arg(PyRefType::Owned, SBTypeToSWIGWrapper(debugger_sb));
8706498aff2SJonas Devlieghere    PythonObject exe_ctx_arg(PyRefType::Owned, SBTypeToSWIGWrapper(exe_ctx_sb));
8716498aff2SJonas Devlieghere    PythonObject cmd_retobj_arg(PyRefType::Owned, SBTypeToSWIGWrapper(&cmd_retobj_sb));
8726498aff2SJonas Devlieghere
8736498aff2SJonas Devlieghere    pfunc(debugger_arg, PythonString(args), exe_ctx_arg, cmd_retobj_arg);
8746498aff2SJonas Devlieghere
8756498aff2SJonas Devlieghere    return true;
8766498aff2SJonas Devlieghere}
8776498aff2SJonas Devlieghere
8786498aff2SJonas DevlieghereSWIGEXPORT void*
8796498aff2SJonas DevlieghereLLDBSWIGPythonCreateOSPlugin
8806498aff2SJonas Devlieghere(
8816498aff2SJonas Devlieghere    const char *python_class_name,
8826498aff2SJonas Devlieghere    const char *session_dictionary_name,
8836498aff2SJonas Devlieghere    const lldb::ProcessSP& process_sp
8846498aff2SJonas Devlieghere)
8856498aff2SJonas Devlieghere{
8866498aff2SJonas Devlieghere    if (python_class_name == NULL || python_class_name[0] == '\0' || !session_dictionary_name)
8876498aff2SJonas Devlieghere        Py_RETURN_NONE;
8886498aff2SJonas Devlieghere
8896498aff2SJonas Devlieghere    PyErr_Cleaner py_err_cleaner(true);
8906498aff2SJonas Devlieghere
8916498aff2SJonas Devlieghere    auto dict = PythonModule::MainModule().ResolveName<PythonDictionary>(session_dictionary_name);
8926498aff2SJonas Devlieghere    auto pfunc = PythonObject::ResolveNameWithDictionary<PythonCallable>(python_class_name, dict);
8936498aff2SJonas Devlieghere
8946498aff2SJonas Devlieghere    if (!pfunc.IsAllocated())
8956498aff2SJonas Devlieghere        Py_RETURN_NONE;
8966498aff2SJonas Devlieghere
8976498aff2SJonas Devlieghere    // I do not want the SBProcess to be deallocated when going out of scope because python
8986498aff2SJonas Devlieghere    // has ownership of it and will manage memory for this object by itself
8996498aff2SJonas Devlieghere    lldb::SBProcess *process_sb = new lldb::SBProcess(process_sp);
9006498aff2SJonas Devlieghere    PythonObject process_arg(PyRefType::Owned, SBTypeToSWIGWrapper(process_sb));
9016498aff2SJonas Devlieghere    if (!process_arg.IsAllocated())
9026498aff2SJonas Devlieghere        Py_RETURN_NONE;
9036498aff2SJonas Devlieghere
9046498aff2SJonas Devlieghere    auto result = pfunc(process_arg);
9056498aff2SJonas Devlieghere
9066498aff2SJonas Devlieghere    if (result.IsAllocated())
9076498aff2SJonas Devlieghere        return result.release();
9086498aff2SJonas Devlieghere
9096498aff2SJonas Devlieghere    Py_RETURN_NONE;
9106498aff2SJonas Devlieghere}
9116498aff2SJonas Devlieghere
9126498aff2SJonas DevlieghereSWIGEXPORT void*
9136498aff2SJonas DevlieghereLLDBSWIGPython_CreateFrameRecognizer
9146498aff2SJonas Devlieghere(
9156498aff2SJonas Devlieghere    const char *python_class_name,
9166498aff2SJonas Devlieghere    const char *session_dictionary_name
9176498aff2SJonas Devlieghere)
9186498aff2SJonas Devlieghere{
9196498aff2SJonas Devlieghere    if (python_class_name == NULL || python_class_name[0] == '\0' || !session_dictionary_name)
9206498aff2SJonas Devlieghere        Py_RETURN_NONE;
9216498aff2SJonas Devlieghere
9226498aff2SJonas Devlieghere    PyErr_Cleaner py_err_cleaner(true);
9236498aff2SJonas Devlieghere
9246498aff2SJonas Devlieghere    auto dict = PythonModule::MainModule().ResolveName<PythonDictionary>(session_dictionary_name);
9256498aff2SJonas Devlieghere    auto pfunc = PythonObject::ResolveNameWithDictionary<PythonCallable>(python_class_name, dict);
9266498aff2SJonas Devlieghere
9276498aff2SJonas Devlieghere    if (!pfunc.IsAllocated())
9286498aff2SJonas Devlieghere        Py_RETURN_NONE;
9296498aff2SJonas Devlieghere
9306498aff2SJonas Devlieghere    auto result = pfunc();
9316498aff2SJonas Devlieghere
9326498aff2SJonas Devlieghere    if (result.IsAllocated())
9336498aff2SJonas Devlieghere        return result.release();
9346498aff2SJonas Devlieghere
9356498aff2SJonas Devlieghere    Py_RETURN_NONE;
9366498aff2SJonas Devlieghere}
9376498aff2SJonas Devlieghere
9386498aff2SJonas DevlieghereSWIGEXPORT PyObject*
9396498aff2SJonas DevlieghereLLDBSwigPython_GetRecognizedArguments
9406498aff2SJonas Devlieghere(
9416498aff2SJonas Devlieghere    PyObject *implementor,
9426498aff2SJonas Devlieghere    const lldb::StackFrameSP& frame_sp
9436498aff2SJonas Devlieghere)
9446498aff2SJonas Devlieghere{
9456498aff2SJonas Devlieghere    static char callee_name[] = "get_recognized_arguments";
9466498aff2SJonas Devlieghere
9476498aff2SJonas Devlieghere    lldb::SBFrame frame_sb(frame_sp);
9486498aff2SJonas Devlieghere    PyObject *arg = SBTypeToSWIGWrapper(frame_sb);
9496498aff2SJonas Devlieghere
9506498aff2SJonas Devlieghere    PythonString str(callee_name);
9516498aff2SJonas Devlieghere    PyObject* result = PyObject_CallMethodObjArgs(implementor, str.get(), arg,
9526498aff2SJonas Devlieghere                                                  NULL);
9536498aff2SJonas Devlieghere    return result;
9546498aff2SJonas Devlieghere}
9556498aff2SJonas Devlieghere
9566498aff2SJonas DevlieghereSWIGEXPORT void*
9576498aff2SJonas DevlieghereLLDBSWIGPython_GetDynamicSetting (void* module, const char* setting, const lldb::TargetSP& target_sp)
9586498aff2SJonas Devlieghere{
9596498aff2SJonas Devlieghere    if (!module || !setting)
9606498aff2SJonas Devlieghere        Py_RETURN_NONE;
9616498aff2SJonas Devlieghere
9626498aff2SJonas Devlieghere    PyErr_Cleaner py_err_cleaner(true);
9636498aff2SJonas Devlieghere    PythonObject py_module(PyRefType::Borrowed, (PyObject *)module);
9646498aff2SJonas Devlieghere    auto pfunc = py_module.ResolveName<PythonCallable>("get_dynamic_setting");
9656498aff2SJonas Devlieghere
9666498aff2SJonas Devlieghere    if (!pfunc.IsAllocated())
9676498aff2SJonas Devlieghere        Py_RETURN_NONE;
9686498aff2SJonas Devlieghere
9696498aff2SJonas Devlieghere    lldb::SBTarget target_sb(target_sp);
9706498aff2SJonas Devlieghere    PythonObject target_arg(PyRefType::Owned, SBTypeToSWIGWrapper(target_sb));
9716498aff2SJonas Devlieghere    auto result = pfunc(target_arg, PythonString(setting));
9726498aff2SJonas Devlieghere
9736498aff2SJonas Devlieghere    return result.release();
9746498aff2SJonas Devlieghere}
9756498aff2SJonas Devlieghere
9766498aff2SJonas DevlieghereSWIGEXPORT bool
9776498aff2SJonas DevlieghereLLDBSWIGPythonRunScriptKeywordProcess
9786498aff2SJonas Devlieghere(const char* python_function_name,
9796498aff2SJonas Devlieghereconst char* session_dictionary_name,
9806498aff2SJonas Devliegherelldb::ProcessSP& process,
9816498aff2SJonas Devliegherestd::string& output)
9826498aff2SJonas Devlieghere
9836498aff2SJonas Devlieghere{
9846498aff2SJonas Devlieghere    if (python_function_name == NULL || python_function_name[0] == '\0' || !session_dictionary_name)
9856498aff2SJonas Devlieghere        return false;
9866498aff2SJonas Devlieghere
9876498aff2SJonas Devlieghere    PyErr_Cleaner py_err_cleaner(true);
9886498aff2SJonas Devlieghere
9896498aff2SJonas Devlieghere    auto dict = PythonModule::MainModule().ResolveName<PythonDictionary>(session_dictionary_name);
9906498aff2SJonas Devlieghere    auto pfunc = PythonObject::ResolveNameWithDictionary<PythonCallable>(python_function_name, dict);
9916498aff2SJonas Devlieghere
9926498aff2SJonas Devlieghere    if (!pfunc.IsAllocated())
9936498aff2SJonas Devlieghere        return false;
9946498aff2SJonas Devlieghere
9956498aff2SJonas Devlieghere    lldb::SBProcess process_sb(process);
9966498aff2SJonas Devlieghere    PythonObject process_arg(PyRefType::Owned, SBTypeToSWIGWrapper(process_sb));
9976498aff2SJonas Devlieghere    auto result = pfunc(process_arg, dict);
9986498aff2SJonas Devlieghere
9996498aff2SJonas Devlieghere    output = result.Str().GetString().str();
10006498aff2SJonas Devlieghere
10016498aff2SJonas Devlieghere    return true;
10026498aff2SJonas Devlieghere}
10036498aff2SJonas Devlieghere
10046498aff2SJonas DevlieghereSWIGEXPORT bool
10056498aff2SJonas DevlieghereLLDBSWIGPythonRunScriptKeywordThread
10066498aff2SJonas Devlieghere(const char* python_function_name,
10076498aff2SJonas Devlieghereconst char* session_dictionary_name,
10086498aff2SJonas Devliegherelldb::ThreadSP& thread,
10096498aff2SJonas Devliegherestd::string& output)
10106498aff2SJonas Devlieghere
10116498aff2SJonas Devlieghere{
10126498aff2SJonas Devlieghere    if (python_function_name == NULL || python_function_name[0] == '\0' || !session_dictionary_name)
10136498aff2SJonas Devlieghere        return false;
10146498aff2SJonas Devlieghere
10156498aff2SJonas Devlieghere    PyErr_Cleaner py_err_cleaner(true);
10166498aff2SJonas Devlieghere
10176498aff2SJonas Devlieghere    auto dict = PythonModule::MainModule().ResolveName<PythonDictionary>(session_dictionary_name);
10186498aff2SJonas Devlieghere    auto pfunc = PythonObject::ResolveNameWithDictionary<PythonCallable>(python_function_name, dict);
10196498aff2SJonas Devlieghere
10206498aff2SJonas Devlieghere    if (!pfunc.IsAllocated())
10216498aff2SJonas Devlieghere        return false;
10226498aff2SJonas Devlieghere
10236498aff2SJonas Devlieghere    lldb::SBThread thread_sb(thread);
10246498aff2SJonas Devlieghere    PythonObject thread_arg(PyRefType::Owned, SBTypeToSWIGWrapper(thread_sb));
10256498aff2SJonas Devlieghere    auto result = pfunc(thread_arg, dict);
10266498aff2SJonas Devlieghere
10276498aff2SJonas Devlieghere    output = result.Str().GetString().str();
10286498aff2SJonas Devlieghere
10296498aff2SJonas Devlieghere    return true;
10306498aff2SJonas Devlieghere}
10316498aff2SJonas Devlieghere
10326498aff2SJonas DevlieghereSWIGEXPORT bool
10336498aff2SJonas DevlieghereLLDBSWIGPythonRunScriptKeywordTarget
10346498aff2SJonas Devlieghere(const char* python_function_name,
10356498aff2SJonas Devlieghereconst char* session_dictionary_name,
10366498aff2SJonas Devliegherelldb::TargetSP& target,
10376498aff2SJonas Devliegherestd::string& output)
10386498aff2SJonas Devlieghere
10396498aff2SJonas Devlieghere{
10406498aff2SJonas Devlieghere    if (python_function_name == NULL || python_function_name[0] == '\0' || !session_dictionary_name)
10416498aff2SJonas Devlieghere        return false;
10426498aff2SJonas Devlieghere
10436498aff2SJonas Devlieghere    PyErr_Cleaner py_err_cleaner(true);
10446498aff2SJonas Devlieghere
10456498aff2SJonas Devlieghere    auto dict = PythonModule::MainModule().ResolveName<PythonDictionary>(session_dictionary_name);
10466498aff2SJonas Devlieghere    auto pfunc = PythonObject::ResolveNameWithDictionary<PythonCallable>(python_function_name,dict);
10476498aff2SJonas Devlieghere
10486498aff2SJonas Devlieghere    if (!pfunc.IsAllocated())
10496498aff2SJonas Devlieghere        return false;
10506498aff2SJonas Devlieghere
10516498aff2SJonas Devlieghere    lldb::SBTarget target_sb(target);
10526498aff2SJonas Devlieghere    PythonObject target_arg(PyRefType::Owned, SBTypeToSWIGWrapper(target_sb));
10536498aff2SJonas Devlieghere    auto result = pfunc(target_arg, dict);
10546498aff2SJonas Devlieghere
10556498aff2SJonas Devlieghere    output = result.Str().GetString().str();
10566498aff2SJonas Devlieghere
10576498aff2SJonas Devlieghere    return true;
10586498aff2SJonas Devlieghere}
10596498aff2SJonas Devlieghere
10606498aff2SJonas DevlieghereSWIGEXPORT bool
10616498aff2SJonas DevlieghereLLDBSWIGPythonRunScriptKeywordFrame
10626498aff2SJonas Devlieghere(const char* python_function_name,
10636498aff2SJonas Devlieghereconst char* session_dictionary_name,
10646498aff2SJonas Devliegherelldb::StackFrameSP& frame,
10656498aff2SJonas Devliegherestd::string& output)
10666498aff2SJonas Devlieghere
10676498aff2SJonas Devlieghere{
10686498aff2SJonas Devlieghere    if (python_function_name == NULL || python_function_name[0] == '\0' || !session_dictionary_name)
10696498aff2SJonas Devlieghere        return false;
10706498aff2SJonas Devlieghere
10716498aff2SJonas Devlieghere    PyErr_Cleaner py_err_cleaner(true);
10726498aff2SJonas Devlieghere
10736498aff2SJonas Devlieghere    auto dict = PythonModule::MainModule().ResolveName<PythonDictionary>(session_dictionary_name);
10746498aff2SJonas Devlieghere    auto pfunc = PythonObject::ResolveNameWithDictionary<PythonCallable>(python_function_name,dict);
10756498aff2SJonas Devlieghere
10766498aff2SJonas Devlieghere    if (!pfunc.IsAllocated())
10776498aff2SJonas Devlieghere        return false;
10786498aff2SJonas Devlieghere
10796498aff2SJonas Devlieghere    lldb::SBFrame frame_sb(frame);
10806498aff2SJonas Devlieghere    PythonObject frame_arg(PyRefType::Owned, SBTypeToSWIGWrapper(frame_sb));
10816498aff2SJonas Devlieghere    auto result = pfunc(frame_arg, dict);
10826498aff2SJonas Devlieghere
10836498aff2SJonas Devlieghere    output = result.Str().GetString().str();
10846498aff2SJonas Devlieghere
10856498aff2SJonas Devlieghere    return true;
10866498aff2SJonas Devlieghere}
10876498aff2SJonas Devlieghere
10886498aff2SJonas DevlieghereSWIGEXPORT bool
10896498aff2SJonas DevlieghereLLDBSWIGPythonRunScriptKeywordValue
10906498aff2SJonas Devlieghere(const char* python_function_name,
10916498aff2SJonas Devlieghereconst char* session_dictionary_name,
10926498aff2SJonas Devliegherelldb::ValueObjectSP& value,
10936498aff2SJonas Devliegherestd::string& output)
10946498aff2SJonas Devlieghere
10956498aff2SJonas Devlieghere{
10966498aff2SJonas Devlieghere    if (python_function_name == NULL || python_function_name[0] == '\0' || !session_dictionary_name)
10976498aff2SJonas Devlieghere        return false;
10986498aff2SJonas Devlieghere
10996498aff2SJonas Devlieghere    PyErr_Cleaner py_err_cleaner(true);
11006498aff2SJonas Devlieghere
11016498aff2SJonas Devlieghere    auto dict = PythonModule::MainModule().ResolveName<PythonDictionary>(session_dictionary_name);
11026498aff2SJonas Devlieghere    auto pfunc = PythonObject::ResolveNameWithDictionary<PythonCallable>(python_function_name, dict);
11036498aff2SJonas Devlieghere
11046498aff2SJonas Devlieghere    if (!pfunc.IsAllocated())
11056498aff2SJonas Devlieghere        return false;
11066498aff2SJonas Devlieghere
11076498aff2SJonas Devlieghere    lldb::SBValue value_sb(value);
11086498aff2SJonas Devlieghere    PythonObject value_arg(PyRefType::Owned, SBTypeToSWIGWrapper(value_sb));
11096498aff2SJonas Devlieghere    auto result = pfunc(value_arg, dict);
11106498aff2SJonas Devlieghere
11116498aff2SJonas Devlieghere    output = result.Str().GetString().str();
11126498aff2SJonas Devlieghere
11136498aff2SJonas Devlieghere    return true;
11146498aff2SJonas Devlieghere}
11156498aff2SJonas Devlieghere
11166498aff2SJonas DevlieghereSWIGEXPORT bool
11176498aff2SJonas DevlieghereLLDBSwigPythonCallModuleInit
11186498aff2SJonas Devlieghere(
11196498aff2SJonas Devlieghere    const char *python_module_name,
11206498aff2SJonas Devlieghere    const char *session_dictionary_name,
11216498aff2SJonas Devlieghere    lldb::DebuggerSP& debugger
11226498aff2SJonas Devlieghere)
11236498aff2SJonas Devlieghere{
11246498aff2SJonas Devlieghere    std::string python_function_name_string = python_module_name;
11256498aff2SJonas Devlieghere    python_function_name_string += ".__lldb_init_module";
11266498aff2SJonas Devlieghere    const char* python_function_name = python_function_name_string.c_str();
11276498aff2SJonas Devlieghere
11286498aff2SJonas Devlieghere    PyErr_Cleaner py_err_cleaner(true);
11296498aff2SJonas Devlieghere
11306498aff2SJonas Devlieghere    auto dict = PythonModule::MainModule().ResolveName<PythonDictionary>(session_dictionary_name);
11316498aff2SJonas Devlieghere    auto pfunc = PythonObject::ResolveNameWithDictionary<PythonCallable>(python_function_name, dict);
11326498aff2SJonas Devlieghere
11336498aff2SJonas Devlieghere    // This method is optional and need not exist.  So if we don't find it,
11346498aff2SJonas Devlieghere    // it's actually a success, not a failure.
11356498aff2SJonas Devlieghere    if (!pfunc.IsAllocated())
11366498aff2SJonas Devlieghere        return true;
11376498aff2SJonas Devlieghere
11386498aff2SJonas Devlieghere    lldb::SBDebugger debugger_sb(debugger);
11396498aff2SJonas Devlieghere    PythonObject debugger_arg(PyRefType::Owned, SBTypeToSWIGWrapper(debugger_sb));
11406498aff2SJonas Devlieghere    pfunc(debugger_arg, dict);
11416498aff2SJonas Devlieghere
11426498aff2SJonas Devlieghere    return true;
11436498aff2SJonas Devlieghere}
11446498aff2SJonas Devlieghere%}
11456498aff2SJonas Devlieghere
11466498aff2SJonas Devlieghere
11476498aff2SJonas Devlieghere%runtime %{
11486498aff2SJonas Devlieghere// Forward declaration to be inserted at the start of LLDBWrapPython.h
11496498aff2SJonas Devlieghere#include "lldb/API/SBDebugger.h"
11506498aff2SJonas Devlieghere#include "lldb/API/SBValue.h"
11516498aff2SJonas Devlieghere
11526498aff2SJonas DevlieghereSWIGEXPORT lldb::ValueObjectSP
11536498aff2SJonas DevlieghereLLDBSWIGPython_GetValueObjectSPFromSBValue (void* data)
11546498aff2SJonas Devlieghere{
11556498aff2SJonas Devlieghere    lldb::ValueObjectSP valobj_sp;
11566498aff2SJonas Devlieghere    if (data)
11576498aff2SJonas Devlieghere    {
11586498aff2SJonas Devlieghere        lldb::SBValue* sb_ptr = (lldb::SBValue *)data;
11596498aff2SJonas Devlieghere        valobj_sp = sb_ptr->GetSP();
11606498aff2SJonas Devlieghere    }
11616498aff2SJonas Devlieghere    return valobj_sp;
11626498aff2SJonas Devlieghere}
11636498aff2SJonas Devlieghere
11646498aff2SJonas Devlieghere#ifdef __cplusplus
11656498aff2SJonas Devlieghereextern "C" {
11666498aff2SJonas Devlieghere#endif
11676498aff2SJonas Devlieghere
11686498aff2SJonas Devliegherevoid LLDBSwigPythonCallPythonLogOutputCallback(const char *str, void *baton);
11696498aff2SJonas Devlieghere
11706498aff2SJonas Devlieghere#ifdef __cplusplus
11716498aff2SJonas Devlieghere}
11726498aff2SJonas Devlieghere#endif
11736498aff2SJonas Devlieghere%}
11746498aff2SJonas Devlieghere
11756498aff2SJonas Devlieghere%wrapper %{
11766498aff2SJonas Devlieghere
11776498aff2SJonas Devlieghere
11786498aff2SJonas Devlieghere// For the LogOutputCallback functions
11796498aff2SJonas Devliegherevoid LLDBSwigPythonCallPythonLogOutputCallback(const char *str, void *baton) {
11806498aff2SJonas Devlieghere    if (baton != Py_None) {
11816498aff2SJonas Devlieghere      SWIG_PYTHON_THREAD_BEGIN_BLOCK;
11826498aff2SJonas Devlieghere      PyObject *result = PyObject_CallFunction(reinterpret_cast<PyObject*>(baton), const_cast<char*>("s"), str);
11836498aff2SJonas Devlieghere	  Py_XDECREF(result);
11846498aff2SJonas Devlieghere      SWIG_PYTHON_THREAD_END_BLOCK;
11856498aff2SJonas Devlieghere    }
11866498aff2SJonas Devlieghere}
11876498aff2SJonas Devlieghere%}
1188