2021-07-22 21:39:20 +00:00
|
|
|
$CHECKING:OFF
|
|
|
|
|
2021-07-26 17:52:14 +00:00
|
|
|
SUB vwatch (globalVariables AS _OFFSET, localVariables AS _OFFSET)
|
2021-07-29 17:58:05 +00:00
|
|
|
STATIC AS LONG vw_ideHost, vw_breakpointCount, vw_skipCount, vw_timeout, vw_startLevel, vw_lastLine
|
|
|
|
STATIC AS LONG vw_runToLine
|
2021-08-15 00:27:57 +00:00
|
|
|
STATIC AS _BYTE vw_pauseMode, vw_stepOver, vw_bypass, vw_setNextLine, vw_hwndsent
|
2021-08-13 02:00:43 +00:00
|
|
|
STATIC AS _OFFSET vw_idehwnd
|
2021-07-29 17:58:05 +00:00
|
|
|
STATIC vw_buffer$, vw_endc$
|
|
|
|
DIM AS LONG vw_i, vw_tempIndex, vw_localIndex, vw_varSize, vw_sequence
|
|
|
|
DIM AS _OFFSET vw_address
|
|
|
|
DIM AS _MEM vw_m, vw_m2
|
|
|
|
DIM vw_start!, vw_temp$, vw_cmd$, vw_value$, vw_k&, vw_buf$, vw_scope$
|
2021-07-22 21:39:20 +00:00
|
|
|
|
|
|
|
DECLARE LIBRARY
|
|
|
|
SUB vwatch_stoptimers ALIAS stop_timers
|
|
|
|
SUB vwatch_starttimers ALIAS start_timers
|
|
|
|
SUB unlockvWatchHandle
|
2021-08-03 03:36:21 +00:00
|
|
|
SUB set_qbs_size (target AS _OFFSET, BYVAL length&)
|
2021-08-05 00:12:33 +00:00
|
|
|
FUNCTION stop_program_state&
|
2021-07-22 21:39:20 +00:00
|
|
|
END DECLARE
|
|
|
|
|
2021-08-15 03:49:06 +00:00
|
|
|
$IF WIN THEN
|
|
|
|
DECLARE DYNAMIC LIBRARY "user32"
|
|
|
|
FUNCTION SetForegroundWindow& (BYVAL hWnd AS _OFFSET)
|
|
|
|
END DECLARE
|
|
|
|
$END IF
|
|
|
|
|
2021-07-29 17:58:05 +00:00
|
|
|
IF vw_bypass THEN EXIT SUB
|
2021-07-22 21:39:20 +00:00
|
|
|
|
|
|
|
vwatch_goto = 0
|
|
|
|
|
2021-07-29 17:58:05 +00:00
|
|
|
IF vw_ideHost = 0 THEN
|
|
|
|
vw_timeout = 10
|
|
|
|
vw_endc$ = "<END>"
|
2021-07-22 21:39:20 +00:00
|
|
|
|
|
|
|
'initial setup
|
|
|
|
GOSUB Connect
|
|
|
|
|
|
|
|
'send this binary's path/exe name
|
2021-07-29 17:58:05 +00:00
|
|
|
vw_cmd$ = "me:" + COMMAND$(0)
|
2021-07-22 21:39:20 +00:00
|
|
|
GOSUB SendCommand
|
2021-08-15 00:27:57 +00:00
|
|
|
IF _WINDOWHANDLE THEN
|
|
|
|
vw_hwndsent = -1
|
|
|
|
vw_cmd$ = "hwnd:" + _MK$(_OFFSET, _WINDOWHANDLE)
|
|
|
|
GOSUB SendCommand
|
|
|
|
END IF
|
2021-07-22 21:39:20 +00:00
|
|
|
|
|
|
|
DO
|
|
|
|
GOSUB GetCommand
|
2021-07-29 17:58:05 +00:00
|
|
|
SELECT CASE vw_cmd$
|
2021-07-22 21:39:20 +00:00
|
|
|
CASE "vwatch"
|
2021-07-29 17:58:05 +00:00
|
|
|
IF vw_value$ <> "ok" THEN
|
|
|
|
unlockvWatchHandle: CLOSE #vw_ideHost
|
|
|
|
vw_bypass = -1
|
2021-07-22 21:39:20 +00:00
|
|
|
EXIT SUB
|
|
|
|
END IF
|
|
|
|
CASE "line count"
|
2021-07-29 17:58:05 +00:00
|
|
|
REDIM vwatch_breakpoints(CVL(vw_value$)) AS _BYTE
|
|
|
|
REDIM vwatch_skiplines(CVL(vw_value$)) AS _BYTE
|
2021-07-22 21:39:20 +00:00
|
|
|
CASE "breakpoint count"
|
2021-07-29 17:58:05 +00:00
|
|
|
vw_breakpointCount = CVL(vw_value$)
|
2021-07-22 21:39:20 +00:00
|
|
|
CASE "breakpoint list"
|
2021-07-29 17:58:05 +00:00
|
|
|
IF LEN(vw_value$) \ 4 <> vw_breakpointCount THEN
|
|
|
|
vw_cmd$ = "quit:Communication error."
|
2021-07-22 21:39:20 +00:00
|
|
|
GOSUB SendCommand
|
2021-07-29 17:58:05 +00:00
|
|
|
unlockvWatchHandle: CLOSE #vw_ideHost
|
|
|
|
vw_bypass = -1
|
2021-07-22 21:39:20 +00:00
|
|
|
EXIT SUB
|
|
|
|
END IF
|
2021-07-29 17:58:05 +00:00
|
|
|
FOR vw_i = 1 TO vw_breakpointCount
|
|
|
|
vw_temp$ = MID$(vw_value$, vw_i * 4 - 3, 4)
|
|
|
|
vwatch_breakpoints(CVL(vw_temp$)) = -1
|
2021-07-22 21:39:20 +00:00
|
|
|
NEXT
|
2021-08-13 02:00:43 +00:00
|
|
|
CASE "hwnd"
|
|
|
|
vw_idehwnd = _CV(_OFFSET, vw_value$)
|
2021-07-22 21:39:20 +00:00
|
|
|
CASE "skip count"
|
2021-07-29 17:58:05 +00:00
|
|
|
vw_skipCount = CVL(vw_value$)
|
2021-07-22 21:39:20 +00:00
|
|
|
CASE "skip list"
|
2021-07-29 17:58:05 +00:00
|
|
|
IF LEN(vw_value$) \ 4 <> vw_skipCount THEN
|
|
|
|
vw_cmd$ = "quit:Communication error."
|
2021-07-22 21:39:20 +00:00
|
|
|
GOSUB SendCommand
|
2021-07-29 17:58:05 +00:00
|
|
|
unlockvWatchHandle: CLOSE #vw_ideHost
|
|
|
|
vw_bypass = -1
|
2021-07-22 21:39:20 +00:00
|
|
|
EXIT SUB
|
|
|
|
END IF
|
2021-07-29 17:58:05 +00:00
|
|
|
FOR vw_i = 1 TO vw_skipCount
|
|
|
|
vw_temp$ = MID$(vw_value$, vw_i * 4 - 3, 4)
|
|
|
|
vwatch_skiplines(CVL(vw_temp$)) = -1
|
2021-07-22 21:39:20 +00:00
|
|
|
NEXT
|
|
|
|
CASE "run"
|
|
|
|
IF vwatch_breakpoints(vwatch_linenumber) THEN EXIT DO
|
2021-07-29 17:58:05 +00:00
|
|
|
vw_pauseMode = 0
|
2021-07-22 21:39:20 +00:00
|
|
|
EXIT SUB
|
|
|
|
CASE "break"
|
2021-07-29 17:58:05 +00:00
|
|
|
vw_pauseMode = -1
|
2021-07-22 21:39:20 +00:00
|
|
|
EXIT DO
|
|
|
|
END SELECT
|
|
|
|
LOOP
|
|
|
|
END IF
|
|
|
|
|
2021-08-15 00:27:57 +00:00
|
|
|
IF vw_hwndsent = 0 AND _WINDOWHANDLE > 0 THEN
|
|
|
|
vw_hwndsent = -1
|
|
|
|
vw_cmd$ = "hwnd:" + _MK$(_OFFSET, _WINDOWHANDLE)
|
|
|
|
GOSUB SendCommand
|
|
|
|
END IF
|
|
|
|
|
2021-07-22 21:39:20 +00:00
|
|
|
IF vwatch_linenumber = 0 THEN
|
|
|
|
GOSUB SendCallStack
|
2021-07-29 17:58:05 +00:00
|
|
|
vw_cmd$ = "quit:Program ended."
|
2021-07-22 21:39:20 +00:00
|
|
|
GOSUB SendCommand
|
2021-07-29 17:58:05 +00:00
|
|
|
unlockvWatchHandle: CLOSE #vw_ideHost
|
|
|
|
vw_bypass = -1
|
|
|
|
vw_ideHost = 0
|
2021-07-22 21:39:20 +00:00
|
|
|
EXIT SUB
|
|
|
|
ELSEIF vwatch_linenumber = -1 THEN
|
|
|
|
'report an error in the most recent line
|
|
|
|
GOSUB SendCallStack
|
2021-07-29 17:58:05 +00:00
|
|
|
vw_cmd$ = "error:" + MKL$(vw_lastLine)
|
2021-07-22 21:39:20 +00:00
|
|
|
GOSUB SendCommand
|
|
|
|
EXIT SUB
|
|
|
|
ELSEIF vwatch_linenumber = -2 THEN
|
|
|
|
'report a new sub/function has been "entered"
|
2021-07-27 15:18:50 +00:00
|
|
|
IF vwatch_sublevel > UBOUND(vwatch_stack) THEN
|
|
|
|
REDIM _PRESERVE vwatch_stack(UBOUND(vwatch_stack) + 1000) AS STRING
|
|
|
|
END IF
|
2021-07-29 17:58:05 +00:00
|
|
|
vwatch_stack(vwatch_sublevel) = vwatch_internalsubname$ + "," + vwatch_subname$ + ", line" + STR$(vw_lastLine)
|
2021-07-22 21:39:20 +00:00
|
|
|
EXIT SUB
|
|
|
|
ELSEIF vwatch_linenumber = -3 THEN
|
|
|
|
'handle STOP - instead of quitting, pause execution
|
2021-07-29 17:58:05 +00:00
|
|
|
vw_pauseMode = -1
|
|
|
|
vw_stepOver = 0
|
2021-07-22 21:39:20 +00:00
|
|
|
EXIT SUB
|
2021-08-15 00:28:21 +00:00
|
|
|
ELSEIF vwatch_linenumber = -4 THEN
|
|
|
|
'handle INPUT/LINE INPUT - tell the IDE we'll be hanging for a while
|
|
|
|
vw_cmd$ = "enter input:" + MKL$(vw_lastLine)
|
|
|
|
GOSUB SendCommand
|
|
|
|
ELSEIF vwatch_linenumber = -5 THEN
|
|
|
|
'handle end of INPUT/LINE INPUT - tell the IDE we're moving on
|
|
|
|
vw_cmd$ = "leave input"
|
|
|
|
GOSUB SendCommand
|
2021-07-22 21:39:20 +00:00
|
|
|
END IF
|
|
|
|
|
2021-07-29 17:58:05 +00:00
|
|
|
IF vwatch_linenumber = vw_lastLine AND vw_setNextLine = 0 THEN EXIT SUB
|
|
|
|
vw_setNextLine = 0
|
|
|
|
vw_lastLine = vwatch_linenumber
|
2021-07-22 21:39:20 +00:00
|
|
|
|
|
|
|
GOSUB GetCommand
|
2021-07-29 17:58:05 +00:00
|
|
|
SELECT CASE vw_cmd$
|
2021-07-22 21:39:20 +00:00
|
|
|
CASE "break"
|
2021-07-29 17:58:05 +00:00
|
|
|
vw_pauseMode = -1
|
|
|
|
vw_stepOver = 0
|
|
|
|
vw_runToLine = 0
|
|
|
|
vw_cmd$ = ""
|
2021-07-22 21:39:20 +00:00
|
|
|
CASE "set breakpoint"
|
2021-07-29 17:58:05 +00:00
|
|
|
vwatch_breakpoints(CVL(vw_value$)) = -1
|
|
|
|
vwatch_skiplines(CVL(vw_value$)) = 0
|
2021-07-22 21:39:20 +00:00
|
|
|
CASE "clear breakpoint"
|
2021-07-29 17:58:05 +00:00
|
|
|
vwatch_breakpoints(CVL(vw_value$)) = 0
|
2021-07-22 21:39:20 +00:00
|
|
|
CASE "set skip line"
|
2021-07-29 17:58:05 +00:00
|
|
|
vwatch_skiplines(CVL(vw_value$)) = -1
|
|
|
|
vwatch_breakpoints(CVL(vw_value$)) = 0
|
2021-07-22 21:39:20 +00:00
|
|
|
CASE "clear skip line"
|
2021-07-29 17:58:05 +00:00
|
|
|
vwatch_skiplines(CVL(vw_value$)) = 0
|
2021-07-22 21:39:20 +00:00
|
|
|
CASE "clear all breakpoints"
|
|
|
|
REDIM vwatch_breakpoints(UBOUND(vwatch_breakpoints)) AS _BYTE
|
|
|
|
CASE "clear all skips"
|
|
|
|
REDIM vwatch_skiplines(UBOUND(vwatch_skiplines)) AS _BYTE
|
|
|
|
END SELECT
|
|
|
|
|
|
|
|
IF vwatch_skiplines(vwatch_linenumber) THEN vwatch_goto = -vwatch_linenumber: EXIT SUB
|
|
|
|
|
2021-07-29 17:58:05 +00:00
|
|
|
IF vw_stepOver = -1 AND vwatch_sublevel > vw_startLevel AND vwatch_breakpoints(vwatch_linenumber) = 0 THEN
|
2021-07-22 21:39:20 +00:00
|
|
|
EXIT SUB
|
2021-07-29 17:58:05 +00:00
|
|
|
ELSEIF vw_stepOver = -1 AND vwatch_sublevel = vw_startLevel THEN
|
|
|
|
vw_stepOver = 0
|
|
|
|
vw_pauseMode = -1
|
2021-07-22 21:39:20 +00:00
|
|
|
END IF
|
|
|
|
|
2021-07-29 17:58:05 +00:00
|
|
|
IF vw_runToLine > 0 AND vw_runToLine <> vwatch_linenumber THEN
|
2021-07-22 21:39:20 +00:00
|
|
|
EXIT SUB
|
2021-07-29 17:58:05 +00:00
|
|
|
ELSEIF vw_runToLine > 0 AND vw_runToLine = vwatch_linenumber THEN
|
|
|
|
vw_pauseMode = -1
|
|
|
|
vw_runToLine = 0
|
2021-07-22 21:39:20 +00:00
|
|
|
END IF
|
|
|
|
|
2021-07-29 17:58:05 +00:00
|
|
|
IF vwatch_breakpoints(vwatch_linenumber) = 0 AND vw_pauseMode = 0 THEN
|
2021-07-22 21:39:20 +00:00
|
|
|
EXIT SUB
|
|
|
|
END IF
|
|
|
|
|
|
|
|
vwatch_stoptimers
|
2021-07-29 17:58:05 +00:00
|
|
|
vw_cmd$ = "line number:"
|
|
|
|
IF vwatch_breakpoints(vwatch_linenumber) THEN vw_cmd$ = "breakpoint:"
|
|
|
|
vw_cmd$ = vw_cmd$ + MKL$(vwatch_linenumber)
|
2021-07-22 21:39:20 +00:00
|
|
|
GOSUB SendCommand
|
2021-07-29 17:58:05 +00:00
|
|
|
vw_cmd$ = "current sub:" + LEFT$(vwatch_stack(vwatch_sublevel), INSTR(vwatch_stack(vwatch_sublevel), ",") - 1)
|
2021-07-27 02:56:48 +00:00
|
|
|
GOSUB SendCommand
|
2021-07-22 21:39:20 +00:00
|
|
|
|
2021-08-15 03:49:06 +00:00
|
|
|
$IF WIN THEN
|
|
|
|
vw_i = SetForegroundWindow&(vw_idehwnd)
|
|
|
|
$END IF
|
2021-08-13 02:00:43 +00:00
|
|
|
|
2021-07-22 21:39:20 +00:00
|
|
|
DO 'main loop
|
2021-08-05 00:23:59 +00:00
|
|
|
IF stop_program_state& THEN vw_bypass = -1: EXIT DO
|
2021-07-29 17:58:05 +00:00
|
|
|
SELECT CASE vw_cmd$
|
2021-07-22 21:39:20 +00:00
|
|
|
CASE "run"
|
2021-07-29 17:58:05 +00:00
|
|
|
vw_pauseMode = 0
|
|
|
|
vw_stepOver = 0
|
2021-07-22 21:39:20 +00:00
|
|
|
vwatch_starttimers
|
|
|
|
EXIT SUB
|
|
|
|
CASE "run to line"
|
2021-07-29 17:58:05 +00:00
|
|
|
vw_pauseMode = 0
|
|
|
|
vw_stepOver = 0
|
|
|
|
vw_runToLine = CVL(vw_value$)
|
2021-07-22 21:39:20 +00:00
|
|
|
vwatch_starttimers
|
|
|
|
EXIT SUB
|
|
|
|
CASE "step"
|
2021-07-29 17:58:05 +00:00
|
|
|
vw_pauseMode = -1
|
|
|
|
vw_stepOver = 0
|
2021-07-22 21:39:20 +00:00
|
|
|
EXIT SUB
|
|
|
|
CASE "step over"
|
2021-07-29 17:58:05 +00:00
|
|
|
vw_pauseMode = -1
|
|
|
|
vw_stepOver = -1
|
|
|
|
vw_startLevel = vwatch_sublevel
|
2021-07-22 21:39:20 +00:00
|
|
|
vwatch_starttimers
|
|
|
|
EXIT SUB
|
|
|
|
CASE "step out"
|
2021-07-29 17:58:05 +00:00
|
|
|
vw_pauseMode = -1
|
|
|
|
vw_stepOver = -1
|
|
|
|
vw_startLevel = vwatch_sublevel - 1
|
2021-07-22 21:39:20 +00:00
|
|
|
vwatch_starttimers
|
|
|
|
EXIT SUB
|
|
|
|
CASE "free"
|
2021-07-29 17:58:05 +00:00
|
|
|
unlockvWatchHandle: CLOSE #vw_ideHost
|
|
|
|
vw_ideHost = 0
|
|
|
|
vw_bypass = -1
|
2021-07-22 21:39:20 +00:00
|
|
|
vwatch_starttimers
|
|
|
|
EXIT SUB
|
|
|
|
CASE "set breakpoint"
|
2021-07-29 17:58:05 +00:00
|
|
|
vwatch_breakpoints(CVL(vw_value$)) = -1
|
|
|
|
vwatch_skiplines(CVL(vw_value$)) = 0
|
2021-07-22 21:39:20 +00:00
|
|
|
CASE "clear breakpoint"
|
2021-07-29 17:58:05 +00:00
|
|
|
vwatch_breakpoints(CVL(vw_value$)) = 0
|
2021-07-22 21:39:20 +00:00
|
|
|
CASE "clear all breakpoints"
|
|
|
|
REDIM vwatch_breakpoints(UBOUND(vwatch_breakpoints)) AS _BYTE
|
|
|
|
CASE "clear all skips"
|
|
|
|
REDIM vwatch_skiplines(UBOUND(vwatch_skiplines)) AS _BYTE
|
|
|
|
CASE "call stack"
|
2021-07-27 07:09:28 +00:00
|
|
|
'send call stack history
|
2021-07-22 21:39:20 +00:00
|
|
|
GOSUB SendCallStack
|
2021-08-03 03:47:37 +00:00
|
|
|
CASE "global var", "local var"
|
2021-07-29 17:58:05 +00:00
|
|
|
vw_tempIndex = CVL(LEFT$(vw_value$, 4))
|
|
|
|
vw_localIndex = CVL(MID$(vw_value$, 5, 4))
|
2021-08-03 03:47:37 +00:00
|
|
|
vw_scope$ = MID$(vw_value$, 9)
|
|
|
|
IF vw_cmd$ = "global var" THEN
|
|
|
|
vw_address = _OFFSET(globalVariables) + LEN(vw_address) * vw_localIndex
|
|
|
|
ELSE
|
|
|
|
IF vw_scope$ = LEFT$(vwatch_stack(vwatch_sublevel), INSTR(vwatch_stack(vwatch_sublevel), ",") - 1) THEN
|
|
|
|
vw_address = _OFFSET(localVariables) + LEN(vw_address) * vw_localIndex
|
|
|
|
ELSE
|
|
|
|
GOTO cmdProcessingDone
|
|
|
|
END IF
|
|
|
|
END IF
|
2021-07-29 17:58:05 +00:00
|
|
|
vw_address = _MEMGET(vw_m, vw_address, _OFFSET) 'first resolve pass
|
|
|
|
vw_address = _MEMGET(vw_m, vw_address, _OFFSET) 'second resolve pass
|
2021-08-03 03:47:37 +00:00
|
|
|
vw_cmd$ = vw_cmd$ + ":" + MKL$(vw_tempIndex) + _MK$(_OFFSET, vw_address)
|
2021-07-26 17:52:14 +00:00
|
|
|
GOSUB SendCommand
|
2021-07-27 11:52:13 +00:00
|
|
|
CASE "get address"
|
2021-07-29 17:58:05 +00:00
|
|
|
vw_tempIndex = CVL(LEFT$(vw_value$, 4))
|
|
|
|
vw_sequence = CVI(MID$(vw_value$, 5, 2))
|
|
|
|
vw_varSize = CVL(MID$(vw_value$, 7, 4))
|
2021-07-30 22:46:13 +00:00
|
|
|
vw_address = _CV(_OFFSET, MID$(vw_value$, 11, LEN(vw_address)))
|
2021-07-29 17:58:05 +00:00
|
|
|
vw_buf$ = SPACE$(vw_varSize)
|
|
|
|
vw_m = _MEM(vw_address, vw_varSize)
|
|
|
|
vw_m2 = _MEM(_OFFSET(vw_buf$), vw_varSize)
|
|
|
|
_MEMCOPY vw_m, vw_m.OFFSET, vw_m.SIZE TO vw_m2, vw_m2.OFFSET
|
|
|
|
vw_cmd$ = "address read:" + MKL$(vw_tempIndex) + MKI$(vw_sequence) + vw_buf$
|
2021-07-27 09:52:13 +00:00
|
|
|
GOSUB SendCommand
|
2021-08-03 07:08:58 +00:00
|
|
|
CASE "set global address", "set local address"
|
|
|
|
vw_localIndex = CVL(LEFT$(vw_value$, 4))
|
|
|
|
vw_varSize = CVL(MID$(vw_value$, 5, 4))
|
|
|
|
vw_value$ = RIGHT$(vw_value$, vw_varSize)
|
|
|
|
IF vw_cmd$ = "set global address" THEN
|
|
|
|
vw_address = _OFFSET(globalVariables) + LEN(vw_address) * vw_localIndex
|
|
|
|
ELSE
|
|
|
|
vw_address = _OFFSET(localVariables) + LEN(vw_address) * vw_localIndex
|
|
|
|
END IF
|
|
|
|
vw_address = _MEMGET(vw_m, vw_address, _OFFSET) 'first resolve pass
|
|
|
|
vw_address = _MEMGET(vw_m, vw_address, _OFFSET) 'second resolve pass
|
|
|
|
|
|
|
|
'vw_address now points to the actual data
|
2021-07-30 15:11:19 +00:00
|
|
|
vw_m = _MEM(vw_address, vw_varSize)
|
2021-08-03 07:08:58 +00:00
|
|
|
_MEMPUT vw_m, vw_m.OFFSET, vw_value$
|
2021-08-03 03:36:21 +00:00
|
|
|
CASE "set global string", "set local string"
|
|
|
|
vw_localIndex = CVL(LEFT$(vw_value$, 4))
|
|
|
|
vw_varSize = CVL(MID$(vw_value$, 5, 4))
|
|
|
|
vw_value$ = RIGHT$(vw_value$, vw_varSize)
|
|
|
|
IF vw_cmd$ = "set global string" THEN
|
|
|
|
vw_address = _OFFSET(globalVariables) + LEN(vw_address) * vw_localIndex
|
|
|
|
ELSE
|
|
|
|
vw_address = _OFFSET(localVariables) + LEN(vw_address) * vw_localIndex
|
|
|
|
END IF
|
|
|
|
vw_address = _MEMGET(vw_m, vw_address, _OFFSET) 'first resolve pass
|
|
|
|
vw_address = _MEMGET(vw_m, vw_address, _OFFSET) 'second resolve pass
|
|
|
|
|
|
|
|
'vw_address now points to the qbs struct
|
|
|
|
set_qbs_size vw_address, vw_varSize
|
|
|
|
|
|
|
|
vw_varSize = LEN(vw_address) + LEN(vw_varSize)
|
|
|
|
vw_buf$ = SPACE$(vw_varSize)
|
|
|
|
vw_m = _MEM(vw_address, vw_varSize)
|
|
|
|
vw_m2 = _MEM(_OFFSET(vw_buf$), vw_varSize)
|
|
|
|
_MEMCOPY vw_m, vw_m.OFFSET, vw_m.SIZE TO vw_m2, vw_m2.OFFSET
|
|
|
|
|
|
|
|
vw_address = _CV(_OFFSET, LEFT$(vw_buf$, LEN(vw_address))) 'pointer to actual data
|
|
|
|
vw_varSize = CVL(MID$(vw_buf$, LEN(vw_address) + 1))
|
2021-08-03 18:14:18 +00:00
|
|
|
IF vw_varSize < LEN(vw_value$) THEN
|
|
|
|
vw_value$ = LEFT$(vw_value$, vw_varSize)
|
2021-08-03 03:36:21 +00:00
|
|
|
END IF
|
2021-08-03 18:14:18 +00:00
|
|
|
vw_m = _MEM(vw_address, vw_varSize)
|
|
|
|
_MEMPUT vw_m, vw_m.OFFSET, vw_value$
|
2021-07-24 22:31:58 +00:00
|
|
|
CASE "current sub"
|
2021-07-29 17:58:05 +00:00
|
|
|
vw_cmd$ = "current sub:" + LEFT$(vwatch_stack(vwatch_sublevel), INSTR(vwatch_stack(vwatch_sublevel), ",") - 1)
|
2021-07-24 22:31:58 +00:00
|
|
|
GOSUB SendCommand
|
2021-07-22 21:39:20 +00:00
|
|
|
CASE "set next line"
|
2021-07-29 17:58:05 +00:00
|
|
|
vw_pauseMode = -1
|
|
|
|
vw_stepOver = 0
|
|
|
|
vw_setNextLine = -1
|
|
|
|
vwatch_goto = CVL(vw_value$)
|
2021-07-22 21:39:20 +00:00
|
|
|
EXIT SUB
|
|
|
|
CASE "set skip line"
|
2021-07-29 17:58:05 +00:00
|
|
|
vwatch_skiplines(CVL(vw_value$)) = -1
|
|
|
|
vwatch_breakpoints(CVL(vw_value$)) = 0
|
2021-07-22 21:39:20 +00:00
|
|
|
CASE "clear skip line"
|
2021-07-29 17:58:05 +00:00
|
|
|
vwatch_skiplines(CVL(vw_value$)) = 0
|
2021-07-22 21:39:20 +00:00
|
|
|
END SELECT
|
|
|
|
|
2021-08-03 03:47:37 +00:00
|
|
|
cmdProcessingDone:
|
2021-07-22 21:39:20 +00:00
|
|
|
GOSUB GetCommand
|
|
|
|
_LIMIT 100
|
|
|
|
LOOP
|
|
|
|
|
|
|
|
vwatch_starttimers
|
|
|
|
EXIT SUB
|
|
|
|
|
|
|
|
Connect:
|
2021-07-29 17:58:05 +00:00
|
|
|
DIM vw_ideport$
|
|
|
|
vw_ideport$ = ENVIRON$("QB64DEBUGPORT")
|
|
|
|
IF vw_ideport$ = "" THEN vw_bypass = -1: EXIT SUB
|
2021-07-22 21:39:20 +00:00
|
|
|
|
2021-07-29 17:58:05 +00:00
|
|
|
vw_start! = TIMER
|
2021-07-22 21:39:20 +00:00
|
|
|
DO
|
2021-07-29 17:58:05 +00:00
|
|
|
vw_k& = _KEYHIT
|
|
|
|
vw_ideHost = _OPENCLIENT("QB64IDE:" + vw_ideport$ + ":localhost")
|
2021-07-22 21:39:20 +00:00
|
|
|
_LIMIT 30
|
2021-07-29 17:58:05 +00:00
|
|
|
LOOP UNTIL vw_k& = 27 OR vw_ideHost <> 0 OR TIMER - vw_start! > vw_timeout
|
|
|
|
IF vw_ideHost = 0 THEN vw_bypass = -1: EXIT SUB
|
2021-07-22 21:39:20 +00:00
|
|
|
RETURN
|
|
|
|
|
|
|
|
GetCommand:
|
2021-07-29 17:58:05 +00:00
|
|
|
GET #vw_ideHost, , vw_temp$
|
|
|
|
vw_buffer$ = vw_buffer$ + vw_temp$
|
2021-07-22 21:39:20 +00:00
|
|
|
|
2021-07-29 17:58:05 +00:00
|
|
|
IF INSTR(vw_buffer$, vw_endc$) THEN
|
|
|
|
vw_cmd$ = LEFT$(vw_buffer$, INSTR(vw_buffer$, vw_endc$) - 1)
|
|
|
|
vw_buffer$ = MID$(vw_buffer$, INSTR(vw_buffer$, vw_endc$) + LEN(vw_endc$))
|
2021-07-22 21:39:20 +00:00
|
|
|
|
2021-07-29 17:58:05 +00:00
|
|
|
IF INSTR(vw_cmd$, ":") THEN
|
|
|
|
vw_value$ = MID$(vw_cmd$, INSTR(vw_cmd$, ":") + 1)
|
|
|
|
vw_cmd$ = LEFT$(vw_cmd$, INSTR(vw_cmd$, ":") - 1)
|
2021-07-22 21:39:20 +00:00
|
|
|
ELSE
|
2021-07-29 17:58:05 +00:00
|
|
|
vw_value$ = ""
|
2021-07-22 21:39:20 +00:00
|
|
|
END IF
|
|
|
|
ELSE
|
2021-07-29 17:58:05 +00:00
|
|
|
vw_cmd$ = "": vw_value$ = ""
|
2021-07-22 21:39:20 +00:00
|
|
|
END IF
|
|
|
|
RETURN
|
|
|
|
|
|
|
|
SendCallStack:
|
2021-07-29 15:07:12 +00:00
|
|
|
IF vwatch_sublevel - 1 > 0 THEN
|
|
|
|
vwatch_callstack = MID$(vwatch_stack(2), INSTR(vwatch_stack(2), ",") + 1)
|
2021-07-29 17:58:05 +00:00
|
|
|
FOR vw_i = 3 TO vwatch_sublevel
|
|
|
|
vwatch_callstack = vwatch_callstack + CHR$(0) + MID$(vwatch_stack(vw_i), INSTR(vwatch_stack(vw_i), ",") + 1)
|
2021-07-29 15:07:12 +00:00
|
|
|
NEXT
|
|
|
|
ELSE
|
|
|
|
vwatch_callstack = ""
|
|
|
|
END IF
|
2021-07-29 17:58:05 +00:00
|
|
|
vw_cmd$ = "call stack size:" + MKL$(vwatch_sublevel - 1)
|
2021-07-22 21:39:20 +00:00
|
|
|
GOSUB SendCommand
|
2021-07-29 17:58:05 +00:00
|
|
|
vw_cmd$ = "call stack:" + vwatch_callstack
|
2021-07-22 21:39:20 +00:00
|
|
|
GOSUB SendCommand
|
|
|
|
RETURN
|
|
|
|
|
|
|
|
SendCommand:
|
2021-07-29 17:58:05 +00:00
|
|
|
vw_cmd$ = vw_cmd$ + vw_endc$
|
|
|
|
PUT #vw_ideHost, , vw_cmd$
|
|
|
|
vw_cmd$ = ""
|
2021-07-22 21:39:20 +00:00
|
|
|
RETURN
|
2021-07-26 17:52:14 +00:00
|
|
|
|
2021-07-22 21:39:20 +00:00
|
|
|
END SUB
|