Change dap::integer backing type to int64_t
`int` may be < 64 bit, and some dap protocols use a 64 bit integer. Chnage to `int64_t` to be consistent. Fixes: #45
This commit is contained in:
parent
7b02b9f73a
commit
1e5ec3e405
@ -50,7 +50,7 @@ You can set breakpoints, and single line step.
|
||||
You may also notice that the locals contains a single variable for the currently executing line number.)";
|
||||
|
||||
// Total number of newlines in source.
|
||||
constexpr int numSourceLines = 7;
|
||||
constexpr int64_t numSourceLines = 7;
|
||||
|
||||
// Debugger holds the dummy debugger state and fires events to the EventHandler
|
||||
// passed to the constructor.
|
||||
@ -68,7 +68,7 @@ class Debugger {
|
||||
void pause();
|
||||
|
||||
// currentLine() returns the currently executing line number.
|
||||
int currentLine();
|
||||
int64_t currentLine();
|
||||
|
||||
// stepForward() instructs the debugger to step forward one line.
|
||||
void stepForward();
|
||||
@ -77,21 +77,21 @@ class Debugger {
|
||||
void clearBreakpoints();
|
||||
|
||||
// addBreakpoint() sets a new breakpoint on the given line.
|
||||
void addBreakpoint(int line);
|
||||
void addBreakpoint(int64_t line);
|
||||
|
||||
private:
|
||||
EventHandler onEvent;
|
||||
std::mutex mutex;
|
||||
int line = 1;
|
||||
std::unordered_set<int> breakpoints;
|
||||
int64_t line = 1;
|
||||
std::unordered_set<int64_t> breakpoints;
|
||||
};
|
||||
|
||||
Debugger::Debugger(const EventHandler& onEvent) : onEvent(onEvent) {}
|
||||
|
||||
void Debugger::run() {
|
||||
std::unique_lock<std::mutex> lock(mutex);
|
||||
for (int i = 0; i < numSourceLines; i++) {
|
||||
auto l = ((line + i) % numSourceLines) + 1;
|
||||
for (int64_t i = 0; i < numSourceLines; i++) {
|
||||
int64_t l = ((line + i) % numSourceLines) + 1;
|
||||
if (breakpoints.count(l)) {
|
||||
line = l;
|
||||
lock.unlock();
|
||||
@ -105,7 +105,7 @@ void Debugger::pause() {
|
||||
onEvent(Event::Paused);
|
||||
}
|
||||
|
||||
int Debugger::currentLine() {
|
||||
int64_t Debugger::currentLine() {
|
||||
std::unique_lock<std::mutex> lock(mutex);
|
||||
return line;
|
||||
}
|
||||
@ -122,7 +122,7 @@ void Debugger::clearBreakpoints() {
|
||||
this->breakpoints.clear();
|
||||
}
|
||||
|
||||
void Debugger::addBreakpoint(int l) {
|
||||
void Debugger::addBreakpoint(int64_t l) {
|
||||
std::unique_lock<std::mutex> lock(mutex);
|
||||
this->breakpoints.emplace(l);
|
||||
}
|
||||
|
@ -25,6 +25,8 @@
|
||||
#include <unordered_map>
|
||||
#include <vector>
|
||||
|
||||
#include <stdint.h>
|
||||
|
||||
namespace dap {
|
||||
|
||||
// string is a sequence of characters.
|
||||
@ -52,9 +54,9 @@ class boolean {
|
||||
class integer {
|
||||
public:
|
||||
inline integer() : val(0) {}
|
||||
inline integer(int i) : val(i) {}
|
||||
inline operator int() const { return val; }
|
||||
inline integer& operator=(int i) {
|
||||
inline integer(int64_t i) : val(i) {}
|
||||
inline operator int64_t() const { return val; }
|
||||
inline integer& operator=(int64_t i) {
|
||||
val = i;
|
||||
return *this;
|
||||
}
|
||||
@ -65,7 +67,7 @@ class integer {
|
||||
}
|
||||
|
||||
private:
|
||||
int val;
|
||||
int64_t val;
|
||||
};
|
||||
|
||||
// number holds a 64-bit floating point number.
|
||||
|
@ -167,7 +167,8 @@ class Impl : public dap::Session {
|
||||
}
|
||||
}
|
||||
|
||||
std::pair<const dap::TypeInfo*, GenericResponseHandler> response(int seq) {
|
||||
std::pair<const dap::TypeInfo*, GenericResponseHandler> response(
|
||||
int64_t seq) {
|
||||
std::unique_lock<std::mutex> lock(responseMutex);
|
||||
auto responseIt = responseMap.find(seq);
|
||||
if (responseIt == responseMap.end()) {
|
||||
@ -252,7 +253,7 @@ class Impl : public dap::Session {
|
||||
requestMap;
|
||||
|
||||
std::mutex responseMutex;
|
||||
std::unordered_map<int,
|
||||
std::unordered_map<int64_t,
|
||||
std::pair<const dap::TypeInfo*, GenericResponseHandler>>
|
||||
responseMap;
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user