process.launch();
close(fds[1]);
- breakpoints.clear();
+ for(BreakList::iterator i=breakpoints.begin(); i!=breakpoints.end(); )
+ {
+ if(i->has_owner(0))
+ {
+ i->owners.clear();
+ i->owners.push_back(0);
+ send_breakpoint(i->function, i->flag, 0);
+ ++i;
+ }
+ else
+ breakpoints.erase(i++);
+ }
+
for(ToolList::iterator i=tools.begin(); i!=tools.end(); ++i)
(*i)->process_started();
}
send(pkt);
}
+void GlDbg::send_breakpoint(unsigned short func, unsigned char set_flags, unsigned char clear_flags)
+{
+ GlPacket *pkt = packet_begin(FUNC_GLDBREAK);
+ packet_write_short(pkt, func);
+ packet_write_char(pkt, set_flags);
+ packet_write_char(pkt, clear_flags);
+ send(pkt);
+}
+
void GlDbg::set_breakpoint(unsigned short func, unsigned char flag, Tool *owner)
{
Breakpoint *bp = (func ? get_breakpoint(func, flag) : 0);
breakpoints.back().add_owner(owner);
}
- GlPacket *pkt = packet_begin(FUNC_GLDBREAK);
- packet_write_short(pkt, func);
- packet_write_char(pkt, flag);
- packet_write_char(pkt, 0);
- send(pkt);
+ if(process.get_state()>=Process::RUNNING)
+ send_breakpoint(func, flag, 0);
}
}
break;
}
- GlPacket *pkt = packet_begin(FUNC_GLDBREAK);
- packet_write_short(pkt, func);
- packet_write_char(pkt, 0);
- packet_write_char(pkt, flag);
- send(pkt);
+ if(process.get_state()>=Process::RUNNING)
+ send_breakpoint(func, 0, flag);
}
}
}
void launch();
void send(GlPacket *);
void hold();
+private:
+ void send_breakpoint(unsigned short, unsigned char, unsigned char);
+public:
void set_breakpoint(unsigned short, unsigned char, Tool *);
void clear_breakpoint(unsigned short, unsigned char, Tool *);
void resume_from_break(Tool *);