[1] | 1 | 'debug.sbp
|
---|
| 2 | 'このファイル内のコードはデバッグ コンパイル時のみ有効です(リリース コンパイルでは無視されます)。
|
---|
| 3 |
|
---|
| 4 | 'Dim _DebugSys_dwThreadID[255] As DWord - コンパイラが自動的に定義します
|
---|
| 5 | 'Dim _DebugSys_ProcNum[255] As DWord - コンパイラが自動的に定義します
|
---|
| 6 | 'Dim _DebugSys_lplpObp[255] As *ULONG_PTR - コンパイラが自動的に定義します
|
---|
| 7 | 'Dim _DebugSys_lplpSpBase[255] As *ULONG_PTR - コンパイラが自動的に定義します
|
---|
| 8 |
|
---|
| 9 | Function _DebugSys_GetThread() As Long
|
---|
| 10 | Dim dwThreadID As DWord
|
---|
| 11 | Dim ThreadNum As Long
|
---|
| 12 |
|
---|
| 13 | dwThreadID=GetCurrentThreadId()
|
---|
| 14 | ThreadNum=0
|
---|
| 15 | Do
|
---|
| 16 | If dwThreadID=_DebugSys_dwThreadID[ThreadNum] Then Exit Do
|
---|
| 17 | ThreadNum=ThreadNum+1
|
---|
| 18 | If ThreadNum>255 Then
|
---|
| 19 | ThreadNum=-1
|
---|
| 20 | Exit Do
|
---|
| 21 |
|
---|
| 22 | /*debug
|
---|
| 23 | OutputDebugString(Ex"[GetThread]デバッグ情報が異常です。プロセスを終了します。\r\n")
|
---|
| 24 | ExitProcess(0)*/
|
---|
| 25 | End If
|
---|
| 26 | Loop
|
---|
| 27 |
|
---|
| 28 | _DebugSys_GetThread=ThreadNum
|
---|
| 29 | End Function
|
---|
| 30 |
|
---|
| 31 | Sub _DebugSys_Set_LONG_PTR(pPtr As VoidPtr, lpData As LONG_PTR)
|
---|
| 32 | #ifdef _WIN64
|
---|
| 33 | SetQWord(pPtr,lpData)
|
---|
| 34 | #else
|
---|
| 35 | SetDWord(pPtr,lpData)
|
---|
| 36 | #endif
|
---|
| 37 | End Sub
|
---|
| 38 |
|
---|
| 39 | Sub _DebugSys_StartProc(lpSpBase As ULONG_PTR, lpObp As ULONG_PTR)
|
---|
| 40 | Dim i As Long
|
---|
| 41 |
|
---|
| 42 | Dim ThreadNum As Long
|
---|
| 43 | ThreadNum=_DebugSys_GetThread()
|
---|
| 44 | If ThreadNum=-1 Then Exit Sub
|
---|
| 45 |
|
---|
| 46 | If _DebugSys_lplpObp[ThreadNum] Then
|
---|
| 47 | i=(_DebugSys_ProcNum[ThreadNum]+2)*SizeOf(ULONG_PTR)
|
---|
| 48 | _DebugSys_lplpObp[ThreadNum]=HeapReAlloc(GetProcessHeap(),0,_DebugSys_lplpObp[ThreadNum],i)
|
---|
| 49 | _DebugSys_lplpSpBase[ThreadNum]=HeapReAlloc(GetProcessHeap(),0,_DebugSys_lplpSpBase[ThreadNum],i)
|
---|
| 50 | Else
|
---|
| 51 | _DebugSys_ProcNum[ThreadNum]=0
|
---|
| 52 | _DebugSys_lplpObp[ThreadNum]=HeapAlloc(GetProcessHeap(),0,SizeOf(ULONG_PTR)*2)
|
---|
| 53 | _DebugSys_lplpSpBase[ThreadNum]=HeapAlloc(GetProcessHeap(),0,SizeOf(ULONG_PTR)*2)
|
---|
| 54 | End If
|
---|
| 55 | _DebugSys_Set_LONG_PTR(_DebugSys_lplpObp[ThreadNum]+_DebugSys_ProcNum[ThreadNum]*SizeOf(ULONG_PTR),lpObp)
|
---|
| 56 | _DebugSys_Set_LONG_PTR(_DebugSys_lplpSpBase[ThreadNum]+_DebugSys_ProcNum[ThreadNum]*SizeOf(ULONG_PTR),lpSpBase)
|
---|
| 57 |
|
---|
| 58 | _DebugSys_ProcNum[ThreadNum]=_DebugSys_ProcNum[ThreadNum]+1
|
---|
| 59 | End Sub
|
---|
| 60 |
|
---|
| 61 | Sub _DebugSys_EndProc()
|
---|
| 62 | Dim ThreadNum As Long
|
---|
| 63 | ThreadNum=_DebugSys_GetThread()
|
---|
| 64 | If ThreadNum=-1 Then Exit Sub
|
---|
| 65 |
|
---|
| 66 | _DebugSys_ProcNum[ThreadNum]=_DebugSys_ProcNum[ThreadNum]-1
|
---|
| 67 | End Sub
|
---|
| 68 |
|
---|
| 69 | Sub _DebugSys_SaveContext(lpSpBase As ULONG_PTR, lpObp As ULONG_PTR)
|
---|
| 70 | Dim ThreadNum As Long
|
---|
| 71 | ThreadNum=_DebugSys_GetThread()
|
---|
| 72 | If ThreadNum=-1 Then Exit Sub
|
---|
| 73 |
|
---|
| 74 | If _DebugSys_lplpObp[ThreadNum]=0 Then
|
---|
| 75 | _DebugSys_ProcNum[ThreadNum]=0
|
---|
| 76 | _DebugSys_lplpObp[ThreadNum]=HeapAlloc(GetProcessHeap(),0,SizeOf(ULONG_PTR)*2)
|
---|
| 77 | _DebugSys_lplpSpBase[ThreadNum]=HeapAlloc(GetProcessHeap(),0,SizeOf(ULONG_PTR)*2)
|
---|
| 78 | End If
|
---|
| 79 | _DebugSys_Set_LONG_PTR(_DebugSys_lplpObp[ThreadNum]+_DebugSys_ProcNum[ThreadNum]*SizeOf(ULONG_PTR), lpObp)
|
---|
| 80 | _DebugSys_Set_LONG_PTR(_DebugSys_lplpSpBase[ThreadNum]+_DebugSys_ProcNum[ThreadNum]*SizeOf(ULONG_PTR), lpSpBase)
|
---|
| 81 | End Sub
|
---|
[140] | 82 |
|
---|
| 83 | Sub _esp_error()
|
---|
| 84 | MessageBox( NULL, "esp is wrong value.", "debug check error", MB_OK or MB_ICONEXCLAMATION )
|
---|
| 85 | End Sub
|
---|