Mercurial > vim
annotate src/testdir/test_debugger.vim @ 22713:e871a824efc9 v8.2.1905
patch 8.2.1905: the wininfo list may contain stale entries
Commit: https://github.com/vim/vim/commit/4882d983397057ea91c584c5a54aaccf15016d18
Author: Bram Moolenaar <Bram@vim.org>
Date: Sun Oct 25 17:55:09 2020 +0100
patch 8.2.1905: the wininfo list may contain stale entries
Problem: The wininfo list may contain stale entries.
Solution: When closing a window remove any other entry where the window
pointer is NULL.
author | Bram Moolenaar <Bram@vim.org> |
---|---|
date | Sun, 25 Oct 2020 18:00:04 +0100 |
parents | 4086a1708c83 |
children | dcb59b1cc0c1 |
rev | line source |
---|---|
16350
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
1 " Tests for the Vim script debug commands |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
2 |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
3 source shared.vim |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
4 source screendump.vim |
17657
0da9bc55c31a
patch 8.1.1826: tests use hand coded feature and option checks
Bram Moolenaar <Bram@vim.org>
parents:
17172
diff
changeset
|
5 source check.vim |
16350
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
6 |
21687
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
7 CheckRunVimInTerminal |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
8 |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
9 func CheckCWD() |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
10 " Check that the longer lines don't wrap due to the length of the script name |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
11 " in cwd |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
12 let script_len = len( getcwd() .. '/Xtest1.vim' ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
13 let longest_line = len( 'Breakpoint in "" line 1' ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
14 if script_len > ( 75 - longest_line ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
15 throw 'Skipped: Your CWD has too many characters' |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
16 endif |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
17 endfunc |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
18 command! -nargs=0 -bar CheckCWD call CheckCWD() |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
19 |
21508
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
20 func CheckDbgOutput(buf, lines, options = {}) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
21 " Verify the expected output |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
22 let lnum = 20 - len(a:lines) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
23 for l in a:lines |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
24 if get(a:options, 'match', 'equal') ==# 'pattern' |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
25 call WaitForAssert({-> assert_match(l, term_getline(a:buf, lnum))}, 200) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
26 else |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
27 call WaitForAssert({-> assert_equal(l, term_getline(a:buf, lnum))}, 200) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
28 endif |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
29 let lnum += 1 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
30 endfor |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
31 endfunc |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
32 |
16350
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
33 " Run a Vim debugger command |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
34 " If the expected output argument is supplied, then check for it. |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
35 func RunDbgCmd(buf, cmd, ...) |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
36 call term_sendkeys(a:buf, a:cmd . "\r") |
19954
c087099e9163
patch 8.2.0533: tests using term_wait() can still be flaky
Bram Moolenaar <Bram@vim.org>
parents:
19651
diff
changeset
|
37 call TermWait(a:buf) |
16350
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
38 |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
39 if a:0 != 0 |
21508
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
40 let options = #{match: 'equal'} |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
41 if a:0 > 1 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
42 call extend(options, a:2) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
43 endif |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
44 call CheckDbgOutput(a:buf, a:1, options) |
16350
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
45 endif |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
46 endfunc |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
47 |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
48 " Debugger tests |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
49 func Test_Debugger() |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
50 " Create a Vim script with some functions |
17172
6990c1160ea5
patch 8.1.1585: :let-heredoc does not trim enough
Bram Moolenaar <Bram@vim.org>
parents:
16965
diff
changeset
|
51 let lines =<< trim END |
6990c1160ea5
patch 8.1.1585: :let-heredoc does not trim enough
Bram Moolenaar <Bram@vim.org>
parents:
16965
diff
changeset
|
52 func Foo() |
6990c1160ea5
patch 8.1.1585: :let-heredoc does not trim enough
Bram Moolenaar <Bram@vim.org>
parents:
16965
diff
changeset
|
53 let var1 = 1 |
6990c1160ea5
patch 8.1.1585: :let-heredoc does not trim enough
Bram Moolenaar <Bram@vim.org>
parents:
16965
diff
changeset
|
54 let var2 = Bar(var1) + 9 |
6990c1160ea5
patch 8.1.1585: :let-heredoc does not trim enough
Bram Moolenaar <Bram@vim.org>
parents:
16965
diff
changeset
|
55 return var2 |
6990c1160ea5
patch 8.1.1585: :let-heredoc does not trim enough
Bram Moolenaar <Bram@vim.org>
parents:
16965
diff
changeset
|
56 endfunc |
6990c1160ea5
patch 8.1.1585: :let-heredoc does not trim enough
Bram Moolenaar <Bram@vim.org>
parents:
16965
diff
changeset
|
57 func Bar(var) |
6990c1160ea5
patch 8.1.1585: :let-heredoc does not trim enough
Bram Moolenaar <Bram@vim.org>
parents:
16965
diff
changeset
|
58 let var1 = 2 + a:var |
6990c1160ea5
patch 8.1.1585: :let-heredoc does not trim enough
Bram Moolenaar <Bram@vim.org>
parents:
16965
diff
changeset
|
59 let var2 = Bazz(var1) + 4 |
6990c1160ea5
patch 8.1.1585: :let-heredoc does not trim enough
Bram Moolenaar <Bram@vim.org>
parents:
16965
diff
changeset
|
60 return var2 |
6990c1160ea5
patch 8.1.1585: :let-heredoc does not trim enough
Bram Moolenaar <Bram@vim.org>
parents:
16965
diff
changeset
|
61 endfunc |
6990c1160ea5
patch 8.1.1585: :let-heredoc does not trim enough
Bram Moolenaar <Bram@vim.org>
parents:
16965
diff
changeset
|
62 func Bazz(var) |
6990c1160ea5
patch 8.1.1585: :let-heredoc does not trim enough
Bram Moolenaar <Bram@vim.org>
parents:
16965
diff
changeset
|
63 try |
6990c1160ea5
patch 8.1.1585: :let-heredoc does not trim enough
Bram Moolenaar <Bram@vim.org>
parents:
16965
diff
changeset
|
64 let var1 = 3 + a:var |
6990c1160ea5
patch 8.1.1585: :let-heredoc does not trim enough
Bram Moolenaar <Bram@vim.org>
parents:
16965
diff
changeset
|
65 let var3 = "another var" |
6990c1160ea5
patch 8.1.1585: :let-heredoc does not trim enough
Bram Moolenaar <Bram@vim.org>
parents:
16965
diff
changeset
|
66 let var3 = "value2" |
6990c1160ea5
patch 8.1.1585: :let-heredoc does not trim enough
Bram Moolenaar <Bram@vim.org>
parents:
16965
diff
changeset
|
67 catch |
6990c1160ea5
patch 8.1.1585: :let-heredoc does not trim enough
Bram Moolenaar <Bram@vim.org>
parents:
16965
diff
changeset
|
68 let var4 = "exception" |
6990c1160ea5
patch 8.1.1585: :let-heredoc does not trim enough
Bram Moolenaar <Bram@vim.org>
parents:
16965
diff
changeset
|
69 endtry |
6990c1160ea5
patch 8.1.1585: :let-heredoc does not trim enough
Bram Moolenaar <Bram@vim.org>
parents:
16965
diff
changeset
|
70 return var1 |
6990c1160ea5
patch 8.1.1585: :let-heredoc does not trim enough
Bram Moolenaar <Bram@vim.org>
parents:
16965
diff
changeset
|
71 endfunc |
6990c1160ea5
patch 8.1.1585: :let-heredoc does not trim enough
Bram Moolenaar <Bram@vim.org>
parents:
16965
diff
changeset
|
72 END |
6990c1160ea5
patch 8.1.1585: :let-heredoc does not trim enough
Bram Moolenaar <Bram@vim.org>
parents:
16965
diff
changeset
|
73 call writefile(lines, 'Xtest.vim') |
16350
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
74 |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
75 " Start Vim in a terminal |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
76 let buf = RunVimInTerminal('-S Xtest.vim', {}) |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
77 |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
78 " Start the Vim debugger |
16920
8d91579414b8
patch 8.1.1461: tests do not run or are not reliable on some systems
Bram Moolenaar <Bram@vim.org>
parents:
16372
diff
changeset
|
79 call RunDbgCmd(buf, ':debug echo Foo()', ['cmd: echo Foo()']) |
16350
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
80 |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
81 " Create a few stack frames by stepping through functions |
16920
8d91579414b8
patch 8.1.1461: tests do not run or are not reliable on some systems
Bram Moolenaar <Bram@vim.org>
parents:
16372
diff
changeset
|
82 call RunDbgCmd(buf, 'step', ['line 1: let var1 = 1']) |
8d91579414b8
patch 8.1.1461: tests do not run or are not reliable on some systems
Bram Moolenaar <Bram@vim.org>
parents:
16372
diff
changeset
|
83 call RunDbgCmd(buf, 'step', ['line 2: let var2 = Bar(var1) + 9']) |
8d91579414b8
patch 8.1.1461: tests do not run or are not reliable on some systems
Bram Moolenaar <Bram@vim.org>
parents:
16372
diff
changeset
|
84 call RunDbgCmd(buf, 'step', ['line 1: let var1 = 2 + a:var']) |
8d91579414b8
patch 8.1.1461: tests do not run or are not reliable on some systems
Bram Moolenaar <Bram@vim.org>
parents:
16372
diff
changeset
|
85 call RunDbgCmd(buf, 'step', ['line 2: let var2 = Bazz(var1) + 4']) |
8d91579414b8
patch 8.1.1461: tests do not run or are not reliable on some systems
Bram Moolenaar <Bram@vim.org>
parents:
16372
diff
changeset
|
86 call RunDbgCmd(buf, 'step', ['line 1: try']) |
8d91579414b8
patch 8.1.1461: tests do not run or are not reliable on some systems
Bram Moolenaar <Bram@vim.org>
parents:
16372
diff
changeset
|
87 call RunDbgCmd(buf, 'step', ['line 2: let var1 = 3 + a:var']) |
8d91579414b8
patch 8.1.1461: tests do not run or are not reliable on some systems
Bram Moolenaar <Bram@vim.org>
parents:
16372
diff
changeset
|
88 call RunDbgCmd(buf, 'step', ['line 3: let var3 = "another var"']) |
16350
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
89 |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
90 " check backtrace |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
91 call RunDbgCmd(buf, 'backtrace', [ |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
92 \ ' 2 function Foo[2]', |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
93 \ ' 1 Bar[2]', |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
94 \ '->0 Bazz', |
16372
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
95 \ 'line 3: let var3 = "another var"']) |
16350
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
96 |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
97 " Check variables in different stack frames |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
98 call RunDbgCmd(buf, 'echo var1', ['6']) |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
99 |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
100 call RunDbgCmd(buf, 'up') |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
101 call RunDbgCmd(buf, 'back', [ |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
102 \ ' 2 function Foo[2]', |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
103 \ '->1 Bar[2]', |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
104 \ ' 0 Bazz', |
16372
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
105 \ 'line 3: let var3 = "another var"']) |
16350
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
106 call RunDbgCmd(buf, 'echo var1', ['3']) |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
107 |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
108 call RunDbgCmd(buf, 'u') |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
109 call RunDbgCmd(buf, 'bt', [ |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
110 \ '->2 function Foo[2]', |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
111 \ ' 1 Bar[2]', |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
112 \ ' 0 Bazz', |
16372
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
113 \ 'line 3: let var3 = "another var"']) |
16350
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
114 call RunDbgCmd(buf, 'echo var1', ['1']) |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
115 |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
116 " Undefined variables |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
117 call RunDbgCmd(buf, 'step') |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
118 call RunDbgCmd(buf, 'frame 2') |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
119 call RunDbgCmd(buf, 'echo var3', [ |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
120 \ 'Error detected while processing function Foo[2]..Bar[2]..Bazz:', |
16372
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
121 \ 'line 4:', |
16350
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
122 \ 'E121: Undefined variable: var3']) |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
123 |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
124 " var3 is defined in this level with some other value |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
125 call RunDbgCmd(buf, 'fr 0') |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
126 call RunDbgCmd(buf, 'echo var3', ['another var']) |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
127 |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
128 call RunDbgCmd(buf, 'step') |
16372
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
129 call RunDbgCmd(buf, '') |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
130 call RunDbgCmd(buf, '') |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
131 call RunDbgCmd(buf, '') |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
132 call RunDbgCmd(buf, '') |
16350
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
133 call RunDbgCmd(buf, 'step', [ |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
134 \ 'function Foo[2]..Bar', |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
135 \ 'line 3: End of function']) |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
136 call RunDbgCmd(buf, 'up') |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
137 |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
138 " Undefined var2 |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
139 call RunDbgCmd(buf, 'echo var2', [ |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
140 \ 'Error detected while processing function Foo[2]..Bar:', |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
141 \ 'line 3:', |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
142 \ 'E121: Undefined variable: var2']) |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
143 |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
144 " Var2 is defined with 10 |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
145 call RunDbgCmd(buf, 'down') |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
146 call RunDbgCmd(buf, 'echo var2', ['10']) |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
147 |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
148 " Backtrace movements |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
149 call RunDbgCmd(buf, 'b', [ |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
150 \ ' 1 function Foo[2]', |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
151 \ '->0 Bar', |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
152 \ 'line 3: End of function']) |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
153 |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
154 " next command cannot go down, we are on bottom |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
155 call RunDbgCmd(buf, 'down', ['frame is zero']) |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
156 call RunDbgCmd(buf, 'up') |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
157 |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
158 " next command cannot go up, we are on top |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
159 call RunDbgCmd(buf, 'up', ['frame at highest level: 1']) |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
160 call RunDbgCmd(buf, 'where', [ |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
161 \ '->1 function Foo[2]', |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
162 \ ' 0 Bar', |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
163 \ 'line 3: End of function']) |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
164 |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
165 " fil is not frame or finish, it is file |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
166 call RunDbgCmd(buf, 'fil', ['"[No Name]" --No lines in buffer--']) |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
167 |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
168 " relative backtrace movement |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
169 call RunDbgCmd(buf, 'fr -1') |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
170 call RunDbgCmd(buf, 'frame', [ |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
171 \ ' 1 function Foo[2]', |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
172 \ '->0 Bar', |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
173 \ 'line 3: End of function']) |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
174 |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
175 call RunDbgCmd(buf, 'fr +1') |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
176 call RunDbgCmd(buf, 'fram', [ |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
177 \ '->1 function Foo[2]', |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
178 \ ' 0 Bar', |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
179 \ 'line 3: End of function']) |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
180 |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
181 " go beyond limits does not crash |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
182 call RunDbgCmd(buf, 'fr 100', ['frame at highest level: 1']) |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
183 call RunDbgCmd(buf, 'fra', [ |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
184 \ '->1 function Foo[2]', |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
185 \ ' 0 Bar', |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
186 \ 'line 3: End of function']) |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
187 |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
188 call RunDbgCmd(buf, 'frame -40', ['frame is zero']) |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
189 call RunDbgCmd(buf, 'fram', [ |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
190 \ ' 1 function Foo[2]', |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
191 \ '->0 Bar', |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
192 \ 'line 3: End of function']) |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
193 |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
194 " final result 19 |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
195 call RunDbgCmd(buf, 'cont', ['19']) |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
196 |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
197 " breakpoints tests |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
198 |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
199 " Start a debug session, so that reading the last line from the terminal |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
200 " works properly. |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
201 call RunDbgCmd(buf, ':debug echo Foo()') |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
202 |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
203 " No breakpoints |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
204 call RunDbgCmd(buf, 'breakl', ['No breakpoints defined']) |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
205 |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
206 " Place some breakpoints |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
207 call RunDbgCmd(buf, 'breaka func Bar') |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
208 call RunDbgCmd(buf, 'breaklis', [' 1 func Bar line 1']) |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
209 call RunDbgCmd(buf, 'breakadd func 3 Bazz') |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
210 call RunDbgCmd(buf, 'breaklist', [' 1 func Bar line 1', |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
211 \ ' 2 func Bazz line 3']) |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
212 |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
213 " Check whether the breakpoints are hit |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
214 call RunDbgCmd(buf, 'cont', [ |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
215 \ 'Breakpoint in "Bar" line 1', |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
216 \ 'function Foo[2]..Bar', |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
217 \ 'line 1: let var1 = 2 + a:var']) |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
218 call RunDbgCmd(buf, 'cont', [ |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
219 \ 'Breakpoint in "Bazz" line 3', |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
220 \ 'function Foo[2]..Bar[2]..Bazz', |
16372
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
221 \ 'line 3: let var3 = "another var"']) |
16350
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
222 |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
223 " Delete the breakpoints |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
224 call RunDbgCmd(buf, 'breakd 1') |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
225 call RunDbgCmd(buf, 'breakli', [' 2 func Bazz line 3']) |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
226 call RunDbgCmd(buf, 'breakdel func 3 Bazz') |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
227 call RunDbgCmd(buf, 'breakl', ['No breakpoints defined']) |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
228 |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
229 call RunDbgCmd(buf, 'cont') |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
230 |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
231 " Make sure the breakpoints are removed |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
232 call RunDbgCmd(buf, ':echo Foo()', ['19']) |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
233 |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
234 " Delete a non-existing breakpoint |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
235 call RunDbgCmd(buf, ':breakdel 2', ['E161: Breakpoint not found: 2']) |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
236 |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
237 " Expression breakpoint |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
238 call RunDbgCmd(buf, ':breakadd func 2 Bazz') |
16372
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
239 call RunDbgCmd(buf, ':echo Bazz(1)', [ |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
240 \ 'Entering Debug mode. Type "cont" to continue.', |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
241 \ 'function Bazz', |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
242 \ 'line 2: let var1 = 3 + a:var']) |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
243 call RunDbgCmd(buf, 'step') |
16350
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
244 call RunDbgCmd(buf, 'step') |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
245 call RunDbgCmd(buf, 'breaka expr var3') |
16372
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
246 call RunDbgCmd(buf, 'breakl', [' 3 func Bazz line 2', |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
247 \ ' 4 expr var3']) |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
248 call RunDbgCmd(buf, 'cont', ['Breakpoint in "Bazz" line 5', |
16350
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
249 \ 'Oldval = "''another var''"', |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
250 \ 'Newval = "''value2''"', |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
251 \ 'function Bazz', |
16372
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
252 \ 'line 5: catch']) |
16350
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
253 |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
254 call RunDbgCmd(buf, 'breakdel *') |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
255 call RunDbgCmd(buf, 'breakl', ['No breakpoints defined']) |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
256 |
16372
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
257 " Check for error cases |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
258 call RunDbgCmd(buf, 'breakadd abcd', [ |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
259 \ 'Error detected while processing function Bazz:', |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
260 \ 'line 5:', |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
261 \ 'E475: Invalid argument: abcd']) |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
262 call RunDbgCmd(buf, 'breakadd func', ['E475: Invalid argument: func']) |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
263 call RunDbgCmd(buf, 'breakadd func 2', ['E475: Invalid argument: func 2']) |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
264 call RunDbgCmd(buf, 'breaka func a()', ['E475: Invalid argument: func a()']) |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
265 call RunDbgCmd(buf, 'breakd abcd', ['E475: Invalid argument: abcd']) |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
266 call RunDbgCmd(buf, 'breakd func', ['E475: Invalid argument: func']) |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
267 call RunDbgCmd(buf, 'breakd func a()', ['E475: Invalid argument: func a()']) |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
268 call RunDbgCmd(buf, 'breakd func a', ['E161: Breakpoint not found: func a']) |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
269 call RunDbgCmd(buf, 'breakd expr', ['E475: Invalid argument: expr']) |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
270 call RunDbgCmd(buf, 'breakd expr x', [ |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
271 \ 'E121: Undefined variable: x', |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
272 \ 'E161: Breakpoint not found: expr x']) |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
273 |
16350
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
274 " finish the current function |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
275 call RunDbgCmd(buf, 'finish', [ |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
276 \ 'function Bazz', |
16372
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
277 \ 'line 8: End of function']) |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
278 call RunDbgCmd(buf, 'cont') |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
279 |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
280 " Test for :next |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
281 call RunDbgCmd(buf, ':debug echo Bar(1)') |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
282 call RunDbgCmd(buf, 'step') |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
283 call RunDbgCmd(buf, 'next') |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
284 call RunDbgCmd(buf, '', [ |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
285 \ 'function Bar', |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
286 \ 'line 3: return var2']) |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
287 call RunDbgCmd(buf, 'c') |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
288 |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
289 " Test for :interrupt |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
290 call RunDbgCmd(buf, ':debug echo Bazz(1)') |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
291 call RunDbgCmd(buf, 'step') |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
292 call RunDbgCmd(buf, 'step') |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
293 call RunDbgCmd(buf, 'interrupt', [ |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
294 \ 'Exception thrown: Vim:Interrupt', |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
295 \ 'function Bazz', |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
296 \ 'line 5: catch']) |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
297 call RunDbgCmd(buf, 'c') |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
298 |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
299 " Test for :quit |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
300 call RunDbgCmd(buf, ':debug echo Foo()') |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
301 call RunDbgCmd(buf, 'breakdel *') |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
302 call RunDbgCmd(buf, 'breakadd func 3 Foo') |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
303 call RunDbgCmd(buf, 'breakadd func 3 Bazz') |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
304 call RunDbgCmd(buf, 'cont', [ |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
305 \ 'Breakpoint in "Bazz" line 3', |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
306 \ 'function Foo[2]..Bar[2]..Bazz', |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
307 \ 'line 3: let var3 = "another var"']) |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
308 call RunDbgCmd(buf, 'quit', [ |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
309 \ 'Breakpoint in "Foo" line 3', |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
310 \ 'function Foo', |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
311 \ 'line 3: return var2']) |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
312 call RunDbgCmd(buf, 'breakdel *') |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
313 call RunDbgCmd(buf, 'quit') |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
314 call RunDbgCmd(buf, 'enew! | only!') |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
315 |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
316 call StopVimInTerminal(buf) |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
317 |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
318 " Tests for :breakadd file and :breakadd here |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
319 " Breakpoints should be set before sourcing the file |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
320 |
17172
6990c1160ea5
patch 8.1.1585: :let-heredoc does not trim enough
Bram Moolenaar <Bram@vim.org>
parents:
16965
diff
changeset
|
321 let lines =<< trim END |
6990c1160ea5
patch 8.1.1585: :let-heredoc does not trim enough
Bram Moolenaar <Bram@vim.org>
parents:
16965
diff
changeset
|
322 let var1 = 10 |
6990c1160ea5
patch 8.1.1585: :let-heredoc does not trim enough
Bram Moolenaar <Bram@vim.org>
parents:
16965
diff
changeset
|
323 let var2 = 20 |
6990c1160ea5
patch 8.1.1585: :let-heredoc does not trim enough
Bram Moolenaar <Bram@vim.org>
parents:
16965
diff
changeset
|
324 let var3 = 30 |
6990c1160ea5
patch 8.1.1585: :let-heredoc does not trim enough
Bram Moolenaar <Bram@vim.org>
parents:
16965
diff
changeset
|
325 let var4 = 40 |
6990c1160ea5
patch 8.1.1585: :let-heredoc does not trim enough
Bram Moolenaar <Bram@vim.org>
parents:
16965
diff
changeset
|
326 END |
6990c1160ea5
patch 8.1.1585: :let-heredoc does not trim enough
Bram Moolenaar <Bram@vim.org>
parents:
16965
diff
changeset
|
327 call writefile(lines, 'Xtest.vim') |
16372
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
328 |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
329 " Start Vim in a terminal |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
330 let buf = RunVimInTerminal('Xtest.vim', {}) |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
331 call RunDbgCmd(buf, ':breakadd file 2 Xtest.vim') |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
332 call RunDbgCmd(buf, ':4 | breakadd here') |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
333 call RunDbgCmd(buf, ':source Xtest.vim', ['line 2: let var2 = 20']) |
5900941b2e37
patch 8.1.1191: not all debug commands are covered by a test
Bram Moolenaar <Bram@vim.org>
parents:
16350
diff
changeset
|
334 call RunDbgCmd(buf, 'cont', ['line 4: let var4 = 40']) |
16350
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
335 call RunDbgCmd(buf, 'cont') |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
336 |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
337 call StopVimInTerminal(buf) |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
338 |
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
339 call delete('Xtest.vim') |
21781
99fe9e960207
patch 8.2.1440: debugger code insufficiently tested
Bram Moolenaar <Bram@vim.org>
parents:
21777
diff
changeset
|
340 %bw! |
99fe9e960207
patch 8.2.1440: debugger code insufficiently tested
Bram Moolenaar <Bram@vim.org>
parents:
21777
diff
changeset
|
341 call assert_fails('breakadd here', 'E32:') |
22375
595ea7f099cd
patch 8.2.1736: failure to compile a pattern not tested much
Bram Moolenaar <Bram@vim.org>
parents:
21917
diff
changeset
|
342 call assert_fails('breakadd file Xtest.vim /\)/', 'E55:') |
16350
ffa791471a4c
patch 8.1.1180: Vim script debugger tests are old style
Bram Moolenaar <Bram@vim.org>
parents:
diff
changeset
|
343 endfunc |
21508
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
344 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
345 func Test_Backtrace_Through_Source() |
21687
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
346 CheckCWD |
21508
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
347 let file1 =<< trim END |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
348 func SourceAnotherFile() |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
349 source Xtest2.vim |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
350 endfunc |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
351 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
352 func CallAFunction() |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
353 call SourceAnotherFile() |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
354 call File2Function() |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
355 endfunc |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
356 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
357 func GlobalFunction() |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
358 call CallAFunction() |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
359 endfunc |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
360 END |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
361 call writefile(file1, 'Xtest1.vim') |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
362 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
363 let file2 =<< trim END |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
364 func DoAThing() |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
365 echo "DoAThing" |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
366 endfunc |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
367 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
368 func File2Function() |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
369 call DoAThing() |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
370 endfunc |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
371 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
372 call File2Function() |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
373 END |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
374 call writefile(file2, 'Xtest2.vim') |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
375 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
376 let buf = RunVimInTerminal('-S Xtest1.vim', {}) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
377 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
378 call RunDbgCmd(buf, |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
379 \ ':debug call GlobalFunction()', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
380 \ ['cmd: call GlobalFunction()']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
381 call RunDbgCmd(buf, 'step', ['line 1: call CallAFunction()']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
382 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
383 call RunDbgCmd(buf, 'backtrace', ['>backtrace', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
384 \ '->0 function GlobalFunction', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
385 \ 'line 1: call CallAFunction()']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
386 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
387 call RunDbgCmd(buf, 'step', ['line 1: call SourceAnotherFile()']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
388 call RunDbgCmd(buf, 'step', ['line 1: source Xtest2.vim']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
389 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
390 call RunDbgCmd(buf, 'backtrace', ['>backtrace', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
391 \ ' 2 function GlobalFunction[1]', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
392 \ ' 1 CallAFunction[1]', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
393 \ '->0 SourceAnotherFile', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
394 \ 'line 1: source Xtest2.vim']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
395 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
396 " Step into the 'source' command. Note that we print the full trace all the |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
397 " way though the source command. |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
398 call RunDbgCmd(buf, 'step', ['line 1: func DoAThing()']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
399 call RunDbgCmd(buf, 'backtrace', [ |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
400 \ '>backtrace', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
401 \ ' 3 function GlobalFunction[1]', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
402 \ ' 2 CallAFunction[1]', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
403 \ ' 1 SourceAnotherFile[1]', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
404 \ '->0 script ' .. getcwd() .. '/Xtest2.vim', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
405 \ 'line 1: func DoAThing()']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
406 |
21687
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
407 call RunDbgCmd( buf, 'up' ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
408 call RunDbgCmd( buf, 'backtrace', [ |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
409 \ '>backtrace', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
410 \ ' 3 function GlobalFunction[1]', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
411 \ ' 2 CallAFunction[1]', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
412 \ '->1 SourceAnotherFile[1]', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
413 \ ' 0 script ' .. getcwd() .. '/Xtest2.vim', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
414 \ 'line 1: func DoAThing()' ] ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
415 |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
416 call RunDbgCmd( buf, 'up' ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
417 call RunDbgCmd( buf, 'backtrace', [ |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
418 \ '>backtrace', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
419 \ ' 3 function GlobalFunction[1]', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
420 \ '->2 CallAFunction[1]', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
421 \ ' 1 SourceAnotherFile[1]', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
422 \ ' 0 script ' .. getcwd() .. '/Xtest2.vim', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
423 \ 'line 1: func DoAThing()' ] ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
424 |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
425 call RunDbgCmd( buf, 'up' ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
426 call RunDbgCmd( buf, 'backtrace', [ |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
427 \ '>backtrace', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
428 \ '->3 function GlobalFunction[1]', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
429 \ ' 2 CallAFunction[1]', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
430 \ ' 1 SourceAnotherFile[1]', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
431 \ ' 0 script ' .. getcwd() .. '/Xtest2.vim', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
432 \ 'line 1: func DoAThing()' ] ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
433 |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
434 call RunDbgCmd( buf, 'up', [ 'frame at highest level: 3' ] ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
435 call RunDbgCmd( buf, 'backtrace', [ |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
436 \ '>backtrace', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
437 \ '->3 function GlobalFunction[1]', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
438 \ ' 2 CallAFunction[1]', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
439 \ ' 1 SourceAnotherFile[1]', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
440 \ ' 0 script ' .. getcwd() .. '/Xtest2.vim', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
441 \ 'line 1: func DoAThing()' ] ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
442 |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
443 call RunDbgCmd( buf, 'down' ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
444 call RunDbgCmd( buf, 'backtrace', [ |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
445 \ '>backtrace', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
446 \ ' 3 function GlobalFunction[1]', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
447 \ '->2 CallAFunction[1]', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
448 \ ' 1 SourceAnotherFile[1]', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
449 \ ' 0 script ' .. getcwd() .. '/Xtest2.vim', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
450 \ 'line 1: func DoAThing()' ] ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
451 |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
452 call RunDbgCmd( buf, 'down' ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
453 call RunDbgCmd( buf, 'backtrace', [ |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
454 \ '>backtrace', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
455 \ ' 3 function GlobalFunction[1]', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
456 \ ' 2 CallAFunction[1]', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
457 \ '->1 SourceAnotherFile[1]', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
458 \ ' 0 script ' .. getcwd() .. '/Xtest2.vim', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
459 \ 'line 1: func DoAThing()' ] ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
460 |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
461 call RunDbgCmd( buf, 'down' ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
462 call RunDbgCmd( buf, 'backtrace', [ |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
463 \ '>backtrace', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
464 \ ' 3 function GlobalFunction[1]', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
465 \ ' 2 CallAFunction[1]', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
466 \ ' 1 SourceAnotherFile[1]', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
467 \ '->0 script ' .. getcwd() .. '/Xtest2.vim', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
468 \ 'line 1: func DoAThing()' ] ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
469 |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
470 call RunDbgCmd( buf, 'down', [ 'frame is zero' ] ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
471 |
21508
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
472 " step until we have another meaninfgul trace |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
473 call RunDbgCmd(buf, 'step', ['line 5: func File2Function()']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
474 call RunDbgCmd(buf, 'step', ['line 9: call File2Function()']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
475 call RunDbgCmd(buf, 'backtrace', [ |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
476 \ '>backtrace', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
477 \ ' 3 function GlobalFunction[1]', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
478 \ ' 2 CallAFunction[1]', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
479 \ ' 1 SourceAnotherFile[1]', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
480 \ '->0 script ' .. getcwd() .. '/Xtest2.vim', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
481 \ 'line 9: call File2Function()']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
482 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
483 call RunDbgCmd(buf, 'step', ['line 1: call DoAThing()']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
484 call RunDbgCmd(buf, 'step', ['line 1: echo "DoAThing"']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
485 call RunDbgCmd(buf, 'backtrace', [ |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
486 \ '>backtrace', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
487 \ ' 5 function GlobalFunction[1]', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
488 \ ' 4 CallAFunction[1]', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
489 \ ' 3 SourceAnotherFile[1]', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
490 \ ' 2 script ' .. getcwd() .. '/Xtest2.vim[9]', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
491 \ ' 1 function File2Function[1]', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
492 \ '->0 DoAThing', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
493 \ 'line 1: echo "DoAThing"']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
494 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
495 " Now, step (back to Xfile1.vim), and call the function _in_ Xfile2.vim |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
496 call RunDbgCmd(buf, 'step', ['line 1: End of function']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
497 call RunDbgCmd(buf, 'step', ['line 1: End of function']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
498 call RunDbgCmd(buf, 'step', ['line 10: End of sourced file']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
499 call RunDbgCmd(buf, 'step', ['line 1: End of function']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
500 call RunDbgCmd(buf, 'step', ['line 2: call File2Function()']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
501 call RunDbgCmd(buf, 'backtrace', [ |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
502 \ '>backtrace', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
503 \ ' 1 function GlobalFunction[1]', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
504 \ '->0 CallAFunction', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
505 \ 'line 2: call File2Function()']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
506 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
507 call RunDbgCmd(buf, 'step', ['line 1: call DoAThing()']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
508 call RunDbgCmd(buf, 'backtrace', [ |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
509 \ '>backtrace', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
510 \ ' 2 function GlobalFunction[1]', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
511 \ ' 1 CallAFunction[2]', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
512 \ '->0 File2Function', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
513 \ 'line 1: call DoAThing()']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
514 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
515 call StopVimInTerminal(buf) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
516 call delete('Xtest1.vim') |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
517 call delete('Xtest2.vim') |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
518 endfunc |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
519 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
520 func Test_Backtrace_Autocmd() |
21687
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
521 CheckCWD |
21508
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
522 let file1 =<< trim END |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
523 func SourceAnotherFile() |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
524 source Xtest2.vim |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
525 endfunc |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
526 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
527 func CallAFunction() |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
528 call SourceAnotherFile() |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
529 call File2Function() |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
530 endfunc |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
531 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
532 func GlobalFunction() |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
533 call CallAFunction() |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
534 endfunc |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
535 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
536 au User TestGlobalFunction :call GlobalFunction() | echo "Done" |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
537 END |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
538 call writefile(file1, 'Xtest1.vim') |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
539 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
540 let file2 =<< trim END |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
541 func DoAThing() |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
542 echo "DoAThing" |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
543 endfunc |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
544 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
545 func File2Function() |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
546 call DoAThing() |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
547 endfunc |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
548 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
549 call File2Function() |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
550 END |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
551 call writefile(file2, 'Xtest2.vim') |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
552 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
553 let buf = RunVimInTerminal('-S Xtest1.vim', {}) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
554 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
555 call RunDbgCmd(buf, |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
556 \ ':debug doautocmd User TestGlobalFunction', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
557 \ ['cmd: doautocmd User TestGlobalFunction']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
558 call RunDbgCmd(buf, 'step', ['cmd: call GlobalFunction() | echo "Done"']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
559 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
560 " At this point the ontly thing in the stack is the autocommand |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
561 call RunDbgCmd(buf, 'backtrace', [ |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
562 \ '>backtrace', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
563 \ '->0 User Autocommands for "TestGlobalFunction"', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
564 \ 'cmd: call GlobalFunction() | echo "Done"']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
565 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
566 " And now we're back into the call stack |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
567 call RunDbgCmd(buf, 'step', ['line 1: call CallAFunction()']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
568 call RunDbgCmd(buf, 'backtrace', [ |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
569 \ '>backtrace', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
570 \ ' 1 User Autocommands for "TestGlobalFunction"', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
571 \ '->0 function GlobalFunction', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
572 \ 'line 1: call CallAFunction()']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
573 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
574 call RunDbgCmd(buf, 'step', ['line 1: call SourceAnotherFile()']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
575 call RunDbgCmd(buf, 'step', ['line 1: source Xtest2.vim']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
576 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
577 call RunDbgCmd(buf, 'backtrace', [ |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
578 \ '>backtrace', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
579 \ ' 3 User Autocommands for "TestGlobalFunction"', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
580 \ ' 2 function GlobalFunction[1]', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
581 \ ' 1 CallAFunction[1]', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
582 \ '->0 SourceAnotherFile', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
583 \ 'line 1: source Xtest2.vim']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
584 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
585 " Step into the 'source' command. Note that we print the full trace all the |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
586 " way though the source command. |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
587 call RunDbgCmd(buf, 'step', ['line 1: func DoAThing()']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
588 call RunDbgCmd(buf, 'backtrace', [ |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
589 \ '>backtrace', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
590 \ ' 4 User Autocommands for "TestGlobalFunction"', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
591 \ ' 3 function GlobalFunction[1]', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
592 \ ' 2 CallAFunction[1]', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
593 \ ' 1 SourceAnotherFile[1]', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
594 \ '->0 script ' .. getcwd() .. '/Xtest2.vim', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
595 \ 'line 1: func DoAThing()']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
596 |
21917
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
597 call RunDbgCmd( buf, 'up' ) |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
598 call RunDbgCmd( buf, 'backtrace', [ |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
599 \ '>backtrace', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
600 \ ' 4 User Autocommands for "TestGlobalFunction"', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
601 \ ' 3 function GlobalFunction[1]', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
602 \ ' 2 CallAFunction[1]', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
603 \ '->1 SourceAnotherFile[1]', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
604 \ ' 0 script ' .. getcwd() .. '/Xtest2.vim', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
605 \ 'line 1: func DoAThing()' ] ) |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
606 |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
607 call RunDbgCmd( buf, 'up' ) |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
608 call RunDbgCmd( buf, 'backtrace', [ |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
609 \ '>backtrace', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
610 \ ' 4 User Autocommands for "TestGlobalFunction"', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
611 \ ' 3 function GlobalFunction[1]', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
612 \ '->2 CallAFunction[1]', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
613 \ ' 1 SourceAnotherFile[1]', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
614 \ ' 0 script ' .. getcwd() .. '/Xtest2.vim', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
615 \ 'line 1: func DoAThing()' ] ) |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
616 |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
617 call RunDbgCmd( buf, 'up' ) |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
618 call RunDbgCmd( buf, 'backtrace', [ |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
619 \ '>backtrace', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
620 \ ' 4 User Autocommands for "TestGlobalFunction"', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
621 \ '->3 function GlobalFunction[1]', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
622 \ ' 2 CallAFunction[1]', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
623 \ ' 1 SourceAnotherFile[1]', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
624 \ ' 0 script ' .. getcwd() .. '/Xtest2.vim', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
625 \ 'line 1: func DoAThing()' ] ) |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
626 |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
627 call RunDbgCmd( buf, 'up' ) |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
628 call RunDbgCmd( buf, 'backtrace', [ |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
629 \ '>backtrace', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
630 \ '->4 User Autocommands for "TestGlobalFunction"', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
631 \ ' 3 function GlobalFunction[1]', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
632 \ ' 2 CallAFunction[1]', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
633 \ ' 1 SourceAnotherFile[1]', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
634 \ ' 0 script ' .. getcwd() .. '/Xtest2.vim', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
635 \ 'line 1: func DoAThing()' ] ) |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
636 |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
637 call RunDbgCmd( buf, 'up', [ 'frame at highest level: 4' ] ) |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
638 call RunDbgCmd( buf, 'backtrace', [ |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
639 \ '>backtrace', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
640 \ '->4 User Autocommands for "TestGlobalFunction"', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
641 \ ' 3 function GlobalFunction[1]', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
642 \ ' 2 CallAFunction[1]', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
643 \ ' 1 SourceAnotherFile[1]', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
644 \ ' 0 script ' .. getcwd() .. '/Xtest2.vim', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
645 \ 'line 1: func DoAThing()' ] ) |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
646 |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
647 call RunDbgCmd( buf, 'down' ) |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
648 call RunDbgCmd( buf, 'backtrace', [ |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
649 \ '>backtrace', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
650 \ ' 4 User Autocommands for "TestGlobalFunction"', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
651 \ '->3 function GlobalFunction[1]', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
652 \ ' 2 CallAFunction[1]', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
653 \ ' 1 SourceAnotherFile[1]', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
654 \ ' 0 script ' .. getcwd() .. '/Xtest2.vim', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
655 \ 'line 1: func DoAThing()' ] ) |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
656 |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
657 |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
658 call RunDbgCmd( buf, 'down' ) |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
659 call RunDbgCmd( buf, 'backtrace', [ |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
660 \ '>backtrace', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
661 \ ' 4 User Autocommands for "TestGlobalFunction"', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
662 \ ' 3 function GlobalFunction[1]', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
663 \ '->2 CallAFunction[1]', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
664 \ ' 1 SourceAnotherFile[1]', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
665 \ ' 0 script ' .. getcwd() .. '/Xtest2.vim', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
666 \ 'line 1: func DoAThing()' ] ) |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
667 |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
668 call RunDbgCmd( buf, 'down' ) |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
669 call RunDbgCmd( buf, 'backtrace', [ |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
670 \ '>backtrace', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
671 \ ' 4 User Autocommands for "TestGlobalFunction"', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
672 \ ' 3 function GlobalFunction[1]', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
673 \ ' 2 CallAFunction[1]', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
674 \ '->1 SourceAnotherFile[1]', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
675 \ ' 0 script ' .. getcwd() .. '/Xtest2.vim', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
676 \ 'line 1: func DoAThing()' ] ) |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
677 |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
678 call RunDbgCmd( buf, 'down' ) |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
679 call RunDbgCmd( buf, 'backtrace', [ |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
680 \ '>backtrace', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
681 \ ' 4 User Autocommands for "TestGlobalFunction"', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
682 \ ' 3 function GlobalFunction[1]', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
683 \ ' 2 CallAFunction[1]', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
684 \ ' 1 SourceAnotherFile[1]', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
685 \ '->0 script ' .. getcwd() .. '/Xtest2.vim', |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
686 \ 'line 1: func DoAThing()' ] ) |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
687 |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
688 call RunDbgCmd( buf, 'down', [ 'frame is zero' ] ) |
94376326c096
patch 8.2.1508: not all debugger commands covered by tests
Bram Moolenaar <Bram@vim.org>
parents:
21781
diff
changeset
|
689 |
21508
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
690 " step until we have another meaninfgul trace |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
691 call RunDbgCmd(buf, 'step', ['line 5: func File2Function()']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
692 call RunDbgCmd(buf, 'step', ['line 9: call File2Function()']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
693 call RunDbgCmd(buf, 'backtrace', [ |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
694 \ '>backtrace', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
695 \ ' 4 User Autocommands for "TestGlobalFunction"', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
696 \ ' 3 function GlobalFunction[1]', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
697 \ ' 2 CallAFunction[1]', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
698 \ ' 1 SourceAnotherFile[1]', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
699 \ '->0 script ' .. getcwd() .. '/Xtest2.vim', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
700 \ 'line 9: call File2Function()']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
701 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
702 call RunDbgCmd(buf, 'step', ['line 1: call DoAThing()']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
703 call RunDbgCmd(buf, 'step', ['line 1: echo "DoAThing"']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
704 call RunDbgCmd(buf, 'backtrace', [ |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
705 \ '>backtrace', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
706 \ ' 6 User Autocommands for "TestGlobalFunction"', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
707 \ ' 5 function GlobalFunction[1]', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
708 \ ' 4 CallAFunction[1]', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
709 \ ' 3 SourceAnotherFile[1]', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
710 \ ' 2 script ' .. getcwd() .. '/Xtest2.vim[9]', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
711 \ ' 1 function File2Function[1]', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
712 \ '->0 DoAThing', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
713 \ 'line 1: echo "DoAThing"']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
714 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
715 " Now, step (back to Xfile1.vim), and call the function _in_ Xfile2.vim |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
716 call RunDbgCmd(buf, 'step', ['line 1: End of function']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
717 call RunDbgCmd(buf, 'step', ['line 1: End of function']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
718 call RunDbgCmd(buf, 'step', ['line 10: End of sourced file']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
719 call RunDbgCmd(buf, 'step', ['line 1: End of function']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
720 call RunDbgCmd(buf, 'step', ['line 2: call File2Function()']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
721 call RunDbgCmd(buf, 'backtrace', [ |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
722 \ '>backtrace', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
723 \ ' 2 User Autocommands for "TestGlobalFunction"', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
724 \ ' 1 function GlobalFunction[1]', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
725 \ '->0 CallAFunction', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
726 \ 'line 2: call File2Function()']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
727 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
728 call RunDbgCmd(buf, 'step', ['line 1: call DoAThing()']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
729 call RunDbgCmd(buf, 'backtrace', [ |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
730 \ '>backtrace', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
731 \ ' 3 User Autocommands for "TestGlobalFunction"', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
732 \ ' 2 function GlobalFunction[1]', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
733 \ ' 1 CallAFunction[2]', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
734 \ '->0 File2Function', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
735 \ 'line 1: call DoAThing()']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
736 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
737 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
738 " Now unwind so that we get back to the original autocommand (and the second |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
739 " cmd echo "Done") |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
740 call RunDbgCmd(buf, 'finish', ['line 1: End of function']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
741 call RunDbgCmd(buf, 'backtrace', [ |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
742 \ '>backtrace', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
743 \ ' 3 User Autocommands for "TestGlobalFunction"', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
744 \ ' 2 function GlobalFunction[1]', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
745 \ ' 1 CallAFunction[2]', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
746 \ '->0 File2Function', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
747 \ 'line 1: End of function']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
748 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
749 call RunDbgCmd(buf, 'finish', ['line 2: End of function']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
750 call RunDbgCmd(buf, 'backtrace', [ |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
751 \ '>backtrace', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
752 \ ' 2 User Autocommands for "TestGlobalFunction"', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
753 \ ' 1 function GlobalFunction[1]', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
754 \ '->0 CallAFunction', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
755 \ 'line 2: End of function']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
756 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
757 call RunDbgCmd(buf, 'finish', ['line 1: End of function']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
758 call RunDbgCmd(buf, 'backtrace', [ |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
759 \ '>backtrace', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
760 \ ' 1 User Autocommands for "TestGlobalFunction"', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
761 \ '->0 function GlobalFunction', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
762 \ 'line 1: End of function']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
763 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
764 call RunDbgCmd(buf, 'step', ['cmd: echo "Done"']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
765 call RunDbgCmd(buf, 'backtrace', [ |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
766 \ '>backtrace', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
767 \ '->0 User Autocommands for "TestGlobalFunction"', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
768 \ 'cmd: echo "Done"']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
769 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
770 call StopVimInTerminal(buf) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
771 call delete('Xtest1.vim') |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
772 call delete('Xtest2.vim') |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
773 endfunc |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
774 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
775 func Test_Backtrace_CmdLine() |
21687
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
776 CheckCWD |
21508
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
777 let file1 =<< trim END |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
778 func SourceAnotherFile() |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
779 source Xtest2.vim |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
780 endfunc |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
781 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
782 func CallAFunction() |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
783 call SourceAnotherFile() |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
784 call File2Function() |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
785 endfunc |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
786 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
787 func GlobalFunction() |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
788 call CallAFunction() |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
789 endfunc |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
790 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
791 au User TestGlobalFunction :call GlobalFunction() | echo "Done" |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
792 END |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
793 call writefile(file1, 'Xtest1.vim') |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
794 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
795 let file2 =<< trim END |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
796 func DoAThing() |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
797 echo "DoAThing" |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
798 endfunc |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
799 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
800 func File2Function() |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
801 call DoAThing() |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
802 endfunc |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
803 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
804 call File2Function() |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
805 END |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
806 call writefile(file2, 'Xtest2.vim') |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
807 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
808 let buf = RunVimInTerminal( |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
809 \ '-S Xtest1.vim -c "debug call GlobalFunction()"', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
810 \ {'wait_for_ruler': 0}) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
811 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
812 " Need to wait for the vim-in-terminal to be ready |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
813 call CheckDbgOutput(buf, ['command line', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
814 \ 'cmd: call GlobalFunction()']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
815 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
816 " At this point the ontly thing in the stack is the cmdline |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
817 call RunDbgCmd(buf, 'backtrace', [ |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
818 \ '>backtrace', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
819 \ '->0 command line', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
820 \ 'cmd: call GlobalFunction()']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
821 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
822 " And now we're back into the call stack |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
823 call RunDbgCmd(buf, 'step', ['line 1: call CallAFunction()']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
824 call RunDbgCmd(buf, 'backtrace', [ |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
825 \ '>backtrace', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
826 \ ' 1 command line', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
827 \ '->0 function GlobalFunction', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
828 \ 'line 1: call CallAFunction()']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
829 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
830 call StopVimInTerminal(buf) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
831 call delete('Xtest1.vim') |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
832 call delete('Xtest2.vim') |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
833 endfunc |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
834 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
835 func Test_Backtrace_DefFunction() |
21687
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
836 CheckCWD |
21508
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
837 let file1 =<< trim END |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
838 vim9script |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
839 import File2Function from './Xtest2.vim' |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
840 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
841 def SourceAnotherFile() |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
842 source Xtest2.vim |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
843 enddef |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
844 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
845 def CallAFunction() |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
846 SourceAnotherFile() |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
847 File2Function() |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
848 enddef |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
849 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
850 def g:GlobalFunction() |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
851 CallAFunction() |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
852 enddef |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
853 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
854 defcompile |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
855 END |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
856 call writefile(file1, 'Xtest1.vim') |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
857 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
858 let file2 =<< trim END |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
859 vim9script |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
860 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
861 def DoAThing(): number |
22486
4086a1708c83
patch 8.2.1791: Vim9: debugger test fails
Bram Moolenaar <Bram@vim.org>
parents:
22375
diff
changeset
|
862 var a = 100 * 2 |
21508
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
863 a += 3 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
864 return a |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
865 enddef |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
866 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
867 export def File2Function() |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
868 DoAThing() |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
869 enddef |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
870 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
871 defcompile |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
872 File2Function() |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
873 END |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
874 call writefile(file2, 'Xtest2.vim') |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
875 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
876 let buf = RunVimInTerminal('-S Xtest1.vim', {}) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
877 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
878 call RunDbgCmd(buf, |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
879 \ ':debug call GlobalFunction()', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
880 \ ['cmd: call GlobalFunction()']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
881 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
882 " FIXME: Vim9 lines are not debugged! |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
883 call RunDbgCmd(buf, 'step', ['line 1: source Xtest2.vim']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
884 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
885 " But they do appear in the backtrace |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
886 call RunDbgCmd(buf, 'backtrace', [ |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
887 \ '\V>backtrace', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
888 \ '\V 2 function GlobalFunction[1]', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
889 \ '\V 1 <SNR>\.\*_CallAFunction[1]', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
890 \ '\V->0 <SNR>\.\*_SourceAnotherFile', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
891 \ '\Vline 1: source Xtest2.vim'], |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
892 \ #{match: 'pattern'}) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
893 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
894 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
895 call RunDbgCmd(buf, 'step', ['line 1: vim9script']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
896 call RunDbgCmd(buf, 'step', ['line 3: def DoAThing(): number']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
897 call RunDbgCmd(buf, 'step', ['line 9: export def File2Function()']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
898 call RunDbgCmd(buf, 'step', ['line 9: def File2Function()']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
899 call RunDbgCmd(buf, 'step', ['line 13: defcompile']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
900 call RunDbgCmd(buf, 'step', ['line 14: File2Function()']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
901 call RunDbgCmd(buf, 'backtrace', [ |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
902 \ '\V>backtrace', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
903 \ '\V 3 function GlobalFunction[1]', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
904 \ '\V 2 <SNR>\.\*_CallAFunction[1]', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
905 \ '\V 1 <SNR>\.\*_SourceAnotherFile[1]', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
906 \ '\V->0 script ' .. getcwd() .. '/Xtest2.vim', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
907 \ '\Vline 14: File2Function()'], |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
908 \ #{match: 'pattern'}) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
909 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
910 " Don't step into compiled functions... |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
911 call RunDbgCmd(buf, 'step', ['line 15: End of sourced file']) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
912 call RunDbgCmd(buf, 'backtrace', [ |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
913 \ '\V>backtrace', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
914 \ '\V 3 function GlobalFunction[1]', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
915 \ '\V 2 <SNR>\.\*_CallAFunction[1]', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
916 \ '\V 1 <SNR>\.\*_SourceAnotherFile[1]', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
917 \ '\V->0 script ' .. getcwd() .. '/Xtest2.vim', |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
918 \ '\Vline 15: End of sourced file'], |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
919 \ #{match: 'pattern'}) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
920 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
921 |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
922 call StopVimInTerminal(buf) |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
923 call delete('Xtest1.vim') |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
924 call delete('Xtest2.vim') |
6b2a5418cbc3
patch 8.2.1304: debug backtrace isn't tested much
Bram Moolenaar <Bram@vim.org>
parents:
19954
diff
changeset
|
925 endfunc |
21687
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
926 |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
927 func Test_debug_backtrace_level() |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
928 CheckCWD |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
929 let lines =<< trim END |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
930 let s:file1_var = 'file1' |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
931 let g:global_var = 'global' |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
932 |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
933 func s:File1Func( arg ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
934 let s:file1_var .= a:arg |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
935 let local_var = s:file1_var .. ' test1' |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
936 let g:global_var .= local_var |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
937 source Xtest2.vim |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
938 endfunc |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
939 |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
940 call s:File1Func( 'arg1' ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
941 END |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
942 call writefile(lines, 'Xtest1.vim') |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
943 |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
944 let lines =<< trim END |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
945 let s:file2_var = 'file2' |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
946 |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
947 func s:File2Func( arg ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
948 let s:file2_var .= a:arg |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
949 let local_var = s:file2_var .. ' test2' |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
950 let g:global_var .= local_var |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
951 endfunc |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
952 |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
953 call s:File2Func( 'arg2' ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
954 END |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
955 call writefile(lines, 'Xtest2.vim') |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
956 |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
957 let file1 = getcwd() .. '/Xtest1.vim' |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
958 let file2 = getcwd() .. '/Xtest2.vim' |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
959 |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
960 " set a breakpoint and source file1.vim |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
961 let buf = RunVimInTerminal( |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
962 \ '-c "breakadd file 1 Xtest1.vim" -S Xtest1.vim', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
963 \ #{ wait_for_ruler: 0 } ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
964 |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
965 call CheckDbgOutput(buf, [ |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
966 \ 'Breakpoint in "' .. file1 .. '" line 1', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
967 \ 'Entering Debug mode. Type "cont" to continue.', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
968 \ 'command line..script ' .. file1, |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
969 \ 'line 1: let s:file1_var = ''file1''' |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
970 \ ]) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
971 |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
972 " step throught the initial declarations |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
973 call RunDbgCmd(buf, 'step', [ 'line 2: let g:global_var = ''global''' ] ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
974 call RunDbgCmd(buf, 'step', [ 'line 4: func s:File1Func( arg )' ] ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
975 call RunDbgCmd(buf, 'echo s:file1_var', [ 'file1' ] ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
976 call RunDbgCmd(buf, 'echo g:global_var', [ 'global' ] ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
977 call RunDbgCmd(buf, 'echo global_var', [ 'global' ] ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
978 |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
979 " step in to the first function |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
980 call RunDbgCmd(buf, 'step', [ 'line 11: call s:File1Func( ''arg1'' )' ] ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
981 call RunDbgCmd(buf, 'step', [ 'line 1: let s:file1_var .= a:arg' ] ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
982 call RunDbgCmd(buf, 'echo a:arg', [ 'arg1' ] ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
983 call RunDbgCmd(buf, 'echo s:file1_var', [ 'file1' ] ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
984 call RunDbgCmd(buf, 'echo g:global_var', [ 'global' ] ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
985 call RunDbgCmd(buf, |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
986 \'echo global_var', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
987 \[ 'E121: Undefined variable: global_var' ] ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
988 call RunDbgCmd(buf, |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
989 \'echo local_var', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
990 \[ 'E121: Undefined variable: local_var' ] ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
991 call RunDbgCmd(buf, |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
992 \'echo l:local_var', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
993 \[ 'E121: Undefined variable: l:local_var' ] ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
994 |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
995 " backtrace up |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
996 call RunDbgCmd(buf, 'backtrace', [ |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
997 \ '\V>backtrace', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
998 \ '\V 2 command line', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
999 \ '\V 1 script ' .. file1 .. '[11]', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1000 \ '\V->0 function <SNR>\.\*_File1Func', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1001 \ '\Vline 1: let s:file1_var .= a:arg', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1002 \ ], |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1003 \ #{ match: 'pattern' } ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1004 call RunDbgCmd(buf, 'up', [ '>up' ] ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1005 |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1006 call RunDbgCmd(buf, 'backtrace', [ |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1007 \ '\V>backtrace', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1008 \ '\V 2 command line', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1009 \ '\V->1 script ' .. file1 .. '[11]', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1010 \ '\V 0 function <SNR>\.\*_File1Func', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1011 \ '\Vline 1: let s:file1_var .= a:arg', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1012 \ ], |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1013 \ #{ match: 'pattern' } ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1014 |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1015 " Expression evaluation in the script frame (not the function frame) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1016 " FIXME: Unexpected in this scope (a: should not be visibnle) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1017 call RunDbgCmd(buf, 'echo a:arg', [ 'arg1' ] ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1018 call RunDbgCmd(buf, 'echo s:file1_var', [ 'file1' ] ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1019 call RunDbgCmd(buf, 'echo g:global_var', [ 'global' ] ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1020 " FIXME: Unexpected in this scope (global should be found) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1021 call RunDbgCmd(buf, |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1022 \'echo global_var', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1023 \[ 'E121: Undefined variable: global_var' ] ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1024 call RunDbgCmd(buf, |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1025 \'echo local_var', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1026 \[ 'E121: Undefined variable: local_var' ] ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1027 call RunDbgCmd(buf, |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1028 \'echo l:local_var', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1029 \[ 'E121: Undefined variable: l:local_var' ] ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1030 |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1031 |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1032 " step while backtraced jumps to the latest frame |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1033 call RunDbgCmd(buf, 'step', [ |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1034 \ 'line 2: let local_var = s:file1_var .. '' test1''' ] ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1035 call RunDbgCmd(buf, 'backtrace', [ |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1036 \ '\V>backtrace', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1037 \ '\V 2 command line', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1038 \ '\V 1 script ' .. file1 .. '[11]', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1039 \ '\V->0 function <SNR>\.\*_File1Func', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1040 \ '\Vline 2: let local_var = s:file1_var .. '' test1''', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1041 \ ], |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1042 \ #{ match: 'pattern' } ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1043 |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1044 call RunDbgCmd(buf, 'step', [ 'line 3: let g:global_var .= local_var' ] ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1045 call RunDbgCmd(buf, 'echo local_var', [ 'file1arg1 test1' ] ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1046 call RunDbgCmd(buf, 'echo l:local_var', [ 'file1arg1 test1' ] ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1047 |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1048 call RunDbgCmd(buf, 'step', [ 'line 4: source Xtest2.vim' ] ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1049 call RunDbgCmd(buf, 'step', [ 'line 1: let s:file2_var = ''file2''' ] ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1050 call RunDbgCmd(buf, 'backtrace', [ |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1051 \ '\V>backtrace', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1052 \ '\V 3 command line', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1053 \ '\V 2 script ' .. file1 .. '[11]', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1054 \ '\V 1 function <SNR>\.\*_File1Func[4]', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1055 \ '\V->0 script ' .. file2, |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1056 \ '\Vline 1: let s:file2_var = ''file2''', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1057 \ ], |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1058 \ #{ match: 'pattern' } ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1059 |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1060 " Expression evaluation in the script frame file2 (not the function frame) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1061 call RunDbgCmd(buf, 'echo a:arg', [ 'E121: Undefined variable: a:arg' ] ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1062 call RunDbgCmd(buf, |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1063 \ 'echo s:file1_var', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1064 \ [ 'E121: Undefined variable: s:file1_var' ] ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1065 call RunDbgCmd(buf, 'echo g:global_var', [ 'globalfile1arg1 test1' ] ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1066 call RunDbgCmd(buf, 'echo global_var', [ 'globalfile1arg1 test1' ] ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1067 call RunDbgCmd(buf, |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1068 \'echo local_var', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1069 \[ 'E121: Undefined variable: local_var' ] ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1070 call RunDbgCmd(buf, |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1071 \'echo l:local_var', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1072 \[ 'E121: Undefined variable: l:local_var' ] ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1073 call RunDbgCmd(buf, |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1074 \ 'echo s:file2_var', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1075 \ [ 'E121: Undefined variable: s:file2_var' ] ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1076 |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1077 call RunDbgCmd(buf, 'step', [ 'line 3: func s:File2Func( arg )' ] ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1078 call RunDbgCmd(buf, 'echo s:file2_var', [ 'file2' ] ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1079 |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1080 " Up the stack to the other script context |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1081 call RunDbgCmd(buf, 'up') |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1082 call RunDbgCmd(buf, 'backtrace', [ |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1083 \ '\V>backtrace', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1084 \ '\V 3 command line', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1085 \ '\V 2 script ' .. file1 .. '[11]', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1086 \ '\V->1 function <SNR>\.\*_File1Func[4]', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1087 \ '\V 0 script ' .. file2, |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1088 \ '\Vline 3: func s:File2Func( arg )', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1089 \ ], |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1090 \ #{ match: 'pattern' } ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1091 " FIXME: Unexpected. Should see the a: and l: dicts from File1Func |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1092 call RunDbgCmd(buf, 'echo a:arg', [ 'E121: Undefined variable: a:arg' ] ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1093 call RunDbgCmd(buf, |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1094 \ 'echo l:local_var', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1095 \ [ 'E121: Undefined variable: l:local_var' ] ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1096 |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1097 call RunDbgCmd(buf, 'up') |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1098 call RunDbgCmd(buf, 'backtrace', [ |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1099 \ '\V>backtrace', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1100 \ '\V 3 command line', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1101 \ '\V->2 script ' .. file1 .. '[11]', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1102 \ '\V 1 function <SNR>\.\*_File1Func[4]', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1103 \ '\V 0 script ' .. file2, |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1104 \ '\Vline 3: func s:File2Func( arg )', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1105 \ ], |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1106 \ #{ match: 'pattern' } ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1107 |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1108 " FIXME: Unexpected (wrong script vars are used) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1109 call RunDbgCmd(buf, |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1110 \ 'echo s:file1_var', |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1111 \ [ 'E121: Undefined variable: s:file1_var' ] ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1112 call RunDbgCmd(buf, 'echo s:file2_var', [ 'file2' ] ) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1113 |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1114 call StopVimInTerminal(buf) |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1115 call delete('Xtest1.vim') |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1116 call delete('Xtest2.vim') |
83b618c0315d
patch 8.2.1393: insufficient testing for script debugging
Bram Moolenaar <Bram@vim.org>
parents:
21508
diff
changeset
|
1117 endfunc |
21765
08940efa6b4e
patch 8.2.1432: various inconsistencies in test files
Bram Moolenaar <Bram@vim.org>
parents:
21687
diff
changeset
|
1118 |
21777
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1119 " Test for setting a breakpoint on a :endif where the :if condition is false |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1120 " and then quit the script. This should generate an interrupt. |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1121 func Test_breakpt_endif_intr() |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1122 func F() |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1123 let g:Xpath ..= 'a' |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1124 if v:false |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1125 let g:Xpath ..= 'b' |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1126 endif |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1127 invalid_command |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1128 endfunc |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1129 |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1130 let g:Xpath = '' |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1131 breakadd func 4 F |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1132 try |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1133 let caught_intr = 0 |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1134 debuggreedy |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1135 call feedkeys(":call F()\<CR>quit\<CR>", "xt") |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1136 catch /^Vim:Interrupt$/ |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1137 call assert_match('\.F, line 4', v:throwpoint) |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1138 let caught_intr = 1 |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1139 endtry |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1140 0debuggreedy |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1141 call assert_equal(1, caught_intr) |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1142 call assert_equal('a', g:Xpath) |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1143 breakdel * |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1144 delfunc F |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1145 endfunc |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1146 |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1147 " Test for setting a breakpoint on a :else where the :if condition is false |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1148 " and then quit the script. This should generate an interrupt. |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1149 func Test_breakpt_else_intr() |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1150 func F() |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1151 let g:Xpath ..= 'a' |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1152 if v:false |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1153 let g:Xpath ..= 'b' |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1154 else |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1155 invalid_command |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1156 endif |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1157 invalid_command |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1158 endfunc |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1159 |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1160 let g:Xpath = '' |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1161 breakadd func 4 F |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1162 try |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1163 let caught_intr = 0 |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1164 debuggreedy |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1165 call feedkeys(":call F()\<CR>quit\<CR>", "xt") |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1166 catch /^Vim:Interrupt$/ |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1167 call assert_match('\.F, line 4', v:throwpoint) |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1168 let caught_intr = 1 |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1169 endtry |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1170 0debuggreedy |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1171 call assert_equal(1, caught_intr) |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1172 call assert_equal('a', g:Xpath) |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1173 breakdel * |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1174 delfunc F |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1175 endfunc |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1176 |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1177 " Test for setting a breakpoint on a :endwhile where the :while condition is |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1178 " false and then quit the script. This should generate an interrupt. |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1179 func Test_breakpt_endwhile_intr() |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1180 func F() |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1181 let g:Xpath ..= 'a' |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1182 while v:false |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1183 let g:Xpath ..= 'b' |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1184 endwhile |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1185 invalid_command |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1186 endfunc |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1187 |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1188 let g:Xpath = '' |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1189 breakadd func 4 F |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1190 try |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1191 let caught_intr = 0 |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1192 debuggreedy |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1193 call feedkeys(":call F()\<CR>quit\<CR>", "xt") |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1194 catch /^Vim:Interrupt$/ |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1195 call assert_match('\.F, line 4', v:throwpoint) |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1196 let caught_intr = 1 |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1197 endtry |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1198 0debuggreedy |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1199 call assert_equal(1, caught_intr) |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1200 call assert_equal('a', g:Xpath) |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1201 breakdel * |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1202 delfunc F |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1203 endfunc |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1204 |
21781
99fe9e960207
patch 8.2.1440: debugger code insufficiently tested
Bram Moolenaar <Bram@vim.org>
parents:
21777
diff
changeset
|
1205 " Test for setting a breakpoint on a script local function |
99fe9e960207
patch 8.2.1440: debugger code insufficiently tested
Bram Moolenaar <Bram@vim.org>
parents:
21777
diff
changeset
|
1206 func Test_breakpt_scriptlocal_func() |
99fe9e960207
patch 8.2.1440: debugger code insufficiently tested
Bram Moolenaar <Bram@vim.org>
parents:
21777
diff
changeset
|
1207 let g:Xpath = '' |
99fe9e960207
patch 8.2.1440: debugger code insufficiently tested
Bram Moolenaar <Bram@vim.org>
parents:
21777
diff
changeset
|
1208 func s:G() |
99fe9e960207
patch 8.2.1440: debugger code insufficiently tested
Bram Moolenaar <Bram@vim.org>
parents:
21777
diff
changeset
|
1209 let g:Xpath ..= 'a' |
21777
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1210 endfunc |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1211 |
21781
99fe9e960207
patch 8.2.1440: debugger code insufficiently tested
Bram Moolenaar <Bram@vim.org>
parents:
21777
diff
changeset
|
1212 let funcname = expand("<SID>") .. "G" |
99fe9e960207
patch 8.2.1440: debugger code insufficiently tested
Bram Moolenaar <Bram@vim.org>
parents:
21777
diff
changeset
|
1213 exe "breakadd func 1 " .. funcname |
99fe9e960207
patch 8.2.1440: debugger code insufficiently tested
Bram Moolenaar <Bram@vim.org>
parents:
21777
diff
changeset
|
1214 debuggreedy |
99fe9e960207
patch 8.2.1440: debugger code insufficiently tested
Bram Moolenaar <Bram@vim.org>
parents:
21777
diff
changeset
|
1215 redir => output |
99fe9e960207
patch 8.2.1440: debugger code insufficiently tested
Bram Moolenaar <Bram@vim.org>
parents:
21777
diff
changeset
|
1216 call feedkeys(":call " .. funcname .. "()\<CR>c\<CR>", "xt") |
99fe9e960207
patch 8.2.1440: debugger code insufficiently tested
Bram Moolenaar <Bram@vim.org>
parents:
21777
diff
changeset
|
1217 redir END |
21777
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1218 0debuggreedy |
21781
99fe9e960207
patch 8.2.1440: debugger code insufficiently tested
Bram Moolenaar <Bram@vim.org>
parents:
21777
diff
changeset
|
1219 call assert_match('Breakpoint in "' .. funcname .. '" line 1', output) |
21777
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1220 call assert_equal('a', g:Xpath) |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1221 breakdel * |
21781
99fe9e960207
patch 8.2.1440: debugger code insufficiently tested
Bram Moolenaar <Bram@vim.org>
parents:
21777
diff
changeset
|
1222 exe "delfunc " .. funcname |
21777
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1223 endfunc |
4279767da6e8
patch 8.2.1438: missing tests for interrupting script execution from debugger
Bram Moolenaar <Bram@vim.org>
parents:
21765
diff
changeset
|
1224 |
21765
08940efa6b4e
patch 8.2.1432: various inconsistencies in test files
Bram Moolenaar <Bram@vim.org>
parents:
21687
diff
changeset
|
1225 " vim: shiftwidth=2 sts=2 expandtab |