File: NodeJSSetBreakpointHandler.cpp

package info (click to toggle)
codelite 12.0%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 95,112 kB
  • sloc: cpp: 424,040; ansic: 18,284; php: 9,569; lex: 4,186; yacc: 2,820; python: 2,294; sh: 312; makefile: 51; xml: 13
file content (32 lines) | stat: -rw-r--r-- 1,104 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
#include "NodeJSSetBreakpointHandler.h"
#include "NodeJSDebugger.h"
#include "json_node.h"
#include "file_logger.h"
#include "cl_command_event.h"
#include "NodeJSEvents.h"
#include "event_notifier.h"

NodeJSSetBreakpointHandler::NodeJSSetBreakpointHandler(const NodeJSBreakpoint& bp)
    : m_breakpoint(bp)
{
}

NodeJSSetBreakpointHandler::~NodeJSSetBreakpointHandler() {}
void NodeJSSetBreakpointHandler::Process(NodeJSDebugger* debugger, const wxString& output)
{
    JSONRoot root(output);
    JSONElement json = root.toElement();
    int bpId = json.namedObject("body").namedObject("breakpoint").toInt();
    bool success = json.namedObject("success").toBool();
    if(success) {
        NodeJSBreakpoint& bp =
            debugger->GetBreakpointsMgr()->GetBreakpoint(m_breakpoint.GetFilename(), m_breakpoint.GetLine());
        if(bp.IsOk()) {
            bp.SetNodeBpID(bpId);
            CL_DEBUG("CodeLite: Found breakpoint ID: %d", bpId);

            clDebugEvent event(wxEVT_NODEJS_DEBUGGER_UPDATE_BREAKPOINTS_VIEW);
            EventNotifier::Get()->AddPendingEvent(event);
        }
    }
}