From a4e969f4965059196ca948db781e52f7cfebf19e Mon Sep 17 00:00:00 2001 From: Lorry Tar Creator Date: Tue, 24 May 2016 08:28:08 +0000 Subject: webkitgtk-2.12.3 --- Source/JavaScriptCore/debugger/Breakpoint.h | 57 ++++++++++++++++++++++------- 1 file changed, 43 insertions(+), 14 deletions(-) (limited to 'Source/JavaScriptCore/debugger/Breakpoint.h') diff --git a/Source/JavaScriptCore/debugger/Breakpoint.h b/Source/JavaScriptCore/debugger/Breakpoint.h index 95b92881d..78d208a2b 100644 --- a/Source/JavaScriptCore/debugger/Breakpoint.h +++ b/Source/JavaScriptCore/debugger/Breakpoint.h @@ -27,38 +27,67 @@ #define Breakpoint_h #include "DebuggerPrimitives.h" +#include +#include #include namespace JSC { -struct Breakpoint { +struct Breakpoint : public DoublyLinkedListNode { Breakpoint() - : id(noBreakpointID) - , sourceID(noSourceID) - , line(0) - , column(0) - , autoContinue(false) { } - Breakpoint(SourceID sourceID, unsigned line, unsigned column, String condition, bool autoContinue) - : id(noBreakpointID) - , sourceID(sourceID) + Breakpoint(SourceID sourceID, unsigned line, unsigned column, const String& condition, bool autoContinue, unsigned ignoreCount) + : sourceID(sourceID) , line(line) , column(column) , condition(condition) , autoContinue(autoContinue) + , ignoreCount(ignoreCount) { } - BreakpointID id; - SourceID sourceID; - unsigned line; - unsigned column; + Breakpoint(const Breakpoint& other) + : id(other.id) + , sourceID(other.sourceID) + , line(other.line) + , column(other.column) + , condition(other.condition) + , autoContinue(other.autoContinue) + , ignoreCount(other.ignoreCount) + , hitCount(other.hitCount) + { + } + + BreakpointID id { noBreakpointID }; + SourceID sourceID { noSourceID }; + unsigned line { 0 }; + unsigned column { 0 }; String condition; - bool autoContinue; + bool autoContinue { false }; + unsigned ignoreCount { 0 }; + unsigned hitCount { 0 }; static const unsigned unspecifiedColumn = UINT_MAX; + +private: + Breakpoint* m_prev; + Breakpoint* m_next; + + friend class WTF::DoublyLinkedListNode; +}; + +class BreakpointsList : public DoublyLinkedList, + public RefCounted { +public: + ~BreakpointsList() + { + Breakpoint* breakpoint; + while ((breakpoint = removeHead())) + delete breakpoint; + ASSERT(isEmpty()); + } }; } // namespace JSC -- cgit v1.2.1