1
1
Fork 0
mirror of https://github.com/QB64-Phoenix-Edition/QB64pe.git synced 2024-06-29 10:30:36 +00:00

Add support for inspecting string variables

This commit is contained in:
Luke Ceddia 2021-07-27 17:09:28 +10:00
parent a2a49cef01
commit 7e4a5b9799
No known key found for this signature in database
GPG key ID: 319344384A0759B0
2 changed files with 86 additions and 78 deletions

View file

@ -5,10 +5,10 @@ SUB vwatch (globalVariables AS _OFFSET, localVariables AS _OFFSET)
STATIC AS LONG callStackLength, runToLine
STATIC AS _BYTE pauseMode, stepOver, bypass, setNextLine
STATIC buffer$, endc$
DIM AS LONG i, tempIndex, localIndex
DIM AS LONG i, tempIndex, localIndex, varSize, sequence
DIM AS _OFFSET address
DIM AS _MEM m
DIM start!, temp$, cmd$, value$, k&, dataType$, result$
DIM AS _MEM m, m2
DIM start!, temp$, cmd$, value$, k&, dataType$, result$, buf$
DECLARE LIBRARY
SUB vwatch_stoptimers ALIAS stop_timers
@ -217,29 +217,37 @@ SUB vwatch (globalVariables AS _OFFSET, localVariables AS _OFFSET)
CASE "clear all skips"
REDIM vwatch_skiplines(UBOUND(vwatch_skiplines)) AS _BYTE
CASE "call stack"
'send call stack history"
'send call stack history
GOSUB SendCallStack
CASE "global var"
tempIndex = CVL(LEFT$(value$, 4))
localIndex = CVL(MID$(value$, 5, 4))
dataType$ = MID$(value$, 9)
address = globalVariables + LEN(address) * localIndex
address = _MEMGET(m, address, _OFFSET)
GOSUB GetMemData
$CONSOLE
_ECHO "Sending global var: " + STR$(tempIndex) + " = " + result$
cmd$ = "global var:" + MKL$(tempIndex) + result$
cmd$ = "global var:" + MKL$(tempIndex) + str$(address)
GOSUB SendCommand
CASE "local var"
tempIndex = CVL(LEFT$(value$, 4))
localIndex = CVL(MID$(value$, 5, 4))
dataType$ = MID$(value$, 9)
address = localVariables + LEN(address) * localIndex
address = _MEMGET(m, address, _OFFSET)
GOSUB GetMemData
_ECHO "Sending local var: " + STR$(tempIndex) + " = " + result$
cmd$ = "local var:" + MKL$(tempIndex) + result$
GOSUB SendCommand
' tempIndex = CVL(LEFT$(value$, 4))
' localIndex = CVL(MID$(value$, 5, 4))
' dataType$ = MID$(value$, 9)
' address = localVariables + LEN(address) * localIndex
' address = _MEMGET(m, address, _OFFSET)
' GOSUB GetMemData
' _ECHO "Sending local var: " + STR$(tempIndex) + " = " + result$
' cmd$ = "local var:" + MKL$(tempIndex) + result$
' GOSUB SendCommand
case "get address"
tempIndex = cvl(left$(value$, 4))
sequence = cvi(mid$(value$, 5, 2))
varSize = cvl(mid$(value$, 7, 4))
address = val(mid$(value$, 11))
buf$ = space$(varSize)
m = _mem(address, varSize)
m2 = _mem(_offset(buf$), varSize)
_memcopy m, m.offset, m.size to m2, m2.offset
cmd$ = "address read:" + mkl$(tempIndex) + mki$(sequence) + buf$
gosub sendcommand
CASE "current sub"
cmd$ = "current sub:" + vwatch_internalsubname$
GOSUB SendCommand
@ -309,55 +317,4 @@ SUB vwatch (globalVariables AS _OFFSET, localVariables AS _OFFSET)
cmd$ = ""
RETURN
GetMemData:
DIM integerType AS INTEGER, uintegerType AS _UNSIGNED INTEGER
DIM longType AS LONG, ulongType AS _UNSIGNED LONG
DIM singleType AS SINGLE, doubleType AS DOUBLE
DIM varOffset AS _OFFSET, m2 AS _MEM
SELECT CASE dataType$
CASE "INTEGER"
m = _MEM(address, 2)
m2 = _MEM(integerType)
_MEMCOPY m, m.OFFSET, m.SIZE TO m2, m2.OFFSET
_MEMFREE m
_MEMFREE m2
result$ = STR$(integerType)
CASE "_UNSIGNED INTEGER"
m = _MEM(address, 2)
m2 = _MEM(uintegerType)
_MEMCOPY m, m.OFFSET, m.SIZE TO m2, m2.OFFSET
_MEMFREE m
_MEMFREE m2
result$ = STR$(uintegerType)
CASE "LONG"
m = _MEM(address, 4)
m2 = _MEM(longType)
_MEMCOPY m, m.OFFSET, m.SIZE TO m2, m2.OFFSET
_MEMFREE m
_MEMFREE m2
result$ = STR$(longType)
CASE "_UNSIGNED LONG"
m = _MEM(address, 4)
m2 = _MEM(ulongType)
_MEMCOPY m, m.OFFSET, m.SIZE TO m2, m2.OFFSET
_MEMFREE m
_MEMFREE m2
result$ = STR$(ulongType)
CASE "SINGLE"
m = _MEM(address, 4)
m2 = _MEM(singleType)
_MEMCOPY m, m.OFFSET, m.SIZE TO m2, m2.OFFSET
_MEMFREE m
_MEMFREE m2
result$ = STR$(singleType)
CASE "DOUBLE"
m = _MEM(address, 8)
m2 = _MEM(doubleType)
_MEMCOPY m, m.OFFSET, m.SIZE TO m2, m2.OFFSET
_MEMFREE m
_MEMFREE m2
result$ = STR$(doubleType)
END SELECT
RETURN
END SUB

View file

@ -6940,8 +6940,8 @@ SUB DebugMode
temp$ = MID$(temp$, 5)
IF usedVariableList(tempIndex&).watch THEN
cmd$ = ""
_ECHO "usedVariableList(tempIndex&).subfunc =" + usedVariableList(tempIndex&).subfunc
_ECHO "currentSub$ =" + currentSub$
'_ECHO "usedVariableList(tempIndex&).subfunc =" + usedVariableList(tempIndex&).subfunc
'_ECHO "currentSub$ =" + currentSub$
IF LEN(usedVariableList(tempIndex&).subfunc) = 0 THEN
cmd$ = "global var:"
ELSEIF usedVariableList(tempIndex&).subfunc = currentSub$ THEN
@ -6949,21 +6949,72 @@ SUB DebugMode
END IF
IF LEN(cmd$) THEN
_CONSOLE ON
_ECHO "Requesting " + cmd$
_ECHO "currentSub$ = " + currentSub$
cmd$ = cmd$ + MKL$(tempIndex&) + MKL$(usedVariableList(tempIndex&).localIndex) + usedVariableList(tempIndex&).varType
_ECHO "Requesting " + cmd$ + str$(tempIndex&)
'_ECHO "currentSub$ = " + currentSub$
cmd$ = cmd$ + MKL$(tempIndex&) + MKL$(usedVariableList(tempIndex&).localIndex)
GOSUB SendCommand
END IF
END IF
LOOP
END IF
CASE "global var", "local var"
_ECHO "Received " + cmd$
tempIndex& = CVL(LEFT$(value$, 4))
value$ = MID$(value$, 5)
_ECHO "index = " + STR$(tempIndex&)
_ECHO "=== value$ = " + value$
usedVariableList(tempIndex&).mostRecentValue = value$
address%& = val(mid$(value$, 5))
varType$ = usedVariableList(tempIndex&).varType
if instr(varType$, "STRING *") then varType$ = "STRING"
select case varType$
case "_BYTE", "_UNSIGNED _BYTE": varSize& = len(dummy%%)
case "INTEGER", "_UNSIGNED INTEGER": varSize& = len(dummy%)
case "LONG", "_UNSIGNED LONG": varSize& = len(dummy&)
case "_INTEGER64", "_UNSIGNED _INTEGER64": varSize& = len(dummy&&)
case "SINGLE": varSize& = len(dummy!)
case "DOUBLE": varSize& = len(dummy#)
case "_FLOAT": varSize& = len(dummy##)
case "_OFFSET", "_UNSIGNED _OFFSET": varSize& = len(dummy%&)
case "STRING": varSize& = len(dummy%&) + len(dummy&)
end select
_echo "Requesting " + str$(varSize&) + " bytes from &H" + hex$(address%&)
cmd$ = "get address:" + mkl$(tempIndex&) + mki$(1) + mkl$(varSize&) + str$(address%&)
gosub SendCommand
case "address read"
tempIndex& = cvl(left$(value$, 4))
sequence% = cvi(mid$(value$, 5, 2))
_echo "Received data for " + str$(tempIndex&)
recvData$ = mid$(value$, 7)
varType$ = usedVariableList(tempIndex&).varType
if instr(varType$, "STRING *") then varType$ = "STRING"
select case varType$
case "_BYTE": recvData$ = str$(_cv(_byte, recvData$))
case "_UNSIGNED _BYTE": recvData$ = str$(_cv(_unsigned _byte, recvData$))
case "INTEGER": recvData$ = str$(_cv(integer, recvData$))
case "_UNSIGNED INTEGER": recvData$ = str$(_cv(_unsigned integer, recvData$))
case "LONG": recvData$ = str$(_cv(long, recvData$))
case "_UNSIGNED LONG": recvData$ = str$(_cv(_unsigned long, recvData$))
case "_INTEGER64": recvData$ = str$(_cv(_integer64, recvData$))
case "_UNSIGNED _INTEGER64": recvData$ = str$(_cv(_unsigned _integer64, recvData$))
case "SINGLE": recvData$ = str$(_cv(single, recvData$))
case "DOUBLE": recvData$ = str$(_cv(double, recvData$))
case "_FLOAT": recvData$ = str$(_cv(_float, recvData$))
case "_OFFSET": 'TODO
case "_UNSIGNED _OFFSET": 'TODO
case "STRING"
if sequence% = 1 then
if len(dummy%&) = 8 then
address%& = _cv(_integer64, left$(recvData$, 8))
strLength& = cvl(mid$(recvData$, 9))
else
address%& = _cv(long, left$(recvData$, 4))
strLength& = cvl(mid$(recvData$, 5))
end if
address$ = left$(recvData$, len(dummy%&)) 'Pointer to data
_echo "Requesting string of length " + str$(strLength&) + " at &H" + hex$(address%&)
cmd$ = "get address:" + mkl$(tempIndex&) + mki$(2) + mkl$(strLength&) + str$(address%&)
gosub sendcommand
goto vwatch_string_seq1_done
end if
end select
usedVariableList(tempIndex&).mostRecentValue = recvData$
vwatch_string_seq1_done:
CASE "current sub"
currentSub$ = value$
CASE "quit"