char * formatBreakpoint (StringB &breakpointdescB, SBBreakpoint breakpoint, STATE *pstate) { logprintf (LOG_TRACE, "formatBreakpoint (0x%x, 0x%x, 0x%x)\n", &breakpointdescB, &breakpoint, pstate); // 18^done,bkpt={number="1",type="breakpoint",disp="keep",enabled="y",addr="0x00000001000/00f58", // func="main",file="../Sources/tests.cpp",fullname="/pro/runtime-EclipseApplication/tests/Sources/tests.cpp", // line="17",thread-groups=["i1"],times="0",original-location="/pro/runtime-EclipseApplication/tests/Sources/tests.cpp:17"} int bpid = breakpoint.GetID(); SBBreakpointLocation location = breakpoint.GetLocationAtIndex(0); SBAddress addr = location.GetAddress(); uint32_t file_addr=addr.GetFileAddress(); SBFunction function=addr.GetFunction(); const char *func_name=function.GetName(); SBLineEntry line_entry=addr.GetLineEntry(); SBFileSpec filespec = line_entry.GetFileSpec(); const char *filename=filespec.GetFilename(); char filepath[PATH_MAX]; snprintf (filepath, sizeof(filepath), "%s/%s", filespec.GetDirectory(), filename); uint32_t line=line_entry.GetLine(); const char *dispose = (breakpoint.IsOneShot())? "del": "keep"; const char *originallocation = ""; // originallocation,dispose = breakpoints[bpid] breakpointdescB.catsprintf ( "{number=\"%d\",type=\"breakpoint\",disp=\"%s\",enabled=\"y\",addr=\"0x%016x\"," "func=\"%s\",file=\"%s\",fullname=\"%s\",line=\"%d\"," "thread-groups=[\"%s\"],times=\"0\",original-location=\"%s\"}", bpid,dispose,file_addr,func_name,filename, filepath,line,pstate->threadgroup,originallocation); return breakpointdescB.c_str(); }
char * formatFrame (StringB &framedescB, SBFrame frame, FrameDetails framedetails) { logprintf (LOG_TRACE, "formatFrame (0x%x, 0x%x, 0x%x)\n", &framedescB, &frame, framedetails); int frameid = frame.GetFrameID(); SBAddress addr = frame.GetPCAddress(); uint32_t file_addr = addr.GetFileAddress(); SBFunction function = addr.GetFunction(); char levelstring[NAME_MAX]; if (framedetails&WITH_LEVEL) snprintf (levelstring, sizeof(levelstring), "level=\"%d\",", frameid); else levelstring[0] = '\0'; const char *modulefilename = ""; SBModule module = frame.GetModule(); if (module.IsValid()) { SBFileSpec modulefilespec = module.GetPlatformFileSpec(); modulefilename = modulefilespec.GetFilename(); } const char *func_name="??"; static StringB argsstringB(LINE_MAX); argsstringB.clear(); if (function.IsValid()) { const char *filename, *filedir; int line = 0; func_name = function.GetName(); SBLineEntry line_entry = addr.GetLineEntry(); SBFileSpec filespec = line_entry.GetFileSpec(); filename = filespec.GetFilename(); filedir = filespec.GetDirectory(); line = line_entry.GetLine(); if (framedetails&WITH_ARGS) { SBValueList args = frame.GetVariables(1,0,0,0); static StringB argsdescB(LINE_MAX); argsdescB.clear(); SBFunction function = frame.GetFunction(); formatVariables (argsdescB, args); argsstringB.catsprintf ("%sargs=[%s]", (framedetails==JUST_LEVEL_AND_ARGS)?"":",", argsdescB.c_str()); } if (framedetails==JUST_LEVEL_AND_ARGS) framedescB.catsprintf ("frame={%s%s}", levelstring, argsstringB.c_str()); else framedescB.catsprintf ("frame={%saddr=\"0x%016x\",func=\"%s\"%s,file=\"%s\"," "fullname=\"%s/%s\",line=\"%d\"}", levelstring,file_addr,func_name,argsstringB.c_str(),filename,filedir,filename,line); } else { if (framedetails&WITH_ARGS) argsstringB.catsprintf ("%sargs=[]", (framedetails==JUST_LEVEL_AND_ARGS)?"":","); if (framedetails==JUST_LEVEL_AND_ARGS) framedescB.catsprintf ("frame={%s%s}", levelstring, argsstringB.c_str()); else { func_name = frame.GetFunctionName(); framedescB.catsprintf ("frame={%saddr=\"0x%016x\",func=\"%s\"%s,file=\"%s\"}", levelstring, file_addr, func_name, argsstringB.c_str(), modulefilename); } } return framedescB.c_str(); }